@import url("https://fonts.googleapis.com/css2?family=Dancing+Script:wght@700&family=Playfair+Display:wght@700&family=Poppins:wght@400;500;600;700&display=swap");@import url("https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700;800&family=Poppins:wght@300;400;500;600;700&family=Dancing+Script:wght@700&display=swap");:root{--primary:#4f46e5;--primary-light:#818cf8;--primary-dark:#4338ca;--secondary:#f59e0b;--secondary-light:#fcd34d;--secondary-dark:#d97706;--accent:#ec4899;--session-sec:#3b82f6;--session-pri:#10b981;--session-kg:#f59e0b;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--dark:#1e293b;--light:#f8fafc;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--gradient-sky:linear-gradient(135deg,#667eea,#764ba2 40%,#a855f7 70%,#ec4899);--gradient-gold:linear-gradient(135deg,#f59e0b,#fbbf24 50%,#f97316);--gradient-card:linear-gradient(145deg,hsla(0,0%,100%,.95),hsla(0,0%,100%,.85));--gradient-header:linear-gradient(135deg,hsla(0,0%,100%,.98),hsla(0,0%,100%,.95));--gradient-sec:linear-gradient(135deg,#1d4ed8,#3b82f6);--gradient-pri:linear-gradient(135deg,#059669,#10b981);--gradient-kg:linear-gradient(135deg,#d97706,#f59e0b);--shadow-xs:0 1px 2px rgba(0,0,0,.05);--shadow-sm:0 2px 4px rgba(0,0,0,.06);--shadow-md:0 4px 12px rgba(0,0,0,.08);--shadow-lg:0 8px 24px rgba(0,0,0,.1);--shadow-xl:0 12px 40px rgba(0,0,0,.12);--shadow-glow:0 0 40px rgba(245,158,11,.3);--shadow-purple:0 10px 40px rgba(102,126,234,.25);--shadow-card:0 4px 20px rgba(102,126,234,.15);--font-display:"Playfair Display",Georgia,serif;--font-body:"Poppins",-apple-system,BlinkMacSystemFont,sans-serif;--font-script:"Dancing Script",cursive;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-2xl:32px;--radius-full:9999px}*,:after,:before{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-body);min-height:100vh;color:var(--dark);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.animated-bg,body{background:var(--gradient-sky)}.animated-bg{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;overflow:hidden}.animated-bg:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,hsla(0,0%,100%,.3) 0,transparent 40%),radial-gradient(circle at 70% 80%,rgba(251,191,36,.2) 0,transparent 40%);animation:bgFloat 15s ease-in-out infinite}@keyframes bgFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(3%,3%) scale(1.05)}}.orbs{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;animation:orbFloat 20s ease-in-out infinite}.orb-1{width:400px;height:400px;background:linear-gradient(135deg,#fcd34d,#f97316);top:5%;left:5%}.orb-2{width:300px;height:300px;background:linear-gradient(135deg,#a78bfa,#ec4899);top:50%;right:5%;animation-delay:-5s}.orb-3{width:200px;height:200px;background:linear-gradient(135deg,#34d399,#3b82f6);bottom:10%;left:20%;animation-delay:-10s}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.1)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(20px,30px) scale(1.05)}}.sparkles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.sparkle{position:absolute;width:6px;height:6px;background:#fff;border-radius:50%;animation:sparkle 4s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.3}.tagline{font-family:var(--font-script);font-size:1.2rem;background:var(--gradient-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header{background:var(--gradient-header);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 4px 30px rgba(102,126,234,.15);position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;padding:12px 24px;justify-content:space-between}.header-content,.header-left{display:flex;align-items:center}.header-left{gap:14px}.header-logo{width:55px;height:55px;object-fit:cover;border-radius:50%;box-shadow:0 4px 15px rgba(102,126,234,.25);border:2px solid #fff}.header-text h1{font-size:1.2rem;color:var(--primary);margin-bottom:0}.header-text p{font-size:.8rem;color:var(--gray-500);margin:0}.header-text .tagline{font-size:.85rem}.main-container{max-width:1200px;margin:0 auto;padding:32px 24px;position:relative;z-index:2}.glass-card{background:var(--gradient-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.9);border-radius:var(--radius-2xl);padding:32px;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.glass-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-gold)}.card-white{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-md)}.welcome-card{background:linear-gradient(135deg,var(--primary) 0,var(--primary-light) 100%);border-radius:var(--radius-2xl);padding:28px 32px;justify-content:space-between;color:#fff;margin-bottom:28px;box-shadow:var(--shadow-purple)}.welcome-card,.welcome-left{display:flex;align-items:center}.welcome-left{gap:18px}.welcome-avatar{width:60px;height:60px;background:hsla(0,0%,100%,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;border:3px solid hsla(0,0%,100%,.3)}.welcome-info h2{font-size:1.4rem;margin-bottom:4px;color:#fff}.welcome-info p{font-size:.9rem;opacity:.9;margin:0}.welcome-right{text-align:right}.welcome-right .label{font-size:.75rem;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.welcome-right .date{font-size:1.1rem;font-weight:700;color:var(--secondary-light)}.section-title{font-size:1.1rem;color:var(--dark);margin-bottom:16px;font-family:var(--font-body);font-weight:600}.section-title-light{font-size:1.2rem;color:#fff;margin-bottom:20px;text-shadow:0 2px 10px rgba(0,0,0,.2)}.children-list{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:28px}.child-item{display:flex;align-items:center;gap:12px;padding:14px 20px;background:#fff;border-radius:var(--radius-lg);border-left:4px solid var(--gray-300);box-shadow:var(--shadow-sm);flex:1 1;min-width:200px}.child-item.session-sec{border-left-color:var(--session-sec)}.child-item.session-pri{border-left-color:var(--session-pri)}.child-item.session-kg{border-left-color:var(--session-kg)}.child-info h4{font-size:.95rem;color:var(--dark);margin-bottom:2px;font-family:var(--font-body);font-weight:600}.child-info p{font-size:.8rem;color:var(--gray-500);margin:0}.sessions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:20px;gap:20px;margin-bottom:28px}.session-card{background:#fff;border-radius:var(--radius-xl);padding:24px;position:relative;overflow:hidden;box-shadow:var(--shadow-md);transition:all .3s ease;border:1px solid var(--gray-100)}.session-card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px}.session-card.session-sec:before{background:var(--gradient-sec)}.session-card.session-pri:before{background:var(--gradient-pri)}.session-card.session-kg:before{background:var(--gradient-kg)}.session-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.session-card.disabled{opacity:.6;pointer-events:none}.session-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.session-title{font-size:1.15rem;color:var(--dark);margin-bottom:4px;font-family:var(--font-body);font-weight:700}.session-time{font-size:.85rem;color:var(--gray-500)}.session-classes{font-size:.8rem;color:var(--gray-400);margin-top:4px}.session-icon{font-size:2rem;opacity:.8}.session-details{background:var(--gray-50);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:16px}.session-entitled{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.session-entitled span{font-size:.85rem;color:var(--gray-600)}.session-entitled strong{font-size:1.2rem;color:var(--primary)}.session-children{font-size:.8rem;color:var(--gray-500)}.session-no-children{font-size:.85rem;color:var(--gray-400);font-style:italic;text-align:center;padding:12px}.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;font-size:.7rem;font-weight:700;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px}.badge-sec{background:#dbeafe;color:#1d4ed8}.badge-pri{background:#d1fae5;color:#059669}.badge-kg{background:#fef3c7;color:#b45309}.badge-success{background:#d1fae5;color:#059669}.badge-pending{background:#fef3c7;color:#b45309}.badge-booked{background:#dbeafe;color:#1d4ed8}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;font-family:var(--font-body);font-size:.95rem;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;text-decoration:none}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.25),transparent);transition:left .5s ease}.btn:hover:before{left:100%}.btn-primary{background:var(--gradient-gold);color:#fff;box-shadow:0 4px 15px rgba(245,158,11,.4)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,158,11,.5)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sec{background:var(--gradient-sec);color:#fff;box-shadow:0 4px 15px rgba(59,130,246,.4)}.btn-pri{background:var(--gradient-pri);color:#fff;box-shadow:0 4px 15px rgba(16,185,129,.4)}.btn-kg{background:var(--gradient-kg);color:#fff;box-shadow:0 4px 15px rgba(245,158,11,.4)}.btn-secondary{background:#fff;color:var(--dark);border:2px solid var(--gray-200)}.btn-secondary:hover{background:var(--gray-50);border-color:var(--primary);color:var(--primary)}.btn-ghost{background:hsla(0,0%,100%,.1);color:var(--primary);padding:10px 20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-ghost:hover{background:rgba(79,70,229,.1)}.btn-outline-white{background:transparent;color:#fff;border:2px solid hsla(0,0%,100%,.3)}.btn-outline-white:hover{background:hsla(0,0%,100%,.1);border-color:#fff}.btn-full{width:100%}.btn-lg{padding:16px 32px;font-size:1rem}.btn-sm{padding:10px 18px;font-size:.85rem}.request-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:var(--radius-xl);padding:24px;gap:16px;border:1px solid #fcd34d}.request-card,.request-icon{display:flex;align-items:center}.request-icon{width:50px;height:50px;background:linear-gradient(135deg,#f97316,#ea580c);border-radius:50%;justify-content:center;font-size:1.5rem;flex-shrink:0}.request-content h3{font-size:1rem;color:#92400e;margin-bottom:4px;font-family:var(--font-body);font-weight:600}.request-content p{font-size:.85rem;color:#a16207;margin:0 0 12px}.request-content .btn{background:#92400e;color:#fff;padding:10px 20px;font-size:.85rem}.form-group{margin-bottom:20px}.form-label{display:block;font-size:.9rem;font-weight:600;color:var(--dark);margin-bottom:8px}.form-input{width:100%;padding:14px 18px;font-family:var(--font-body);font-size:1rem;color:var(--dark);background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius-lg);transition:all .2s ease}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(79,70,229,.1)}.form-input::placeholder{color:var(--gray-400)}.form-input-dark{background:hsla(0,0%,100%,.1);border:2px solid hsla(0,0%,100%,.2);color:#fff}.form-input-dark:focus{border-color:var(--secondary);box-shadow:0 0 0 4px rgba(245,158,11,.2)}.form-input-dark::placeholder{color:hsla(0,0%,100%,.5)}.login-card{max-width:480px;width:100%;margin:0 auto;padding:48px 40px}.login-logo{width:130px;height:130px;margin:0 auto 24px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-glow),0 8px 32px rgba(102,126,234,.25);overflow:hidden;border:4px solid #fff;background:#fff;animation:float 3s ease-in-out infinite}.login-logo img{width:100%;height:100%;object-fit:cover}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-title{text-align:center;margin-bottom:24px}.login-title h1{font-size:1.8rem;color:var(--primary);margin-bottom:8px}.school-logos{display:flex;align-items:center;justify-content:center;gap:20px;margin:24px 0}.school-logo-box{background:#fff;border-radius:var(--radius-lg);padding:12px 18px;box-shadow:var(--shadow-sm);transition:all .3s ease;border:1px solid var(--gray-100)}.school-logo-box:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.school-logo-box img{height:42px;width:auto;max-width:150px;object-fit:contain}.venue-card{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:16px 20px;border-radius:var(--radius-lg);margin-bottom:24px;border:1px solid #fcd34d}.venue-card h4{font-size:.9rem;color:#b45309;margin-bottom:4px;font-family:var(--font-body);font-weight:600}.venue-card p{font-size:.8rem;color:#92400e;margin:0}.login-divider{text-align:center;color:var(--gray-400);font-size:.85rem;margin:20px 0;position:relative}.login-divider:after,.login-divider:before{content:"";position:absolute;top:50%;width:30%;height:1px;background:var(--gray-200)}.login-divider:before{left:0}.login-divider:after{right:0}.sms-note{margin-top:16px;display:flex;align-items:center;justify-content:center;gap:8px;color:var(--gray-500);font-size:.85rem;margin-top:12px}.sms-note svg{flex-shrink:0}.portal-links{gap:24px;padding-top:20px;border-top:1px solid var(--gray-200);display:flex;justify-content:center;align-items:center;gap:8px;margin-top:24px;flex-wrap:wrap}.portal-link{color:#6366f1;font-size:.85rem;padding:4px 8px;border-radius:4px;transition:background .2s}.portal-link:hover{background:rgba(99,102,241,.1)}.portal-divider{color:#cbd5e1;font-size:.75rem}.portal-link{font-size:.8rem;color:var(--gray-400);text-decoration:none;transition:color .2s ease;font-weight:500}.portal-link:hover{color:var(--primary)}.booked-card{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:1px solid #6ee7b7;border-radius:var(--radius-lg);padding:16px 20px;margin-top:12px}.booked-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.booked-seats{display:flex;gap:8px;flex-wrap:wrap}.seat-tag{background:var(--success);color:#fff;padding:4px 10px;border-radius:6px;font-size:.8rem;font-weight:600}.otp-input{text-align:center;font-size:2rem;letter-spacing:.5em;font-weight:700;font-family:monospace}.demo-otp-box{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px dashed #3b82f6;border-radius:var(--radius-lg);padding:16px;text-align:center;margin-bottom:20px}.demo-otp-box p{font-size:.8rem;color:#1d4ed8;margin-bottom:8px}.demo-otp-box .otp-display{font-size:2rem;font-weight:700;font-family:monospace;color:#1d4ed8;letter-spacing:.3em}.animate-fadeIn{animation:fadeIn .5s ease forwards}.animate-slideUp{animation:slideUp .6s ease forwards}.animate-slideDown{animation:slideDown .4s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:currentcolor;border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:hsla(0,0%,100%,.9);display:flex;align-items:center;justify-content:center;z-index:1000}@media (max-width:768px){.header-content{padding:10px 16px}.header-logo{width:45px;height:45px}.header-text h1{font-size:1rem}.main-container{padding:20px 16px}.welcome-card{text-align:center;gap:16px;padding:24px}.welcome-card,.welcome-left{flex-direction:column}.welcome-right{text-align:center}.glass-card{padding:24px}.login-card{padding:32px 24px}.login-logo{width:110px;height:110px}.sessions-grid{grid-template-columns:1fr}.children-list{flex-direction:column}.child-item{min-width:auto}.school-logos{flex-direction:column;gap:12px}.request-card{flex-direction:column;text-align:center}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.hidden{display:none}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.gap-1{gap:8px}.gap-2{gap:16px}