@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--navy: #2c2c2c;--navy-light: #3d3d3d;--navy-mid: #333333;--teal: #f5a623;--teal-dark: #d48e1a;--teal-light: #fff8eb;--gold: #f5c518;--gold-dark: #d4a90f;--coral: #ff6b35;--white: #ffffff;--gray-50: #fafafa;--gray-100: #f3f3f3;--gray-200: #e5e5e5;--gray-300: #d4d4d4;--gray-400: #a3a3a3;--gray-600: #636363;--gray-800: #2c2c2c;--text: #1a1a1a;--text-light: #636363;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .15);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--white);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100vh}a{color:var(--teal);text-decoration:none;transition:color .2s}a:hover{color:var(--teal-dark)}img{max-width:100%}.scroll-reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.scroll-reveal-visible{opacity:1;transform:translateY(0)}h1,h2,h3,h4{color:var(--navy);line-height:1.2;font-weight:700}h1{font-size:2.75rem}h2{font-size:2rem}h3{font-size:1.35rem}.btn{display:inline-block;padding:12px 28px;font-size:1rem;font-weight:600;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;transition:all .25s ease;text-align:center;font-family:inherit;position:relative;overflow:hidden}.btn-primary{background:var(--teal);color:#1a1a1a;border-color:var(--teal)}.btn-primary:hover{background:var(--teal-dark);border-color:var(--teal-dark);color:#1a1a1a;transform:translateY(-2px);box-shadow:0 4px 15px #f5a62366}.btn-secondary{background:var(--navy);color:var(--white);border-color:var(--navy)}.btn-secondary:hover{background:var(--navy-light);border-color:var(--navy-light);color:var(--white);transform:translateY(-2px)}.btn-outline{background:transparent;color:var(--navy);border-color:var(--gray-300)}.btn-outline:hover{background:var(--navy);color:var(--white);border-color:var(--navy);transform:translateY(-2px)}.btn-lg{padding:16px 36px;font-size:1.1rem;border-radius:var(--radius-md)}.btn-full{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.container{max-width:1200px;margin:0 auto;padding:0 24px}.section{padding:100px 0}.section-alt{background:var(--gray-50)}.section-dark{background:var(--navy);color:var(--white)}.section-dark h2,.section-dark h3{color:var(--white)}.section-title{text-align:center;margin-bottom:16px;font-size:2.5rem;letter-spacing:-.5px}.section-subtitle{text-align:center;color:var(--text-light);font-size:1.15rem;margin-bottom:56px;max-width:600px;margin-left:auto;margin-right:auto}.section-cta{background:linear-gradient(135deg,var(--teal-light) 0%,#fff3d6 100%);padding:100px 0}.section-cta h2{margin-bottom:16px;font-size:2.5rem}.section-cta p{color:var(--text-light);font-size:1.15rem;margin-bottom:36px;max-width:500px;margin-left:auto;margin-right:auto}.cta-content{text-align:center}.navbar{position:sticky;top:0;z-index:1000;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);transition:box-shadow .3s}.navbar-container{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:70px}.navbar-banner{display:flex;align-items:center;flex-shrink:0;margin-left:-20px;position:relative;overflow:visible}.navbar-logo-img{height:55px;width:auto;position:relative;z-index:2}.navbar-banner:before{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0) 20%,rgba(255,255,255,.6) 50%,rgba(255,255,255,0) 80%,transparent);z-index:3;animation:shimmerSweep 4s ease-in-out infinite;pointer-events:none}.navbar-banner:after{content:"";position:absolute;top:50%;left:-30px;width:30px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);box-shadow:0 0 8px var(--gold),0 0 16px var(--gold);z-index:3;animation:shootingStar 6s ease-in-out infinite;pointer-events:none;border-radius:2px;opacity:0}@keyframes shimmerSweep{0%,to{left:-100%;opacity:0}10%{opacity:1}50%{left:120%;opacity:1}60%,to{opacity:0}}@keyframes shootingStar{0%{left:5%;top:71%;opacity:0;width:30px}8%{opacity:1}22%{opacity:.8;width:50px}28%{left:85%;opacity:0;width:50px}30%,to{opacity:0;left:85%}}.logo-sparkle{position:absolute;width:4px;height:4px;background:var(--gold);border-radius:50%;z-index:3;pointer-events:none;animation:sparkle 3s ease-in-out infinite;box-shadow:0 0 6px var(--gold),0 0 12px #f5a62366}.logo-sparkle:nth-child(2){top:15%;left:25%;animation-delay:.8s;width:3px;height:3px}.logo-sparkle:nth-child(3){top:60%;left:55%;animation-delay:1.6s;width:3px;height:3px}.logo-sparkle:nth-child(4){top:30%;left:80%;animation-delay:2.4s}.logo-sparkle:nth-child(5){top:70%;left:40%;animation-delay:.4s;width:2px;height:2px}.logo-sparkle:nth-child(6){top:10%;left:65%;animation-delay:1.2s;width:3px;height:3px}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}.navbar-links{display:flex;align-items:center;gap:36px}.navbar-links a{color:var(--text);font-weight:500;font-size:.95rem;transition:color .2s;position:relative}.navbar-links a:not(.btn):after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--teal);transition:width .25s ease}.navbar-links a:not(.btn):hover:after{width:100%}.navbar-links a:hover{color:var(--teal)}.navbar-links .btn{padding:10px 24px;font-size:.9rem}.navbar-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}.navbar-toggle span{display:block;width:24px;height:2.5px;background:var(--navy);border-radius:2px;transition:all .3s ease}.navbar-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.navbar-toggle.active span:nth-child(2){opacity:0}.navbar-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.hero{position:relative;padding:140px 24px 120px;text-align:center;overflow:hidden;min-height:85vh;display:flex;align-items:center;justify-content:center;flex-direction:column}.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(245,166,35,.1) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(245,197,24,.08) 0%,transparent 50%),linear-gradient(135deg,#f0f0f0,#e8e8e8,#f5f5f5);z-index:0}.hero-bg:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23000000' fill-opacity='0.04'%3E%3Ccircle cx='20' cy='20' r='1.5'/%3E%3C/g%3E%3C/svg%3E")}.hero-bg:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:120px;background:linear-gradient(to top,var(--white),transparent)}.hero-content{max-width:760px;margin:0 auto;position:relative;z-index:1;animation:heroFadeIn 1s ease-out}@keyframes heroFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-badge{display:inline-block;background:var(--teal);color:#1a1a1a;padding:8px 20px;border-radius:30px;font-size:.9rem;font-weight:600;margin-bottom:28px;border:1px solid var(--teal-dark);letter-spacing:.5px}.hero h1{color:var(--navy);font-size:3.75rem;margin-bottom:24px;font-weight:800;letter-spacing:-1.5px;line-height:1.1}.hero p{color:var(--text-light);font-size:1.25rem;line-height:1.75;margin-bottom:44px;max-width:600px;margin-left:auto;margin-right:auto}.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.hero-scroll-indicator{position:relative;z-index:1;margin-top:48px;animation:bounce 2s infinite}.hero-scroll-indicator span{display:block;width:24px;height:40px;border:2px solid rgba(0,0,0,.2);border-radius:12px;position:relative;margin:0 auto}.hero-scroll-indicator span:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:4px;height:8px;background:#0000004d;border-radius:2px;animation:scrollPulse 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}60%{transform:translateY(-4px)}}@keyframes scrollPulse{0%{opacity:1;top:8px}to{opacity:0;top:20px}}.page-hero{background:radial-gradient(ellipse at 30% 50%,rgba(245,166,35,.08) 0%,transparent 50%),linear-gradient(135deg,#f0f0f0,#e8e8e8,#f5f5f5);padding:80px 24px 72px;text-align:center;position:relative;overflow:hidden}.page-hero:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:60px;background:linear-gradient(to top,var(--white),transparent)}.page-hero h1{color:var(--navy);font-size:2.75rem;margin-bottom:12px;letter-spacing:-.5px}.page-hero p{color:var(--text-light);font-size:1.15rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:32px;transition:all .3s ease;display:block;color:var(--text)}.card-hover:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--teal)}.card-hover:hover .card-link{color:var(--teal)}.card-icon{font-size:2.75rem;margin-bottom:20px;display:block}.card h3{margin-bottom:12px;font-size:1.25rem}.card p{color:var(--text-light);line-height:1.65;font-size:.95rem}.card-link{display:inline-block;margin-top:16px;color:var(--gray-400);font-weight:600;font-size:.9rem;transition:color .2s}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px}.feature-item{display:flex;gap:20px;padding:28px;background:var(--white);border-radius:var(--radius-md);border:1px solid var(--gray-200);transition:all .3s ease}.feature-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-icon{font-size:2rem;flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--teal-light);border-radius:var(--radius-sm)}.feature-item h3{margin-bottom:8px;font-size:1.1rem}.feature-item p{color:var(--text-light);font-size:.92rem;line-height:1.6}.stats-section{background:radial-gradient(ellipse at 50% 50%,rgba(245,166,35,.08) 0%,transparent 60%),var(--navy)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px;text-align:center;margin-top:48px}.stat{padding:20px}.stat-number{display:block;font-size:3.25rem;font-weight:800;color:var(--gold);margin-bottom:8px;letter-spacing:-1px}.stat-label{font-size:1rem;color:#fff9;font-weight:500}.testimonial-card{background:var(--white);border-radius:var(--radius-lg);padding:36px;border:1px solid var(--gray-200);transition:all .3s ease;display:flex;flex-direction:column}.testimonial-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.testimonial-stars{color:var(--gold);font-size:1.1rem;letter-spacing:2px;margin-bottom:16px}.testimonial-text{font-size:1rem;font-style:italic;line-height:1.75;color:var(--text);margin-bottom:24px;flex:1}.testimonial-footer{display:flex;align-items:center;gap:12px}.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:var(--teal);color:#1a1a1a;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.testimonial-author{font-weight:700;color:var(--navy);font-style:normal;font-size:.95rem}.testimonial-role{color:var(--text-light);font-size:.85rem}.programs-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.program-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:28px;transition:all .3s ease;display:flex;flex-direction:column}.program-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--teal)}.program-card-header{display:flex;align-items:center;gap:16px;margin-bottom:12px}.program-card-icon{font-size:2.5rem;flex-shrink:0}.program-card-header h3{margin-bottom:0;font-size:1.2rem}.program-highlight-badge{display:inline-block;background:var(--teal-light);color:var(--teal-dark);padding:2px 10px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.program-card-desc{color:var(--text-light);font-size:.92rem;line-height:1.6;margin-bottom:16px}.program-card-features{list-style:none;margin-bottom:20px;display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;flex:1}.program-card-features li{padding:4px 0 4px 22px;position:relative;color:var(--text);font-size:.85rem}.program-card-features li:before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:700;font-size:.95rem}.program-card .btn{align-self:flex-start;padding:10px 24px;font-size:.9rem}.about-content h2{margin-top:56px;margin-bottom:16px}.about-content h2:first-child{margin-top:0}.about-content>p{color:var(--text-light);font-size:1.1rem;line-height:1.75;margin-bottom:16px;max-width:720px}.about-content .card-grid{margin-top:36px}.founder-card{display:flex;align-items:center;gap:48px;margin-top:40px;padding:48px;background:var(--white);border-radius:var(--radius-md);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm)}.founder-photo{flex-shrink:0;width:200px;height:200px;border-radius:50%;overflow:hidden;border:4px solid var(--teal);box-shadow:0 8px 24px #0000001a}.founder-photo img{width:100%;height:100%;object-fit:cover;object-position:top}.founder-info h3{font-size:1.5rem;margin-bottom:4px;color:var(--navy)}.founder-info .founder-role{color:var(--teal);font-weight:600;font-size:.95rem;margin-bottom:16px}.founder-info p:last-child{color:var(--text-light);font-size:1rem;line-height:1.7}.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}.contact-info h2{margin-bottom:32px}.contact-item{margin-bottom:28px;display:flex;gap:16px;align-items:start}.contact-icon{width:44px;height:44px;background:var(--teal-light);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.contact-item strong{display:block;color:var(--navy);margin-bottom:4px;font-size:.95rem}.contact-item p{color:var(--text-light);font-size:.95rem}.contact-form-wrapper{background:var(--white);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-md);border:1px solid var(--gray-200)}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:6px;color:var(--navy);font-size:.9rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--text);background:var(--white);transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #f5a62326}.form-group textarea{resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-card{background:var(--gray-50);border-radius:var(--radius-md);padding:32px;margin-bottom:32px;border:1px solid var(--gray-200)}.form-card h2{margin-bottom:24px}.alert{padding:20px 24px;border-radius:var(--radius-md);margin-bottom:20px;font-size:.95rem}.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.alert-success h3{color:#166534;margin-bottom:8px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 50%,rgba(245,166,35,.08) 0%,transparent 50%),linear-gradient(135deg,#f0f0f0,#e8e8e8,#f5f5f5);padding:24px}.login-card{background:var(--white);border-radius:var(--radius-xl);padding:48px;width:100%;max-width:420px;box-shadow:var(--shadow-xl);animation:heroFadeIn .5s ease-out}.login-card h1{font-size:1.75rem;margin-bottom:8px}.login-subtitle{color:var(--text-light);margin-bottom:32px}.login-back{display:block;text-align:center;margin-top:24px;color:var(--text-light);font-size:.9rem}.login-back:hover{color:var(--teal)}.footer{background:var(--navy);color:var(--gray-300);padding:72px 0 0}.footer-container{max-width:1200px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}.footer h3{color:var(--white);margin-bottom:16px;font-size:1.35rem}.footer h4{color:var(--white);margin-bottom:16px;font-size:1rem;text-transform:uppercase;letter-spacing:1px;font-weight:700}.footer p{margin-bottom:6px;font-size:.95rem;color:#ffffff8c}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:56px;padding:24px;text-align:center;font-size:.85rem;color:#fff6}.portal-layout{display:flex;min-height:100vh}.portal-content{flex:1;padding:32px 40px;background:var(--gray-50);overflow-y:auto}.sidebar{width:260px;background:var(--navy);color:var(--white);display:flex;flex-direction:column;min-height:100vh;position:sticky;top:0}.sidebar-header{padding:28px 24px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-header h2{color:var(--white);font-size:1.25rem;margin-bottom:8px}.sidebar-user{font-size:.9rem;color:#ffffff8c}.sidebar-role{display:inline-block;background:var(--teal);color:#1a1a1a;padding:2px 10px;border-radius:20px;font-size:.75rem;margin-left:8px;text-transform:capitalize}.sidebar-nav-wrapper{flex:1;position:relative}.sidebar-nav{padding:16px 0}.sidebar-scroll-arrow{display:none}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 24px;color:#ffffff8c;font-size:.95rem;font-weight:500;transition:all .2s;border-left:3px solid transparent}.sidebar-link:hover{background:#ffffff0d;color:var(--white)}.sidebar-link.active{background:#ffffff14;color:var(--white);border-left-color:var(--teal)}.sidebar-icon{font-size:1.2rem}.sidebar-logout{margin:16px 24px 24px;padding:12px;background:transparent;border:1px solid rgba(255,255,255,.15);color:#ffffff8c;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;font-size:.9rem;transition:all .2s}.sidebar-logout:hover{background:#ffffff14;color:var(--white);border-color:#ffffff40}.sidebar-logout-mobile{display:none;background:none;border:none;cursor:pointer;font-family:inherit}.dashboard h1{margin-bottom:8px}.dashboard-subtitle{color:var(--text-light);margin-bottom:32px}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-bottom:40px}.dashboard-card{background:var(--white);border-radius:var(--radius-md);padding:24px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);transition:all .2s}.dashboard-card:hover{box-shadow:var(--shadow-md)}.dashboard-card-icon{font-size:2rem}.dashboard-card-number{display:block;font-size:1.75rem;font-weight:700;color:var(--navy)}.dashboard-card-label{color:var(--text-light);font-size:.85rem}.dashboard-welcome{background:var(--white);border-radius:var(--radius-md);padding:32px;border:1px solid var(--gray-200)}.dashboard-welcome h2{margin-bottom:12px}.dashboard-welcome p{color:var(--text-light)}.data-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200)}.data-table th{background:var(--navy);color:var(--white);padding:14px 20px;text-align:left;font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:14px 20px;border-bottom:1px solid var(--gray-100);font-size:.95rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--gray-50)}.badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:capitalize}.badge-present,.badge-paid,.badge-active{background:#dcfce7;color:#166534}.badge-absent,.badge-overdue,.badge-inactive{background:#fef2f2;color:#991b1b}.badge-late,.badge-pending{background:#fef9c3;color:#854d0e}.badge-excused{background:#dbeafe;color:#1e40af}.badge-admin{background:#f3e8ff;color:#6b21a8}.badge-teacher{background:#dbeafe;color:#1e40af}.badge-parent{background:#dcfce7;color:#166534}.badge-student{background:#fef9c3;color:#854d0e}.schedule-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}.schedule-day{background:var(--white);border-radius:var(--radius-md);padding:20px;border:1px solid var(--gray-200)}.schedule-day h3{font-size:1rem;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--teal)}.schedule-item{background:var(--gray-50);border-radius:var(--radius-sm);padding:12px;margin-bottom:8px}.schedule-item strong{display:block;margin-bottom:4px;color:var(--navy)}.schedule-item span{display:block;font-size:.85rem;color:var(--text-light)}.schedule-empty{color:var(--gray-400);font-size:.9rem;font-style:italic}.message-list{display:flex;flex-direction:column;gap:8px}.message-item{background:var(--white);border-radius:var(--radius-md);padding:20px;border:1px solid var(--gray-200);cursor:pointer;transition:all .2s}.message-item:hover{box-shadow:var(--shadow-sm)}.message-unread{border-left:3px solid var(--teal);background:var(--teal-light)}.message-header{display:flex;justify-content:space-between;margin-bottom:4px}.message-date{color:var(--text-light);font-size:.85rem}.message-subject{font-weight:600;margin-bottom:8px}.message-preview{color:var(--text-light);font-size:.9rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.empty-state,.loading{text-align:center;color:var(--text-light);padding:64px 24px;font-size:1.1rem}.tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid var(--gray-200)}.tab{padding:12px 24px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:500;color:var(--text-light);transition:all .2s}.tab:hover{color:var(--teal)}.tab-active{color:var(--teal);border-bottom-color:var(--teal)}.radio-group{display:flex;gap:12px;flex-wrap:wrap}.radio-card{cursor:pointer;padding:10px 20px;border:2px solid var(--gray-200);border-radius:var(--radius-sm);transition:all .2s;display:flex;align-items:center;gap:8px}.radio-card input[type=radio]{display:none}.radio-card-active{border-color:var(--teal);background:var(--teal-light)}.assignments-list{display:flex;flex-direction:column;gap:16px}.assignment-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:24px;transition:all .2s}.assignment-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:12px}.assignment-header h3{margin-bottom:4px}.assignment-meta{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-light)}.assignment-due{text-align:right}.assignment-due-label{display:block;font-size:.8rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px}.assignment-due-date{font-weight:600;color:var(--navy)}.assignment-desc{color:var(--text-light);font-size:.95rem;line-height:1.6;margin-bottom:16px}.assignment-actions{display:flex;gap:16px;padding-top:12px;border-top:1px solid var(--gray-100)}.grade-form{margin-top:16px;padding:20px;background:var(--gray-50);border-radius:var(--radius-sm);border:1px solid var(--gray-200)}.grades-section{margin-top:16px}.score-input{display:flex;align-items:center;gap:8px}.score-input input{width:100px;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit}.score-input input:focus{outline:none;border-color:var(--teal)}.score-input span{font-size:1.25rem;color:var(--text-light)}.btn-text{background:none;border:none;color:var(--teal);font-weight:600;font-size:.9rem;cursor:pointer;font-family:inherit;padding:4px 0;transition:color .2s}.btn-text:hover{color:var(--teal-dark)}.btn-danger{color:#dc2626}.btn-danger:hover{color:#991b1b}.btn-success{color:#16a34a}.btn-success:hover{color:#166534}.btn-warning{color:#d97706}.btn-warning:hover{color:#854d0e}.message-detail{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:32px}.message-detail h2{margin-bottom:16px}.message-detail-meta{display:flex;justify-content:space-between;color:var(--text-light);font-size:.9rem;padding-bottom:16px;border-bottom:1px solid var(--gray-200);margin-bottom:12px}.message-detail-to{font-size:.9rem;color:var(--text-light);margin-bottom:24px}.message-detail-body{line-height:1.75;white-space:pre-wrap}.recipient-list{display:flex;flex-wrap:wrap;gap:8px;max-height:200px;overflow-y:auto;padding:8px 0}.recipient-chip{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--gray-200);border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s}.recipient-chip input[type=checkbox]{display:none}.recipient-chip-active{background:var(--teal-light);border-color:var(--teal);color:var(--teal-dark)}.table-actions{display:flex;gap:12px}.billing-cards{display:flex;flex-direction:column;gap:12px}.billing-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:16px 20px;box-shadow:var(--shadow-sm)}.billing-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.billing-card-details{display:flex;gap:24px;margin-bottom:12px}.billing-card-detail{display:flex;flex-direction:column;gap:2px}.billing-card-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);font-weight:600}.billing-card-actions{display:flex;gap:12px;padding-top:10px;border-top:1px solid var(--gray-100)}.page-header-actions{display:flex;gap:12px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.dashboard-list{display:flex;flex-direction:column}.dashboard-list-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--gray-100)}.dashboard-list-item:last-child{border-bottom:none}.dashboard-list-item strong{color:var(--navy)}.dashboard-list-meta{display:block;font-size:.85rem;color:var(--text-light)}.dashboard-list-time,.dashboard-list-date{font-size:.85rem;color:var(--teal);font-weight:600;white-space:nowrap}.empty-text{color:var(--text-light);padding:20px 0;font-style:italic}.card-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;cursor:pointer;gap:12px}.card-row-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.card-row-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.role-breakdown{display:flex;flex-direction:column;gap:16px}.role-bar-label{display:flex;justify-content:space-between;margin-bottom:6px;font-size:.9rem}.role-bar-track{height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}.role-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}@media(max-width:1024px){.schedule-grid{grid-template-columns:repeat(3,1fr)}.features-grid{grid-template-columns:1fr}}@media(max-width:768px){h1{font-size:2rem}h2{font-size:1.5rem}.hero{padding:100px 24px 80px;min-height:70vh}.hero h1{font-size:2.5rem}.hero p{font-size:1.05rem}.section{padding:64px 0}.section-title{font-size:2rem}.navbar-toggle{display:flex}.navbar-links{display:none;position:absolute;top:72px;left:0;right:0;background:var(--white);flex-direction:column;padding:24px;gap:16px;box-shadow:var(--shadow-lg);border-top:1px solid var(--gray-200)}.navbar-links.mobile-open{display:flex}.navbar-links a{font-size:1.05rem;padding:8px 0}.navbar-links a:not(.btn):after{display:none}.navbar-banner{margin-left:0}.contact-grid{grid-template-columns:1fr;gap:40px}.contact-form-wrapper{padding:28px}.footer-container{grid-template-columns:1fr;gap:32px}.portal-layout{flex-direction:column}.sidebar{width:100%;min-height:auto;position:sticky;top:0;z-index:100}.sidebar-header{display:none}.sidebar-nav-wrapper{position:relative;flex:none}.sidebar-nav{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-scroll-arrow{display:flex;align-items:center;justify-content:center;position:absolute;top:0;bottom:0;width:36px;color:var(--white);border:none;cursor:pointer;font-size:1.5rem;font-weight:700;z-index:2;padding:0}.sidebar-scroll-right{right:0;background:linear-gradient(to right,transparent,var(--navy) 50%)}.sidebar-scroll-left{left:0;background:linear-gradient(to left,transparent,var(--navy) 50%)}.sidebar-link{white-space:nowrap;flex:0 0 auto;padding:12px 14px;border-left:none;border-bottom:3px solid transparent;font-size:.85rem;gap:6px}.sidebar-link.active{border-left:none;border-bottom-color:var(--teal)}.sidebar-icon{font-size:1rem}.sidebar-logout{display:none}.sidebar-logout-mobile{display:flex;color:#ffffff8c}.portal-content{padding:20px 14px}.btn{padding:10px 20px;font-size:.9rem}.btn-lg{padding:12px 28px;font-size:1rem}.page-header h1{font-size:1.5rem}.form-card{padding:20px 16px}.recipient-chip{padding:5px 10px;font-size:.8rem}.schedule-grid,.form-row,.dashboard-cards,.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr);gap:24px;margin-top:32px}.stat-number{font-size:2.5rem}.stat-label{font-size:.85rem}.programs-grid,.program-card-features{grid-template-columns:1fr}.assignment-header{flex-direction:column;gap:8px}.assignment-due{text-align:left}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header-actions{flex-wrap:wrap}.founder-card{flex-direction:column;text-align:center;padding:36px 24px}.card-row{flex-wrap:wrap;padding:12px 16px;gap:6px}.card-row-left{flex-wrap:wrap;width:100%;gap:6px}.card-row-left strong{white-space:normal;word-break:break-word}.card-row-right{width:100%;gap:8px;font-size:.82rem}.dashboard-welcome{padding:20px 16px}.dashboard-welcome h2{font-size:1.2rem}.dashboard-list-item{flex-direction:column;align-items:flex-start;gap:4px}}@media(max-width:480px){.hero{min-height:60vh}.hero h1{font-size:2rem;letter-spacing:-.5px}.hero-buttons{flex-direction:column}.hero-badge{font-size:.8rem}.navbar-container{padding:0 16px}.login-card{padding:32px 24px}.founder-photo{width:160px;height:160px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}.stat{padding:12px 8px}.stat-number{font-size:2rem}.stat-label{font-size:.8rem}}
