:root{--cb-background:#fbfaf7;--cb-background-strong:#f5f1e8;--cb-foreground:#1f2430;--cb-muted:#6a7280;--cb-card:#fff;--cb-border:#e8e6df;--cb-primary:#2f9e7a;--cb-primary-foreground:#fff;--cb-secondary:#f4f0e6;--cb-secondary-foreground:#2f3644;--cb-accent:#5ca7e6;--cb-destructive:#d64b3b;--cb-sidebar:#fdfcf9;--cb-sidebar-foreground:#283041;--cb-sidebar-accent:#e6f1eb;--cb-sidebar-border:#e3e0d7;--cb-shadow-soft:0 16px 45px #1e2e2524;--cb-shadow-card:0 20px 55px #1b33281f;--cb-radius-lg:18px;--cb-radius-xl:22px;--cb-radius-md:14px}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#fbfaf7,#fdfcfb 40%,#f7f4ec);background:linear-gradient(135deg,var(--cb-background) 0,#fdfcfb 40%,#f7f4ec 100%);color:#1f2430;color:var(--cb-foreground);font-family:Inter,Geist,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}#root,body{overflow-x:hidden}#root{max-width:100vw;width:100%}code{font-family:Fira Code,source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#d4a574;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#c19660}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #d4a574;outline-offset:2px}.loading-container{align-items:center;background:#f7f5f0;display:flex;justify-content:center;min-height:100vh}.loading-spinner{text-align:center}.spinner{border:4px solid #e8e2db;height:40px;margin:0 auto 16px;width:40px}.loading-spinner p{color:#6b7280;font-size:16px;font-weight:500;margin:0}@media (max-width:1159px){body{font-size:14px;margin:0;padding:0}*{box-sizing:border-box}h1{font-size:24px!important}h2{font-size:20px!important}h3{font-size:18px!important}h4{font-size:16px!important}h5,h6{font-size:14px!important}.classes-page,.dashboard,.students-page{display:block!important;margin:0!important;padding:0!important}.main-content{margin-left:0!important;margin-top:56px!important;max-width:100vw!important;padding-left:0!important;width:100%!important}.classes-section,.content-area,.students-section{box-sizing:border-box!important;margin:0!important;max-width:100%!important;padding:12px!important;width:100%!important}.header{margin:0!important;width:100%!important}.header-content{padding-left:12px!important;padding-right:12px!important}}.notification-modal-container{animation:notificationModalSlide .3s ease-out;background:#fff;border-radius:16px;border-top:4px solid #d4a574;box-shadow:0 20px 40px #2d501633;max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:100%}.notification-modal-container.success{border-top-color:#10b981;box-shadow:0 20px 40px #10b98126}.notification-modal-container.error{border-top-color:#dc2626;box-shadow:0 20px 40px #dc262626}.notification-modal-container.warning{border-top-color:#d97706;box-shadow:0 20px 40px #d9770626}.notification-modal-container.info{border-top-color:#2563eb;box-shadow:0 20px 40px #2563eb26}@keyframes notificationModalSlide{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-modal-header{align-items:flex-start;background:linear-gradient(135deg,#f7f5f0,#e8e2db);border-bottom:2px solid #e8e2db;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;padding:24px 32px}.notification-title-section{align-items:center;display:flex;gap:12px}.notification-title{color:#2d5016;font-size:20px;font-weight:700;margin:0}.notification-icon{font-size:24px!important}.notification-icon.success{color:#10b981}.notification-icon.error{color:#dc2626}.notification-icon.warning{color:#d97706}.notification-icon.info{color:#2563eb}.notification-modal-body{padding:24px 32px}.notification-message{color:#374151;font-size:16px;line-height:1.6;margin:0;white-space:pre-line}.notification-modal-actions{border-top:1px solid #e8e2db;display:flex;justify-content:center;padding:20px 32px 24px}.btn{padding:10px 24px}.btn-primary:hover{box-shadow:0 6px 16px #2d501659}.btn-success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b98140;color:#fff}.btn-success:hover{box-shadow:0 6px 16px #10b98159;transform:translateY(-1px)}.btn-danger:hover{box-shadow:0 6px 16px #dc262659;transform:translateY(-1px)}.btn-warning{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #d9770640;color:#fff}.btn-warning:hover{box-shadow:0 6px 16px #d9770659;transform:translateY(-1px)}@media (max-width:1159px){.notification-modal-container{border-radius:12px;margin:20px;max-width:calc(100% - 40px)}.notification-modal-header{padding:20px 24px}.notification-title{font-size:18px}.notification-modal-body{padding:20px 24px}.notification-modal-actions{padding:16px 24px 20px}.btn{max-width:200px;width:100%}}@media (max-width:480px){.notification-modal-body,.notification-modal-header{padding:16px 20px}.notification-modal-actions{padding:12px 20px 16px}}.notification-modal-container.auto-closing{animation:notificationModalFadeOut .3s ease-in forwards}@keyframes notificationModalFadeOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.95)}}.notification-modal-container::-webkit-scrollbar{width:6px}.notification-modal-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.notification-modal-container::-webkit-scrollbar-thumb{background:#d4a574;border-radius:3px}.notification-modal-container::-webkit-scrollbar-thumb:hover{background:#c19660}:root{--font-sans:"Geist","Inter","Segoe UI",system-ui,-apple-system,sans-serif;--color-slate-50:#f8fafc;--color-slate-100:#f1f5f9;--color-slate-200:#e2e8f0;--color-slate-400:#94a3b8;--color-slate-600:#475569;--color-slate-700:#334155;--color-slate-800:#1e293b;--color-slate-900:#0f172a;--color-blue-50:#eff6ff;--color-blue-100:#dbeafe;--color-blue-200:#bfdbfe;--color-blue-500:#3b82f6;--color-blue-600:#2563eb;--color-blue-700:#1d4ed8;--color-purple-50:#faf5ff;--color-purple-100:#f3e8ff;--color-purple-200:#e9d5ff;--color-purple-400:#c084fc;--color-purple-500:#a855f7;--color-purple-600:#9333ea;--color-purple-700:#7e22ce;--color-green-50:#f0fdf4;--color-green-100:#dcfce7;--color-green-200:#bbf7d0;--color-green-400:#4ade80;--color-green-500:#22c55e;--color-green-600:#16a34a;--color-pink-50:#fdf2f8;--color-pink-100:#fce7f3;--color-pink-200:#fbcfe8;--color-pink-500:#ec4899;--color-pink-600:#db2777;--color-yellow-50:#fefce8;--color-yellow-100:#fef9c3;--color-yellow-200:#fef08a;--color-yellow-400:#facc15;--color-yellow-500:#eab308;--color-yellow-600:#ca8a04;--color-yellow-700:#a16207}.landing-page{background:#fff;font-family:Geist,Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-family:var(--font-sans);min-height:100vh;scroll-behavior:smooth}.landing-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-slate-200);box-shadow:0 1px 3px #0000000d;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header-container{margin:0 auto;max-width:1280px;padding:0 16px}.header-content{height:64px;justify-content:space-between}.header-nav-desktop{align-items:center;display:none;gap:32px}.nav-link{background:none;border:none;border-bottom:2px solid #0000;color:#334155;color:var(--color-slate-700);font-size:.875rem;font-weight:500;padding:4px 0;transition:all .2s ease}.nav-link:hover{border-bottom-color:#2563eb;border-bottom-color:var(--color-blue-600);color:#2563eb;color:var(--color-blue-600)}.header-actions{align-items:center;gap:16px;margin-left:auto}.sign-in-link{background:none;border:none;color:#334155;color:var(--color-slate-700);cursor:pointer;display:none;font-size:.875rem;font-weight:500;transition:color .2s ease}.sign-in-link:hover{color:#2563eb;color:var(--color-blue-600)}.demo-button-header{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--color-blue-600),var(--color-blue-700));border:none;border-radius:12px;box-shadow:0 2px 8px #3b82f640;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:10px 24px;transition:all .2s ease}.demo-button-header:hover{box-shadow:0 4px 16px #3b82f659;transform:scale(1.05)}.mobile-menu-button{color:#334155;color:var(--color-slate-700);display:flex!important}.mobile-menu-button:hover{color:#2563eb;color:var(--color-blue-600)}.mobile-drawer-content{padding:16px;width:280px}.mobile-drawer-header{display:flex;justify-content:flex-end;margin-bottom:16px}.hero-section{background:linear-gradient(135deg,#eff6ff,#faf5ff,#fdf2f8);background:linear-gradient(135deg,var(--color-blue-50),var(--color-purple-50),var(--color-pink-50));overflow:hidden;padding:32px 16px 64px;position:relative}.hero-background-blur{border-radius:50%;filter:blur(64px);pointer-events:none;position:absolute}.hero-blur-1{background:#fde0474d;height:128px;right:40px;top:80px;width:128px}.hero-blur-2{background:#93c5fd4d;bottom:40px;height:160px;left:40px;width:160px}.hero-container{margin:0 auto;max-width:1280px}.hero-grid{grid-gap:48px;align-items:flex-start;display:grid;gap:48px;grid-template-columns:1fr}.hero-content-left{align-items:flex-start;display:flex;flex-direction:column;text-align:left}.hero-logo{height:auto;margin-bottom:20px;mix-blend-mode:multiply;width:224px}.hero-logo-fallback{align-items:center;display:flex;gap:8px;margin-bottom:20px}.hero-logo-text{font-size:1.5rem}.hero-logo-text,.hero-title{color:#0f172a;color:var(--color-slate-900);font-weight:700}.hero-title{font-size:clamp(2.25rem,6vw,3.75rem);letter-spacing:-.02em;line-height:1.1;margin:0 0 24px}.hero-title-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#2563eb,#9333ea);background:linear-gradient(135deg,var(--color-blue-600),var(--color-purple-600));-webkit-background-clip:text;background-clip:text}.hero-description{color:#334155;color:var(--color-slate-700);font-size:clamp(1.125rem,2.5vw,1.25rem);line-height:1.7;margin:0 0 32px}.hero-actions{align-items:flex-start;display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.google-login-hero{display:flex;justify-content:flex-start}.google-login-hero>div{border-radius:16px!important;overflow:hidden}.demo-button{background:#fff;border:2px solid #e2e8f0;border:2px solid var(--color-slate-200);border-radius:16px;color:#334155;color:var(--color-slate-700);cursor:pointer;font-size:1.125rem;font-weight:600;padding:16px 32px;transition:all .2s ease}.demo-button:hover{border-color:#2563eb;border-color:var(--color-blue-600);color:#2563eb;color:var(--color-blue-600)}.hero-student-link{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.hero-student-link p{color:#475569;color:var(--color-slate-600);font-size:.9375rem;margin:0}.hero-image-container{display:none;position:relative}.hero-image-wrapper{border-radius:24px;box-shadow:0 25px 50px -12px #00000040;overflow:hidden;position:relative;width:100%}.hero-image{border-radius:24px;display:block;width:100%}.hero-image-placeholder{align-items:center;aspect-ratio:4/3;background:linear-gradient(135deg,#eff6ff,#faf5ff,#fdf2f8);background:linear-gradient(135deg,var(--color-blue-50),var(--color-purple-50),var(--color-pink-50));border-radius:24px;display:flex;justify-content:center;width:100%}.hero-floating-card{background:#fff;border-radius:16px;box-shadow:0 10px 25px #0000001a;padding:16px;position:absolute}.floating-card-content{align-items:center;display:flex;gap:8px}.floating-icon{height:24px;width:24px}.floating-icon-blue{color:#2563eb;color:var(--color-blue-600)}.floating-icon-green{color:#16a34a;color:var(--color-green-600)}.floating-icon-purple{color:#9333ea;color:var(--color-purple-600)}.floating-text{color:#1e293b;color:var(--color-slate-800);font-size:.875rem;font-weight:600}.hero-card-reading{border:2px solid #facc15;border:2px solid var(--color-yellow-400);left:-16px;top:-16px}.hero-card-language{border:2px solid #4ade80;border:2px solid var(--color-green-400);right:-16px;top:25%}.hero-card-differentiated{border:2px solid #c084fc;border:2px solid var(--color-purple-400);bottom:32px;left:-16px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-5%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:translateY(0)}}.animate-float{animation:float 3s ease-in-out infinite}.animate-bounce-slow{animation:bounce 2s ease-in-out infinite}.animate-pulse-slow{animation:pulse 3s cubic-bezier(.4,0,.6,1) infinite}.section-container{margin:0 auto;max-width:1280px;padding:0 16px}.section-header{margin-bottom:64px;text-align:center}.section-title{color:#0f172a;color:var(--color-slate-900);font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.02em;margin:0 0 16px}.section-description{color:#475569;color:var(--color-slate-600);font-size:1.25rem;line-height:1.6;margin:0 auto;max-width:768px}.why-works-section{background:#fff;padding:80px 16px}.alternating-section{grid-gap:48px;align-items:center;display:grid;gap:48px;grid-template-columns:1fr;margin-bottom:80px}.alternating-section:last-child{margin-bottom:0}.alternating-image{order:2}.order-first-mobile{order:1}.section-image{border-radius:24px;box-shadow:0 20px 40px #0000001a;width:100%}.image-placeholder{align-items:center;aspect-ratio:4/3;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);background:linear-gradient(135deg,var(--color-slate-100),var(--color-slate-200));border-radius:24px;color:var(--color-slate-500);display:flex;font-size:1.25rem;font-weight:500;justify-content:center;padding:24px;text-align:center;width:100%}.alternating-content{order:1}.content-badge{border-radius:9999px;display:inline-block;font-size:.875rem;font-weight:600;margin-bottom:16px;padding:8px 16px}.content-badge-blue{background:#dbeafe;background:var(--color-blue-100);color:#1d4ed8;color:var(--color-blue-700)}.content-badge-purple{background:#f3e8ff;background:var(--color-purple-100);color:#7e22ce;color:var(--color-purple-700)}.content-badge-green{background:#dcfce7;background:var(--color-green-100);color:#16a34a;color:var(--color-green-600)}.content-badge-yellow{background:#fef9c3;background:var(--color-yellow-100);color:#a16207;color:var(--color-yellow-700)}.content-title{color:#0f172a;color:var(--color-slate-900);font-size:clamp(1.5rem,4vw,2.25rem);font-weight:700;line-height:1.2;margin:0 0 16px}.content-description{color:#334155;color:var(--color-slate-700);font-size:1.125rem;line-height:1.7;margin:0 0 24px}.checklist{display:flex;flex-direction:column;gap:12px}.checklist-item{align-items:flex-start;display:flex;gap:12px}.check-icon{color:#16a34a;color:var(--color-green-600);flex-shrink:0;height:24px;margin-top:2px;width:24px}.checklist-item p{color:#334155;color:var(--color-slate-700);font-size:1rem;line-height:1.5;margin:0}.how-it-works-section{background:linear-gradient(135deg,#eff6ff,#faf5ff);background:linear-gradient(135deg,var(--color-blue-50),var(--color-purple-50));padding:80px 16px}.steps-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.step-card{flex-direction:column;text-align:center}.step-card,.step-icon{align-items:center;display:flex}.step-icon{border-radius:24px;box-shadow:0 10px 25px #00000026;height:80px;justify-content:center;margin-bottom:16px;transition:all .3s ease;width:80px}.step-card:hover .step-icon{box-shadow:0 15px 35px #0003;transform:scale(1.1)}.step-icon svg{color:#fff;height:40px;width:40px}.step-icon-blue{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--color-blue-500),var(--color-blue-600))}.step-icon-purple{background:linear-gradient(135deg,#a855f7,#9333ea);background:linear-gradient(135deg,var(--color-purple-500),var(--color-purple-600))}.step-icon-green{background:linear-gradient(135deg,#22c55e,#16a34a);background:linear-gradient(135deg,var(--color-green-500),var(--color-green-600))}.step-icon-yellow{background:linear-gradient(135deg,#eab308,#ca8a04);background:linear-gradient(135deg,var(--color-yellow-500),var(--color-yellow-600))}.step-icon-pink{background:linear-gradient(135deg,#ec4899,#db2777);background:linear-gradient(135deg,var(--color-pink-500),var(--color-pink-600))}.step-title{color:#0f172a;color:var(--color-slate-900);font-size:1.125rem;margin:0 0 8px}.step-description{color:#475569;color:var(--color-slate-600);font-size:.875rem;margin:0}.solutions-section{background:#fff;padding:80px 16px}.solutions-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:48px}.solution-card{border:2px solid;border-radius:24px;padding:32px;transition:all .3s ease}.solution-card:hover{box-shadow:0 20px 40px #0000001a}.solution-card-blue{background:linear-gradient(135deg,#eff6ff,#fff);background:linear-gradient(135deg,var(--color-blue-50),#fff);border-color:#bfdbfe;border-color:var(--color-blue-200)}.solution-card-purple{background:linear-gradient(135deg,#faf5ff,#fff);background:linear-gradient(135deg,var(--color-purple-50),#fff);border-color:#e9d5ff;border-color:var(--color-purple-200)}.solution-card-green{background:linear-gradient(135deg,#f0fdf4,#fff);background:linear-gradient(135deg,var(--color-green-50),#fff);border-color:#bbf7d0;border-color:var(--color-green-200)}.solution-card-yellow{background:linear-gradient(135deg,#fefce8,#fff);background:linear-gradient(135deg,var(--color-yellow-50),#fff);border-color:#fef08a;border-color:var(--color-yellow-200)}.solution-icon{align-items:center;border-radius:16px;display:flex;height:56px;justify-content:center;margin-bottom:16px;width:56px}.solution-icon svg{color:#fff;height:28px;width:28px}.solution-icon-blue{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--color-blue-500),var(--color-blue-600))}.solution-icon-purple{background:linear-gradient(135deg,#a855f7,#9333ea);background:linear-gradient(135deg,var(--color-purple-500),var(--color-purple-600))}.solution-icon-green{background:linear-gradient(135deg,#22c55e,#16a34a);background:linear-gradient(135deg,var(--color-green-500),var(--color-green-600))}.solution-icon-yellow{background:linear-gradient(135deg,#eab308,#ca8a04);background:linear-gradient(135deg,var(--color-yellow-500),var(--color-yellow-600))}.solution-title{color:#0f172a;color:var(--color-slate-900);font-size:1.5rem;font-weight:700;margin:0 0 12px}.solution-description{color:#334155;color:var(--color-slate-700);font-size:1rem;line-height:1.6;margin:0}.solutions-hero-image{border-radius:24px;box-shadow:0 25px 50px -12px #00000040;overflow:hidden}.solutions-image{display:block;width:100%}.resources-section{background:#f8fafc;background:var(--color-slate-50);padding:80px 16px}.resources-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.resource-item{flex-direction:column;padding:24px;text-align:center}.resource-icon,.resource-item{align-items:center;display:flex}.resource-icon{border-radius:16px;box-shadow:0 10px 25px #00000026;height:64px;justify-content:center;margin-bottom:16px;width:64px}.resource-icon svg{color:#fff;height:32px;width:32px}.resource-icon-blue{background:linear-gradient(135deg,#3b82f6,#2563eb);background:linear-gradient(135deg,var(--color-blue-500),var(--color-blue-600))}.resource-icon-purple{background:linear-gradient(135deg,#a855f7,#9333ea);background:linear-gradient(135deg,var(--color-purple-500),var(--color-purple-600))}.resource-icon-slate{background:linear-gradient(135deg,#475569,#334155);background:linear-gradient(135deg,var(--color-slate-600),var(--color-slate-700))}.resource-title{color:#0f172a;color:var(--color-slate-900);font-size:1.25rem;font-weight:700;margin:0 0 12px}.resource-description{color:#475569;color:var(--color-slate-600);font-size:1rem;line-height:1.6;margin:0}.testimonial-section{background:linear-gradient(135deg,#faf5ff,#fdf2f8);background:linear-gradient(135deg,var(--color-purple-50),var(--color-pink-50));padding:80px 16px}.testimonial-header-content{align-items:center;display:flex;gap:8px;justify-content:center}.heart-icon{color:#ec4899;color:var(--color-pink-500);height:32px;width:32px}.testimonial-card-featured{background:#fff;border:2px solid #e9d5ff;border:2px solid var(--color-purple-200);border-radius:24px;box-shadow:0 20px 40px #0000001a;margin:0 auto;max-width:896px;padding:40px}.testimonial-author-info{align-items:center;display:flex;gap:16px;margin-bottom:24px}.author-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:64px;justify-content:center;width:64px}.author-avatar-purple{background:linear-gradient(135deg,#a855f7,#ec4899);background:linear-gradient(135deg,var(--color-purple-500),var(--color-pink-500))}.author-details{flex:1 1}.author-name{color:#0f172a;color:var(--color-slate-900);font-size:1.125rem;font-weight:700;margin:0 0 4px}.author-role{color:#475569;color:var(--color-slate-600);font-size:1rem;margin:0}.testimonial-quote-featured{color:#334155;color:var(--color-slate-700);font-size:1.25rem;font-style:italic;line-height:1.7;margin:0 0 16px}.testimonial-stats{color:#475569;color:var(--color-slate-600);display:flex;flex-wrap:wrap;font-size:.875rem;gap:24px}.testimonial-stat{align-items:center;display:flex;gap:8px}.stat-icon{height:20px;width:20px}.stat-icon-green{color:#16a34a;color:var(--color-green-600)}.stat-icon-blue{color:#2563eb;color:var(--color-blue-600)}.cta-section{background:linear-gradient(135deg,#2563eb,#9333ea);background:linear-gradient(135deg,var(--color-blue-600),var(--color-purple-600));padding:80px 16px;text-align:center}.cta-title{color:#fff;font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.2;margin:0 0 24px}.cta-description{color:#dbeafe;font-size:1.25rem;line-height:1.6;margin:0 auto 40px;max-width:640px}.cta-actions{align-items:center;display:flex;flex-direction:column;gap:16px}.cta-button-primary{background:#fff;border:none;border-radius:16px;box-shadow:0 20px 40px #0003;color:#1d4ed8;color:var(--color-blue-700);cursor:pointer;font-size:1.125rem;font-weight:700;padding:20px 40px;transition:all .3s ease}.cta-button-primary:hover{background:#eff6ff;background:var(--color-blue-50);box-shadow:0 25px 50px #00000040;transform:scale(1.05)}.cta-button-secondary{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1d4ed880;border:2px solid #ffffff80;border-radius:16px;color:#fff;cursor:pointer;font-size:1.125rem;font-weight:600;padding:20px 40px;transition:all .3s ease}.cta-button-secondary:hover{background:#1d4ed8b3;border-color:#fff}.landing-footer{background:#0f172a;background:var(--color-slate-900);padding:48px 16px}.footer-container{margin:0 auto;max-width:1280px}.footer-top{border-bottom:1px solid #1e293b;border-bottom:1px solid var(--color-slate-800);flex-direction:column;gap:32px;margin-bottom:32px;padding-bottom:32px}.footer-brand,.footer-top{align-items:center;display:flex}.footer-brand{gap:12px}.footer-logo{align-items:center;background:linear-gradient(135deg,#3b82f6,#9333ea);background:linear-gradient(135deg,var(--color-blue-500),var(--color-purple-600));border-radius:12px;display:flex;height:40px;justify-content:center;width:40px}.footer-brand-name{color:#fff;font-size:1.25rem;font-weight:700}.footer-nav{display:flex;flex-wrap:wrap;gap:32px;justify-content:center}.footer-nav a{color:#94a3b8;color:var(--color-slate-400);font-size:.9375rem;text-decoration:none;transition:color .2s ease}.footer-nav a:hover{color:#fff}.footer-bottom{text-align:center}.footer-bottom p{color:#94a3b8;color:var(--color-slate-400);font-size:.875rem;margin:0}.landing-error{background:#fff;border:2px solid #fef2f2;border-radius:24px;box-shadow:0 20px 40px #0000001a;margin:80px auto;max-width:480px;padding:48px;text-align:center}.landing-error h2{color:#dc2626;font-size:1.5rem;margin:0 0 16px}.landing-error p{color:#475569;color:var(--color-slate-600);margin:0}@media (min-width:640px){.header-container{padding:0 24px}.hero-actions{align-items:center;flex-direction:row}.cta-actions{flex-direction:row;justify-content:center}.footer-top{flex-direction:row;justify-content:space-between}.sign-in-link{display:inline-block}}@media (min-width:768px){.header-nav-desktop{display:flex}.mobile-menu-button{display:none!important}.hero-section{padding:64px 24px 96px}.hero-logo{width:280px}.cta-section,.how-it-works-section,.resources-section,.solutions-section,.testimonial-section,.why-works-section{padding:96px 24px}.section-container{padding:0 24px}}@media (min-width:1024px){.hero-grid{align-items:center;gap:48px;grid-template-columns:1fr 1fr}.hero-image-container{display:block;min-height:400px}.alternating-section{grid-template-columns:1fr 1fr}.alternating-section .alternating-image{order:1}.alternating-section .alternating-content{order:2}.alternating-reverse .alternating-content{order:1}.alternating-reverse .alternating-image{order:2}.order-first-mobile{order:1}.steps-grid{grid-template-columns:repeat(5,1fr)}}@media (max-width:639px){.hero-logo{width:180px}.hero-logo-text{font-size:1.25rem}.cta-button-primary,.cta-button-secondary,.demo-button{text-align:center;width:100%}.google-login-hero{width:100%}.solution-card,.testimonial-card-featured{padding:24px}.step-icon{height:64px;width:64px}.step-icon svg{height:32px;width:32px}}@media (prefers-reduced-motion:reduce){.animate-bounce-slow,.animate-float,.animate-pulse-slow{animation:none}.cta-button-primary:hover,.demo-button-header:hover,.step-card:hover .step-icon{transform:none}}@media (prefers-contrast:high){.solution-card,.testimonial-card-featured{border-width:3px}.hero-title,.section-title{color:#000}}.cta-button-primary:focus,.cta-button-secondary:focus,.demo-button-header:focus,.demo-button:focus,.nav-link:focus,.sign-in-link:focus{outline:2px solid #2563eb;outline:2px solid var(--color-blue-600);outline-offset:2px}.sidebar{background:var(--cb-sidebar);border-right:1px solid var(--cb-sidebar-border);box-shadow:6px 0 24px #1c2e250f;display:flex;flex-direction:column;height:100%;width:100%}.sidebar-header{background:linear-gradient(145deg,#fff,#f9f7f1);border-bottom:1px solid var(--cb-sidebar-border);padding:26px 24px}.logo{gap:14px}.logo,.logo-icon{align-items:center;display:flex}.logo-icon{background:linear-gradient(135deg,var(--cb-primary),#2c8d6d);border-radius:14px;box-shadow:0 14px 28px #2f9e7a40;height:44px;justify-content:center;width:44px}.logo-icon,.logo-icon svg{color:var(--cb-primary-foreground)}.logo-icon svg{height:26px;width:26px}.logo-text{color:var(--cb-sidebar-foreground);font-size:17px;font-weight:800;letter-spacing:-.3px}.sidebar-nav{flex:1 1;padding:22px 12px 10px}.nav-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.nav-item{margin:0}.nav-link{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--cb-radius-lg);color:#283041c7;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;justify-content:flex-start;padding:13px 14px;position:relative;text-align:left;text-decoration:none;transition:all .25s ease;width:100%}.nav-link:hover{background:var(--cb-sidebar-accent);border-color:var(--cb-sidebar-border);box-shadow:0 10px 30px #1b332814}.nav-link.active,.nav-link:hover{color:var(--cb-sidebar-foreground)}.nav-link.active{background:linear-gradient(135deg,#2f9e7a1f,#2f9e7a14);border-color:#2f9e7a2e;box-shadow:0 14px 32px #2f9e7a2e}.nav-icon{align-items:center;color:inherit;display:flex;font-size:20px;justify-content:center;min-width:20px}.nav-icon svg{color:inherit!important;font-size:20px!important;transition:transform .2s ease,color .2s ease}.nav-link.active .nav-icon svg,.nav-link:hover .nav-icon svg{color:var(--cb-primary)!important;transform:scale(1.04)}.nav-label{flex:1 1;font-weight:600}.external-icon{align-items:center;display:flex;font-size:14px;justify-content:center;min-width:14px;opacity:.7;transition:all .2s ease}.external-icon svg{color:inherit!important;font-size:14px!important}.nav-link.external-link:focus-visible .external-icon,.nav-link.external-link:hover .external-icon{opacity:1}.nav-link.has-children{justify-content:flex-start}.nav-link.has-children .nav-label{flex:1 1;text-align:left}.expand-icon{color:#28304199;font-size:12px;transition:transform .2s ease,opacity .2s ease}.expand-icon.expanded{opacity:.9;transform:rotate(180deg)}.nav-submenu{border-left:2px solid #2f9e7a33;list-style:none;margin:4px 0 0 8px;padding:6px 0 4px 12px}.nav-subitem{margin:0}.nav-sublink{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--cb-radius-md);color:#283041bf;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px;padding:10px 12px;text-decoration:none;transition:all .2s ease;width:100%}.nav-sublink:hover{background:#e6f1ebb3;border-color:var(--cb-sidebar-border);color:var(--cb-sidebar-foreground)}.nav-sublink.active{background:#2f9e7a24;border-color:#2f9e7a2e;box-shadow:0 10px 24px #2f9e7a24;color:var(--cb-sidebar-foreground)}.nav-subicon{align-items:center;color:inherit;display:flex;font-size:16px;justify-content:center;min-width:16px}.nav-subicon svg{color:inherit!important;font-size:16px!important}.nav-sublabel{font-weight:inherit}.sidebar-footer{background:linear-gradient(145deg,#fff,#fbfaf7);border-top:1px solid var(--cb-sidebar-border);margin-top:auto;padding:12px 12px 16px}.footer-nav-list{margin-bottom:8px}.footer-nav-list .nav-submenu{margin:4px 0 0 8px;padding:6px 0 4px 12px}.settings-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--cb-radius-lg);color:#283041c7;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;padding:13px 14px;text-align:left;transition:all .25s ease;width:100%}.settings-btn:hover{background:var(--cb-sidebar-accent);border-color:var(--cb-sidebar-border);box-shadow:0 10px 26px #1b332814;color:var(--cb-sidebar-foreground)}.settings-btn.active{background:linear-gradient(135deg,#2f9e7a1f,#2f9e7a14);border-color:#2f9e7a2e;box-shadow:0 14px 32px #2f9e7a2e;color:var(--cb-sidebar-foreground)}.settings-btn.active .settings-icon svg,.settings-btn:hover .settings-icon svg{color:var(--cb-primary)!important;transform:scale(1.04)}.settings-icon{align-items:center;display:flex;font-size:20px;justify-content:center;min-width:20px}.settings-icon svg{color:inherit!important;font-size:20px!important;transition:transform .2s ease,color .2s ease}@media (max-width:1159px){.sidebar{box-shadow:none}}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border-bottom:1px solid var(--cb-border);box-shadow:0 12px 36px #172c2314;height:78px;position:-webkit-sticky;position:sticky;top:0;z-index:900}.header-content{height:100%;justify-content:flex-end;padding:0 28px}.header-content,.header-right{align-items:center;display:flex;max-width:100%}.header-right{flex-wrap:nowrap;gap:12px}.search-container{align-items:center;display:flex;flex:0 1 220px;min-width:100px}.search-input{border:1px solid var(--cb-border);border-radius:var(--cb-radius-lg);box-shadow:0 10px 30px #1b33280a;color:var(--cb-foreground);height:44px;padding:0 16px 0 42px;transition:all .25s ease}.search-input:focus{background:#fff;border-color:#2f9e7a66;box-shadow:0 0 0 4px #2f9e7a1f}.search-icon,.search-input::placeholder{color:#2a324299}.search-icon{font-size:16px;left:14px;pointer-events:none}.notifications{position:relative}.notification-btn{align-items:center;background:var(--cb-secondary);border:1px solid var(--cb-border);border-radius:var(--cb-radius-lg);cursor:pointer;display:flex;height:44px;justify-content:center;position:relative;transition:all .25s ease;width:44px}.notification-btn:hover{background:#fff;border-color:#2f9e7a59;box-shadow:0 12px 32px #172c2314;transform:translateY(-1px)}.notification-icon{color:var(--cb-foreground);font-size:18px}.notification-btn:hover .notification-icon{color:var(--cb-primary)}.notification-badge{align-items:center;background:#e94b44;border-radius:10px;box-shadow:0 2px 6px #e94b4459;color:#fff;display:flex;font-size:11px;font-weight:800;height:18px;justify-content:center;min-width:18px;padding:2px 6px;position:absolute;right:-2px;top:-2px}.user-menu{position:relative}.user-menu-btn{align-items:center;background:#fff;border:1px solid var(--cb-border);border-radius:var(--cb-radius-lg);box-shadow:0 10px 26px #1b33280f;cursor:pointer;display:flex;gap:10px;padding:8px 14px;transition:all .25s ease}.user-menu-btn:hover{border-color:#2f9e7a52;box-shadow:0 14px 36px #1b332814}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--cb-primary) 0,#2c8d6d 100%);border-radius:14px;box-shadow:0 10px 24px #2f9e7a40;display:flex;height:38px;justify-content:center;width:38px}.avatar-text{color:#fff;font-size:14px;font-weight:700}.avatar-image{border-radius:14px;height:100%;object-fit:cover;width:100%}.user-name{color:var(--cb-foreground);font-size:14px;font-weight:700;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{color:#2a324299;font-size:10px}.user-menu-btn:hover .dropdown-arrow{transform:translateY(1px)}.user-dropdown{animation:dropdownFadeIn .18s ease;background:#fff;border:1px solid var(--cb-border);border-radius:var(--cb-radius-lg);box-shadow:0 18px 48px #0000001f;margin-top:10px;min-width:200px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-list{list-style:none;margin:0;padding:8px 0}.dropdown-item{background:none;border:none;color:var(--cb-foreground);cursor:pointer;font-size:14px;padding:12px 18px;text-align:left;transition:all .2s ease;width:100%}.dropdown-item:hover{background:var(--cb-secondary);color:var(--cb-primary)}.dropdown-item.logout{color:#e94b44}.dropdown-item.logout:hover{background:#fdf1f0;color:#d0362e}.dropdown-divider{background:var(--cb-border);height:1px;margin:8px 0}.header-dropdowns{align-items:center;display:flex;flex:0 1 auto;gap:8px;min-width:0}.header-select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;background-size:18px;border:1px solid var(--cb-border);border-radius:12px;color:var(--cb-foreground);cursor:pointer;flex:0 1 160px;font-size:14px;font-weight:600;max-width:180px;min-width:80px;outline:none;overflow:hidden;padding:10px 30px 10px 12px;text-overflow:ellipsis;white-space:nowrap}.header-select:focus{border-color:#2f9e7a66;box-shadow:0 0 0 4px #2f9e7a1f}.teacher-context-info{align-items:center;border-radius:8px;display:flex;flex-shrink:1;gap:10px;min-width:0;overflow:hidden;padding:6px 14px}.teacher-context-info.warning{background-color:#fef3c7;border:1px solid #fde68a}.teacher-context-info.normal{background-color:#2f9e7a14;border:1px solid #2f9e7a40}.teacher-context-info .context-text{display:flex;flex-direction:column}.teacher-context-info .primary-text{font-size:14px;font-weight:600;line-height:1.2}.teacher-context-info .secondary-text{font-size:11px;line-height:1.2}.teacher-context-info.warning .primary-text{color:#92400e}.teacher-context-info.warning .secondary-text{color:#b45309}.teacher-context-info.normal .primary-text{color:#2d5016}.teacher-context-info.normal .secondary-text{color:#5a7a3a}@media (max-width:1159px){.header{height:auto;min-height:56px}.header-content{padding:8px 16px}.header-right{gap:8px}.header-dropdowns,.teacher-context-info{display:none!important}.notifications,.search-container{display:none}.header-right>div:has(.language-switcher){display:none}.header-right>div:last-of-type:not(.user-menu){display:none}.user-menu-btn{gap:8px;padding:6px 10px}.user-name{display:none}.user-avatar{height:34px;width:34px}.dropdown-arrow{display:none}.user-dropdown{right:0}}.language-switcher{display:inline-block;position:relative}.language-switcher-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#1a1a2e;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 12px;transition:all .2s ease}.language-switcher-btn:hover{background-color:#1a1a2e0d}.current-language{align-items:center;display:flex;font-size:13px;font-weight:600;gap:4px}.dropdown-arrow{transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.language-dropdown{background:#fff;border:1px solid #e8e2db;border-radius:12px;box-shadow:0 4px 12px #0000001a;min-width:160px;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:1000}.language-list{list-style:none;margin:0;padding:8px 0}.language-option{align-items:center;background:#0000;border:none;color:#374151;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;position:relative;text-align:left;transition:background-color .2s ease;width:100%}.language-option:hover{background-color:#f7f5f0}.language-option.active{background-color:#2d50160d;color:#2d5016;font-weight:600}.language-flag{align-items:center;display:flex;font-size:16px;justify-content:center;width:20px}.language-name{flex:1 1}.active-indicator{color:#2d5016;font-size:12px;font-weight:700}@media (max-width:1159px){.language-switcher-btn{padding:6px 8px}.current-language{font-size:12px}.language-dropdown{right:-8px}}.google-classroom-status{align-items:center;background:#0000;border:1px solid #0000;border-radius:6px;cursor:default;display:flex;gap:6px;justify-content:center;min-width:40px;padding:6px 10px;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.google-classroom-status.clickable{cursor:pointer}.google-classroom-status.clickable:hover{background:#0000000d;border-color:#0000001a}.status-icon{align-items:center;display:flex;justify-content:center;transition:all .2s ease}.status-indicator{border-radius:50%;height:8px;transition:all .2s ease;width:8px}.google-classroom-status.connected .status-icon{color:#10b981}.google-classroom-status.connected .status-indicator{background-color:#10b981;box-shadow:0 0 6px #10b98166}.google-classroom-status.disconnected .status-icon{color:#dc2626;opacity:.6}.google-classroom-status.disconnected .status-indicator{background-color:#dc2626;opacity:.6}.google-classroom-status.disconnected.clickable:hover .status-icon,.google-classroom-status.disconnected.clickable:hover .status-indicator{opacity:.8}.google-classroom-status.expired .status-icon{color:#f59e0b}.google-classroom-status.expired .status-indicator{animation:pulse 2s ease-in-out infinite;background-color:#f59e0b}.google-classroom-status.loading .status-icon{color:#6b7280}.google-classroom-status.loading .status-indicator{animation:pulse 1.5s ease-in-out infinite;background-color:#6b7280}.google-classroom-status:before{background:#1f2937;border-radius:4px;bottom:-35px;color:#fff;content:attr(title);font-size:.75rem;padding:6px 10px;pointer-events:none;white-space:nowrap}.google-classroom-status:after,.google-classroom-status:before{left:50%;opacity:0;position:absolute;transform:translateX(-50%);transition:opacity .2s ease;z-index:1000}.google-classroom-status:after{border-bottom:4px solid #1f2937;border-left:4px solid #0000;border-right:4px solid #0000;bottom:-8px;content:"";height:0;width:0}.google-classroom-status:hover:after,.google-classroom-status:hover:before{opacity:1}@media (max-width:1159px){.google-classroom-status{gap:4px;min-width:32px;padding:4px 6px}.status-icon svg{font-size:16px!important}.status-indicator{height:6px;width:6px}.google-classroom-status:after,.google-classroom-status:before{display:none}}@media (max-width:480px){.google-classroom-status{min-width:28px;padding:3px 4px}.status-icon svg{font-size:14px!important}.status-indicator{height:5px;width:5px}}.charts-dashboard{background:#f8f9fa;min-height:100vh;padding:20px}.charts-header{margin-bottom:30px;text-align:center}.charts-header h2{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:10px}.charts-header p{color:#666;font-size:1.1rem;margin:0}.charts-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin:0 auto;max-width:1400px}.chart-container{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 6px #00000012;overflow:hidden;padding:20px;position:relative;transition:all .3s ease}.chart-container:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.chart-wrapper{height:400px;position:relative;width:100%}.chart-center-text{left:50%;pointer-events:none;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:10}.chart-center-text .total-students{align-items:center;display:flex;flex-direction:column}.chart-center-text .number{color:#2c3e50;font-size:2rem;font-weight:700;line-height:1}.chart-center-text .label{color:#666;font-size:.9rem;letter-spacing:.5px;margin-top:2px;text-transform:uppercase}.chart-loading{align-items:center;color:#666;display:flex;flex-direction:column;height:400px;justify-content:center}.chart-loading .loading-spinner{text-align:center}.chart-loading .spinner{animation:spin 1s linear infinite;border:4px solid #e8e2db;border-radius:50%;border-top-color:#d4a574;height:40px;margin:0 auto 16px;width:40px}.chart-loading p{color:#666;font-size:1rem;margin:0}.chart-error{align-items:center;color:#dc2626;display:flex;flex-direction:column;height:400px;justify-content:center;text-align:center}.chart-error p{font-size:1rem;margin-bottom:15px}.retry-button{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 20px;transition:background .2s ease}.retry-button:hover{background:#b91c1c}.chart-empty{align-items:center;color:#666;display:flex;flex-direction:column;height:400px;justify-content:center;text-align:center}.chart-empty p{margin:5px 0}.chart-empty p:first-child{color:#2c3e50;font-size:1.1rem;font-weight:500}.chart-empty-detail{color:#999;font-size:.9rem}@media (max-width:1159px){.charts-grid{gap:20px;grid-template-columns:1fr;padding:0 10px}.chart-container{margin:0;padding:15px}.chart-wrapper{height:350px}.charts-header h2{font-size:1.6rem}.charts-header p{font-size:1rem}.chart-center-text .number{font-size:1.5rem}.chart-center-text .label{font-size:.8rem}}@media (max-width:480px){.charts-dashboard{padding:15px}.chart-wrapper{height:300px}.charts-header{margin-bottom:20px}.charts-header h2{font-size:1.4rem}}.chart-container{animation:fadeInUp .6s ease-out forwards;opacity:0;transform:translateY(30px)}.chart-container:first-child{animation-delay:.1s}.chart-container:nth-child(2){animation-delay:.2s}.chart-container:nth-child(3){animation-delay:.3s}.chart-container:nth-child(4){animation-delay:.4s}.chart-container:nth-child(5){animation-delay:.5s}.chart-container:nth-child(6){animation-delay:.6s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}@media (min-width:1200px){.charts-grid{grid-template-columns:repeat(2,1fr)}.chart-wrapper{height:450px}}.dashboard{background:linear-gradient(135deg,var(--cb-background) 0,#fdfcfb 40%,#f7f4ec 100%);display:flex;max-width:100vw}.dashboard,.main-content{min-height:100vh;overflow-x:hidden}.content-area,.main-content{max-width:100%;width:100%}.content-area{background:#0000;box-sizing:border-box;flex:1 1;padding:40px 36px 48px}.welcome-section{margin:0 auto;max-width:1400px}.welcome-section h1{color:var(--cb-foreground);display:block;font-size:40px;font-weight:800;letter-spacing:-.8px;line-height:1.1;margin:0 0 10px}.welcome-section>p{color:#1f2430b3;font-size:17px;font-weight:500;line-height:1.6;margin:0 0 56px;max-width:620px}.dashboard-cards{grid-gap:26px;display:grid;gap:26px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:56px}.dashboard-card{background:linear-gradient(135deg,#fff 0,var(--cb-background-strong) 100%);border:1px solid var(--cb-border);border-radius:var(--cb-radius-xl);box-shadow:var(--cb-shadow-card);isolation:isolate;overflow:hidden;padding:32px 30px;position:relative;transition:all .3s ease}.dashboard-card:after{background:radial-gradient(circle at 20% 20%,#2f9e7a14,#0000 40%);content:"";inset:0;position:absolute;z-index:0}.dashboard-card.clickable{-webkit-user-select:none;user-select:none}.dashboard-card.clickable:hover{border-color:#2f9e7a38;box-shadow:0 24px 60px #1b33282e;transform:translateY(-8px)}.dashboard-card.clickable:active{box-shadow:0 12px 30px #1b332824;transform:translateY(-2px)}.dashboard-card:before{background:linear-gradient(90deg,var(--cb-primary) 0,#5ca7e6 100%);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease;z-index:1}.dashboard-card:hover:before{transform:scaleX(1)}.card-icon{align-items:center;border-radius:20px;box-shadow:0 12px 30px #2f9e7a38;display:flex;font-size:28px;height:68px;justify-content:center;margin-bottom:24px;position:relative;width:68px;z-index:1}.classrooms-icon{background:linear-gradient(135deg,var(--cb-primary) 0,#2c8d6d 100%)}.students-icon{background:linear-gradient(135deg,#5ca7e6,#4c93dc);box-shadow:0 12px 30px #4c93dc38}.google-icon{background:linear-gradient(135deg,#7b6cf4,#6457da);box-shadow:0 12px 30px #7b6cf438}.dashboard-card h3{color:var(--cb-foreground);font-size:22px;font-weight:800;letter-spacing:-.4px;margin:0 0 10px;position:relative;z-index:1}.dashboard-card p{color:#1f2430ad;font-size:15px;font-weight:500;line-height:1.55;margin:0 0 18px;position:relative;z-index:1}.card-count{align-items:center;background:var(--cb-secondary);border:1px solid var(--cb-border);border-radius:12px;box-shadow:0 10px 24px #1b332814;color:var(--cb-foreground);display:inline-flex;font-size:12px;font-weight:800;letter-spacing:.7px;padding:8px 14px;text-transform:uppercase}.card-count,.card-detail{position:relative;z-index:1}.card-detail{margin-top:10px}.card-detail small{color:#1f2430b8;font-size:11px;font-weight:600}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:32px}.stat-card{border:1px solid var(--cb-border);border-radius:var(--cb-radius-lg);box-shadow:0 12px 30px #1b33280f}.stat-value{color:var(--cb-primary);font-weight:800}.stat-label{color:#1f2430b3;font-weight:600;margin:10px 0 0}@media (max-width:1159px){.dashboard{margin:0;padding:0}.main-content{flex:1 1;margin-left:0;max-width:100vw;width:100%}.content-area{margin:0;padding:16px 14px 22px}.welcome-section h1{font-size:26px}.welcome-section>p{font-size:14px;margin-bottom:32px}.dashboard-cards{gap:16px;grid-template-columns:1fr;margin-bottom:32px}.dashboard-card{padding:24px 20px}.dashboard-card h3{font-size:18px}.dashboard-card p{font-size:14px}.card-icon{font-size:24px;height:60px;width:60px}.stats-grid{gap:16px;grid-template-columns:repeat(2,1fr)}.stat-card{padding:20px 16px}.stat-value{font-size:24px}}@media (max-width:480px){.dashboard-cards{margin-bottom:28px}.dashboard-card{padding:20px 16px}.stats-grid{grid-template-columns:1fr}}.charts-section{border-top:1px solid var(--cb-border);margin-top:48px;padding-top:30px}@media (max-width:1159px){.charts-section{margin-top:30px;padding-top:20px}}.students-section{margin:0 auto;max-width:1400px;overflow-x:hidden;width:100%}.students-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.page-header-content h1{color:#111827;font-size:20px;font-weight:600;letter-spacing:-.3px;line-height:1.3;margin:0 0 4px}.page-header-content p{font-size:12px}.header-actions{gap:8px}.stats-strip{flex-wrap:wrap;gap:12px;margin-bottom:20px}.stat-pill,.stats-strip{align-items:center;display:flex}.stat-pill{background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;gap:8px;padding:6px 14px}.stat-pill .stat-value{color:#1f2937;font-weight:600}.stat-pill .stat-label{color:#6b7280}.stat-pill.stat-active{background:#ecfdf5;border-color:#a7f3d0}.stat-pill.stat-active .stat-dot{background:#059669;border-radius:50%;height:6px;width:6px}.stat-pill.stat-active .stat-value{color:#047857}.stats-cards{display:none}.controls-bar{flex-wrap:wrap;margin-bottom:16px}.search-container{max-width:420px;min-width:240px}.search-icon{font-size:18px;left:12px}.search-input{border:1px solid #e5e7eb;border-radius:6px;font-size:14px;height:36px;outline:none;padding:0 12px 0 40px;transition:all .2s ease}.search-input:focus{box-shadow:0 0 0 2px #2d50161a}.search-input::placeholder{color:#9ca3af}.filter-controls,.status-filter-container{align-items:center;gap:8px}.status-filter-container{display:flex}.filter-label{display:none}.filter-icon{color:#6b7280;font-size:16px}.filter-select,.status-filter-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;border:1px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;font-size:13px;height:36px;min-width:110px;outline:none;padding:0 32px 0 12px;transition:all .2s ease}.filter-select:focus,.status-filter-select:focus{border-color:#2d5016;box-shadow:0 0 0 2px #2d50161a}.filter-select:disabled,.status-filter-select:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.view-mode-toggle{background:#f3f4f6;border-radius:6px;display:flex;padding:2px}.view-mode-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .15s ease}.view-mode-btn:hover{color:#374151}.view-mode-btn.active{background:#fff;box-shadow:0 1px 2px #0000000d;color:#1f2937}.view-mode-btn svg{font-size:16px}.btn{border-radius:6px;font-weight:500;padding:8px 14px;transition:all .2s ease}.btn-primary{background:#059669}.btn-primary:hover{background:#047857}.btn-secondary{background:#0000;border:1px solid #e5e7eb}.btn-secondary:hover{background:#f9fafb;border-color:#d1d5db}.btn-outline{border:1px solid #e5e7eb}.btn-outline:hover{background:#f9fafb;border-color:#d1d5db}.view-tabs{background:#f3f4f6;border-radius:8px;display:flex;gap:0;margin-bottom:16px;padding:4px;width:-webkit-fit-content;width:fit-content}.view-tab{background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-size:13px;font-weight:500;padding:6px 16px;transition:all .15s ease}.view-tab:hover{color:#374151}.view-tab.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#1f2937}.students-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;overflow:hidden}.students-table{border-collapse:collapse;font-size:14px;width:100%}.students-table thead{background:#f9fafb;position:-webkit-sticky;position:sticky;top:0;z-index:10}.students-table th{border-bottom:1px solid #e5e7eb;color:#374151;font-size:12px;font-weight:500;padding:10px 16px;text-align:left;white-space:nowrap}.students-table th:last-child{min-width:120px;width:120px}.students-table th.sortable{cursor:pointer;position:relative;transition:background-color .15s ease;-webkit-user-select:none;user-select:none}.students-table th.sortable:hover{background:#f3f4f6}.sort-icon{display:inline-block;font-size:14px;margin-left:4px;opacity:.5;transition:all .15s ease;vertical-align:middle}.sort-icon.inactive{color:#9ca3af;opacity:.3}.sort-icon.asc{color:#059669;opacity:1;transform:rotate(0deg)}.sort-icon.desc{color:#059669;opacity:1;transform:rotate(180deg)}.students-table td{border-bottom:1px solid #f3f4f6;padding:10px 16px;vertical-align:middle}.students-table td:last-child{min-width:120px;padding-right:12px;text-align:right;width:120px}@media (min-width:769px){.students-table td{display:table-cell}.students-table td:before{display:none}}.students-table tbody tr{transition:background-color .15s ease}.students-table tbody tr:hover{background:#f9fafb}.clickable-row{cursor:pointer;transition:all .2s ease}.clickable-row:hover{background:#f7f5f0!important;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.clickable-row:active{background:#e8e2db!important;transform:translateY(0)}.inactive-student{background:#f8f8f8!important;border-left:4px solid #ef4444;opacity:.8}.inactive-student:hover{background:#f1f1f1!important}.inactive-student .name{color:#6b7280!important;text-decoration:line-through}.inactive-student td{color:#6b7280}.students-table tr:last-child td{border-bottom:none}.student-name{align-items:center;display:flex;gap:12px}.student-name .name{color:#1f2937;font-size:14px;font-weight:500;line-height:1.2}.student-name .email{color:#6b7280;font-size:12px;margin-top:2px}.student-avatar{align-items:center;background:#ecfdf5;border-radius:50%;color:#047857;display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:28px;justify-content:center;width:28px}.dob-cell{display:flex;flex-direction:column;gap:4px}.age-badge{background:#f3f4f6;border-radius:4px;color:#6b7280;font-size:11px;padding:2px 6px;width:-webkit-fit-content;width:fit-content}.reading-level{border-radius:9999px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px;text-align:center;white-space:nowrap}.reading-level.has-level{background:#047857;color:#fff}.reading-level.no-level{background:#f3f4f6;color:#6b7280;font-style:italic}.primary-language{border-radius:9999px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px;text-align:center;white-space:nowrap}.primary-language.has-language{background:#0891b2;color:#fff}.primary-language.no-language{background:#f3f4f6;color:#6b7280;font-style:italic}.grade-level{border-radius:9999px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px;text-align:center;white-space:nowrap}.grade-level.has-grade{background:#fef3c7;color:#92400e}.grade-level.no-grade{background:#f3f4f6;color:#6b7280;font-style:italic}.cultures-cell{max-width:250px}.culture-tags{align-items:center;gap:4px}.culture-tag{background:#fff7ed;border:1px solid #fed7aa;color:#c2410c;white-space:nowrap}.culture-more,.culture-tag{border-radius:9999px;font-size:11px;font-weight:500;padding:2px 8px}.culture-more{background:#fff;border:1px solid #e5e7eb;color:#6b7280}.no-cultures{color:#9ca3af;font-size:13px;font-style:italic}.classes-cell{max-width:150px}.class-count{background:#eff6ff;border-radius:9999px;color:#1d4ed8;cursor:pointer;font-size:12px;font-weight:500;padding:4px 10px;transition:background-color .15s ease;white-space:nowrap}.class-count:hover{background:#dbeafe}.no-classes{color:#9ca3af;font-size:13px;font-style:italic}.assignment-count{color:#374151;font-weight:500}.actions-cell{flex-direction:row;gap:4px;justify-content:flex-end}.action-btn,.actions-cell{align-items:center;display:flex}.action-btn{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;flex-shrink:0;height:30px;justify-content:center;min-height:30px;min-width:30px;padding:0;transition:all .15s ease;width:30px}.action-btn svg{font-size:16px;height:16px;width:16px}.action-btn:hover{background:#f9fafb;border-color:#d1d5db;color:#374151}.action-btn.edit-btn:hover{background:#f0fdf4;border-color:#86efac;color:#059669}.action-btn.delete-btn:hover{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.action-btn.wizard-btn{background:#fff;color:#6b7280}.action-btn.wizard-btn:hover{background:#eff6ff;border-color:#93c5fd;color:#2563eb}.action-btn.wizard-btn svg{flex-shrink:0;height:16px;width:16px}.action-btn.more-btn{background:#0000;border-color:#0000}.action-btn.more-btn:hover{background:#f3f4f6;border-color:#0000}.pagination{align-items:center;display:flex;gap:16px;justify-content:center;margin-top:24px}.pagination-btn{background:#fff;border:2px solid #e8e2db;border-radius:8px;color:#2d5016;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#f7f5f0;border-color:#d4a574}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#6b7280;font-size:14px;font-weight:500}.empty-state{margin:0 auto;max-width:600px}.empty-state h2{color:#1a1a2e;font-size:24px;font-weight:700;margin:0 0 12px}.empty-state p{margin:0 0 32px}.empty-actions{display:flex;gap:16px;justify-content:center}.loading-state{padding:80px 20px}.loading-state .spinner{border:4px solid #e8e2db;border-top-color:#d4a574}.error-state{padding:80px 20px}.error-state p{color:#dc3545;font-size:16px;margin:0 0 16px}.retry-btn{background:#2d5016;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px}.retry-btn:hover{background:#1e3a0f}@media (max-width:1159px){.main-content{max-width:100vw;overflow-x:hidden;width:100%}.content-area{box-sizing:border-box;max-width:100%;padding:12px;width:100%}.students-section{max-width:100%;overflow-x:hidden;width:100%}.students-header{align-items:stretch;flex-direction:column;gap:12px;margin-bottom:16px;width:100%}.page-header-content h1{font-size:18px;word-break:break-word}.page-header-content p{font-size:12px}.header-actions{flex-direction:row;gap:8px;justify-content:stretch;width:100%}.header-actions .btn{flex:1 1;font-size:13px;justify-content:center;padding:6px 10px}.view-tabs{overflow-x:auto;width:100%}.view-tab{font-size:12px;padding:6px 12px;white-space:nowrap}.stats-strip{gap:8px}.stat-pill{font-size:12px;padding:4px 10px}.controls-bar{flex-direction:column;gap:12px}.search-container{max-width:none;width:100%}.filter-controls{justify-content:flex-start;width:100%}.filter-select{flex:1 1;min-width:0}.search-input{box-sizing:border-box;height:40px;width:100%}.students-table thead{display:none}.students-table-container{background:#0000;border:none;overflow-x:visible}.students-table{max-width:100%;min-width:0;min-width:auto}.students-table,.students-table tbody{display:block;width:100%}.students-table tr{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:10px;padding:14px}.students-table td,.students-table tr{box-sizing:border-box;display:block;max-width:100%;width:100%}.students-table td{word-wrap:break-word;border:none;overflow-wrap:break-word;padding:6px 0;text-align:left}.students-table td:before{color:#6b7280;content:attr(data-label) ": ";display:block;font-size:10px;font-weight:500;letter-spacing:.5px;margin-bottom:2px;text-transform:uppercase}.students-table td:first-child{border-bottom:1px solid #e5e7eb;margin-bottom:10px;padding-bottom:12px}.students-table td:first-child:before{display:none}.student-name{align-items:flex-start;display:flex;gap:10px}.student-name .email{display:block}.student-name .name{color:#111827;font-size:15px;font-weight:600}.student-avatar{font-size:13px;height:36px;width:36px}.actions-cell{border-top:1px solid #e5e7eb;display:flex!important;flex-wrap:wrap;gap:6px;justify-content:flex-start;margin-top:8px;padding-top:10px!important}.actions-cell:before{display:none}.actions-cell .action-btn{align-items:center;display:flex;flex-direction:row;font-size:12px;gap:6px;height:32px;max-width:none;min-width:auto;padding:0 12px;position:relative;width:auto}.actions-cell .action-btn svg{font-size:16px}.actions-cell .wizard-btn:after{content:"Onboard";font-size:11px;font-weight:500}.actions-cell .edit-btn:after{content:"Edit";font-size:11px;font-weight:500}.actions-cell .delete-btn:after{content:"Delete";font-size:11px;font-weight:500}.actions-cell .reactivate-btn:after{content:"Reactivate";font-size:11px;font-weight:500}.actions-cell .permanent-delete-btn:after{content:"Delete";font-size:11px;font-weight:500}.empty-actions{align-items:center;flex-direction:column}.empty-actions .btn{justify-content:center;width:200px}}@media (max-width:480px){.stats-strip{align-items:stretch;flex-direction:column}.stat-pill{justify-content:center}.view-tabs{flex-direction:column;gap:4px;padding:6px}.view-tab{text-align:center}.header-actions{flex-direction:column}.header-actions .btn{width:100%}.culture-tags{align-items:flex-start;flex-direction:column}.pagination{flex-direction:column;gap:12px}}.google-classroom-modal{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.google-classroom-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;position:relative;width:100%}.google-classroom-modal-header{align-items:center;background:linear-gradient(135deg,#4285f4,#34a853);border-radius:12px 12px 0 0;color:#fff;display:flex;gap:12px;padding:24px}.google-classroom-modal-header h2{align-items:center;display:flex;font-size:1.5rem;font-weight:600;gap:12px;margin:0}.google-classroom-logo{background:#fff;border-radius:6px;color:#4285f4;height:32px;width:32px}.google-classroom-logo,.google-classroom-modal-close{align-items:center;display:flex;justify-content:center}.google-classroom-modal-close{background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.2rem;height:40px;position:absolute;right:16px;top:16px;transition:background-color .2s;width:40px}.google-classroom-modal-close:hover{background:#ffffff4d}.google-classroom-modal-body{flex:1 1;overflow-y:auto;padding:24px}.google-classroom-step{margin-bottom:24px}.google-classroom-step h3{color:#333;font-size:1.2rem;gap:8px;margin:0 0 16px}.google-classroom-step h3,.step-number{align-items:center;display:flex;font-weight:600}.step-number{background:#4285f4;border-radius:50%;color:#fff;font-size:.875rem;height:24px;justify-content:center;width:24px}.google-classroom-loading{color:#666;padding:40px 20px;text-align:center}.google-classroom-loading .spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#4285f4;height:40px;margin:0 auto 16px;width:40px}.google-classroom-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b}.google-classroom-error,.google-classroom-success{align-items:center;display:flex;gap:12px;margin-bottom:16px;padding:16px}.google-classroom-success{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#166534}.classroom-items-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:16px}.classroom-item{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:16px;transition:all .2s}.classroom-item:hover{border-color:#4285f4;box-shadow:0 4px 12px #4285f41a}.classroom-item.selected{background:#f8faff;border-color:#4285f4}.classroom-item.already-imported{background:#f9fafb;border-color:#d1d5db;cursor:not-allowed;opacity:.7}.classroom-item-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:12px}.classroom-item-checkbox{margin-top:2px}.classroom-item-checkbox input[type=checkbox]{accent-color:#4285f4;height:18px;width:18px}.classroom-item-info{flex:1 1}.classroom-item-info h4{color:#333;font-size:1rem;font-weight:600;line-height:1.4;margin:0 0 4px}.classroom-item-info p{color:#666;font-size:.875rem;line-height:1.4;margin:0}.classroom-item-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.classroom-meta-tag{background:#f3f4f6;border-radius:4px;color:#374151;font-size:.75rem;font-weight:500;padding:2px 8px}.classroom-meta-tag.teacher{background:#dbeafe;color:#1e40af}.classroom-meta-tag.student{background:#fef3c7;color:#92400e}.classroom-meta-tag.already-imported{background:#e5e7eb;color:#6b7280}.classroom-import-summary{background:#f8faff;border:1px solid #e0e7ff;border-radius:8px;margin:16px 0;padding:16px}.classroom-import-summary h4{color:#1e40af;font-size:1rem;font-weight:600;margin:0 0 12px}.import-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.import-stat{background:#fff;border-radius:6px;padding:8px;text-align:center}.import-stat .number{color:#4285f4;font-size:1.5rem;font-weight:700;margin-bottom:2px}.import-stat .label{color:#666;font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.google-classroom-modal-footer{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.btn-google-classroom{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.btn-google-classroom.primary{background:#4285f4;color:#fff}.btn-google-classroom.primary:hover{background:#3367d6;box-shadow:0 4px 8px #4285f44d}.btn-google-classroom.primary:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed}.btn-google-classroom.secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.btn-google-classroom.secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-google-classroom.danger{background:#ef4444;color:#fff}.btn-google-classroom.danger:hover{background:#dc2626}@media (max-width:1159px){.google-classroom-modal{padding:10px}.google-classroom-modal-content{max-height:95vh}.google-classroom-modal-header{padding:16px}.google-classroom-modal-header h2{font-size:1.25rem}.google-classroom-modal-body{padding:16px}.google-classroom-modal-footer{flex-direction:column-reverse;gap:8px;padding:16px}.btn-google-classroom{justify-content:center;width:100%}.classroom-items-grid{gap:12px;grid-template-columns:1fr}.import-stats{grid-template-columns:repeat(2,1fr)}.classroom-item{padding:12px}.classroom-item-header{gap:8px}.classroom-item-info h4{font-size:.9rem}.classroom-item-info p{font-size:.8rem}.classroom-meta-tag{font-size:.7rem;padding:1px 6px}}@media (max-width:480px){.google-classroom-modal-header h2{font-size:1.1rem}.classroom-import-summary{padding:12px}.import-stats{grid-template-columns:1fr}.import-stat .number{font-size:1.25rem}}.wizard-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.wizard-container{animation:wizardSlideIn .3s ease-out;background:#fff;border-radius:24px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}@keyframes wizardSlideIn{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.wizard-header{align-items:center;background:linear-gradient(135deg,#7c3aed,#5b21b6);border-radius:24px 24px 0 0;color:#fff;display:flex;justify-content:space-between;padding:24px 32px}.wizard-title-section{align-items:center;display:flex;gap:16px}.wizard-icon{align-items:center;background:#fff3;border-radius:12px;display:flex;font-size:24px;height:48px;justify-content:center;width:48px}.wizard-title{font-size:24px;font-weight:700;line-height:1.2;margin:0}.wizard-subtitle{font-size:16px;line-height:1.4;margin:4px 0 0;opacity:.9}.wizard-close-btn{align-items:center;background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.wizard-close-btn:hover{background:#ffffff4d;transform:scale(1.05)}.wizard-close-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.wizard-progress{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:20px 32px}.progress-bar{background:#e2e8f0;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#7c3aed,#5b21b6);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:#64748b;font-size:14px;font-weight:600;text-align:center}.wizard-content{flex:1 1;min-height:400px;overflow-y:auto;padding:32px}.step-header{margin-bottom:32px;text-align:center}.step-title{color:#1e293b;font-size:28px;font-weight:700;line-height:1.2;margin:0 0 12px}.step-description{color:#64748b;font-size:16px;line-height:1.5;margin:0 auto;max-width:400px}.wizard-step-content{margin:0 auto;max-width:500px}.step-input-group{margin-bottom:24px}.step-label{align-items:center;color:#374151;display:flex;font-size:18px;font-weight:600;gap:8px;margin-bottom:12px}.step-icon{color:#7c3aed;font-size:20px}.step-input,.step-select,.step-textarea{background:#fff;border:2px solid #e2e8f0;border-radius:12px;font-family:inherit;font-size:16px;padding:16px 20px;transition:all .2s ease;width:100%}.step-input:focus,.step-select:focus,.step-textarea:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a;outline:none}.step-input:disabled,.step-select:disabled,.step-textarea:disabled{background:#f8fafc;color:#64748b;cursor:not-allowed}.step-textarea{min-height:120px;resize:vertical}.step-help{color:#64748b;font-size:14px;line-height:1.4;margin:8px 0 0}.culture-selection{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;max-height:300px;overflow-y:auto;padding:20px}.culture-item{margin-bottom:8px}.culture-checkbox{align-items:center;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:12px;padding:12px 16px;transition:all .2s ease}.culture-checkbox:hover{background:#e0e7ff}.culture-checkbox input[type=checkbox]{accent-color:#7c3aed;cursor:pointer;height:18px;width:18px}.culture-checkbox input[type=checkbox]:disabled{cursor:not-allowed}.culture-name{flex:1 1;line-height:1.3}.wizard-errors{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:24px;padding:16px}.wizard-error{color:#dc2626;font-size:14px;font-weight:500;margin-bottom:4px}.wizard-error:last-child{margin-bottom:0}.wizard-navigation{background:#f8fafc;border-top:1px solid #e2e8f0;gap:16px;justify-content:space-between;padding:24px 32px}.wizard-btn,.wizard-navigation{align-items:center;display:flex}.wizard-btn{border:none;border-radius:10px;cursor:pointer;font-size:16px;font-weight:600;gap:8px;justify-content:center;min-width:120px;padding:12px 24px;transition:all .2s ease}.wizard-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.wizard-btn-primary{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff}.wizard-btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #7c3aed66;transform:translateY(-1px)}.wizard-btn-secondary{background:#fff;border:2px solid #e2e8f0;color:#374151}.wizard-btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.wizard-step-indicators{align-items:center;display:flex;gap:8px}.step-indicator{align-items:center;background:#e2e8f0;border-radius:50%;color:#64748b;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;transition:all .2s ease;width:32px}.step-indicator.active{background:#7c3aed;color:#fff;transform:scale(1.1)}.step-indicator.completed{background:#10b981;color:#fff}@media (max-width:640px){.wizard-container{border-radius:16px;margin:10px;max-height:95vh}.wizard-header{border-radius:16px 16px 0 0;padding:20px 24px}.wizard-title{font-size:20px}.wizard-subtitle{font-size:14px}.wizard-content{padding:24px}.step-title{font-size:24px}.wizard-navigation{flex-direction:column;gap:16px;padding:20px 24px}.wizard-step-indicators{order:-1}.wizard-btn{min-width:auto;width:100%}}.wizard-btn:disabled{position:relative}.wizard-btn:disabled:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;content:"";height:16px;margin-left:8px;position:absolute;width:16px}.student-detail{margin:0 auto;max-width:1200px;padding:24px}.student-detail-header{margin-bottom:32px}.header-navigation{margin-bottom:20px}.back-button{align-items:center;background:#0000;border:2px solid #e8e2db;border-radius:8px;color:#2d5016;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .3s ease}.back-button:hover{background:#f7f5f0;border-color:#d4a574}.student-header-card{align-items:center;background:linear-gradient(135deg,#f7f5f0,#e8e2db);border:2px solid #e8e2db;border-radius:16px;box-shadow:0 4px 6px #0000001a;display:flex;gap:24px;padding:32px}.student-avatar-large{align-items:center;background:linear-gradient(135deg,#2d5016,#1e3a0f);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:32px;height:80px;justify-content:center;width:80px}.student-header-info{flex:1 1}.student-header-info h1{color:#2d5016;font-size:32px;font-weight:700;line-height:1.2;margin:0 0 12px}.student-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.badge-grade{background:#e0f7fa;color:#006064}.badge-reading{background:#f3e5f5;color:#4a148c}.badge-age{background:#fff3e0;color:#e65100}.student-summary{color:#6b7280;display:flex;gap:24px}.summary-item{align-items:center;display:flex;font-size:14px;font-weight:500;gap:6px}.student-detail-content{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-top:32px}.detail-section{background:#fff;border:2px solid #e8e2db;border-radius:12px;box-shadow:0 2px 4px #0000000d;overflow:hidden}.section-header{align-items:center;background:linear-gradient(135deg,#f7f5f0,#e8e2db);border-bottom:2px solid #e8e2db;display:flex;gap:12px;padding:20px 24px}.section-header h2{color:#2d5016;font-size:18px;font-weight:700;margin:0}.section-content{padding:24px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{display:flex;flex-direction:column;gap:6px}.info-item label{color:#6b7280;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-item span{color:#374151;font-size:16px;font-weight:500}.contact-info,.date-info{align-items:center;color:#374151;display:flex;gap:8px}.contact-info svg,.date-info svg{color:#9ca3af;font-size:16px}.culture-tags{display:flex;flex-wrap:wrap;gap:8px}.student-classes-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.class-card{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:20px}.class-card:hover{border-color:#d4a574;box-shadow:0 4px 8px #0000001a}.class-card-header{border-bottom:1px solid #e2e8f0;margin-bottom:16px;padding-bottom:12px}.class-card-header h3{color:#2d5016;font-size:16px;font-weight:700;margin:0 0 8px}.class-subject{background:#dbeafe;border-radius:12px;color:#1e40af;font-weight:600}.class-card-info{margin-bottom:12px}.class-info-item{align-items:center;display:flex;font-size:14px;justify-content:space-between;margin-bottom:8px}.class-info-item label{color:#6b7280;font-weight:600}.class-info-item span{color:#374151}.class-description{border-top:1px solid #e2e8f0;margin-top:12px;padding-top:12px}.notes-content{background:#fafafa;border:1px solid #e5e5e5;border-radius:8px;padding:16px}.notes-content p{color:#374151;font-size:14px;line-height:1.6;margin:0;white-space:pre-wrap}.no-data{color:#9ca3af;padding:40px 20px;text-align:center}.no-data svg{font-size:48px;margin-bottom:16px}.no-data h3{color:#6b7280;font-size:16px;font-weight:600;margin:0 0 8px}.no-data p{font-size:14px;margin:0}@media (max-width:1159px){.student-detail{padding:16px}.student-header-card{flex-direction:column;gap:16px;padding:24px;text-align:center}.student-header-info h1{font-size:24px}.student-header-info .student-email,.student-header-info .student-id{font-size:14px}.student-summary{gap:16px;justify-content:center}.student-detail-content{gap:16px;grid-template-columns:1fr;margin-top:24px}.section-title{font-size:18px}.section-content{padding:16px}.info-grid,.student-classes-grid{gap:12px;grid-template-columns:1fr}.class-card{padding:16px}.student-badges{justify-content:center}.header-actions{width:100%}.header-actions .btn{justify-content:center;width:100%}}@media (max-width:480px){.student-detail{padding:12px}.student-header-card{padding:16px}.student-avatar-large{font-size:24px;height:60px;width:60px}.student-header-info h1{font-size:20px}.section-header{padding:16px}.section-header h2{font-size:16px}.section-content{padding:12px}.back-button{font-size:12px;padding:8px 12px}.student-summary{flex-direction:column;gap:8px}.summary-item{justify-content:center}}.loading-spinner{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px}.spinner{animation:spin 1s linear infinite;border:3px solid #e8e2db;border-radius:50%;border-top-color:#d4a574;height:32px;margin-bottom:16px;width:32px}.error-state{color:#6b7280;padding:40px 20px}.error-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:20px}@media (max-width:480px){.error-actions{align-items:center;flex-direction:column}.error-actions .btn{width:200px}}.btn{min-width:-webkit-fit-content;min-width:fit-content;padding:12px 20px}.btn-primary:hover{background:linear-gradient(135deg,#1e3a0f,#2d5016);box-shadow:0 4px 8px #2d50164d;transform:translateY(-1px)}.btn-secondary:hover{border-color:#d4a574}.classes-page{background:#f7f5f0;max-width:100vw}.classes-page,.classes-page .main-content{display:flex;min-height:100vh;overflow-x:hidden}.classes-page .main-content{flex:1 1;flex-direction:column;max-width:100%;width:100%}.classes-section{box-sizing:border-box;max-width:100%;padding:32px;width:100%}.classes-header{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:32px}.stats-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e8e2db;border-radius:12px;box-shadow:0 2px 8px #2d50160f;padding:24px;text-align:center;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 16px #2d50161a;transform:translateY(-2px)}.stat-value{color:#2d5016;font-size:28px;font-weight:700;line-height:1;margin:0}.stat-label{color:#6b7280;font-size:14px;font-weight:500;margin:8px 0 0}.controls-bar{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.search-container{flex:1 1;max-width:400px;position:relative}.search-icon{color:#9ca3af;font-size:20px;left:16px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#fff;border:2px solid #e8e2db;border-radius:8px;font-size:16px;height:48px;padding:0 16px 0 48px;transition:border-color .3s ease;width:100%}.search-input:focus{border-color:#2d5016;outline:none}.controls-right{align-items:center;display:flex;gap:12px}.sort-select{background:#fff;border:2px solid #e8e2db;border-radius:8px;cursor:pointer;font-size:14px;min-width:140px;padding:12px 16px;transition:border-color .3s ease}.sort-select:focus{border-color:#2d5016;outline:none}.view-toggle{background:#fff;border:2px solid #e8e2db;overflow:hidden}.view-toggle-btn{align-items:center;background:#0000;border:none;color:#9ca3af;cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s ease;width:44px}.view-toggle-btn:first-child{border-right:1px solid #e8e2db}.view-toggle-btn:hover{background:#f3f4f6;color:#6b7280}.view-toggle-btn.active{background:#2d5016;color:#fff}.view-toggle-btn.active:hover{background:#1e3a0f}.view-toggle-btn svg{font-size:20px}.classes-grid{grid-gap:24px;gap:24px;margin-bottom:32px}.class-card{background:#fff;border:1px solid #e8e2db;border-radius:16px;box-shadow:0 2px 8px #2d50160f;overflow:hidden;transition:all .3s ease}.class-card:hover{box-shadow:0 8px 24px #2d50161f}.class-card.archived{border-color:#d1d5db;opacity:.7}.class-card.archived .class-name{color:#6b7280}.class-card-header{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:20px 20px 16px}.class-info{flex:1 1}.class-name{color:#1a1a2e;font-size:20px;font-weight:600;line-height:1.2;margin:0 0 4px}.class-subject{background:#2d5016;border-radius:4px;color:#fff;display:inline-block;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.class-actions{display:flex;gap:4px;margin-left:16px}.btn-icon{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.btn-icon:hover{background:#e2e8f0;color:#334155}.btn-icon.btn-danger:hover{background:#fee2e2;border-color:#fecaca;color:#dc2626}.btn-icon.btn-feed{background:#e3f2fd;border-color:#90caf9;color:#1976d2}.btn-icon.btn-feed:hover{background:#bbdefb;border-color:#64b5f6;color:#1565c0}.class-details{padding:0 20px 12px}.detail-item{color:#6b7280;font-size:14px;margin-bottom:8px}.detail-item:last-child{margin-bottom:0}.detail-label{font-weight:500;margin-right:8px;min-width:50px}.detail-icon{color:#9ca3af;height:16px;margin-right:8px;width:16px}.detail-value{color:#374151;font-weight:400}.detail-item.teacher-info{background:#f0f9ff;border-left:3px solid #0284c7;border-radius:6px;margin-bottom:12px;padding:8px 12px}.detail-item.teacher-info.warning{background:#fef3c7;border-left-color:#f59e0b}.detail-item.teacher-info .detail-value strong{color:#0369a1}.detail-item.teacher-info.warning .detail-value strong{color:#d97706}.class-enrollment{background:#f8fafc;border-top:1px solid #e2e8f0;padding:16px 20px}.enrollment-info{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:500;margin-bottom:12px}.enrollment-icon{color:#2d5016;height:18px;margin-right:8px;width:18px}.enrollment-count{color:#2d5016}.enrolled-students{display:flex;flex-wrap:wrap;gap:6px}.student-chip{background:#e0f2fe;color:#0277bd}.more-students,.student-chip{border-radius:12px;font-size:12px;font-weight:500;padding:4px 8px}.more-students{background:#f3f4f6;color:#6b7280}.class-description{border-top:1px solid #f3f4f6;padding:12px 20px}.class-description p{color:#6b7280;font-size:14px;line-height:1.5;margin:0}.class-card-footer{align-items:center;background:#fafbfc;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:16px 20px}.class-status{display:flex;gap:8px}.status-badge{border-radius:12px;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#fef3c7;color:#92400e}.status-badge.archived{background:#f3f4f6;color:#6b7280}.status-badge.google-classroom{align-items:center;background:#e3f2fd;border:1px solid #90caf9;color:#1565c0;display:flex}.status-badge.standalone{background:#fff3e0;border:1px solid #ffb74d;color:#e65100}.classes-list{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.class-list-item{align-items:center;background:#fff;border:1px solid #e8e2db;border-radius:12px;box-shadow:0 1px 3px #2d50160a;cursor:pointer;display:flex;justify-content:space-between;padding:18px 24px;transition:all .2s ease}.class-list-item:hover{border-color:#2d5016;box-shadow:0 4px 12px #2d501614;transform:translateY(-1px)}.class-list-item:focus{outline:2px solid #2d5016;outline-offset:2px}.class-list-item.archived{border-color:#d1d5db;opacity:.7}.list-item-main{flex:1 1;min-width:0}.list-item-title{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:8px}.list-class-name{color:#1a1a2e;font-size:18px;font-weight:600;line-height:1.3;margin:0}.list-subject-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase;white-space:nowrap}.list-subject-badge.subject-math{background:#e3f2fd;border:1px solid #90caf9;color:#1565c0}.list-subject-badge.subject-ela{background:#e3f2fd;border:1px solid #90caf9;color:#1976d2}.list-subject-badge.subject-science{background:#fce4ec;border:1px solid #f48fb1;color:#c2185b}.list-subject-badge.subject-social{background:#fff3e0;border:1px solid #ffcc80;color:#e65100}.list-subject-badge.subject-art{background:#ffebee;border:1px solid #ef9a9a;color:#c62828}.list-subject-badge.subject-music{background:#f3e5f5;border:1px solid #ce93d8;color:#7b1fa2}.list-subject-badge.subject-pe{background:#e8f5e9;border:1px solid #a5d6a7;color:#2e7d32}.list-subject-badge.subject-default{background:#2d5016;border:1px solid #1e3a0f;color:#fff}.list-item-details{align-items:center;color:#6b7280;display:flex;flex-wrap:wrap;font-size:14px;gap:8px 20px}.list-detail-item{align-items:center;display:inline-flex;gap:5px;white-space:nowrap}.list-detail-icon{color:#9ca3af;font-size:16px!important}.list-item-badges{display:flex;flex-shrink:0;gap:8px;margin-left:20px}.list-status-badge{align-items:center;border:1px solid #0000;border-radius:6px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.5px;padding:6px 12px;white-space:nowrap}.list-status-badge.active{background:#dcfce7;border-color:#bbf7d0;color:#166534}.list-status-badge.inactive{background:#fef3c7;border-color:#fde68a;color:#92400e}.list-status-badge.standalone{background:#fff3e0;border-color:#ffcc80;color:#e65100}.empty-state{padding:80px 20px}.empty-icon{color:#d1d5db;font-size:64px;margin-bottom:16px}.empty-state h3{color:#374151;font-size:20px;margin:0 0 8px}.empty-state p{margin:0 auto 24px}.loading-state{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-state .loading-spinner{text-align:center}.loading-state .spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#2d5016;height:40px;margin:0 auto 16px;width:40px}.loading-state p{margin:0}.error-message{align-items:center;background:#fef2f2;display:flex;justify-content:space-between;margin-bottom:24px;padding:16px 20px}.error-message p{font-weight:500}.error-message button{background:none;border:none;color:#dc2626;cursor:pointer;font-size:20px;font-weight:700;line-height:1;padding:0}.modal-overlay{background:#000000bf;padding:20px}.modal-content{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.enrollment-modal{max-width:600px}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:24px 32px}.modal-header h2{color:#1a1a2e;font-size:24px;font-weight:600;margin:0}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:28px;line-height:1;padding:0;transition:color .2s ease}.modal-close:hover{color:#374151}.modal-body{flex:1 1;overflow-y:auto;padding:24px 32px}.modal-actions{border-top:1px solid #e2e8f0;flex-shrink:0;padding:24px 32px}.class-form{flex:1 1;overflow-y:auto;padding:0 32px}.form-errors{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:24px;padding:16px}.form-errors p{color:#dc2626;font-size:14px;margin:0}.form-errors p+p{margin-top:8px}.form-grid{display:flex;flex-direction:column;gap:32px}.form-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.form-section h3{border-bottom:1px solid #e2e8f0;color:#1a1a2e;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:20px}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex-direction:column}.form-group label{color:#374151;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;padding:12px 16px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2d5016;outline:none}.form-group textarea{min-height:80px;resize:vertical}.delete-modal{max-width:500px}.delete-class-name{background:#fef2f2;border-radius:8px;color:#dc2626;font-size:18px;font-weight:600;margin:16px 0;padding:12px;text-align:center}.enrollment-content{max-height:60vh;overflow-y:auto;padding:24px 32px}.enrollment-section{margin-bottom:32px}.enrollment-section:last-child{margin-bottom:0}.enrollment-section h3{color:#374151;font-size:16px;font-weight:600;margin:0 0 16px}.student-list{display:flex;flex-direction:column;gap:8px}.student-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;padding:12px 16px;transition:all .2s ease}.student-item:hover{background:#f1f5f9;border-color:#cbd5e1}.student-info{flex:1 1}.student-name{color:#374151;font-weight:500;margin-right:12px}.student-grade{background:#fff;border-radius:4px;color:#6b7280;font-size:12px;padding:2px 6px}.btn-add,.btn-remove{align-items:center;border:1px solid;border-radius:6px;cursor:pointer;display:flex;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;width:32px}.btn-add{background:#dcfce7;border-color:#bbf7d0;color:#166534}.btn-add:hover{background:#bbf7d0}.btn-remove{background:#fee2e2;border-color:#fecaca;color:#dc2626;font-size:16px}.btn-remove:hover{background:#fecaca}.no-students{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;color:#6b7280;font-style:italic;padding:24px;text-align:center}.btn-danger,.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;line-height:1;padding:12px 24px;text-decoration:none;transition:all .3s ease}.btn-primary:hover:not(:disabled){background:#1e3a0f;box-shadow:0 4px 12px #2d50164d}.btn-primary:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.btn-secondary{background:#f8fafc;border:2px solid #e2e8f0;color:#374151}.btn-secondary:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.btn-secondary:disabled{background:#f9fafb;color:#9ca3af;cursor:not-allowed}.btn-danger{background:#dc2626}.btn-danger:hover:not(:disabled){background:#b91c1c;box-shadow:0 4px 12px #dc26264d}.btn-danger:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}@media (max-width:1200px){.classes-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width:1159px){.classes-page{flex-direction:row;margin:0;padding:0}.classes-page .main-content{flex:1 1;margin-left:0;max-width:100vw;width:100%}.classes-section{margin:0;padding:12px}.classes-header{align-items:stretch;flex-direction:column;gap:16px;margin-bottom:24px}.page-header-content h1{font-size:24px}.page-header-content p{font-size:14px}.header-actions{flex-direction:column;gap:12px;justify-content:center}.header-actions .btn-primary,.header-actions .btn-secondary{justify-content:center;width:100%}.controls-bar{align-items:stretch;flex-direction:column;gap:12px}.search-container{max-width:none}.controls-right{justify-content:space-between;width:100%}.sort-select{flex:1 1;min-width:0}.classes-grid{grid-template-columns:1fr}.class-card-header{align-items:stretch;flex-direction:column;gap:12px}.class-actions{justify-content:center;margin-left:0}.class-list-item{align-items:stretch;flex-direction:column;gap:12px;padding:16px}.list-item-badges{justify-content:flex-start;margin-left:0}.list-item-details{font-size:13px;gap:6px 16px}.list-class-name{font-size:16px}.form-row{gap:16px;grid-template-columns:1fr}.modal-content{margin:20px;max-height:calc(100vh - 40px)}.modal-actions,.modal-body,.modal-header{padding-left:20px;padding-right:20px}.class-form{padding:0 20px}.enrollment-content{padding:20px}}@media (max-width:480px){.stats-cards{grid-template-columns:repeat(2,1fr)}.stat-card{padding:16px}.stat-value{font-size:24px}.class-details{padding:0 16px 12px}.class-card-footer,.class-description,.class-enrollment{padding-left:16px;padding-right:16px}}.class-work-section{margin:0 auto;max-width:1400px}.page-header{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:32px}.page-header-content{display:flex;flex-direction:column}.page-header-content h1{color:#1a1a2e;display:block;font-size:32px;font-weight:700;letter-spacing:-.8px;line-height:1.2;margin:0 0 8px}.page-header-content p{color:#6b7280;display:block;font-size:16px;font-weight:400;line-height:1.4;margin:0;opacity:.8}.header-actions{display:flex;flex-shrink:0;gap:12px}.documents-toolbar{align-items:center;background:#fff;border:1px solid #e8e2db;border-radius:12px;box-shadow:0 2px 8px #2d50160f;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px;padding:16px 20px}.toolbar-left{flex:1 1;min-width:0}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:12px}.toolbar-right{flex-shrink:0}.search-box{align-items:center;background:#f7f5f0;border:1px solid #e8e2db;border-radius:8px;display:flex;flex:1 1;max-width:400px;min-width:220px;padding:8px 12px;transition:all .2s ease}.search-box:focus-within{border-color:#2d5016;box-shadow:0 0 0 3px #2d50161a}.search-box .search-icon{color:#9ca3af;font-size:20px;margin-right:8px}.search-box input{background:#0000;border:none;color:#1a1a2e;font-size:14px;outline:none;width:100%}.search-box input::placeholder{color:#9ca3af}.toolbar-filter,.toolbar-select{min-width:120px}.toolbar-filter .MuiSelect-select,.toolbar-select .MuiSelect-select{background:#f7f5f0;font-size:14px;padding:8px 32px 8px 12px}.toolbar-filter .filter-icon{color:#9ca3af;font-size:18px;margin-right:6px}.view-toggle{align-items:center;background:#f7f5f0;border:1px solid #e8e2db;border-radius:8px;display:flex;padding:2px}.view-toggle-btn{border-radius:6px!important;color:#9ca3af!important;height:36px;transition:all .2s ease!important;width:36px}.view-toggle-btn:hover{background:#e8e2db!important;color:#2d5016!important}.view-toggle-btn.active{background:#2d5016!important;color:#fff!important}.documents-list-container{background:#fff;border:1px solid #e8e2db;border-radius:12px;box-shadow:0 2px 8px #2d50160f;margin-bottom:32px;overflow:hidden}.documents-list-table{border-collapse:collapse;width:100%}.documents-list-table thead{background:#f7f5f0;border-bottom:1px solid #e8e2db}.documents-list-table th{color:#6b7280;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.documents-list-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.documents-list-table tbody tr:last-child{border-bottom:none}.documents-list-table tbody tr:hover{background-color:#fafbfc}.documents-list-table tbody tr.selected{background-color:#e8f5e8}.documents-list-table td{padding:16px;vertical-align:middle}.checkbox-cell{text-align:center;width:48px}.document-cell{min-width:280px}.document-cell-content{align-items:center;display:flex;gap:12px}.document-icon{align-items:center;background:#f3f4f6;border-radius:8px;color:#6b7280;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.document-info{display:flex;flex-direction:column;min-width:0}.document-name{color:#1a1a2e;font-size:15px;font-weight:600;margin-bottom:2px}.document-filename,.document-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.document-filename{color:#9ca3af;font-family:Monaco,Menlo,monospace;font-size:13px}.tags-cell{min-width:200px}.document-tags{display:flex;flex-wrap:wrap;gap:6px}.tag{border-radius:6px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.tag-grade{background:#e8f5e8;border:1px solid #a7c7a1;color:#2d5016}.tag-subject{background:#eef2ff;border:1px solid #c7d2fe;color:#4338ca}.tag-type{background:#f3f4f6;border:1px solid #e5e7eb;color:#374151}.tailored-cell{min-width:100px}.tailored-badge{align-items:center;background:linear-gradient(135deg,#fef3e2,#fff9f0);border:1px solid #f4c430;border-radius:20px;color:#b8860b;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease}.tailored-badge:hover{background:linear-gradient(135deg,#fde9cc,#fef3e2);border-color:#b8860b;transform:translateY(-1px)}.no-tailored{color:#d1d5db;font-size:14px}.uploaded-cell{color:#6b7280;font-size:14px;min-width:110px}.actions-cell{text-align:center;width:48px}.document-row .MuiIconButton-root{color:#9ca3af}.document-row .MuiIconButton-root:hover{background:#2d501614;color:#2d5016}.documents-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-bottom:32px}.document-card{background:#fff;border:1px solid #e8e2db;border-radius:16px;box-shadow:0 2px 8px #2d50160f;overflow:hidden;transition:all .3s ease}.document-card:hover{border-color:#d4a574;box-shadow:0 8px 24px #2d50161f;transform:translateY(-4px)}.document-card-header{border-bottom:1px solid #f3f4f6;padding:20px 20px 16px}.document-card-title{color:#1a1a2e;font-size:20px;font-weight:600;line-height:1.2;margin:0 0 4px}.document-card-filename{color:#6b7280;font-family:Monaco,Menlo,monospace;font-size:14px;margin:0 0 8px;opacity:.8}.document-card-description{color:#374151;font-size:14px;line-height:1.4;margin:8px 0 0}.document-card-content{padding:16px 20px}.document-card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.document-chip{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:12px;color:#374151;font-size:12px;font-weight:500;padding:4px 12px}.document-chip.primary{background:#e8f5e8;border-color:#a7c7a1;color:#2d5016}.document-chip.secondary{background:#fef3e2;border-color:#f4c430;color:#d4a574}.document-card-date{color:#9ca3af;font-size:12px;font-weight:400}.document-card-actions{background:#fafbfc;border-top:1px solid #f3f4f6;display:flex;gap:8px;justify-content:flex-start;padding:16px 20px}.document-action-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .3s ease;width:40px}.document-action-btn:hover{border-color:#2d5016;color:#2d5016;transform:translateY(-2px)}.document-action-btn.error:hover{border-color:#dc2626;color:#dc2626}.document-action-btn.tailored-btn{background:linear-gradient(135deg,#fef3e2,#fff9f0);border-color:#d4a574;color:#b8860b}.document-action-btn.tailored-btn:hover{background:linear-gradient(135deg,#fde9cc,#fef3e2);border-color:#b8860b;color:#8b6914}.empty-state{background:#fff;border:1px solid #e8e2db;border-radius:16px;box-shadow:0 2px 8px #2d50160f;padding:80px 40px}.empty-state-icon{color:#d1d5db;font-size:4rem!important;margin-bottom:24px}.empty-state h3{color:#1a1a2e;font-size:24px;font-weight:600;margin:0 0 12px}.empty-state p{color:#6b7280;font-size:16px;line-height:1.5;margin:0 auto 32px;max-width:400px}.loading-state{padding:80px 40px;text-align:center}.loading-state p{color:#6b7280;font-size:16px;margin-top:20px}.error-state{color:#dc2626;font-size:16px;padding:80px 40px;text-align:center}.error-alert{margin-bottom:24px}.btn{border-radius:8px;padding:12px 24px}.btn-primary{background:#2d5016;border:2px solid #2d5016}.btn-primary:hover{background:#1f3710;border-color:#1f3710;box-shadow:0 4px 12px #2d50164d;transform:translateY(-2px)}.btn-secondary{background:#fff;border:2px solid #e8e2db;color:#2d5016}.btn-secondary:hover{background:#f7f5f0;border-color:#2d5016;transform:translateY(-2px)}@media (max-width:1024px){.documents-toolbar{align-items:stretch;flex-direction:column;gap:12px}.toolbar-left{flex-wrap:wrap}.toolbar-right{flex-wrap:wrap;justify-content:flex-start}.search-box{min-width:100%}.documents-list-container{overflow-x:auto}.documents-list-table{min-width:800px}}@media (max-width:1159px){.class-work-section{padding:16px}.page-header{align-items:stretch;flex-direction:column;gap:16px;margin-bottom:24px}.page-header h1{font-size:24px}.page-header p{font-size:14px}.header-actions{flex-direction:column;gap:12px;justify-content:flex-start}.header-actions button{justify-content:center;width:100%}.documents-toolbar{margin-bottom:16px;padding:12px}.toolbar-filter,.toolbar-select{flex:1 1;min-width:100px}.view-toggle{display:none}.documents-grid{gap:16px;grid-template-columns:1fr}.document-card-actions{justify-content:space-between}}.assignment-dialog{width:100%!important}.assignment-section-title{color:#1a1a2e;font-size:1rem;font-weight:600;margin:0 0 8px}.student-list-container{border:1px solid #e0e0e0;border-radius:8px;max-height:400px;overflow-y:auto}.student-list-header{align-items:center;background:#f5f5f5;border-bottom:1px solid #e0e0e0;display:flex;font-size:.9rem;font-weight:600;gap:12px;padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.student-list-header input[type=\"checkbox\"]{transform:scale(1.2)}.assignment-dialog .student-row{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;padding:12px 16px;transition:background-color .2s ease}.assignment-dialog .student-row:hover{background-color:#f8f9fa}.assignment-dialog .student-row.selected{background-color:#e3f2fd;border-color:#bbdefb}.assignment-dialog .student-row input[type=\"checkbox\"]{margin-right:12px;transform:scale(1.1)}.assignment-dialog .student-info{flex:1 1}.assignment-dialog .student-name{font-size:.95rem;margin-bottom:4px}.assignment-dialog .student-details{display:flex;font-size:.8rem;gap:12px;margin-bottom:4px}.assignment-dialog .student-cultures{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.assignment-dialog .culture-tag{background:#e8f4f8;border-radius:8px;color:#1565c0;font-size:.7rem;font-weight:500;padding:2px 8px}.filter-bar{background:#fafafa;border-bottom:1px solid #e0e0e0;padding:16px}.assignment-dialog .filter-controls{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.assignment-dialog .culture-filter-buttons{display:flex;flex-wrap:wrap;gap:8px}.assignment-dialog .culture-filter-button{font-size:.75rem!important;min-width:auto!important;padding:4px 8px!important}.selected-count{color:#1976d2;font-size:.9rem;font-weight:600;margin-left:auto}@media (max-width:1159px){.assignment-dialog{margin:16px;max-width:95%!important}.filter-controls{flex-direction:column;gap:8px}.culture-filter-buttons{justify-content:flex-start}.student-details{flex-direction:column;gap:4px}.student-list-header,.student-row{padding:8px 12px}}@media (max-width:600px){.assignment-dialog{margin:8px;max-width:100%!important}.assignment-mode-section{padding:16px}.filter-bar{padding:12px}.student-name{font-size:.9rem}.student-details{font-size:.75rem}.culture-tag{font-size:.65rem;padding:1px 6px}.culture-filter-button{font-size:.7rem!important;padding:2px 6px!important}}@media (max-width:480px){.class-work-section{padding:0}.document-card-header{padding:16px 16px 12px}.document-card-actions,.document-card-content{padding:12px 16px}.empty-state{padding:60px 24px}.selected-students-summary{padding:12px}.assignment-section-title{font-size:.9rem}}.confirmation-modal-container{animation:confirmationModalSlide .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #2d501633;max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:100%}@keyframes confirmationModalSlide{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.confirmation-modal-header{align-items:flex-start;background:linear-gradient(135deg,#f7f5f0,#e8e2db);border-bottom:2px solid #e8e2db;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;padding:24px 32px}.confirmation-title-section{align-items:center;display:flex;gap:12px}.confirmation-title{color:#2d5016;font-size:20px;font-weight:700;margin:0}.confirmation-icon{font-size:24px!important}.confirmation-icon.danger{color:#dc2626}.confirmation-icon.warning{color:#d97706}.confirmation-icon.info{color:#2563eb}.confirmation-modal-body{padding:24px 32px}.confirmation-message{color:#374151;font-size:16px;line-height:1.6;margin:0;white-space:pre-line}.confirmation-modal-actions{border-top:1px solid #e8e2db;display:flex;gap:12px;justify-content:flex-end;padding:20px 32px 24px}.btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-width:100px;outline:none;padding:10px 20px;text-decoration:none;transition:all .3s ease;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,#2d5016,#1e3a0f);box-shadow:0 4px 12px #2d501640;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:0 6px 16px #2d501659;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #dc262640;color:#fff}.btn-danger:hover:not(:disabled){box-shadow:0 6px 16px #dc262659;transform:translateY(-1px)}.btn-outline{background:#fff;border:2px solid #e8e2db;color:#374151}.btn-outline:hover:not(:disabled){background:#f7f5f0;border-color:#d4a574;transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:1159px){.confirmation-modal-container{border-radius:12px;margin:20px;max-width:calc(100% - 40px)}.confirmation-modal-header{padding:20px 24px}.confirmation-title{font-size:18px}.confirmation-modal-body{padding:20px 24px}.confirmation-modal-actions{flex-direction:column-reverse;gap:8px;padding:16px 24px 20px}.btn{width:100%}}@media (max-width:480px){.confirmation-modal-body,.confirmation-modal-header{padding:16px 20px}.confirmation-modal-actions{padding:12px 20px 16px}}.btn:disabled{position:relative}.btn:disabled:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;content:"";height:14px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:14px}.btn:disabled:not(:hover):after{display:none}.confirmation-modal-container::-webkit-scrollbar{width:6px}.confirmation-modal-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.confirmation-modal-container::-webkit-scrollbar-thumb{background:#d4a574;border-radius:3px}.confirmation-modal-container::-webkit-scrollbar-thumb:hover{background:#c19660}.assignment-dialog .MuiDialog-container{align-items:center;justify-content:center}.assignment-dialog .MuiPaper-root{max-width:1000px;width:100%}.assignment-dialog .MuiDialogContent-root{padding:0!important}.assignment-dialog .MuiDialogTitle-root{background:#fafafa;border-bottom:1px solid #e0e0e0;padding:24px}.assignment-mode-section{background:#fff;border-bottom:1px solid #e0e0e0;padding:24px}.filter-section{background:#fafafa;border-bottom:1px solid #e0e0e0;padding:16px}.filter-controls{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px}.assignment-dialog .MuiTableHead-root{background:#f5f5f5}.assignment-dialog .MuiTableHead-root .MuiTableCell-root{background:#f5f5f5;border-bottom:2px solid #e0e0e0;font-weight:600}.assignment-dialog .MuiTableContainer-root{overflow-x:hidden!important;width:100%}.assignment-dialog .MuiTable-root{table-layout:auto;width:100%}.assignment-dialog .MuiTableRow-root:hover{background-color:#f8f9fa!important}.assignment-dialog .MuiTableRow-root.Mui-selected{background-color:#e3f2fd!important}.assignment-dialog .MuiTableRow-root.Mui-selected:hover{background-color:#bbdefb!important}.assignment-dialog .MuiChip-root{font-size:.7rem;height:20px;margin:1px}.assignment-dialog .MuiDialogActions-root{background:#fafafa;border-top:1px solid #e0e0e0;padding:16px 24px}.assignment-dialog .empty-state{color:#666;padding:40px 20px;text-align:center}.assignment-dialog .empty-state-icon{color:#ccc;font-size:48px!important;margin-bottom:16px}.assignment-dialog .MuiAutocomplete-root .MuiOutlinedInput-root,.assignment-dialog .MuiOutlinedInput-root{background:#fff}@media (max-width:1159px){.assignment-dialog .MuiPaper-root{margin:16px;max-width:95%}.filter-controls{flex-direction:column;gap:12px}.filter-controls>*{min-width:auto!important;width:100%}.assignment-dialog .MuiDialogTitle-root,.assignment-mode-section{padding:16px}.filter-section{padding:12px}.assignment-dialog .MuiDialogActions-root{flex-direction:column;gap:8px;padding:12px 16px}.assignment-dialog .MuiDialogActions-root>div{align-items:stretch!important;flex-direction:column;gap:8px;width:100%}.assignment-dialog .MuiDialogActions-root .MuiButton-root{margin:0!important}}@media (max-width:600px){.assignment-dialog .MuiPaper-root{margin:8px;max-width:100%}.assignment-dialog .MuiTableCell-root{font-size:.8rem;padding:8px 4px}.assignment-dialog .MuiTableHead-root .MuiTableCell-root{font-size:.75rem}.assignment-dialog .MuiTableCell-root:nth-child(4),.assignment-dialog .MuiTableHead-root .MuiTableCell-root:nth-child(4){display:none}.assignment-dialog .MuiTableCell-root:nth-child(2){width:40%!important}.assignment-dialog .MuiTableCell-root:nth-child(3){width:20%!important}.assignment-dialog .MuiTableCell-root:nth-child(5){width:40%!important}}.assignment-dialog .loading-overlay{align-items:center;background:#fffc;bottom:0;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:1000}.assignment-dialog .selection-summary{align-items:center;color:#666;display:flex;font-size:.9rem;gap:8px}.assignment-dialog .selection-count{color:#1976d2;font-weight:600}.assignment-dialog .MuiCheckbox-root{padding:4px}.assignment-dialog .MuiTableHead-root .MuiCheckbox-root{color:#666}.assignment-dialog .student-name{color:#1a1a2e;font-weight:600}.assignment-dialog .student-details{color:#666;font-size:.75rem;margin-top:2px}.assignment-dialog .tailoring-section{background:#f9f9f9;border-top:1px solid #e0e0e0;padding:16px}.assignment-dialog .tailoring-toggle{align-items:center;display:flex;margin-bottom:16px}.assignment-dialog .tailoring-criteria{padding-left:32px}.assignment-dialog .tailoring-description{color:#666;display:block;font-size:.75rem;margin-bottom:16px}.assignment-dialog .tailoring-checkboxes{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px}.assignment-dialog .MuiSwitch-root{margin-right:8px}.assignment-dialog .language-selector{margin-top:8px}.document-camera-dialog .MuiDialog-paper{overflow:hidden}.document-camera-dialog.fullscreen-camera .MuiDialog-paper{background-color:#000}.camera-dialog-title{background-color:#f8f9fa;background-color:var(--bg-secondary,#f8f9fa);border-bottom:1px solid #e9ecef;border-bottom:1px solid var(--border-color,#e9ecef);padding:12px 16px}.fullscreen-camera .camera-dialog-title{background-color:#000c;border-bottom:none;color:#fff;left:0;position:absolute;right:0;top:0;z-index:10}.fullscreen-camera .camera-dialog-title .MuiIconButton-root,.fullscreen-camera .camera-dialog-title .MuiTypography-root{color:#fff}.camera-dialog-content{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:24px}.camera-dialog-content.camera{background-color:#000;min-height:100%;padding:0}.camera-selection-container{align-items:center;display:flex;flex-direction:column;max-width:400px;padding:24px;text-align:center;width:100%}.camera-selection-title{color:#212529;color:var(--text-primary,#212529);font-weight:600!important;margin-bottom:8px!important}.camera-selection-subtitle{color:#6c757d;color:var(--text-secondary,#6c757d);margin-bottom:32px!important}.camera-selection-buttons{display:flex;flex-direction:column;gap:16px;width:100%}.camera-option-btn{background-color:#2563eb!important;border-radius:12px!important;font-size:1rem!important;padding:16px 24px!important}.camera-option-btn:hover{background-color:#1d4ed8!important}.gallery-option-btn{border-color:#2563eb!important;border-radius:12px!important;color:#2563eb!important;font-size:1rem!important;padding:16px 24px!important}.gallery-option-btn:hover{background-color:#2563eb0a!important;border-color:#1d4ed8!important}.camera-error{background-color:#fef2f2;border-radius:8px;margin-top:16px!important;padding:12px;width:100%}.camera-viewfinder-container{align-items:center;background-color:#000;display:flex;height:100%;justify-content:center;overflow:hidden;position:relative;width:100%}.camera-video{height:100%;object-fit:cover;width:100%}.document-overlay{align-items:center;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0}.document-frame{aspect-ratio:8.5/11;border:3px solid #fff9;border-radius:8px;box-shadow:0 0 0 9999px #00000080,inset 0 0 20px #ffffff1a;max-width:340px;position:relative;width:75%}.corner{border:0 solid #fff;height:30px;position:absolute;width:30px}.corner.top-left{border-left-width:5px;border-top-left-radius:8px;border-top-width:5px;left:-3px;top:-3px}.corner.top-right{border-right-width:5px;border-top-right-radius:8px;border-top-width:5px;right:-3px;top:-3px}.corner.bottom-left{border-bottom-left-radius:8px;border-bottom-width:5px;border-left-width:5px;bottom:-3px;left:-3px}.corner.bottom-right{border-bottom-right-radius:8px;border-bottom-width:5px;border-right-width:5px;bottom:-3px;right:-3px}.guide-text{background-color:#0009;border-radius:20px;bottom:-50px;color:#fff;font-size:14px;font-weight:500;left:50%;padding:8px 16px;position:absolute;text-align:center;text-shadow:0 2px 4px #00000080;transform:translateX(-50%);white-space:nowrap}.camera-controls{align-items:center;bottom:32px;display:flex;gap:32px;justify-content:center;left:0;position:absolute;right:0;z-index:10}.cancel-camera-btn,.flip-camera-btn{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#00000080!important;color:#fff!important;height:50px!important;width:50px!important}.cancel-camera-btn:hover,.flip-camera-btn:hover{background-color:#000000b3!important}.capture-btn{background-color:#fff!important;border:4px solid #fffc!important;box-shadow:0 4px 20px #0000004d!important;color:#2563eb!important;height:72px!important;width:72px!important}.capture-btn:hover{background-color:#f0f0f0!important;transform:scale(1.05)}.capture-btn .MuiSvgIcon-root{font-size:32px!important}.camera-preview-container{align-items:center;display:flex;flex-direction:column;gap:24px;width:100%}.captured-image{border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:400px;max-width:100%;object-fit:contain}.pdf-indicator{align-items:center;background-color:#fef3c7;border:1px solid #f59e0b;border-radius:8px;color:#92400e;display:flex;gap:8px;padding:8px 16px}.pdf-indicator .pdf-icon{color:#dc2626;font-size:20px}.pdf-indicator .MuiTypography-root{color:#92400e;font-weight:500}.preview-controls{display:flex;gap:16px;max-width:400px;width:100%}.confirm-btn,.retake-btn{border-radius:10px!important;flex:1 1;padding:12px 24px!important}.confirm-btn{background-color:#059669!important}.confirm-btn:hover{background-color:#047857!important}@media (max-width:1159px){.camera-dialog-content{min-height:250px;padding:16px}.camera-selection-container{padding:16px}.document-frame{max-width:none;width:85%}.guide-text{bottom:-45px;font-size:12px}.camera-controls{bottom:24px;gap:24px}.cancel-camera-btn,.flip-camera-btn{height:44px!important;width:44px!important}.capture-btn{height:64px!important;width:64px!important}.capture-btn .MuiSvgIcon-root{font-size:28px!important}.captured-image{max-height:300px}.preview-controls{flex-direction:column}}@media (max-width:1159px) and (orientation:landscape){.document-frame{aspect-ratio:8.5/11;height:70%;width:auto}.guide-text{bottom:auto;left:auto;right:-120px;transform:none}.camera-controls{bottom:auto;flex-direction:column;left:auto;right:24px;top:50%;transform:translateY(-50%)}}.capture-btn{animation:pulse 2s infinite}.capture-btn:hover{animation:none}@media (prefers-color-scheme:dark){.camera-dialog-title{background-color:#1f2937;border-bottom-color:#374151}.camera-selection-title{color:#f9fafb!important}.camera-selection-subtitle{color:#9ca3af!important}.camera-error{background-color:#450a0a;color:#fca5a5}}.class-feed-container{margin:0 auto;max-width:800px;padding:24px}.class-feed-header{margin-bottom:32px}.class-feed-posts{margin-top:24px}.class-post-card{border-left:4px solid #0000;transition:all .3s ease}.class-post-card:hover{box-shadow:0 4px 12px #0000001a}.class-post-card.pinned{background-color:#fff8e1;border-left-color:#ff9800}@media (max-width:1159px){.class-feed-container{padding:16px}.class-feed-header h1{font-size:24px}.class-feed-header p{font-size:14px}}@media (max-width:480px){.class-feed-container{padding:12px}}.culture-settings{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.culture-header,.culture-settings{margin-bottom:24px}.culture-header h3{color:#1a1a2e;font-size:1.25rem;font-weight:600;margin:0 0 8px}.culture-header p{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0 0 16px}.add-culture-btn{align-items:center;background:#d4a574;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;padding:10px 16px;transition:all .2s ease}.add-culture-btn:hover{background:#c1956a;transform:translateY(-1px)}.cultures-grid{display:flex;flex-wrap:wrap;gap:12px;min-height:60px}.culture-pill{align-items:center;background:#f8f9fa;border:2px solid #e5e7eb;border-radius:20px;display:flex;gap:8px;max-width:100%;padding:12px 16px;position:relative;transition:all .2s ease}.culture-pill.teacher{background:#f0f9ff;border-color:#bfdbfe}.culture-pill.teacher:hover{background:#e0f2fe;border-color:#93c5fd}.culture-pill.editing,.culture-pill.organization:hover,.culture-pill:hover{background:#fefbf7;border-color:#d4a574}.culture-pill.editing{min-width:300px;padding:16px}.culture-content{gap:12px;justify-content:space-between;width:100%}.culture-content,.culture-info{align-items:center;display:flex}.culture-info{flex:1 1;gap:8px;min-width:0}.culture-name{color:#1a1a2e;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.culture-code{background:#e5e7eb;border-radius:4px;color:#6b7280;font-size:.75rem;padding:2px 6px;white-space:nowrap}.culture-pill .culture-code.teacher{background:#dbeafe;border:1px solid #bfdbfe;color:#1e40af}.culture-pill .culture-code.organization{background:#e5e7eb;color:#6b7280}.culture-description{color:#9ca3af;font-size:.75rem;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.culture-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.culture-type{border-radius:10px;font-size:.65rem;font-weight:600;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase;white-space:nowrap}.culture-type.organization{background:#f3f4f6;border:1px solid #e5e7eb;color:#6b7280}.culture-type.teacher{background:#dbeafe;border:1px solid #bfdbfe;color:#1e40af}.culture-creator{color:#9ca3af;font-size:.7rem;font-style:italic;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.culture-details{display:flex;flex-direction:column;gap:2px;margin-top:4px}.culture-actions{align-items:center;display:flex;gap:4px}.delete-btn,.edit-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.edit-btn{color:#6b7280}.edit-btn:hover{background:#e5e7eb;color:#374151}.delete-btn{color:#9ca3af}.delete-btn:hover{background:#fee2e2;color:#dc2626}.culture-form{display:flex;flex-direction:column;gap:8px;width:100%}.form-input{border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;padding:8px 12px;transition:border-color .2s ease}.form-input:focus{border-color:#d4a574;box-shadow:0 0 0 3px #d4a5741a;outline:none}.code-input{max-width:120px;text-transform:uppercase}.form-actions{display:flex;gap:6px;margin-top:4px}.cancel-btn,.save-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.save-btn{background:#10b981;color:#fff}.save-btn:hover:not(:disabled){background:#059669}.save-btn:disabled{background:#d1d5db;cursor:not-allowed}.cancel-btn{background:#f3f4f6;color:#6b7280}.cancel-btn:hover{background:#e5e7eb;color:#374151}.empty-state{color:#6b7280;padding:40px 20px;text-align:center}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;margin-bottom:16px;padding:12px}.error-message p{font-size:.875rem;margin:0}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.delete-modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:400px;padding:24px;width:90%}.delete-modal h4{color:#1a1a2e;font-size:1.125rem;font-weight:600;margin:0 0 12px}.delete-modal p{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0 0 12px}.delete-modal .warning{background:#fef3c7;border:1px solid #fde68a;border-radius:6px;color:#92400e;padding:12px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.cancel-modal-btn,.confirm-delete-btn{border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;padding:8px 16px;transition:all .2s ease}.confirm-delete-btn{background:#dc2626;color:#fff}.confirm-delete-btn:hover{background:#b91c1c}.cancel-modal-btn{background:#f3f4f6;color:#374151}.cancel-modal-btn:hover{background:#e5e7eb}@media (max-width:1159px){.culture-settings{padding:16px}.culture-pill{flex:1 1}.culture-pill,.culture-pill.editing{min-width:100%}.culture-info{align-items:flex-start;flex-direction:column;gap:4px}.culture-description{max-width:none}.delete-modal{margin:20px;width:auto}}@media (max-width:480px){.culture-settings{padding:12px}.cultures-grid{flex-direction:column}.culture-pill{min-width:100%}.modal-actions{flex-direction:column-reverse}.cancel-modal-btn,.confirm-delete-btn{width:100%}}.settings{background-color:#f8f9fa;display:flex;min-height:100vh}.settings .main-content{display:flex;flex:1 1;flex-direction:column}.settings .content-area{flex:1 1;overflow-y:auto;padding:24px}.settings-container{margin:0 auto;max-width:1200px}.settings-content{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:32px}.settings-content h1{color:#1a1a2e;font-size:2rem;font-weight:600;margin:0 0 8px}.settings-content>p{color:#6b7280;font-size:1rem;line-height:1.5;margin:0 0 32px}.settings-placeholder{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:32px}.placeholder-card{background:#f8f9fa;border:2px dashed #d1d5db;border-radius:8px;padding:24px;text-align:center;transition:all .2s ease}.placeholder-card:hover{background:#fefbf7;border-color:#d4a574}.placeholder-card h3{color:#1a1a2e;font-size:1.125rem;font-weight:600;margin:0 0 8px}.placeholder-card p{color:#6b7280;font-size:.875rem;line-height:1.4;margin:0}.settings-section{margin-top:32px}.settings-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;padding:24px}.demo-section{background:#fffbeb;border:2px solid #fbbf24}.demo-section h3{align-items:center;color:#92400e;display:flex;font-size:1.25rem;font-weight:600;margin:0 0 12px}.demo-section>p{color:#78350f;font-size:.875rem;margin:0 0 20px}.demo-reset-section h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 8px}.demo-reset-section p{color:#4b5563;font-size:.875rem;line-height:1.5;margin:0 0 12px}.demo-message{align-items:center;border-radius:6px;display:flex;font-size:.875rem;font-weight:500;gap:8px;margin:16px 0;padding:12px 16px}.demo-message.success{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.demo-message.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.btn-demo-reset{align-items:center;background:#f59e0b;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:8px;margin-top:16px;padding:12px 20px;transition:all .2s}.btn-demo-reset:hover{background:#d97706;box-shadow:0 4px 8px #f59e0b4d}.btn-demo-reset:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed}.btn-demo-reset:disabled:hover{background:#9ca3af}.google-classroom-section h3{align-items:center;color:#1f2937;display:flex;font-size:1.25rem;font-weight:600;margin:0 0 12px}.google-classroom-section>p{color:#6b7280;font-size:.875rem;margin:0 0 20px}.google-classroom-status{padding-top:8px}.status-loading{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:8px;margin:16px 0}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.connection-status{align-items:center;border-radius:6px;display:flex;font-size:.875rem;font-weight:500;gap:8px;margin:16px 0;padding:12px 16px}.connection-status.connected{background:#dcfce7;border:1px solid #bbf7d0;color:#166534}.connection-status.disconnected{background:#f3f4f6;border:1px solid #e5e7eb;color:#6b7280}.status-warning{align-items:center;background:#fef3c7;border:1px solid #fde68a;border-radius:6px;color:#92400e;display:flex;font-size:.875rem;gap:8px;margin:8px 0;padding:8px 12px}.google-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.btn-connect,.btn-disconnect,.btn-refresh{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:8px;padding:10px 16px;text-decoration:none;transition:all .2s}.btn-connect{background:#10b981;color:#fff}.btn-connect:hover{background:#059669;box-shadow:0 4px 8px #10b9814d}.btn-disconnect{background:#ef4444;color:#fff}.btn-disconnect:hover{background:#dc2626;box-shadow:0 4px 8px #ef44444d}.btn-refresh{background:#6b7280;color:#fff}.btn-refresh:hover{background:#4b5563;box-shadow:0 4px 8px #6b72804d}.btn-connect:disabled,.btn-disconnect:disabled,.btn-refresh:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed}.btn-connect:disabled:hover,.btn-disconnect:disabled:hover,.btn-refresh:disabled:hover{background:#9ca3af}.connection-info{background:#f8f9fa;border:1px solid #e5e7eb;border-radius:6px;margin-top:16px;padding:12px 16px}@media (max-width:1159px){.settings .content-area{padding:16px}.settings-content{border-radius:8px;padding:20px}.settings-content h1{font-size:24px}.settings-placeholder{gap:16px;grid-template-columns:1fr;margin-top:24px}.placeholder-card{padding:20px}.placeholder-card h3{font-size:18px}.placeholder-card p{font-size:14px}}@media (max-width:480px){.settings .content-area{padding:12px}.settings-content{padding:16px}.settings-content h1{font-size:1.5rem}.placeholder-card{padding:16px}}.app-container{display:flex;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column}.user-management{flex:1 1;margin:0 auto;max-width:1200px;padding:24px}.user-management .MuiTableContainer-root{margin-top:16px}.user-management .MuiTableHead-root{background-color:#f5f5f5}.user-management .MuiTableRow-root:hover{background-color:#f9f9f9}.user-management .MuiChip-root{margin:2px}.user-management .MuiDialogContent-root{padding-top:16px}.user-management .MuiFormControl-root,.user-management .MuiTextField-root{margin-bottom:16px}@media (max-width:1159px){.user-management{padding:16px}.user-management .MuiTableContainer-root{overflow-x:auto}.user-management .MuiTable{min-width:600px}.user-management .MuiDialogContent-root{padding:16px}.user-management .MuiGrid-container{margin-top:0}.user-management h4{font-size:20px}.user-management .MuiTypography-h6{font-size:18px}}.session-timeout-dialog .MuiDialog-paper{border-radius:12px;overflow:hidden}.session-timeout-title{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:16px 24px}.session-timeout-title .MuiSvgIcon-root{color:#fff!important}.session-timeout-content{padding:32px 24px!important;text-align:center}.countdown-container{display:flex;justify-content:center;margin-bottom:24px}.countdown-circle{align-items:center;display:flex;justify-content:center;position:relative}.countdown-progress{color:#f59e0b!important;transition:color .3s ease}.countdown-progress.critical{color:#ef4444!important}.countdown-time{font-feature-settings:"tnum";color:#374151;font-variant-numeric:tabular-nums;font-weight:700;position:absolute}.timeout-message{color:#374151;font-size:1.1rem;line-height:1.6}.timeout-progress{background-color:#e5e7eb!important;border-radius:4px;height:8px!important}.timeout-progress .MuiLinearProgress-bar{background:linear-gradient(90deg,#f59e0b,#d97706);border-radius:4px;transition:background .3s ease}.timeout-progress.critical .MuiLinearProgress-bar{background:linear-gradient(90deg,#ef4444,#dc2626)}.session-timeout-actions{border-top:1px solid #e5e7eb;gap:12px;justify-content:center;padding:16px 24px!important}.session-timeout-actions .MuiButton-root{border-radius:8px;font-weight:600;padding:10px 24px;text-transform:none}.session-timeout-actions .MuiButton-contained{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 14px #10b98140}.session-timeout-actions .MuiButton-contained:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 6px 20px #10b98159}@keyframes pulse-warning{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.countdown-circle:has(.countdown-progress.critical){animation:pulse-warning 1s ease-in-out infinite}@media (max-width:480px){.session-timeout-content{padding:24px 16px!important}.countdown-circle .MuiCircularProgress-root{height:100px!important;width:100px!important}.countdown-time{font-size:1.5rem!important}.timeout-message{font-size:1rem}.session-timeout-actions{flex-direction:column;padding:16px!important}.session-timeout-actions .MuiButton-root{width:100%}}.student-login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:2rem;position:relative}.student-login-background{inset:0;opacity:.1;position:absolute;z-index:0}.background-pattern{background-image:repeating-linear-gradient(45deg,#0000,#0000 35px,#ffffff1a 0,#ffffff1a 70px);height:100%;width:100%}.student-login-card{animation:slideUp .6s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;position:relative;width:100%;z-index:1}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.student-login-header{background:linear-gradient(135deg,#1976d2,#1565c0);border-radius:16px 16px 0 0;color:#fff;padding:2.5rem 2rem 2rem;text-align:center}.student-login-logo{align-items:center;display:flex;flex-direction:column;gap:1rem}.student-login-logo h1{font-size:2rem;font-weight:700;margin:0}.student-login-subtitle{font-size:1rem;margin:1rem 0 0;opacity:.95}.student-login-content{padding:2.5rem 2rem}.student-login-content h2{color:#333;font-size:1.75rem;margin:0 0 .5rem}.student-login-description{color:#666;margin-bottom:2rem}.student-login-form{margin-top:1.5rem}.student-login-switch{border-top:1px solid #e0e0e0;margin-top:2rem;padding-top:2rem;text-align:center}.student-login-switch p{color:#666;font-size:.9rem;margin-bottom:.5rem}.student-login-footer{background:#f5f5f5;border-radius:0 0 16px 16px;padding:1.5rem 2rem}.feature-list{display:flex;gap:1rem;justify-content:space-around}.feature-item{align-items:center;color:#666;display:flex;flex-direction:column;font-size:.85rem;gap:.5rem;text-align:center}.feature-icon{font-size:2rem}@media (max-width:600px){.student-login-container{padding:1rem}.student-login-header{padding:2rem 1.5rem 1.5rem}.student-login-logo h1{font-size:1.5rem}.student-login-content{padding:2rem 1.5rem}.student-login-content h2{font-size:1.5rem}.feature-list{flex-direction:column;gap:1.5rem}.feature-item{flex-direction:row;justify-content:center}}.student-dashboard{margin:0 auto;max-width:1200px;padding:2rem}.student-dashboard-header{margin-bottom:3rem;text-align:center}.student-dashboard-header h1{color:#333;font-size:2.5rem;margin-bottom:.5rem}.student-info{color:#666;font-size:1.1rem}.student-dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.dashboard-card{height:100%;transition:transform .2s,box-shadow .2s}.dashboard-card.clickable{cursor:pointer}.dashboard-card.clickable:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.card-icon-header{align-items:center;display:flex;margin-bottom:1rem}@media (max-width:1159px){.student-dashboard{padding:1rem}.student-dashboard-header h1{font-size:2rem}.student-dashboard-grid{gap:1.5rem;grid-template-columns:1fr}}.student-layout{background-color:#f5f5f5;display:flex;min-height:100vh}.student-drawer{height:100%}.student-drawer-header{align-items:center;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;display:flex;gap:1rem;padding:1.5rem 1rem}.student-drawer .MuiListItem-root{border-radius:8px;margin:.25rem .5rem;transition:all .2s}.student-drawer .MuiListItem-root.selected{background-color:#e3f2fd;color:#1976d2}.student-drawer .MuiListItem-root.selected .MuiListItemIcon-root{color:#1976d2}.student-drawer .MuiListItem-root:hover{background-color:#f5f5f5}@media (max-width:600px){.student-drawer-header{padding:1rem}}.student-classes-container{margin:0 auto;max-width:1400px;padding:2rem}.student-classes-header{align-items:center;display:flex;margin-bottom:2rem}.student-classes-header h1{color:#333;font-size:2rem;margin:0}.student-classes-header p{color:#666;margin:.5rem 0 0}.student-classes-loading{gap:1rem;min-height:400px}.no-classes,.student-classes-loading{align-items:center;display:flex;flex-direction:column;justify-content:center}.no-classes{padding:4rem 2rem;text-align:center}.classes-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.class-card{height:100%;transition:transform .2s,box-shadow .2s}.class-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.class-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.class-header h2{flex:1 1;margin:0}.class-details{border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;padding-top:1rem}.detail-item svg{color:#1976d2}@media (max-width:1159px){.student-classes-container{padding:1rem}.student-classes-header{align-items:flex-start;flex-direction:column}.student-classes-header h1{font-size:1.5rem}.classes-grid{gap:1.5rem;grid-template-columns:1fr}}.student-assignments-container{margin:0 auto;max-width:1400px;padding:2rem}.student-assignments-header{gap:2rem;justify-content:space-between;margin-bottom:2rem}.header-title,.student-assignments-header{align-items:center;display:flex}.student-assignments-header h1{color:#333;font-size:2rem;margin:0}.student-assignments-header p{color:#666;margin:.5rem 0 0}.student-assignments-loading{gap:1rem;min-height:400px}.no-assignments,.student-assignments-loading{align-items:center;display:flex;flex-direction:column;justify-content:center}.no-assignments{padding:4rem 2rem;text-align:center}.assignments-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.assignment-card{height:100%;transition:transform .2s,box-shadow .2s}.assignment-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.assignment-card.overdue{border-left:4px solid #d32f2f}.assignment-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.assignment-header h2{flex:1 1;margin:0}.assignment-details{border-bottom:1px solid #e0e0e0;border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:.75rem;margin:1rem 0;padding:1rem 0}.detail-item{align-items:center;color:#666;display:flex;font-size:.9rem;gap:.5rem}.detail-item svg{color:#f57c00}.detail-item strong{color:#333;margin-right:.25rem}.assignment-actions{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}@media (max-width:1159px){.student-assignments-container{padding:1rem}.header-title,.student-assignments-header{align-items:flex-start;flex-direction:column}.student-assignments-header h1{font-size:1.5rem}.assignments-grid{gap:1.5rem;grid-template-columns:1fr}}.diagnostic-assessment-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.diagnostic-card{border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%}.diagnostic-card .MuiCardContent-root{padding:3rem}.diagnostic-icon{animation:pulse 2s ease-in-out infinite;display:flex;justify-content:center;margin-bottom:2rem}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.diagnostic-card h1{color:#333;font-size:2.5rem;margin-bottom:1rem}.diagnostic-card h5{margin-bottom:1.5rem}.features-box{background:#f5f5f5;border-radius:12px;margin:2rem 0;padding:1.5rem}.features-box h6{color:#333;font-weight:600;margin-bottom:1rem}.features-list{list-style:none;margin:0;padding:0}.features-list li{border-bottom:1px solid #e0e0e0;color:#666;font-size:1rem;padding:.75rem 0}.features-list li:last-child{border-bottom:none}.action-box{margin-top:2rem}.action-box button{font-size:1.1rem;font-weight:600;padding:1rem 2rem;text-transform:none}@media (max-width:1159px){.diagnostic-assessment-container{padding:1rem}.diagnostic-card .MuiCardContent-root{padding:2rem 1.5rem}.diagnostic-card h1{font-size:2rem}.diagnostic-card h5{font-size:1.25rem}.features-box{padding:1rem}.features-list li{font-size:.9rem}}.test-container{padding:2rem}.test-container,.test-loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.test-loading{flex-direction:column}.test-card{border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:800px;width:100%}.test-card .MuiCardContent-root{padding:3rem}.question-section{margin:2rem 0}.passage-box{background:#f5f5f5;border-left:4px solid #1976d2;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.passage-text{color:#333;font-size:1.1rem;line-height:1.8}.question-text{color:#333;font-weight:600;margin-bottom:2rem}.option-label{border:2px solid #e0e0e0;border-radius:8px;margin:.75rem 0;padding:1rem;transition:all .2s}.option-label:hover{background-color:#f5f5f5;border-color:#1976d2}.option-label.Mui-checked{background-color:#e3f2fd;border-color:#1976d2}.test-navigation{border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem}.test-navigation button{min-width:150px;padding:.75rem 1.5rem}@media (max-width:1159px){.test-container{padding:1rem}.test-card .MuiCardContent-root{padding:2rem 1.5rem}.passage-box{padding:1rem}.passage-text{font-size:1rem}.question-text{font-size:1.25rem}.test-navigation{flex-direction:column;gap:1rem}.test-navigation button{width:100%}}.App{background:#f7f5f0;min-height:100vh}
/*# sourceMappingURL=main.d5715689.css.map*/