body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}@media screen and (max-width:768px){body{overflow-x:hidden}.container{max-width:100%;padding:10px}button{min-height:44px;min-width:44px}h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}p{font-size:16px}.grid{grid-template-columns:1fr!important}img{height:auto;max-width:100%}table{display:block;overflow-x:auto;white-space:nowrap}}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:40px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-message{color:#667eea;font-size:16px;margin-top:15px}.error-boundary{align-items:center;background:#f9fafb;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:40px 20px}.error-boundary-card{background:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-width:28rem;padding:1.5rem;width:100%}.error-icon-container{align-items:center;background:#fee2e2;border-radius:9999px;display:flex;height:3rem;justify-content:center;margin:0 auto;width:3rem}.error-icon{color:#dc2626;height:1.5rem;width:1.5rem}.error-boundary h1{color:#111827;font-size:1.125rem;font-weight:500;margin-top:1rem;text-align:center}.error-boundary p{color:#6b7280;font-size:.875rem;margin-top:.5rem;text-align:center}.error-boundary button{background:#2563eb;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:1rem;margin-top:1.5rem;padding:.5rem 1rem;transition:background .2s;width:100%}.error-boundary button:hover{background:#1d4ed8}.error-boundary details{margin-top:1rem;text-align:left}.error-boundary summary{color:#6b7280;cursor:pointer;font-size:.875rem;padding:.5rem 0}.error-boundary summary:hover{color:#374151}.error-boundary pre{background:#f3f4f6;border-radius:.375rem;color:#dc2626;font-size:.75rem;margin-top:.5rem;max-height:200px;overflow:auto;padding:.5rem}@media (max-width:640px){.error-boundary{padding:20px 16px}.error-boundary-card{padding:1.25rem}}.navbar{background-color:#2c3e50;box-shadow:0 2px 4px #0000001a;color:#fff;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 2rem;position:relative}.navbar-brand{color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none;z-index:1001}.navbar-menu{align-items:center;display:flex;gap:1.5rem}.navbar-link{color:#fff;padding:.5rem 0;text-decoration:none;transition:opacity .2s}.navbar-link:hover{opacity:.8}.navbar-user{color:#ecf0f1;font-size:.9rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-button{background-color:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-block;font-size:1rem;padding:.5rem 1.5rem;text-decoration:none;transition:background-color .2s;white-space:nowrap}.navbar-button:hover{background-color:#2980b9}.navbar-toggle{background:none;border:none;color:#fff;cursor:pointer;display:none;padding:.5rem;z-index:1001}.hamburger{cursor:pointer;display:flex;flex-direction:column;height:20px;justify-content:space-around;width:24px}.hamburger span{background-color:#fff;border-radius:3px;height:3px;transition:all .3s ease;width:100%}.hamburger.active span:first-child{transform:rotate(45deg) translate(8px,8px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(8px,-8px)}@media (max-width:768px){.navbar-container{padding:0 1rem}.navbar-toggle{display:block}.navbar-menu{align-items:stretch;background-color:#2c3e50;box-shadow:0 4px 6px #0000001a;flex-direction:column;gap:0;left:0;max-height:calc(100vh - 60px);overflow-y:auto;padding:1rem 0;position:fixed;right:0;top:60px;transform:translateX(-100%);transition:transform .3s ease;z-index:1000}.navbar-menu.active{transform:translateX(0)}.navbar-button,.navbar-link,.navbar-user{border-bottom:1px solid #ffffff1a;display:block;padding:1rem 2rem;text-align:left;width:100%}.navbar-button:last-child,.navbar-link:last-child{border-bottom:none}.navbar-user{border-bottom:1px solid #ffffff1a;max-width:none;padding:1rem 2rem}.navbar-button{margin:0 2rem;text-align:center;width:calc(100% - 4rem)}.navbar-brand{font-size:1.25rem}}@media (max-width:480px){.navbar-container{padding:0 .75rem}.navbar-brand{font-size:1.125rem}.navbar-menu{top:56px}.navbar-button,.navbar-link,.navbar-user{font-size:.9375rem;padding:.875rem 1.5rem}.navbar-button{margin:0 1.5rem;width:calc(100% - 3rem)}}body.menu-open{overflow:hidden}.home{display:flex;flex-direction:column;min-height:100vh}.hero-parallax{align-items:center;background-attachment:fixed;background-image:url(https://images.unsplash.com/photo-1520250497591-112f2f40a3f4?ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D&auto=format&fit=crop&w=2070&q=80);background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;height:100vh;justify-content:center;min-height:600px;overflow:hidden;position:relative}@supports not (background-attachment:fixed){.hero-parallax{background-attachment:scroll}}.hero-overlay{align-items:center;background:linear-gradient(135deg,#667eead9,#764ba2d9);bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1}.hero-content{color:#fff;margin:0 auto;max-width:900px;padding:2rem;position:relative;text-align:center;z-index:2}.hero-title{animation:fadeInUp .8s ease-out;font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem;text-shadow:2px 2px 4px #0000004d}.hero-subtitle{animation:fadeInUp 1s ease-out;font-size:1.5rem;line-height:1.6;margin-bottom:2.5rem;opacity:.95;text-shadow:1px 1px 2px #0003}.hero-actions{animation:fadeInUp 1.2s ease-out;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;margin-bottom:4rem}.btn{border:none;border-radius:50px;cursor:pointer;display:inline-block;font-size:1.125rem;font-weight:600;padding:1rem 2.5rem;text-decoration:none;transition:all .3s ease}.btn-primary{background:#fff;box-shadow:0 4px 15px #0003;color:#667eea}.btn-primary:hover{background:#f8f9fa;box-shadow:0 6px 20px #0000004d;transform:translateY(-3px)}.btn-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000;border:2px solid #fff;color:#fff}.btn-secondary:hover{background:#fff;box-shadow:0 6px 20px #0000004d;color:#667eea;transform:translateY(-3px)}.hero-stats{animation:fadeInUp 1.4s ease-out;display:flex;flex-wrap:wrap;gap:3rem;justify-content:center;margin-top:3rem}.stat-item{text-align:center}.stat-number{font-size:3rem;font-weight:700;margin-bottom:.5rem;text-shadow:2px 2px 4px #0000004d}.stat-label{font-size:1rem;letter-spacing:1px;opacity:.9;text-transform:uppercase}.about-section{background:#fff;padding:6rem 2rem}.about-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr}.about-text{max-width:600px}.section-title{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:1.5rem}.section-description{color:#555;font-size:1.125rem;line-height:1.8;margin-bottom:1.5rem}.about-features{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin-top:2rem}.about-feature{align-items:center;color:#333;display:flex;font-size:1rem;gap:1rem}.about-feature .feature-icon{font-size:2rem}.about-image,.image-placeholder{align-items:center;display:flex;justify-content:center}.image-placeholder{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 10px 40px #0003;color:#fff;flex-direction:column;height:400px;width:100%}.placeholder-icon{font-size:5rem;margin-bottom:1rem}.image-placeholder p{font-size:1.25rem;font-weight:600}.features-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:6rem 2rem}.features-section .section-title{margin-bottom:1rem;text-align:center}.features-section .section-description{margin:0 auto 4rem;max-width:700px;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.feature-card{background:#fff;border:1px solid #e9ecef;border-radius:15px;box-shadow:0 4px 15px #0000001a;padding:2.5rem;text-align:center;transition:all .3s ease}.feature-card:hover{border-color:#667eea;box-shadow:0 8px 30px #00000026;transform:translateY(-10px)}.feature-card .feature-icon{display:block;font-size:3.5rem;margin-bottom:1.5rem}.feature-card h3{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.feature-card p{color:#666;font-size:1rem;line-height:1.6}.benefits-section{background:#fff;padding:6rem 2rem}.benefits-section .section-title{margin-bottom:4rem;text-align:center}.benefits-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.benefit-item{border-radius:15px;padding:2rem;text-align:center;transition:all .3s ease}.benefit-item:hover{background:#f8f9fa;transform:translateY(-5px)}.benefit-icon{display:block;font-size:3rem;margin-bottom:1rem}.benefit-item h3{color:#2c3e50;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.benefit-item p{color:#666;font-size:1rem;line-height:1.6}.cta-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6rem 2rem;text-align:center}.cta-title{color:#fff;font-size:3rem;font-weight:700;margin-bottom:1.5rem}.cta-description{font-size:1.25rem;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:700px;opacity:.95}.cta-actions{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.btn-cta{background:#fff;border-radius:50px;box-shadow:0 4px 15px #0003;color:#667eea;font-size:1.25rem;font-weight:600;padding:1.25rem 3rem;text-decoration:none;transition:all .3s ease}.btn-cta:hover{background:#f8f9fa;box-shadow:0 6px 20px #0000004d;transform:translateY(-3px)}.btn-cta-secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000;border:2px solid #fff;border-radius:50px;color:#fff;font-size:1.25rem;font-weight:600;padding:1.25rem 3rem;text-decoration:none;transition:all .3s ease}.btn-cta-secondary:hover{background:#fff;box-shadow:0 6px 20px #0000004d;color:#667eea;transform:translateY(-3px)}.footer{background:#2c3e50;color:#fff;padding:4rem 2rem 2rem}.footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.footer-section h3,.footer-section h4{color:#fff;margin-bottom:1.5rem}.footer-section p{color:#bdc3c7;line-height:1.6;margin-bottom:.5rem}.footer-section ul{list-style:none;padding:0}.footer-section ul li{margin-bottom:.75rem}.footer-section ul li a{color:#bdc3c7;text-decoration:none;transition:color .3s ease}.footer-section ul li a:hover{color:#fff}.footer-bottom{border-top:1px solid #ffffff1a;color:#bdc3c7;padding-top:2rem;text-align:center}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.container{margin:0 auto;max-width:1200px}@media (max-width:968px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.25rem}.hero-stats{gap:2rem}.stat-number{font-size:2.5rem}.about-content{gap:3rem}.about-content,.about-features{grid-template-columns:1fr}.section-title{font-size:2rem}.features-grid{grid-template-columns:1fr}.benefits-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.cta-title{font-size:2rem}.cta-description{font-size:1.125rem}.footer-content{gap:2rem;grid-template-columns:1fr}}@media (max-width:768px){.hero-parallax{background-attachment:scroll;min-height:500px}.hero-title{font-size:2rem}.hero-subtitle{font-size:1.125rem}.hero-actions{align-items:stretch;flex-direction:column}.btn{text-align:center;width:100%}.hero-stats{flex-direction:column;gap:1.5rem}.stat-number{font-size:2rem}.about-section,.benefits-section,.cta-section,.features-section{padding:4rem 1.5rem}.section-title{font-size:1.75rem}.feature-card{padding:2rem}.benefit-item{padding:1.5rem}.cta-title{font-size:1.75rem}.cta-actions{align-items:stretch;flex-direction:column}.btn-cta,.btn-cta-secondary{text-align:center;width:100%}}@media (max-width:480px){.hero-title{font-size:1.75rem}.hero-subtitle{font-size:1rem}.hero-stats{gap:1rem}.stat-number{font-size:1.75rem}.stat-label{font-size:.875rem}.about-section,.benefits-section,.cta-section,.features-section{padding:3rem 1rem}.section-title{font-size:1.5rem}.feature-card{padding:1.5rem}.feature-card .feature-icon{font-size:2.5rem}.benefit-item{padding:1rem}.benefit-icon{font-size:2.5rem}.cta-title{font-size:1.5rem}.cta-description{font-size:1rem}}html{scroll-behavior:smooth}@media (prefers-reduced-motion:reduce){.hero-parallax{background-attachment:scroll}*,.hero-parallax{animation:none!important;transition:none!important}}.auth-page{display:flex;flex-direction:column;min-height:100vh}.auth-container{align-items:center;background-color:#f8f9fa;display:flex;flex:1 1;justify-content:center;padding:2rem}.auth-card{background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001a;max-width:400px;padding:3rem;width:100%}.auth-card h2{color:#2c3e50;margin-bottom:2rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{color:#34495e;display:block;font-weight:500;margin-bottom:.5rem}.form-group input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#3498db;outline:none}.checkbox-group{margin:1.5rem 0}.checkbox-label{align-items:flex-start;cursor:pointer;display:flex;font-weight:400!important}.checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;margin-right:.75rem;margin-top:.25rem;width:auto}.checkbox-label span{color:#555;font-size:.95rem;line-height:1.5}.checkbox-label span a{border-bottom:1px dotted #3498db;color:#3498db;font-weight:500;text-decoration:none}.checkbox-label span a:hover{border-bottom:1px solid #2980b9;color:#2980b9}.btn-primary{background-color:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem;transition:background-color .2s;width:100%}.btn-primary:hover:not(:disabled){background-color:#2980b9}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.error-message{background-color:#fee;border-radius:4px;color:#c33;margin-bottom:1.5rem;padding:1rem}.auth-divider{align-items:center;color:#666;display:flex;font-size:14px;margin:24px 0;text-align:center}.auth-divider:after,.auth-divider:before{border-bottom:1px solid #ddd;content:"";flex:1 1}.auth-divider span{padding:0 16px}.google-signin-container{align-items:center;display:flex;flex-direction:column;gap:12px;margin-bottom:20px;width:100%}.google-signin-container>div{display:flex;justify-content:center;width:100%!important}.google-signin-container>div>div{width:100%!important}.google-signin-container p{color:#666;font-size:14px;margin:0}.auth-footer{color:#7f8c8d;margin-top:1.5rem;text-align:center}.auth-footer a{color:#3498db;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.account-type-selector{display:flex;gap:12px;margin-top:8px}.account-type-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;flex:1 1;flex-direction:column;padding:16px 12px;transition:all .2s ease}.account-type-btn:hover{background:#f8fafc;border-color:#3498db}.account-type-btn.active{background:#ebf5ff;border-color:#3498db}.account-type-icon{font-size:28px;margin-bottom:8px}.account-type-label{color:#2c3e50;font-size:14px;font-weight:600;margin-bottom:4px}.account-type-desc{color:#7f8c8d;font-size:11px;line-height:1.3;text-align:center}.terms-acceptance-box{background:linear-gradient(135deg,#f0f9ff,#e8f4fd);border:2px solid #3498db;border-radius:10px;margin-bottom:20px;padding:16px 20px}.terms-checkbox-prominent{font-weight:400!important}.terms-checkbox-prominent span{color:#2c3e50;font-size:.95rem;line-height:1.5}.terms-checkbox-prominent span a{color:#2980b9;font-weight:600}.google-signin-top{margin-bottom:0}.google-terms-hint{color:#e74c3c;display:block;font-size:.85rem;margin-top:8px;text-align:center}