@import"https://fonts.googleapis.com/css2?family=IM+Fell+Great+Primer:ital@1&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.gsap-section{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative}.landing-page{min-height:100vh;background-color:var(--color-bg-primary)}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);background:radial-gradient(ellipse at top,rgba(255,255,255,.3) 0%,transparent 50%),var(--color-bg-primary)}.hero-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:800px}.logo-container{margin-bottom:var(--space-8)}.photo-collage{position:relative;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-8);height:320px;width:100%;max-width:600px}.photo-collage .photo-card{position:absolute;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-xl);background:#fff;padding:8px}.photo-collage .photo-placeholder{border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);color:var(--color-text-muted);background:linear-gradient(135deg,#e8e4d8,#d4d0c4,#c5c1b5)}.photo-left{left:5%;z-index:1;transform:rotate(-8deg)}.photo-center{z-index:3;transform:rotate(0)}.photo-right{right:5%;z-index:2;transform:rotate(6deg)}.photo-collage .photo-card{transition:transform var(--transition-base),z-index 0s}.photo-collage .photo-left:hover{transform:rotate(-4deg) scale(1.05);z-index:4}.photo-collage .photo-center:hover{transform:scale(1.05);z-index:4}.photo-collage .photo-right:hover{transform:rotate(3deg) scale(1.05);z-index:4}.hero-headline{font-family:var(--font-header);font-size:clamp(2rem,5vw,3.5rem);font-weight:var(--font-semibold);line-height:1.15;color:var(--color-text);margin-bottom:var(--space-8)}.hero-headline .emoji{display:inline-block;font-style:normal}.hero-cta{display:flex;gap:var(--space-4)}.greeting-section{padding:var(--space-12) var(--space-4);background-color:var(--color-bg-primary);min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.greeting-content{text-align:center;max-width:600px}.greeting-text{margin-bottom:var(--space-8)}.greeting-line{font-family:var(--font-header);font-size:clamp(2.5rem,8vw,4rem);font-weight:var(--font-semibold);color:var(--color-text);margin:0;line-height:1.2}.greeting-cycling{animation:greetingFadeIn .5s ease forwards}@keyframes greetingFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.greeting-subtitle{font-size:var(--text-lg);color:var(--color-text);line-height:1.5;margin-bottom:var(--space-6)}.coming-soon{font-family:var(--font-header);font-size:var(--text-xl);font-weight:var(--font-medium);color:var(--color-text-muted);opacity:.7;margin:0;letter-spacing:.05em}.greeting-cta{display:flex;justify-content:center}.btn-dark{background-color:var(--color-text);color:var(--color-bg-primary);padding:var(--space-3) var(--space-8);border-radius:var(--radius-full);font-weight:var(--font-medium);transition:all var(--transition-base)}.btn-dark:hover{background-color:var(--color-text-muted);transform:translateY(-2px)}.how-it-works{padding:var(--space-20) var(--space-4);min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:var(--color-bg-primary)}.section-title{font-family:var(--font-header);font-size:var(--text-3xl);text-align:center;margin-bottom:var(--space-12);color:var(--color-text)}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-8);max-width:1000px;margin:0 auto}.step-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-6)}.step-number{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--color-button-primary);color:#fff;font-family:var(--font-header);font-size:var(--text-xl);font-weight:var(--font-semibold);border-radius:var(--radius-full);margin-bottom:var(--space-4)}.step-card h3{font-family:var(--font-header);font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-2);color:var(--color-text)}.step-card p{font-size:var(--text-sm);color:var(--color-text-muted);margin:0;line-height:var(--leading-relaxed)}.cta-section{padding:var(--space-20) var(--space-4);background-color:var(--color-bg-secondary)}.cta-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:600px;margin:0 auto}.cta-content h2{font-family:var(--font-header);font-size:var(--text-3xl);margin-bottom:var(--space-4);color:var(--color-text)}.cta-content>p{font-size:var(--text-lg);color:var(--color-text-muted);margin-bottom:var(--space-8)}.cta-buttons{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:center}.footer{padding:var(--space-12) var(--space-4);background-color:var(--color-bg-primary);border-top:1px solid var(--color-border-light)}.footer-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-4)}.footer-tagline{font-size:var(--text-sm);color:var(--color-text-muted);font-style:italic;margin:0}.footer-links{display:flex;flex-wrap:wrap;gap:var(--space-6);justify-content:center}.footer-links a{font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--transition-fast)}.footer-links a:hover{color:var(--color-button-primary)}.footer-copyright{font-size:var(--text-xs);color:var(--color-text-light);margin:0}@media (max-width: 768px){.hero{min-height:auto;padding:var(--space-12) var(--space-4)}.photo-collage{height:260px;max-width:100%}.photo-collage .photo-placeholder{width:140px!important;height:180px!important}.photo-center .photo-placeholder{width:160px!important;height:200px!important}.greeting-section{min-height:auto;padding:var(--space-16) var(--space-4)}.greeting-line{font-size:clamp(2rem,7vw,3rem)}.steps-grid{grid-template-columns:1fr}.gsap-section{min-height:auto;padding:var(--space-12) var(--space-4)}.how-it-works{min-height:auto}.hero-headline{font-size:clamp(1.75rem,5vw,2.5rem)}.cta-buttons{flex-direction:column;width:100%}.cta-buttons .btn{width:100%}}@media (max-width: 480px){.greeting-line{font-size:clamp(1.75rem,8vw,2.5rem)}.photo-collage{height:220px}.photo-collage .photo-placeholder{width:100px!important;height:140px!important}.photo-center .photo-placeholder{width:120px!important;height:160px!important}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);animation:fadeIn .3s ease}.modal-content{background-color:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--space-8);max-width:400px;width:100%;position:relative;animation:scaleIn .3s ease}.modal-close{position:absolute;top:var(--space-3);right:var(--space-3);background:none;border:none;font-size:var(--text-2xl);color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);line-height:1;transition:color var(--transition-fast)}.modal-close:hover{color:var(--color-text)}.waitlist-modal h3{font-family:var(--font-header);font-size:var(--text-2xl);margin-bottom:var(--space-2);text-align:center}.waitlist-modal>p{color:var(--color-text-muted);text-align:center;margin-bottom:var(--space-6)}.waitlist-form{display:flex;flex-direction:column;gap:var(--space-3)}.waitlist-form .input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--text-base)}.waitlist-form .btn{width:100%;padding:var(--space-3)}.waitlist-success{text-align:center;padding:var(--space-4) 0}.waitlist-success .success-icon{width:60px;height:60px;background-color:var(--color-button-primary);color:var(--color-text);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);margin:0 auto var(--space-4);animation:scaleIn .4s ease}.waitlist-success h3{margin-bottom:var(--space-2)}.waitlist-success p{color:var(--color-text-muted);margin-bottom:var(--space-6)}.waitlist-success .btn{min-width:120px}@media (max-width: 480px){.modal-content{padding:var(--space-6);margin:var(--space-4)}.waitlist-modal h3{font-size:var(--text-xl)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);background-color:var(--color-bg-primary)}.auth-container{width:100%;max-width:400px;background-color:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-8);animation:fadeInUp var(--transition-slow) ease forwards}.auth-container h1{font-family:var(--font-header);font-size:var(--text-2xl);text-align:center;margin-bottom:var(--space-6);color:var(--color-text)}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.form-group input{padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background-color:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--color-button-primary);box-shadow:0 0 0 3px #39565c1a}.form-group input::placeholder{color:var(--color-text-light)}.auth-message{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);text-align:center;animation:fadeIn var(--transition-base) ease forwards}.auth-message.error{background-color:#dc35451a;color:var(--color-error);border:1px solid rgba(220,53,69,.2)}.auth-message.success{background-color:#28a7451a;color:var(--color-success);border:1px solid rgba(40,167,69,.2)}.resend-btn{background:none;border:none;color:var(--color-button-primary);font-size:var(--text-xs);text-decoration:underline;cursor:pointer;margin-left:var(--space-2);padding:0;transition:color var(--transition-fast)}.resend-btn:hover:not(:disabled){color:var(--color-button-primary-hover)}.resend-btn:disabled{opacity:.6;cursor:not-allowed}.auth-submit{width:100%;padding:var(--space-4);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:#fff;background-color:var(--color-button-primary);border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-2)}.auth-submit:hover:not(:disabled){background-color:var(--color-button-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-toggle{margin-top:var(--space-6);text-align:center}.auth-toggle button{background:none;border:none;color:var(--color-button-primary);font-size:var(--text-sm);cursor:pointer;transition:color var(--transition-fast)}.auth-toggle button:hover{color:var(--color-button-primary-hover);text-decoration:underline}.auth-back{display:block;text-align:center;margin-top:var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted)}.auth-back:hover{color:var(--color-button-primary)}.onboarding-page{min-height:100vh;background-color:var(--color-bg-primary);display:flex;flex-direction:column}.onboarding-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);background-color:var(--color-bg-primary)}.onboarding-loading p{color:var(--color-text-muted);font-size:var(--text-sm)}.onboarding-header{position:sticky;top:0;background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border-light);z-index:10;padding:var(--space-4)}.onboarding-header-content{display:flex;align-items:center;justify-content:space-between;max-width:800px;margin:0 auto;margin-bottom:var(--space-3)}.progress-info{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1)}.step-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.step-count{font-size:var(--text-xs);color:var(--color-text-muted)}.progress-bar-container{max-width:800px;margin:0 auto;height:4px;background-color:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background-color:var(--color-button-primary);border-radius:var(--radius-full);transition:width .6s ease}.saving-indicator{position:absolute;top:var(--space-4);right:var(--space-4);display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted);animation:fadeIn var(--transition-fast) ease}.saving-indicator .spinner{width:12px;height:12px;border-width:1px}.onboarding-error{max-width:800px;margin:var(--space-4) auto;padding:var(--space-3) var(--space-4);background-color:#dc35451a;border:1px solid rgba(220,53,69,.2);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-sm);text-align:center}.onboarding-content{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:var(--space-8) var(--space-4)}.step-content{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-6) var(--space-4);min-height:calc(100vh - 80px)}.step-container{width:100%;max-width:500px;position:relative;margin:0 auto}.step-transition-enter{opacity:0;transform:translate(30px)}.step-transition-enter-active{opacity:1;transform:translate(0);transition:opacity .4s ease,transform .4s ease}.step-transition-exit{opacity:1;transform:translate(0)}.step-transition-exit-active{opacity:0;transform:translate(-30px);transition:opacity .3s ease,transform .3s ease}.step-fade-enter{opacity:0;transform:translateY(20px)}.step-fade-enter-active{opacity:1;transform:translateY(0);transition:opacity .5s ease,transform .5s ease}.step-wrapper{display:flex;flex-direction:column;gap:var(--space-6);animation:fadeInUp .5s ease forwards;width:100%;max-width:500px;margin:0 auto}.step-header{text-align:center;margin-bottom:var(--space-4)}.step-title{font-family:var(--font-header);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.step-subtitle{font-size:var(--text-base);color:var(--color-text-muted);line-height:var(--leading-relaxed)}.step-form{display:flex;flex-direction:column;gap:var(--space-5);margin-bottom:var(--space-6)}.step-actions{display:flex;gap:var(--space-4);margin-top:var(--space-6)}.step-actions .btn{flex:1}.step-actions .btn-back{flex:0 0 auto;background:transparent;color:var(--color-text-muted)}.step-actions .btn-back:hover{color:var(--color-text);background:transparent;transform:none;box-shadow:none}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}@media (max-width: 480px){.form-row{grid-template-columns:1fr}}.option-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3)}.option-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);background-color:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);text-align:center}.option-card:hover{border-color:var(--color-button-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.option-card.selected{border-color:var(--color-button-primary);background-color:#39565c0d}.option-card .option-icon{font-size:var(--text-2xl)}.option-card .option-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.select-input{padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background-color:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234a4a4a' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}.select-input:focus{outline:none;border-color:var(--color-button-primary);box-shadow:0 0 0 3px #39565c1a}.textarea-input{padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background-color:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);resize:vertical;min-height:120px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.textarea-input:focus{outline:none;border-color:var(--color-button-primary);box-shadow:0 0 0 3px #39565c1a}.textarea-hint{font-size:var(--text-xs);color:var(--color-text-light);margin-top:var(--space-1)}.tag-input-container{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);background-color:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:48px}.tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background-color:var(--color-button-secondary);border-radius:var(--radius-full);font-size:var(--text-sm)}.tag-remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:0;font-size:var(--text-xs);line-height:1}.tag-remove:hover{color:var(--color-error)}.tag-input{flex:1;min-width:100px;border:none;outline:none;font-family:var(--font-body);font-size:var(--text-base);padding:var(--space-1)}.complete-wrapper{text-align:center;padding:var(--space-8) 0}.complete-icon{font-size:4rem;margin-bottom:var(--space-4);animation:scaleIn var(--transition-slow) ease forwards}.complete-title{font-family:var(--font-header);font-size:var(--text-3xl);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.complete-subtitle{font-size:var(--text-lg);color:var(--color-text-muted);margin-bottom:var(--space-8)}.complete-actions{display:flex;flex-direction:column;gap:var(--space-3);max-width:300px;margin:0 auto}.photo-upload-area{display:flex;flex-direction:column;gap:var(--space-6)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.photo-slot{position:relative;aspect-ratio:3/4;border:2px dashed var(--color-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-base)}.photo-slot:hover{border-color:var(--color-button-primary);background-color:#39565c0d}.photo-slot-label{position:absolute;top:var(--space-2);left:var(--space-2);padding:var(--space-1) var(--space-2);background-color:var(--color-button-primary);color:#fff;font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-sm);z-index:1}.photo-slot-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--space-2);color:var(--color-text-muted)}.photo-slot-icon{font-size:var(--text-2xl);opacity:.5}.photo-slot-text{font-size:var(--text-xs)}.photo-guidelines{padding:var(--space-4);background-color:var(--color-bg-secondary);border-radius:var(--radius-md)}.photo-guidelines h4{font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--space-2);color:var(--color-text)}.photo-guidelines ul{list-style:none;padding:0;margin:0}.photo-guidelines li{font-size:var(--text-sm);color:var(--color-text-muted);padding-left:var(--space-4);position:relative;margin-bottom:var(--space-1)}.photo-guidelines li:before{content:"•";position:absolute;left:0;color:var(--color-button-primary)}.step-note{padding:var(--space-3) var(--space-4);background-color:#fd43;border:1px solid rgba(255,221,68,.4);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text)}.step-error{padding:var(--space-3) var(--space-4);background-color:#dc35451a;border:1px solid rgba(220,53,69,.2);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-error)}@media (max-width: 768px){.onboarding-header{padding:var(--space-3) var(--space-4)}.step-content{padding:var(--space-4) var(--space-3);min-height:calc(100vh - 60px)}.step-container{max-width:100%}.step-header h2{font-size:var(--text-xl)}.step-header p{font-size:var(--text-sm)}.form-row{flex-direction:column;gap:0}.step-actions{flex-direction:column;gap:var(--space-2)}.step-actions .btn{width:100%}.option-cards{grid-template-columns:1fr}.photo-slots-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.onboarding-page{padding:0}.onboarding-header{padding:var(--space-2) var(--space-3)}.step-content{padding:var(--space-3) var(--space-2)}.step-header{margin-bottom:var(--space-4)}.step-header h2{font-size:var(--text-lg);margin-bottom:var(--space-1)}.step-header p{font-size:var(--text-xs);line-height:1.4}.step-form{gap:var(--space-4)}.input-group{margin-bottom:var(--space-3)}.input-label{font-size:var(--text-sm);margin-bottom:var(--space-1)}.input,.select-input,.textarea-input{padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.btn{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.photo-slots-grid{grid-template-columns:1fr;gap:var(--space-2)}.photo-slot{height:80px}.photo-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-page{min-height:100vh;background-color:var(--color-bg-primary)}.dashboard-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-primary)}.dashboard-header{background-color:var(--color-bg-card);border-bottom:1px solid var(--color-border-light);padding:var(--space-4)}.dashboard-header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.header-actions{display:flex;align-items:center;gap:var(--space-4)}.user-email{font-size:var(--text-sm);color:var(--color-text-muted)}.dashboard-content{padding:var(--space-8) var(--space-4)}.dashboard-content h1{font-family:var(--font-header);font-size:var(--text-3xl);margin-bottom:var(--space-2)}.dashboard-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-16) var(--space-4);background-color:var(--color-bg-card);border-radius:var(--radius-lg);margin-top:var(--space-8)}.placeholder-icon{font-size:4rem;margin-bottom:var(--space-4);opacity:.5}.dashboard-placeholder h3{font-family:var(--font-header);font-size:var(--text-xl);margin-bottom:var(--space-2);color:var(--color-text)}.dashboard-placeholder p{color:var(--color-text-muted);margin-bottom:var(--space-6)}:root{--color-text: #020207;--color-text-muted: #4a4a4a;--color-text-light: #6b6b6b;--color-bg-primary: #f5f0e1;--color-bg-secondary: #ebe6d7;--color-bg-card: #ffffff;--color-button-primary: #39565C;--color-button-primary-hover: #2d4549;--color-button-secondary: #D5E5CE;--color-button-secondary-hover: #c5d5be;--color-accent-primary: #435303;--color-accent-secondary: #FFDD44;--color-border: #d4d0c4;--color-border-light: #e8e4d8;--color-error: #dc3545;--color-success: #28a745;--font-logo: "IM Fell Great Primer", serif;--font-header: "Hiragino Sans GB", "Hiragino Sans", "Microsoft YaHei", sans-serif;--font-body: "FFF Acid Grotesk", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.1;--leading-snug: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.625;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--transition-slower: .5s ease;--z-dropdown: 100;--z-modal: 200;--z-toast: 300}.logo{font-family:var(--font-logo);font-style:italic;font-size:var(--text-2xl);color:var(--color-button-primary);letter-spacing:.02em}.logo-lg{font-size:var(--text-3xl)}.logo-xl{font-size:var(--text-4xl)}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{font-family:var(--font-header);font-weight:var(--font-semibold);color:var(--color-text);line-height:var(--leading-tight);margin:0}h1,.h1{font-size:var(--text-5xl)}h2,.h2{font-size:var(--text-4xl)}h3,.h3{font-size:var(--text-3xl)}h4,.h4{font-size:var(--text-2xl)}h5,.h5{font-size:var(--text-xl)}h6,.h6{font-size:var(--text-lg)}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-normal);color:var(--color-text);line-height:var(--leading-normal)}p{margin:0 0 var(--space-4)}.text-sm{font-size:var(--text-sm)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-muted{color:var(--color-text-muted)}.text-light{color:var(--color-text-light)}.text-center{text-align:center}a{color:var(--color-button-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-button-primary-hover)}.display-text{font-family:var(--font-header);font-size:clamp(2rem,5vw,3.5rem);font-weight:var(--font-semibold);line-height:var(--leading-tight);color:var(--color-text)}.display-text-lg{font-size:clamp(2.5rem,6vw,4.5rem)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-on-load{opacity:0;transform:translateY(16px)}.animate-fade-in,.animate-fade-in-up,.animate-slide-up{opacity:1;transform:translateY(0);transition:opacity .6s ease,transform .6s ease}.animate-scale-in{opacity:1;transform:scale(1);transition:opacity .6s ease,transform .6s ease}.stagger-1{transition-delay:.1s}.stagger-2{transition-delay:.2s}.stagger-3{transition-delay:.3s}.stagger-4{transition-delay:.4s}.stagger-5{transition-delay:.5s}.stagger-6{transition-delay:.6s}.hover-lift{transition:transform var(--transition-base) ease,box-shadow var(--transition-base) ease}.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.hover-scale{transition:transform var(--transition-base) ease}.hover-scale:hover{transform:scale(1.05)}.animate{animation-fill-mode:both}.animate-fade-in-class{animation:fadeIn .6s ease forwards}.animate-fade-in-up-class{animation:fadeInUp .6s ease forwards}.animate-slide-up-class{animation:slideUp .6s ease forwards}.animate-scale-in-class{animation:scaleIn .4s ease forwards}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease forwards}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) ease forwards}.animate-fade-in-down{animation:fadeInDown var(--transition-slow) ease forwards}.animate-fade-in-left{animation:fadeInLeft var(--transition-slow) ease forwards}.animate-fade-in-right{animation:fadeInRight var(--transition-slow) ease forwards}.animate-scale-in{animation:scaleIn var(--transition-slow) ease forwards}.animate-float{animation:float 3s ease-in-out infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.stagger-6{animation-delay:.6s}.animate-on-load{opacity:0}.hover-lift{transition:transform var(--transition-base),box-shadow var(--transition-base)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.hover-scale{transition:transform var(--transition-fast)}.hover-scale:hover{transform:scale(1.02)}.hover-scale:active{transform:scale(.98)}.page-enter{opacity:0;transform:translateY(10px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity var(--transition-slow),transform var(--transition-slow)}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity var(--transition-base)}.photo-tilt-left{transform:rotate(-5deg);transition:transform var(--transition-base)}.photo-tilt-left:hover{transform:rotate(-3deg) scale(1.02)}.photo-tilt-right{transform:rotate(5deg);transition:transform var(--transition-base)}.photo-tilt-right:hover{transform:rotate(3deg) scale(1.02)}.photo-straight{transform:rotate(0);transition:transform var(--transition-base)}.photo-straight:hover{transform:scale(1.02)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-8);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);line-height:1;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-button-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-button-primary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background-color:var(--color-button-secondary);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background-color:var(--color-button-secondary-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-ghost{background-color:transparent;color:var(--color-button-primary)}.btn-ghost:hover:not(:disabled){background-color:#39565c1a}.btn-lg{padding:var(--space-5) var(--space-10);font-size:var(--text-lg)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-sm)}.input-group{display:flex;flex-direction:column;gap:var(--space-2)}.input-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text)}.input{padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background-color:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-button-primary);box-shadow:0 0 0 3px #39565c1a}.input::placeholder{color:var(--color-text-light)}.input-error{border-color:var(--color-error)}.input-error:focus{box-shadow:0 0 0 3px #dc35451a}.error-message{font-size:var(--text-sm);color:var(--color-error)}.card{background-color:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.card-body{padding:var(--space-6)}.card-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light)}.photo-card{position:relative;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg)}.photo-card img{width:100%;height:100%;object-fit:cover}.photo-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-border) 100%);color:var(--color-text-muted);font-size:var(--text-sm)}.spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-button-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:40px;height:40px;border-width:3px}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-4)}.container-sm{max-width:640px}.container-md{max-width:768px}.container-lg{max-width:1024px}.section{padding:var(--space-16) 0}.section-sm{padding:var(--space-8) 0}.section-lg{padding:var(--space-24) 0}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{scroll-behavior:smooth}body{min-height:100vh;background-color:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}button{cursor:pointer}#root{min-height:100vh;display:flex;flex-direction:column}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.w-full{width:100%}.h-full{height:100%}.relative{position:relative}.absolute{position:absolute}.overflow-hidden{overflow:hidden}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.app{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:inherit;cursor:pointer;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:#213547;background-color:#fff}button{background-color:#f9f9f9}}.auth-container{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:400px;margin:0 auto;padding:2rem;border-radius:8px;background-color:#ffffff1a}.auth-container form{display:flex;flex-direction:column;gap:1rem;width:100%}.auth-container div{display:flex;flex-direction:column;gap:.5rem;text-align:left}.auth-container label{font-weight:500}.auth-container input{padding:.5rem;border-radius:4px;border:1px solid #ccc;background-color:#ffffffe6;color:#213547}.button-group{display:flex;gap:1rem;justify-content:center}.error{color:#ff6b6b;font-size:.9rem}
