:root{--primary-orange:#ff8c42;--dark-orange:#e67a2e;--light-orange:#ffb380;--primary-green:#4caf50;--dark-green:#388e3c;--light-green:#81c784;--white:#fff;--off-white:#f5f5f5;--gray:#757575;--light-gray:#e0e0e0;--dark-gray:#424242;--shadow:#0000001a}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;background-color:var(--off-white);color:#424242;color:var(--dark-gray);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.navbar{background:linear-gradient(135deg,#ff8c42,#e67a2e);background:linear-gradient(135deg,var(--primary-orange) 0,var(--dark-orange) 100%);box-shadow:0 2px 8px var(--shadow);color:#fff;color:var(--white);padding:1rem 2rem;z-index:100}.navbar-container{max-width:1200px}.navbar-logo{color:var(--white);font-size:1.8rem;gap:.5rem}.navbar-menu{gap:1.5rem}.navbar-link{border-radius:5px;color:#fff;color:var(--white);padding:.5rem 1rem;transition:all .3s ease}.navbar-link:hover{background-color:#fff3;transform:translateY(-2px)}.navbar-button{background-color:#4caf50;background-color:var(--primary-green);border-radius:25px;color:var(--white);font-size:1rem;padding:.6rem 1.5rem;transition:all .3s ease}.navbar-button:hover{background-color:#388e3c;background-color:var(--dark-green);box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow)}.container{margin:0 auto;max-width:1200px;padding:2rem}.landing-hero{background:linear-gradient(135deg,#ff8c42,#4caf50);background:linear-gradient(135deg,var(--primary-orange) 0,var(--primary-green) 100%);border-radius:15px;box-shadow:0 8px 16px #0000001a;box-shadow:0 8px 16px var(--shadow);color:#fff;color:var(--white);margin:2rem;padding:4rem 2rem;text-align:center}.landing-hero h1{font-size:3rem;margin-bottom:1rem}.landing-hero p{font-size:1.3rem;margin-bottom:2rem;opacity:.95}.hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.btn-primary{background-color:#fff;background-color:var(--white);border:none;border-radius:30px;color:#ff8c42;color:var(--primary-orange);cursor:pointer;display:inline-block;font-size:1.1rem;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.btn-primary:hover{box-shadow:0 6px 12px #0000001a;box-shadow:0 6px 12px var(--shadow);transform:translateY(-3px)}.btn-secondary{background-color:initial;border:2px solid #fff;border:2px solid var(--white);border-radius:30px;color:#fff;color:var(--white);cursor:pointer;display:inline-block;font-size:1.1rem;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.btn-secondary:hover{background-color:#fff;background-color:var(--white);color:#ff8c42;color:var(--primary-orange);transform:translateY(-3px)}.features-section{padding:4rem 2rem}.features-section h2{color:#424242;color:var(--dark-gray);font-size:2.5rem;margin-bottom:3rem;text-align:center}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:0 auto;max-width:1200px}.feature-card{background:#fff;background:var(--white);border-radius:15px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);padding:2rem;text-align:center;transition:all .3s ease}.feature-card:hover{box-shadow:0 8px 16px #0000001a;box-shadow:0 8px 16px var(--shadow);transform:translateY(-5px)}.feature-icon{color:#ff8c42;color:var(--primary-orange);font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#4caf50;color:var(--primary-green);font-size:1.5rem;margin-bottom:1rem}.feature-card p{color:#757575;color:var(--gray);line-height:1.6}.auth-container{background:#fff;background:var(--white);border-radius:15px;box-shadow:0 8px 16px #0000001a;box-shadow:0 8px 16px var(--shadow);margin:3rem auto;max-width:450px;padding:2rem}.auth-container h2{color:#ff8c42;color:var(--primary-orange);font-size:2rem;margin-bottom:2rem;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{color:#424242;color:var(--dark-gray);display:block;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;border:2px solid var(--light-gray);border-radius:8px;font-size:1rem;padding:.8rem;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#ff8c42;border-color:var(--primary-orange);outline:none}.btn-submit{background:linear-gradient(135deg,#ff8c42,#e67a2e);background:linear-gradient(135deg,var(--primary-orange) 0,var(--dark-orange) 100%);border-radius:8px;color:var(--white);font-size:1.1rem;padding:1rem;transition:all .3s ease}.btn-submit:hover{box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);transform:translateY(-2px)}.btn-submit:disabled{background:#757575;background:var(--gray);transform:none}.auth-footer{color:#757575;color:var(--gray);margin-top:1.5rem;text-align:center}.auth-footer a{color:#4caf50;color:var(--primary-green);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.error-message{background-color:#ffebee;color:#c62828}.error-message,.success-message{border-radius:8px;margin-bottom:1rem;padding:.8rem;text-align:center}.success-message{background-color:#e8f5e9;color:#388e3c;color:var(--dark-green)}.dashboard{padding:2rem}.dashboard-header{background:linear-gradient(135deg,#ff8c42,#4caf50);background:linear-gradient(135deg,var(--primary-orange) 0,var(--primary-green) 100%);border-radius:15px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);color:#fff;color:var(--white);margin-bottom:2rem;padding:2rem}.dashboard-header h1{font-size:2.5rem;margin-bottom:.5rem}.dashboard-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:2rem}.dashboard-card{background:#fff;background:var(--white);border-radius:12px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);color:inherit;cursor:pointer;padding:1.5rem;text-decoration:none;transition:all .3s ease}.dashboard-card:hover{box-shadow:0 8px 16px #0000001a;box-shadow:0 8px 16px var(--shadow);transform:translateY(-5px)}.dashboard-card-icon{color:#ff8c42;color:var(--primary-orange);font-size:2.5rem;margin-bottom:1rem}.dashboard-card h3{color:#4caf50;color:var(--primary-green);margin-bottom:.5rem}.dashboard-card p{color:#757575;color:var(--gray)}.upload-container{background:#fff;background:var(--white);border-radius:15px;box-shadow:0 8px 16px #0000001a;box-shadow:0 8px 16px var(--shadow);margin:2rem auto;max-width:600px;padding:2rem}.upload-zone{border:3px dashed #ff8c42;border:3px dashed var(--primary-orange);border-radius:12px;cursor:pointer;margin-bottom:1.5rem;padding:3rem;text-align:center;transition:all .3s ease}.upload-zone:hover{background-color:#ff8c420d;border-color:#e67a2e;border-color:var(--dark-orange)}.upload-zone-active{background-color:#4caf500d;border-color:#4caf50;border-color:var(--primary-green)}.upload-icon{color:#ff8c42;color:var(--primary-orange);font-size:4rem;margin-bottom:1rem}.preview-image{border-radius:12px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);margin:1rem 0;max-width:100%}.photo-gallery{padding:2rem}.event-section{background:#fff;background:var(--white);border-radius:15px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);margin-bottom:3rem;padding:2rem}.event-header{border-bottom:3px solid #ff8c42;border-bottom:3px solid var(--primary-orange);margin-bottom:1.5rem;padding-bottom:1rem}.event-header h3{color:#ff8c42;color:var(--primary-orange);font-size:1.8rem;margin-bottom:.5rem}.event-meta{color:#757575;color:var(--gray);display:flex;flex-wrap:wrap;gap:1rem}.category-badge{background:#4caf50;background:var(--primary-green);border-radius:15px;color:#fff;color:var(--white);font-size:.9rem;font-weight:600;padding:.3rem .8rem}.photos-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.photo-card{background:var(--white);box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);transition:all .3s ease}.photo-card:hover{box-shadow:0 8px 16px #0000001a;box-shadow:0 8px 16px var(--shadow);transform:translateY(-5px)}.photo-card img{height:200px}.photo-info{padding:1rem}.confidence-bar{background:var(--light-gray);border-radius:10px;height:8px;margin:.5rem 0}.confidence-fill{background:linear-gradient(90deg,#4caf50,#ff8c42);background:linear-gradient(90deg,var(--primary-green) 0,var(--primary-orange) 100%);transition:width .5s ease}.confidence-score{color:#4caf50;color:var(--primary-green);font-size:1.1rem;font-weight:600}.events-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:2rem}.event-card{background:#fff;background:var(--white);border-radius:12px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);cursor:pointer;padding:1.5rem;transition:all .3s ease}.event-card:hover{box-shadow:0 8px 16px #0000001a;box-shadow:0 8px 16px var(--shadow);transform:translateY(-5px)}.event-card h3{color:#ff8c42;color:var(--primary-orange);margin-bottom:.5rem}.analytics-container{padding:2rem}.stats-grid{grid-gap:1.5rem;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:var(--white);border-radius:12px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);padding:1.5rem;text-align:center}.stat-value{color:#ff8c42;color:var(--primary-orange);font-size:2.5rem;margin-bottom:.5rem}.stat-label{color:#757575;color:var(--gray);font-size:1rem}.chart-container{background:#fff;background:var(--white);border-radius:15px;box-shadow:0 4px 8px #0000001a;box-shadow:0 4px 8px var(--shadow);margin-bottom:2rem;padding:2rem}.chart-container h3{color:#4caf50;color:var(--primary-green);margin-bottom:1.5rem}.loading-screen{align-items:center;background:linear-gradient(135deg,#ff8c42,#4caf50);background:linear-gradient(135deg,var(--primary-orange) 0,var(--primary-green) 100%);color:#fff;color:var(--white);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.spinner{border:4px solid #ffffff4d;border-top:4px solid var(--white);height:50px;margin-bottom:1rem;width:50px}@media (max-width:768px){.navbar-container{flex-direction:column;gap:1rem}.navbar-menu{flex-direction:column;width:100%}.landing-hero h1{font-size:2rem}.landing-hero p{font-size:1rem}.features-grid{grid-template-columns:1fr}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.navbar{background:linear-gradient(135deg,#e0961e,#02cb1d);box-shadow:0 2px 8px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.navbar-container{height:70px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 20px}.navbar-container,.navbar-logo{align-items:center;display:flex}.navbar-logo{color:#fff;font-size:24px;font-weight:700;gap:12px;text-decoration:none;transition:all .3s}.navbar-logo:hover{color:#ff8c42;transform:scale(1.05)}.logo-icon{font-size:28px}.logo-text{font-weight:700}.mobile-menu-toggle{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:none;font-size:24px;justify-content:center;padding:8px;transition:all .3s}.mobile-menu-toggle:hover{color:#ff8c42}.navbar-menu{align-items:center;display:flex;gap:8px;list-style:none;margin:0;padding:0}.navbar-menu li{position:relative}.navbar-link{align-items:center;border-radius:8px;color:#ffffffe6;display:flex;font-size:15px;font-weight:500;gap:8px;padding:10px 16px;text-decoration:none;transition:all .3s}.navbar-link.active,.navbar-link:hover{background:#ffffff1a;color:#ff8c42}.navbar-link svg{font-size:18px}.navbar-button{align-items:center;background:linear-gradient(135deg,#ff8c42,#ff6b35);border:none;border-radius:8px;box-shadow:0 4px 12px #ff8c424d;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;padding:10px 20px;text-decoration:none;transition:all .3s}.navbar-button:hover{box-shadow:0 6px 16px #ff8c4266;transform:translateY(-2px)}.navbar-cart-menu,.navbar-user-menu{position:relative}.cart-menu-trigger{align-items:center;background:#ffffff1f;border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;height:44px;justify-content:center;position:relative;transition:all .2s;width:44px}.cart-menu-trigger:hover{background:#ffffff2e;transform:translateY(-1px)}.cart-menu-trigger svg{font-size:20px}.cart-count-badge{background:#ff8c42;border:2px solid #ffffffe6;border-radius:999px;color:#fff;font-size:11px;font-weight:800;height:18px;line-height:14px;min-width:18px;padding:0 5px;position:absolute;right:2px;top:3px}.cart-dropdown{background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000029;padding:14px;position:absolute;right:0;top:calc(100% + 10px);width:min(340px,88vw);z-index:1001}.cart-dropdown-header,.cart-total-row{align-items:center;display:flex;gap:1rem;justify-content:space-between}.cart-dropdown-header{border-bottom:1px solid #e0e0e0;color:#2c3e50;padding-bottom:10px}.cart-dropdown-header span{color:#7f8c8d;font-size:13px}.cart-empty{color:#7f8c8d;margin:14px 0 2px;text-align:center}.cart-items{max-height:260px;overflow-y:auto;padding:8px 0}.cart-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:10px;justify-content:space-between;padding:9px 0}.cart-item-info{grid-gap:3px;display:grid;gap:3px;min-width:0}.cart-item-name{color:#2c3e50;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-item-price{color:#7f8c8d;font-size:13px}.cart-item-remove{align-items:center;background:#f5f5f5;border:none;border-radius:8px;color:#e74c3c;cursor:pointer;display:inline-flex;flex:0 0 auto;height:30px;justify-content:center;width:30px}.cart-item-remove:hover{background:#fee}.cart-total-row{color:#2c3e50;font-weight:700;padding-top:10px}.cart-checkout-button{align-items:center;background:linear-gradient(135deg,#ff8c42,#ff6b35);border:none;border-radius:8px;box-shadow:0 4px 12px #ff8c4240;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:800;gap:8px;justify-content:center;margin-top:12px;min-height:42px;padding:0 14px;width:100%}.cart-checkout-button:hover{box-shadow:0 6px 16px #ff8c4259;transform:translateY(-1px)}.user-menu-trigger{align-items:center;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;gap:10px;padding:6px 12px;transition:all .3s}.user-menu-trigger:hover{background:#ffffff26}.user-avatar{align-items:center;background:#ff8c42;border:2px solid #fff;border-radius:50%;display:flex;font-size:16px;font-weight:700;height:36px;justify-content:center;overflow:hidden;width:36px}.user-avatar img{height:100%;object-fit:cover;width:100%}.user-name{font-size:14px;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown{background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:240px;padding:12px 0;position:absolute;right:0;top:calc(100% + 10px);z-index:1001}.dropdown-header{padding:12px 20px}.dropdown-name{color:#2c3e50;font-size:16px;font-weight:600;margin:0 0 4px}.dropdown-email{color:#7f8c8d;font-size:13px;margin:0 0 8px}.dropdown-role{background:#ff8c42;border-radius:6px;color:#fff;display:inline-block;font-size:11px;font-weight:600;padding:4px 12px;text-transform:uppercase}.dropdown-divider{background:#e0e0e0;height:1px;margin:8px 0}.dropdown-link{align-items:center;background:none;border:none;color:#2c3e50;cursor:pointer;display:flex;font-size:14px;gap:12px;padding:10px 20px;text-align:left;text-decoration:none;transition:all .2s;width:100%}.dropdown-link:hover{background:#f5f5f5}.dropdown-link svg{color:#7f8c8d;font-size:16px}.logout-link,.logout-link svg{color:#e74c3c}.logout-link:hover{background:#fee}@media (max-width:768px){.navbar{position:-webkit-sticky;position:sticky}.navbar-container{flex-direction:row;gap:12px;height:64px;padding:0 16px}.mobile-menu-toggle{display:inline-flex;flex:0 0 auto}.navbar-menu{align-items:stretch;background:#2c3e50;box-shadow:0 8px 16px #0003;flex-direction:column;gap:12px;left:0;max-height:0;opacity:0;overflow:hidden;padding:20px;pointer-events:none;position:fixed;right:0;top:64px;transition:max-height .3s ease,opacity .2s ease;width:100%}.navbar-menu.mobile-active{-webkit-overflow-scrolling:touch;max-height:calc(100dvh - 64px);opacity:1;overflow-y:auto;pointer-events:auto}.navbar-menu li{width:100%}.navbar-button,.navbar-link{justify-content:flex-start;min-height:44px;width:100%}.user-menu-trigger{justify-content:flex-start;min-height:48px;width:100%}.user-dropdown{border:1px solid #ffffff1a;box-shadow:none;margin-top:12px;position:static}.cart-menu-trigger{min-height:44px;width:100%}.cart-dropdown{box-shadow:none;margin-top:12px;position:static;width:100%}}@media (max-width:480px){.navbar-logo{font-size:20px}.logo-text,.user-name{display:none}}.main-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{background:#f5f7fa;flex:1 1}.main-content-padded{padding:20px}.content-container{margin:0 auto;max-width:1400px;padding:20px}.login-page{background:#f5f7fa;display:flex;min-height:100vh}.login-branding{align-items:center;background:linear-gradient(135deg,#ff8c42,#ff6b35);display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:60px;position:relative}.branding-content{color:#fff;max-width:500px;position:relative;z-index:2}.brand-logo{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;display:flex;font-size:40px;height:80px;justify-content:center;margin-bottom:30px;width:80px}.brand-title{font-size:48px;font-weight:800;letter-spacing:-1px;margin:0 0 16px}.brand-subtitle{font-size:18px;line-height:1.6;margin-bottom:40px;opacity:.95}.features-list{display:flex;flex-direction:column;gap:16px}.feature-item{align-items:center;display:flex;font-size:16px;gap:12px;opacity:.9}.feature-icon{color:#ffffffe6;font-size:20px}.branding-decoration{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.decoration-circle{background:#ffffff1a;border-radius:50%;position:absolute}.circle-1{height:400px;right:-100px;top:-100px;width:400px}.circle-2{bottom:-50px;height:300px;left:-50px;width:300px}.circle-3{height:200px;left:10%;opacity:.5;top:50%;width:200px}.login-form-container{align-items:center;background:#fff;display:flex;flex:1 1;justify-content:center;padding:40px}.login-form-wrapper{max-width:450px;width:100%}.form-header{margin-bottom:32px;text-align:center}.form-header h2{color:#2c3e50;font-size:32px;font-weight:700;margin:0 0 8px}.form-header p{color:#7f8c8d;font-size:16px;margin:0}.alert{align-items:center;border-radius:12px;display:flex;font-size:14px;font-weight:500;gap:10px;margin-bottom:24px;padding:14px 16px}.alert-error{background:#fee;border:1px solid #e74c3c;color:#e74c3c}.alert-icon{font-size:18px}.login-form{gap:20px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#2c3e50;font-size:14px;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#7f8c8d;font-size:18px;left:14px;position:absolute}.input-wrapper input{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:12px;font-size:15px;padding:14px 14px 14px 45px;transition:all .3s;width:100%}.input-wrapper input:focus{background:#fff;border-color:#ff8c42;box-shadow:0 0 0 4px #ff8c421a;outline:none}.input-wrapper.error input{border-color:#e74c3c}.input-wrapper input:disabled{background:#f5f5f5;cursor:not-allowed}.password-toggle{background:none;border:none;color:#7f8c8d;cursor:pointer;padding:8px;position:absolute;right:14px;transition:color .3s}.password-toggle:hover{color:#ff8c42}.field-error{color:#e74c3c;font-size:13px;margin-top:4px}.form-options{justify-content:space-between;margin-top:4px}.checkbox-label,.form-options{align-items:center;display:flex}.checkbox-label{color:#2c3e50;cursor:pointer;font-size:14px;gap:8px}.checkbox-label input{cursor:pointer;height:18px;width:18px}.forgot-link{color:#ff8c42;font-size:14px;font-weight:600;text-decoration:none}.forgot-link:hover{text-decoration:underline}.btn-submit{align-items:center;background:linear-gradient(135deg,#ff8c42,#ff6b35);border:none;border-radius:12px;box-shadow:0 4px 12px #ff8c424d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;padding:16px;transition:all .3s;width:100%}.btn-submit:hover:not(:disabled){box-shadow:0 6px 16px #ff8c4266;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.7}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:18px;width:18px}.divider{margin:24px 0;position:relative;text-align:center}.divider:before{background:#e0e0e0;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.divider span{background:#fff;color:#7f8c8d;font-size:14px;padding:0 16px;position:relative}.form-footer{text-align:center}.form-footer p{color:#7f8c8d;font-size:15px;margin:0}.register-link{color:#ff8c42;font-weight:600;text-decoration:none}.register-link:hover{text-decoration:underline}@media (max-width:968px){.login-page{flex-direction:column}.login-branding{min-height:300px;padding:40px 20px}.brand-title{font-size:36px}.brand-subtitle{font-size:16px}.login-form-container{padding:30px 20px}}@media (max-width:480px){.login-branding{min-height:250px}.brand-title{font-size:28px}.form-header h2{font-size:26px}}.dashboard{background:#f5f7fa;margin:0 auto;max-width:1400px;min-height:100vh;padding:30px}.dashboard-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin-bottom:40px;padding:30px}.welcome-section h1{color:#2c3e50;font-size:32px;font-weight:700;margin:0 0 10px}.subtitle{color:#7f8c8d;font-size:16px;margin:0;max-width:600px}.user-profile-badge{align-items:center;background:linear-gradient(135deg,#ff8c42,#ff6b35);border-radius:12px;color:#fff;display:flex;gap:15px;padding:15px 25px}.profile-avatar{border:3px solid #fff;border-radius:50%;box-shadow:0 4px 12px #00000026;height:60px;overflow:hidden;width:60px}.profile-avatar img{height:100%;object-fit:cover;width:100%}.avatar-placeholder{align-items:center;background:#ffffff4d;color:#fff;display:flex;font-size:28px;font-weight:700;height:100%;justify-content:center;width:100%}.profile-info{display:flex;flex-direction:column;gap:4px}.profile-name{font-size:18px;font-weight:600}.profile-role{font-size:14px;opacity:.9;text-transform:capitalize}.dashboard-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.stat-content{display:flex;flex-direction:column;gap:8px}.stat-label{color:#7f8c8d;font-size:14px;font-weight:500}.subscription-section{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;margin-bottom:40px;padding:30px}.subscription-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:24px}.subscription-header h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0 0 8px}.subscription-header p{color:#7f8c8d;font-size:15px;margin:0}.current-plan-pill{background:#f8f9fa;border:1px solid #e9ecef;border-radius:999px;color:#2c3e50;font-size:14px;font-weight:700;padding:10px 16px;white-space:nowrap}.subscription-message{border-radius:10px;font-size:14px;font-weight:600;margin-bottom:20px;padding:14px 16px}.subscription-message.success{background:#eaf7ea;color:#2e7d32}.subscription-message.error{background:#fee;color:#c0392b}.subscription-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(4,minmax(0,1fr))}.subscription-card{border:2px solid #e9ecef;border-radius:14px;display:flex;flex-direction:column;min-height:100%;padding:22px;position:relative;transition:all .3s}.subscription-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-3px)}.subscription-card.current{background:#fbfcfd;box-shadow:0 6px 18px #00000014}.subscription-card.featured{border-color:#ff8c42}.current-badge,.popular-badge{border-radius:999px;color:#fff;font-size:11px;font-weight:800;letter-spacing:0;padding:6px 10px;position:absolute;right:14px;text-transform:uppercase;top:14px}.popular-badge{background:#ff8c42}.current-badge{right:14px;top:44px}.plan-heading{gap:12px;padding-right:86px}.plan-heading,.plan-icon{align-items:center;display:flex}.plan-icon{background:#f8f9fa;border-radius:10px;flex-shrink:0;font-size:24px;font-weight:800;height:46px;justify-content:center;width:46px}.plan-heading h3{color:#2c3e50;font-size:20px;font-weight:700;margin:0;word-break:break-word}.plan-price{color:#2c3e50;font-size:34px;font-weight:800;margin:20px 0}.plan-price span{color:#7f8c8d;font-size:14px;font-weight:600;margin-left:4px}.plan-features{border-top:1px solid #e9ecef;flex:1 1;list-style:none;margin:0 0 20px;padding:16px 0 0}.plan-features li{align-items:flex-start;color:#34495e;display:flex;font-size:14px;gap:10px;line-height:1.45;margin-bottom:12px}.plan-features li span{flex-shrink:0;font-weight:800}.plan-select-button{border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:15px;font-weight:800;min-height:46px;padding:12px 16px;transition:all .3s;width:100%}.plan-select-button:hover:not(:disabled){box-shadow:0 6px 14px #0000002e;transform:translateY(-2px)}.plan-select-button:disabled{cursor:not-allowed;opacity:.75}.dashboard-actions{margin-bottom:40px}.dashboard-actions h2{color:#2c3e50;font-size:24px;font-weight:600;margin-bottom:20px}.actions-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.action-card{align-items:center;background:#fff;border:2px solid #0000;border-radius:16px;box-shadow:0 2px 8px #00000014;cursor:pointer;display:flex;gap:16px;padding:24px;transition:all .3s}.action-card:hover{border-color:currentColor;box-shadow:0 8px 20px #00000026;transform:translateY(-4px)}.action-card.highlight{animation:pulse 2s infinite;background:linear-gradient(135deg,#fff5f5,#fff);border-color:#e74c3c}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.action-icon{font-size:40px;line-height:1}.action-content{flex:1 1}.action-content h3{color:#2c3e50;font-size:18px;font-weight:600;margin:0 0 6px}.action-content p{color:#7f8c8d;font-size:14px;margin:0}.action-arrow{font-size:24px;font-weight:700;opacity:.3;transition:all .3s}.action-card:hover .action-arrow{opacity:1;transform:translateX(5px)}.dashboard-recent{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;padding:30px}.dashboard-recent h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0 0 24px}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{align-items:center;background:#f8f9fa;border-radius:12px;display:flex;gap:16px;padding:16px;transition:all .3s}.activity-item:hover{background:#e9ecef;transform:translateX(4px)}.activity-icon{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;font-size:32px;height:50px;justify-content:center;width:50px}.activity-content{flex:1 1}.activity-content h4{color:#2c3e50;font-size:16px;font-weight:600;margin:0 0 4px}.activity-content p{color:#7f8c8d;font-size:14px;margin:0}.activity-stats{color:#7f8c8d;font-size:14px;font-weight:500}.activity-badge{font-size:24px}.activity-loading,.dashboard-loading,.stats-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px}.spinner-small{animation:spin 1s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#ff8c42;height:40px;width:40px}.empty-state{color:#7f8c8d;padding:40px;text-align:center}.empty-state p{font-size:16px;margin:0}.error-banner{align-items:center;background:#fee;border:2px solid #e74c3c;border-radius:12px;display:flex;gap:12px;margin-bottom:30px;padding:20px}.error-icon{font-size:24px}.error-banner p{color:#c0392b;flex:1 1;font-weight:500;margin:0}.btn-retry{background:#e74c3c;border-radius:8px;padding:10px 20px}.btn-retry:hover{background:#c0392b}@media (max-width:1024px){.dashboard-header{flex-direction:column;gap:20px;text-align:center}.actions-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.subscription-header{flex-direction:column}.subscription-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:768px){.dashboard,.dashboard-header{padding:20px}.welcome-section h1{font-size:24px}.subtitle{font-size:14px}.actions-grid,.dashboard-stats{grid-template-columns:1fr}.subscription-section{padding:20px}.subscription-grid{grid-template-columns:1fr}.current-plan-pill{white-space:normal}.user-profile-badge{justify-content:center;width:100%}}.analytics-container{background:#f5f7fa;min-height:100vh;padding:30px}.analytics-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.analytics-header h1{color:#2c3e50;font-size:32px;font-weight:700;margin:0}.btn-refresh{background:linear-gradient(135deg,#ff8c42,#ff6b35);border:none;border-radius:12px;box-shadow:0 4px 12px #ff8c424d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s}.btn-refresh:hover{box-shadow:0 6px 16px #ff8c4266;transform:translateY(-2px)}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:16px;box-shadow:0 2px 8px #00000014;display:flex;gap:20px;padding:24px;transition:all .3s}.stat-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-4px)}.stat-icon{font-size:48px;line-height:1}.stat-content{flex:1 1}.stat-title{color:#7f8c8d;font-size:14px;font-weight:500;margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;line-height:1}.charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:30px}.chart-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;padding:24px}.chart-card h3{color:#2c3e50;font-size:20px;font-weight:600;margin:0 0 20px}.events-table-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;margin-bottom:30px;padding:24px}.events-table{border-collapse:collapse;width:100%}.events-table th{border-bottom:2px solid #e0e0e0;color:#7f8c8d;font-size:14px;font-weight:600;padding:12px;text-align:left;text-transform:uppercase}.events-table td{border-bottom:1px solid #f0f0f0;color:#2c3e50;padding:16px 12px}.events-table tr:hover{background:#f8f9fa}.progress-bar{background:#e0e0e0;border-radius:12px;height:24px;overflow:hidden;width:100%}.progress-fill{align-items:center;background:linear-gradient(90deg,#4caf50,#2e7d32);color:#fff;display:flex;font-size:12px;font-weight:600;height:100%;justify-content:center;transition:width .3s}.confidence-bars{display:flex;flex-direction:column;gap:20px;padding:20px 0}.confidence-item{align-items:center;display:flex;gap:12px}.confidence-item span{color:#2c3e50;font-weight:600;min-width:80px}.confidence-bar{background:#e0e0e0;border-radius:16px;flex:1 1;height:32px;overflow:hidden}.confidence-fill{align-items:center;color:#fff;display:flex;font-size:14px;font-weight:600;height:100%;justify-content:center;transition:width .3s}.my-photos-section{margin-top:30px}.my-photos-section h3{color:#2c3e50;font-size:24px;margin-bottom:20px}.event-photo-group{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:24px}.event-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;gap:16px;margin-bottom:20px;padding-bottom:16px}.event-header h4{color:#2c3e50;flex:1 1;font-size:20px;margin:0}.event-category{background:#ff8c42;border-radius:8px;color:#fff;font-size:12px;font-weight:600;padding:6px 12px;text-transform:uppercase}.photo-count{color:#7f8c8d;font-size:14px;font-weight:500}.photos-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.photo-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;cursor:pointer;overflow:hidden;position:relative;transition:all .3s}.photo-card:hover{box-shadow:0 8px 20px #0003;transform:scale(1.05)}.photo-card img{aspect-ratio:1;display:block;object-fit:cover;width:100%}.photo-name{color:#2c3e50;font-size:14px;font-weight:600;overflow:hidden;padding:10px 12px;text-overflow:ellipsis;white-space:nowrap}.photo-overlay{background:linear-gradient(180deg,#00000080,#0000);bottom:0;display:flex;justify-content:flex-end;left:0;padding:12px;position:absolute;right:0;top:0}.confidence-badge{background:#fffffff2;border-radius:8px;color:#ff8c42;font-size:14px;font-weight:700;height:-webkit-fit-content;height:fit-content;padding:6px 12px}.error-screen,.loading-screen{align-items:center;display:flex;flex-direction:column;gap:20px;justify-content:center;min-height:60vh}.spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#ff8c42;height:60px;width:60px}@keyframes spin{to{transform:rotate(1turn)}}.error-icon{font-size:64px}.error-screen p{color:#e74c3c;font-size:18px;margin:0}.btn-retry{background:#ff8c42;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 32px;transition:all .3s}.btn-retry:hover{background:#ff6b35;transform:translateY(-2px)}@media (max-width:768px){.analytics-container{padding:20px}.analytics-header h1{font-size:24px}.charts-grid,.stats-grid{grid-template-columns:1fr}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.events-table{font-size:14px}.events-table td,.events-table th{padding:8px}}.payment-history-page{margin:0 auto;max-width:1200px;padding:2rem}.payment-history-header{align-items:center;background:var(--white);border:1px solid var(--light-gray);border-radius:8px;box-shadow:0 4px 12px var(--shadow);display:flex;gap:1.5rem;justify-content:space-between;padding:1.5rem}.payment-history-kicker{color:var(--primary-green);font-size:.78rem;font-weight:800;letter-spacing:0;margin-bottom:.45rem;text-transform:uppercase}.payment-history-header h1{color:var(--primary-orange);font-size:2.1rem;margin-bottom:.5rem}.payment-history-header p{color:var(--gray);line-height:1.5}.payment-history-header-icon{color:var(--primary-orange);flex:0 0 auto;font-size:3rem}.payment-history-loading{align-items:center;color:var(--gray);display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:50vh}.payment-history-alert{margin-top:1.25rem}.payment-history-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,minmax(0,1fr));margin:1.25rem 0}.payment-stat{background:var(--white);border:1px solid var(--light-gray);border-radius:8px;box-shadow:0 3px 10px var(--shadow);padding:1rem}.payment-stat span{color:var(--gray);display:block;font-size:.9rem;margin-bottom:.35rem}.payment-stat strong{color:var(--dark-gray);font-size:1.55rem}.payment-history-controls{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.25rem}.payment-search{align-items:center;background:var(--white);border:1px solid var(--light-gray);border-radius:8px;color:var(--gray);display:flex;flex:1 1;gap:.65rem;min-height:46px;padding:0 .9rem}.payment-search input{border:0;color:var(--dark-gray);font:inherit;outline:0;width:100%}.payment-status-tabs{background:var(--white);border:1px solid var(--light-gray);border-radius:8px;display:flex;gap:.25rem;padding:.25rem}.payment-status-tabs button{background:#0000;border:0;border-radius:6px;color:var(--dark-gray);cursor:pointer;font-weight:700;min-height:36px;padding:0 .8rem}.payment-status-tabs button.active,.payment-status-tabs button:hover{background:var(--primary-orange);color:var(--white)}.payment-history-table-wrap{background:var(--white);border:1px solid var(--light-gray);border-radius:8px;box-shadow:0 4px 12px var(--shadow);overflow-x:auto}.payment-history-table{border-collapse:collapse;min-width:940px;width:100%}.payment-history-table td,.payment-history-table th{border-bottom:1px solid var(--light-gray);padding:.95rem;text-align:left;vertical-align:middle}.payment-history-table th{background:var(--off-white);color:var(--dark-gray);font-size:.82rem;letter-spacing:0;text-transform:uppercase}.payment-history-table tbody tr:last-child td{border-bottom:0}.payment-history-table td strong{color:var(--dark-gray);display:block;margin-bottom:.2rem}.payment-history-table td span{color:var(--gray);font-size:.86rem}.payment-history-table code{background:var(--off-white);border-radius:6px;color:var(--dark-gray);display:inline-block;max-width:150px;overflow:hidden;padding:.25rem .4rem;text-overflow:ellipsis;white-space:nowrap}.amount-cell{color:var(--dark-gray);font-weight:800;text-align:right}.payment-status{align-items:center;border-radius:999px;display:inline-flex;font-weight:800;gap:.4rem;padding:.35rem .6rem;text-transform:capitalize;white-space:nowrap}.payment-status.completed{background:#4caf501f;color:var(--dark-green)}.payment-status.pending{background:#ff8c4224;color:var(--dark-orange)}.payment-status.failed{background:#d32f2f1f;color:#b42318}.download-receipt-button,.payment-empty-action{align-items:center;background:var(--primary-green);border:0;border-radius:8px;color:var(--white);cursor:pointer;display:inline-flex;font-weight:800;gap:.5rem;justify-content:center;min-height:38px;padding:0 .8rem;text-decoration:none;white-space:nowrap}.download-receipt-button:disabled{background:var(--light-gray);color:var(--gray);cursor:not-allowed}.payment-empty-state{background:var(--white);border:1px solid var(--light-gray);border-radius:8px;box-shadow:0 4px 12px var(--shadow);padding:3rem 1.5rem;text-align:center}.payment-empty-state svg{color:var(--primary-orange);font-size:3rem;margin-bottom:1rem}.payment-empty-state h2{color:var(--dark-gray);margin-bottom:.5rem}.payment-empty-state p{color:var(--gray);margin:0 auto 1.25rem;max-width:460px}@media (max-width:860px){.payment-history-page{padding:1rem}.payment-history-header{align-items:flex-start}.payment-history-header-icon{display:none}.payment-history-controls,.payment-history-stats{align-items:stretch;flex-direction:column;grid-template-columns:1fr}.payment-history-stats{display:grid}.payment-status-tabs{overflow-x:auto}.payment-history-table{min-width:0}.payment-history-table thead{display:none}.payment-history-table,.payment-history-table tbody,.payment-history-table td,.payment-history-table tr{display:block;width:100%}.payment-history-table tr{border-bottom:1px solid var(--light-gray);padding:.75rem 0}.payment-history-table td{border-bottom:0;display:flex;gap:1rem;justify-content:space-between;padding:.55rem .95rem;text-align:right}.payment-history-table td:before{color:var(--gray);content:attr(data-label);font-weight:800;text-align:left}.amount-cell{text-align:right}}@media (max-width:640px){.payment-history-stats{grid-template-columns:1fr}.payment-history-header h1{font-size:1.7rem}.payment-status-tabs button{flex:1 0 auto}}.not-found-page{grid-gap:2rem;align-items:center;display:grid;gap:2rem;grid-template-columns:minmax(220px,.85fr) minmax(280px,1.15fr);margin:0 auto;max-width:1080px;min-height:calc(100vh - 86px);padding:3rem 2rem}.not-found-visual{align-items:center;background:linear-gradient(135deg,#ff8c422e,#4caf5029),var(--white);border:1px solid var(--light-gray);border-radius:8px;box-shadow:0 8px 24px var(--shadow);color:var(--primary-orange);display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:320px}.not-found-visual svg{font-size:4rem}.not-found-visual span{color:var(--dark-gray);font-size:4.5rem;font-weight:900;line-height:1}.not-found-content{background:var(--white);border:1px solid var(--light-gray);border-radius:8px;box-shadow:0 8px 24px var(--shadow);padding:2rem}.not-found-kicker{color:var(--primary-green);font-size:.82rem;font-weight:800;letter-spacing:0;margin-bottom:.65rem;text-transform:uppercase}.not-found-content h1{color:var(--primary-orange);font-size:2.3rem;margin-bottom:.85rem}.not-found-content p{color:var(--gray);font-size:1rem;line-height:1.6}.not-found-content code{background:var(--off-white);border-radius:6px;color:var(--dark-gray);display:inline-block;max-width:100%;overflow-wrap:anywhere;padding:.1rem .35rem}.not-found-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.not-found-ghost,.not-found-primary,.not-found-secondary{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font:inherit;font-weight:800;gap:.5rem;justify-content:center;min-height:42px;padding:0 1rem;text-decoration:none}.not-found-primary{background:var(--primary-orange);border:1px solid var(--primary-orange);color:var(--white)}.not-found-secondary{background:var(--primary-green);border:1px solid var(--primary-green);color:var(--white)}.not-found-ghost{background:var(--white);border:1px solid var(--light-gray);color:var(--dark-gray)}@media (max-width:780px){.not-found-page{grid-template-columns:1fr;padding:1.25rem}.not-found-visual{min-height:190px}.not-found-visual svg{font-size:3rem}.not-found-visual span{font-size:3.4rem}.not-found-content{padding:1.5rem}.not-found-content h1{font-size:1.8rem}.not-found-actions{flex-direction:column}}
/*# sourceMappingURL=main.e3236409.css.map*/