@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800;900&family=Fredoka:wght@400;500;600;700&display=swap";:root{--teal-green: 170 54% 39%;--soft-aqua: 150 57% 64%;--light-mint: 100 72% 76%;--fresh-green: 148 51% 48%;--pastel-green: 140 57% 69%;--background: 0 0% 98%;--foreground: 170 54% 15%;--card: 0 0% 100%;--card-foreground: 170 54% 15%;--popover: 0 0% 100%;--popover-foreground: 170 54% 15%;--primary: 170 54% 39%;--primary-foreground: 0 0% 100%;--secondary: 150 57% 64%;--secondary-foreground: 0 0% 100%;--muted: 170 20% 95%;--muted-foreground: 170 25% 45%;--accent: 148 51% 48%;--accent-foreground: 0 0% 100%;--success: 140 57% 69%;--warning: 45 95% 60%;--destructive: 0 84% 60%;--destructive-foreground: 0 0% 100%;--border: 170 20% 88%;--input: 170 20% 88%;--ring: 170 54% 39%;--radius: .75rem;--gradient-primary: linear-gradient(135deg, hsl(170 54% 39%) 0%, hsl(150 57% 64%) 100%);--gradient-soft: linear-gradient(135deg, hsl(150 57% 64%) 0%, hsl(100 72% 76%) 100%);--gradient-fresh: linear-gradient(135deg, hsl(148 51% 48%) 0%, hsl(140 57% 69%) 100%);--shadow-sm: 0 2px 8px hsla(170, 54%, 39%, .08);--shadow-md: 0 4px 16px hsla(170, 54%, 39%, .12);--shadow-lg: 0 8px 32px hsla(170, 54%, 39%, .16);--transition-smooth: all .3s cubic-bezier(.4, 0, .2, 1)}.dark{--color-background: hsl(222, 47%, 8%);--color-foreground: hsl(210, 40%, 98%);--background-light: hsl(222, 47%, 11%);--background-light-foreground: hsl(210, 40%, 98%);--color-popover: hsl(222, 47%, 11%);--color-popover-foreground: hsl(210, 40%, 98%);--color-primary: hsl(174, 72%, 50%);--color-primary-foreground: hsl(0, 0%, 100%);--color-secondary: hsl(174, 30%, 18%);--color-secondary-foreground: hsl(174, 72%, 70%);--color-muted: hsl(217, 33%, 17%);--color-muted-foreground: hsl(215, 20%, 65%);--color-accent: hsl(16, 90%, 55%);--color-accent-foreground: hsl(0, 0%, 100%);--color-destructive: hsl(0, 63%, 31%);--color-destructive-foreground: hsl(210, 40%, 98%);--color-border: hsl(217, 33%, 17%);--color-input: hsl(217, 33%, 17%);--color-ring: hsl(174, 72%, 50%)}*{margin:0;padding:0;box-sizing:border-box;border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground));font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}@keyframes progressFill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.animate-fade-in-up{animation:fadeInUp .5s ease-out forwards}.animate-scale-in{animation:scaleIn .4s ease-out forwards}.animate-slide-in-right{animation:slideInRight .5s ease-out forwards}.animate-progress-fill{animation:progressFill 1s ease-out forwards}.animate-pulse-subtle{animation:pulse 2s ease-in-out infinite}:root{--teal-green: #2e9780;--soft-aqua: #68dca3;--light-mint: #b0ec99;--fresh-green: #3eb870;--pastel-green: #81dc9c;--color-primary: hsl(174, 72%, 40%);--color-primary-foreground: hsl(0, 0%, 100%);--primary: var(--teal-green);--primary-light: var(--soft-aqua);--primary-dark: #1f6b5c;--secondary: var(--fresh-green);--accent: var(--light-mint);--success: var(--fresh-green);--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--color-background: hsl(210, 40%, 98%);--color-foreground: hsl(222, 47%, 11%);--background-light: #f8fafc;--background-white: #ffffff;--background-gray: #f1f5f9;--background-dark: #1e293b;--text-dark: #1e293b;--text-gray: #64748b;--text-light: #f8fafc;--text-muted: rgba(0, 0, 0, .54);--border-light: #e2e8f0;--border-gray: #cbd5e1;--border-dark: #475569;--color-workshop-1: hsl(174, 72%, 40%);--color-workshop-2: hsl(262, 83%, 58%);--color-workshop-3: hsl(16, 90%, 60%);--color-workshop-4: hsl(142, 72%, 45%);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 2.5rem;--space-3xl: 3rem;--space-4xl: 4rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--font-light: 300;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-extrabold: 800;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--radius-xs: .125rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 50%;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-card: 0 4px 20px -4px hsla(174, 72%, 40%, .15);--shadow-hover: 0 8px 30px -6px hsla(174, 72%, 40%, .25);--shadow-glow: 0 0 30px hsla(174, 72%, 40%, .4);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal: 1040;--z-tooltip: 1050;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--container-xs: 100%;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--container-2xl: 1536px;--font-nunito: "Nunito", sans-serif;--font-fredoka: "Fredoka", sans-serif;--gradient-primary: linear-gradient(135deg, hsl(174, 72%, 40%), hsl(174, 72%, 55%));--gradient-accent: linear-gradient(135deg, hsl(16, 90%, 60%), hsl(45, 93%, 55%));--gradient-success: linear-gradient(135deg, hsl(142, 72%, 45%), hsl(142, 72%, 55%));--gradient-workshop-1: linear-gradient(135deg, hsl(174, 72%, 45%), hsl(190, 80%, 55%));--gradient-workshop-2: linear-gradient(135deg, hsl(262, 83%, 58%), hsl(280, 80%, 65%));--gradient-workshop-3: linear-gradient(135deg, hsl(16, 90%, 60%), hsl(35, 95%, 60%));--gradient-workshop-4: linear-gradient(135deg, hsl(142, 72%, 45%), hsl(160, 75%, 50%))}html{font-size:16px}@media (max-width: 1200px){html{font-size:15px}}@media (max-width: 768px){html{font-size:14px}}@media (max-width: 480px){html{font-size:13px}}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}@media (max-width: 768px){.container{padding:0 .5rem}}.dashboard-layout{display:flex;min-height:100vh}.sidebar-dashboard{width:250px;transition:transform .3s ease}.main-content{flex:1;min-width:0}@media (max-width: 1024px){.sidebar-dashboard{width:200px}}@media (max-width: 768px){.dashboard-layout{flex-direction:column}.sidebar-dashboard{width:280px;height:100vh;position:fixed;top:0;left:0;z-index:1000;transform:translate(-100%);background-color:#fff;box-shadow:2px 0 5px #0000001a;transition:transform .3s ease}.sidebar-dashboard.open{transform:translate(0)}.main-content{padding-top:60px}.mobile-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:999}}.mobile-nav-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:1001;background-color:var(--primary);color:#fff;border:none;padding:.5rem;border-radius:var(--radius-sm);cursor:pointer}@media (max-width: 768px){.mobile-nav-toggle{display:block}}.card{padding:1.5rem;border-radius:var(--radius-sm);box-shadow:0 2px 4px #0000001a;background-color:#fff}@media (max-width: 768px){.card{padding:1rem;margin-bottom:1rem}}.grid{display:grid;gap:1.5rem}.grid-1{grid-template-columns:1fr}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-4{grid-template-columns:repeat(3,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.grid{gap:1rem}}.btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background-color:var(--secondary);color:#fff}.btn-primary{background-color:var(--primary);color:#fff}.btn-primary:hover{background-color:var(--primary-light)}.btn-secondary{background-color:var(--secondary);color:#fff}.btn-outline{background-color:transparent;border:2px solid var(--primary);color:var(--primary)}.btn-outline:hover{background-color:var(--primary);color:#fff}@media (max-width: 768px){.btn{padding:.5rem 1rem;font-size:.9rem}}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-dark)}.form-input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:var(--radius-sm);font-size:1rem;transition:border-color .3s ease}.form-input:focus{outline:none;border-color:var(--primary)}@media (max-width: 768px){.form-input{padding:.5rem .75rem;font-size:.9rem}}.hero{padding-block:0 1rem;text-align:center}.hero h1{font-size:3rem;margin-bottom:1rem}.hero p{font-size:1.2rem;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}@media (max-width: 1024px){.hero{padding:3rem 0}.hero h1{font-size:2.5rem}.hero p{font-size:1.1rem}}@media (max-width: 768px){.hero{padding:2rem 0}.hero h1{font-size:2rem}.hero p{font-size:1rem;padding:0 1rem}}@media (max-width: 480px){.hero h1{font-size:1.8rem}.hero p{font-size:.9rem}}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;background-color:#fff;box-shadow:0 2px 4px #0000001a}.navbar-brand{font-size:1.5rem;font-weight:700;color:var(--primary)}.navbar-nav{display:flex;list-style:none;margin:0;padding:0;gap:2rem}.navbar-nav a{text-decoration:none;color:var(--text-dark);font-weight:500;transition:color .3s ease}.navbar-nav a:hover{color:var(--primary)}.navbar-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer}@media (max-width: 768px){.navbar-nav{position:fixed;top:100%;left:0;width:100%;background-color:#fff;flex-direction:column;padding:1rem;box-shadow:0 2px 4px #0000001a;transform:translateY(-100%);transition:transform .3s ease;gap:1rem}.navbar-nav.open{transform:translateY(0)}.navbar-toggle{display:block}}.footer{background-color:var(--text-dark);color:var(--text-light);padding:3rem 0 1rem}.footer-content{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;margin-bottom:2rem}.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid #374151}@media (max-width: 1024px){.footer-content{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.footer{padding:2rem 0 1rem}.footer-content{grid-template-columns:1fr;gap:1.5rem}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.d-flex{display:flex}.d-block{display:block}.d-none{display:none}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.align-center{align-items:center}.mb-1{margin-bottom:var(--space-sm)}.mb-2{margin-bottom:var(--space-md)}.mb-3{margin-bottom:var(--space-lg)}.mb-4{margin-bottom:var(--space-xl)}.mt-1{margin-top:var(--space-sm)}.mt-2{margin-top:var(--space-md)}.mt-3{margin-top:var(--space-lg)}.mt-4{margin-top:var(--space-xl)}.p-1{padding:var(--space-sm)}.p-2{padding:var(--space-md)}.p-3{padding:var(--space-lg)}.p-4{padding:var(--space-xl)}@media (max-width: 768px){.d-md-none{display:none}.d-md-block{display:block}}@media (max-width: 480px){.d-sm-none{display:none}.d-sm-block{display:block}}.navbar-landing{width:100%;min-height:100px;position:relative;z-index:10}.navbar-landing:before{content:"";position:absolute;width:30vw;height:20vw;top:-26vh;right:-4%;background-color:#43937b;z-index:1;transform:rotate(170deg);border-radius:6.5em}.navbar-inner{padding:0 40px;height:15vh;display:flex;align-items:center;justify-content:space-between;position:relative}.navbar-logo{display:flex;align-items:center;text-decoration:none;z-index:2;width:10vw;margin-top:3em;position:relative}.navbar-logo img{width:100%;height:100%;margin-top:5em}.navbar-links{display:flex;align-items:center;justify-content:space-between;width:50%;z-index:2}.navbar-link{color:#333;text-decoration:none;font-weight:700;font-size:18px;padding-bottom:4px;position:relative;z-index:10;width:auto}.navbar-link:after{content:"";position:absolute;height:40%;width:100%;bottom:.3em;left:0;z-index:-1;background:linear-gradient(0deg,var(--primary-light),var(--accent));background-size:0% 100%;background-repeat:no-repeat;background-position:left bottom;transition:background-size .3s ease}.navbar-link:hover:after,.navbar-link:focus:after{background-size:100% 100%}.navbar-link:hover,.navbar-link:focus{color:var(--primary)}.navbar-actions-wrapper{position:relative;height:100%;display:flex;align-items:center;justify-content:flex-end;width:25%}.navbar-actions{position:relative;display:flex;align-items:center;gap:24px;z-index:2;padding-right:none;margin-left:50px}.navbar-login{color:#fff;background:transparent;border:none;font-weight:500;font-size:18px;transition:.3s}.navbar-login:hover{cursor:pointer;text-shadow:0 0 15px #fff}.navbar-register{padding:.5rem .75rem;border:none;background-color:#fff;color:var(--primary-light);border-radius:8px;display:flex;justify-content:center;font-weight:500;font-size:18px;transition:.3s;text-decoration:none}.navbar-register:hover{cursor:pointer;transform:translateY(-.25em);box-shadow:0 .25em #0000006b}@media (max-width: 1024px){.navbar-inner{padding:0 20px}.navbar-links{gap:20px;margin-left:30px}.navbar-angled-bg{width:300px}}@media (max-width: 900px){.navbar-links{display:none}.navbar-burger{display:flex;flex-direction:column;gap:6px;cursor:pointer;width:32px;height:32px;justify-content:center;align-items:center;margin-left:20px;z-index:20}.navbar-burger span{display:block;width:26px;height:3px;background:#3ca381;border-radius:2px;transition:all .3s}}@media (max-width: 600px){.navbar-inner{height:80px;padding:0 8px}.navbar-logo img{width:40px;height:40px}.navbar-logo span{font-size:1.1rem}.navbar-angled-bg{height:80px;width:120px;border-top-left-radius:30px;border-bottom-left-radius:30px}.navbar-actions{gap:10px;padding-right:10px}.navbar-register{padding:6px 18px;font-size:.9rem}}.hero-section{min-height:85vh;position:relative;display:flex;align-items:center;padding:4em 0;margin-bottom:20vh}.hero-section:before{content:"";position:absolute;background-color:#e3f5e5;width:105vw;height:115vh;top:-45%;z-index:1;border-radius:5rem;transform:rotate(170deg);border-radius:6.5em}.hero-container{max-width:80vw;margin:0 auto;padding:0 20px;position:relative;z-index:2;width:100%;height:65vh}.hero-content{display:flex;align-items:center;gap:80px}.hero-text{flex:1;max-width:500px}.hero-title{width:8em;font-size:4rem;font-weight:700;line-height:1.1;color:#1a1a1a;margin:0 0 24px;letter-spacing:-.02em}.highlight{color:#2e9780;position:relative}.hero-description{font-size:var(--text-base);line-height:1.6;color:#6b7280;margin-bottom:1em;max-width:30em}.cta-button{background:#81dc9c;color:#000;border:none;padding:9px 19px;border-radius:8px;font-size:1.3em;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;margin-bottom:1em;justify-content:space-between;width:80%}.cta-button:hover{background:#22c55e;transform:translateY(-2px);box-shadow:0 8px 20px #22c55e4d}.arrow{font-size:34px;transition:transform .3s ease;width:30%}.cta-button:hover .arrow{transform:translate(4px)}.features{display:grid;grid-template-columns:1fr 1fr;gap:2em;max-width:25em}.feature-item{display:flex;align-items:center;gap:12px;font-size:14px;color:#374151;font-weight:500}.feature-icon{width:4em;height:4em;background:#4ade801a;border-radius:6px;display:flex;align-items:center;justify-content:center;color:#4ade80;flex-shrink:0}.feature-icon svg{width:2em;height:2em}.hero-visual{flex:1;display:flex;justify-content:center;align-items:center}.dashboard-mockup{background:#fff;border-radius:16px;padding:32px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:30vw;position:relative;animation:slide 5s ease-in-out infinite;animation-direction:alternate;margin-left:10em}.dashboard-mockup:before{content:"";position:absolute;top:-3em;left:-3em;width:6em;height:6em;background:linear-gradient(135deg,#4ade80,#22c55e);border-radius:50%;opacity:.1;z-index:-1}.dashboard-header{background:linear-gradient(90deg,var(--primary),var(--primary-light));padding:1em;border-radius:.725rem}.dashboard-header h3{font-size:var(--text-lg);font-weight:600;color:#fff;border-radius:var(--radius-md)}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.progress-label{font-size:13px;color:#6b7280;font-weight:500}.progress-percentage{font-size:13px;color:#1f2937;font-weight:600}.progress-bar{width:100%;height:10px;background:#f3f4f6;border-radius:5px;overflow:hidden;margin-bottom:16px}.progress-fill{width:90%;height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);border-radius:5px;transition:width .3s ease}.milestone-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.milestone-label{font-size:13px;color:#6b7280;font-weight:500}.milestone-percentage{font-size:13px;color:#1f2937;font-weight:600}.dashboard-stats{display:flex;gap:20px;margin-top:2em}.stat-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;background:#b0ec9946;border-radius:12px;height:10em}.dashboard-stats .stat-item:nth-child(2){background:#68dca446}.stat-icon{color:#fff;width:5em;height:5em}.stat-icon.activity{color:#fff}.stat-item span{font-size:1.5rem;color:#6b7280;font-weight:500;text-align:center}@media (max-width: 968px){.hero-content{flex-direction:column;gap:40px;text-align:center}.hero-title{font-size:48px}.features{max-width:none;justify-content:center}}@media (max-width: 768px){.hero-section{padding:40px 0}.hero-container{padding:0 16px}.hero-title{font-size:40px}.hero-description{font-size:14px}.dashboard-mockup{width:340px;padding:28px}.features{grid-template-columns:1fr;gap:16px}}@media (max-width: 480px){.hero-title{font-size:32px}.dashboard-mockup{width:100%;max-width:280px}.cta-button{width:100%;justify-content:center}}@keyframes slide{0%,to{transform:translateY(0)}25%{transform:translateY(-2em)}75%{transform:translateY(2em)}}.features-section{position:relative;margin-bottom:37vh}.features-container{max-width:1200px;margin:0 auto;padding:0 20px}.features-header{text-align:center;margin-bottom:5em}.title-h1{display:flex;justify-content:center}.features-title{font-size:48px;font-weight:700;color:#1a1a1a;margin:0 0 16px;letter-spacing:-.02em}.features-description{font-size:1.5rem;color:#6b7280;max-width:500px;margin:0 auto;line-height:1.6}.features-gridd{display:grid;grid-template-columns:repeat(2,1fr);gap:10em 5em}.feature-row{display:flex;gap:4em;align-items:center;justify-content:flex-start}.feature-card{border-radius:20px;padding:40px 30px;text-align:center;transition:transform .3s ease;display:flex;flex-direction:column;align-items:center}.feature-icon-wrapper{margin-bottom:32px;position:relative}.feature-icon-border{width:17em;height:10em;border:2px solid #b4edd1;border-radius:16px;display:flex;align-items:center;justify-content:center;position:relative;background:#fff;transform:rotate(45deg);transition:all .3s ease}.feature-card:hover .feature-icon-border{border-color:#4ade80;transform:rotate(45deg) scale(1.05);box-shadow:0 10px 25px #4ade8026}.feature-icon-container{width:80px;height:80px;display:flex;align-items:center;justify-content:center;transform:rotate(-45deg);position:relative;z-index:2}.feature-icon-image{width:10em;height:5em;object-fit:contain;filter:grayscale(100%);transition:filter .3s ease;transform:rotate(-45deg)}.feature-card:hover .feature-icon-image{filter:grayscale(0%)}.feature-accent{position:absolute;bottom:1.5em;right:-.7em;width:1.5em;height:1.5em;background:#68dca3;border-radius:2px;transform:rotate(180deg);z-index:3}.feature-content{text-align:center}.feature-number{font-size:3rem;font-weight:700;color:#1a1a1a;letter-spacing:-.02em}.feature-label{font-size:1.5rem;color:#6b7280;font-weight:500;line-height:1.4}@media (max-width: 768px){.features-section{padding:80px 0}.features-container{padding:0 16px}.features-title{font-size:36px}.features-description{font-size:16px}.features-header{margin-bottom:60px}.features-grid{grid-template-columns:1fr;gap:50px;max-width:400px}.feature-icon-border{width:100px;height:100px}.feature-icon-container{width:70px;height:70px}.feature-icon-image{width:35px;height:35px}.feature-number{font-size:32px}.feature-label{font-size:15px}}@media (max-width: 480px){.features-section{padding:60px 0}.features-title{font-size:28px}.features-description{font-size:14px}.features-grid{gap:40px}.feature-icon-border{width:90px;height:90px}.feature-icon-container{width:60px;height:60px}.feature-icon-image{width:30px;height:30px}.feature-number{font-size:28px}.feature-label{font-size:14px}}.explore-section{background:linear-gradient(180deg,#68dca3,#9de7c177 70%,#fff0);margin-bottom:30vh}.header{padding-block:5vh 10vh;position:relative;overflow:hidden}.header:after{content:"";position:absolute;width:30vw;height:50vh;background:#3e8b70;top:-35vh;border-radius:20%;left:-8vw;z-index:0;transform:rotate(10deg)}.explore-head{position:relative;z-index:1;font-size:2vw;font-weight:700;color:#fff;margin-left:2vh}.hero{display:inline-block;position:relative;width:25em;min-width:27em;height:33em;border-radius:30px;overflow:hidden;box-shadow:5px 5px 30px #0000004d;margin:30px}.image{height:70%;width:100%;object-fit:cover;object-position:center;display:block}.text{background-image:linear-gradient(180deg,#68dca4 -10%,#2e9780);border-radius:21px;position:absolute;top:50%;left:-5px;height:70%;width:110%;transform:skew(19deg,-9deg)}.rating-people{color:#fff;font-size:1.2rem;display:flex;align-items:center;padding-top:.2em}.second .text{background-image:linear-gradient(-20deg,#bb7413,#e7d25c)}.progress-course{position:relative;padding-inline:2em;margin-top:-2%}.specialite-course{position:absolute;top:5%;right:5%;width:fit-content;padding:.5em 1em;background:linear-gradient(0deg,#62d49f,#52c196);box-shadow:0 0 15px #81dc9c;color:#fff;border-radius:5px;text-shadow:0 0 5px #fff}.rating{position:relative;display:flex;align-items:center;margin-top:5%;margin-bottom:2%;padding-inline:2em;gap:1em}.logo{height:5em;width:5em;border-radius:1em;background-color:#fff;position:absolute;bottom:40%;left:30px;overflow:hidden;box-shadow:5px 5px 30px 2px #000000b3}.logo img{height:100%;width:100%;object-fit:cover}.main-text{position:absolute;color:#fff;font-weight:900;left:150px;top:52%;bottom:26%;width:62%}.hero-btn{position:absolute;color:#fff;right:30px;bottom:10%;padding:10px 20px;border:1px solid #fff;animation:button-anim 2s ease 0s infinite normal forwards}.hero-btn:hover{animation:none}.hero-btn a{color:#fff}.date{position:absolute;color:#fff;left:30px;bottom:10%}.buttons-section-card{position:relative;display:flex;align-items:center;padding-inline:2em;gap:1em;justify-content:space-between}.buttons-section-card .outline-button{color:#fff;border:1px solid #fff}.carousel-container{position:relative;width:100vw;max-width:88vw;margin-inline:auto;padding:1rem 0}.carousel-track{display:flex;gap:1.5rem;overflow-x:auto;scroll-behavior:smooth;scroll-snap-type:x mandatory;padding:1rem}.carousel-track::-webkit-scrollbar{display:none}.carousel-card{flex:0 0 280px;scroll-snap-align:start;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column}.carousel-card img{width:100%;height:180px;object-fit:cover}.carousel-card h2{font-size:1.1rem;margin:.75rem 1rem .25rem}.carousel-card p{font-size:.85rem;margin:0 1rem .75rem}.carousel-card a{margin:auto 1rem 1rem;font-size:.8rem;color:#007acc;text-decoration:none;border:1px solid #007acc;padding:.3rem .6rem;border-radius:5px}.carousel-card a:hover{background:#007acc;color:#fff}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:2.5rem;height:2.5rem;border:none;border-radius:50%;background:#0009;color:#fff;font-size:1.5rem;cursor:pointer;z-index:1;margin-inline:-3em}.carousel-btn.prev{left:.5rem}.carousel-btn.next{right:-.5rem}.interactive-section{flex-direction:column;justify-content:center!important;margin-block:10vh!important;height:90vh!important;gap:10%}.il-hero-row{display:flex;align-items:center;justify-content:center;gap:40px;margin-top:24px;margin-left:8rem}.il-hero-img{width:13vw;height:auto;margin-top:10px}.il-title{font-size:4rem;font-weight:700;line-height:1.5;color:#111;margin:0;font-family:Poppins,sans-serif;display:flex;align-items:center}.il-cards-row{display:flex;justify-content:center;gap:5em;flex-wrap:wrap}.il-card{background:#d6ffdd;border-radius:12px;box-shadow:0 1px 10px #11111146;width:20vw;height:100%;display:flex;flex-direction:column;align-items:center;padding:2em;transition:.2s}.il-card:hover{transform:scale(1.1);box-shadow:0 1px 15px #11111146}.il-card:hover .il-card-img{transform:translateY(-3vh)}.il-card:nth-child(1){background:#dff6e4}.il-card:nth-child(3){background:#e2f7e4}.il-card-img{width:15em;object-fit:contain;margin-bottom:1em;transition:.4s}.il-card h3{font-size:2rem;font-weight:600;color:#222;font-family:Poppins,sans-serif;text-align:center}.il-card p{font-size:1rem;color:#555;text-align:start;font-family:Poppins,sans-serif;line-height:1.5;margin-top:1em}.woman-reading{position:relative;width:100%;height:100%}.woman-figure{position:absolute;left:50px;top:20px}.woman-head{width:45px;height:50px;background:#fdbcb4;border-radius:50% 50% 45% 45%;position:relative;z-index:3}.woman-hair{width:60px;height:55px;background:#2c2c2c;border-radius:50% 50% 30% 30%;position:absolute;top:-15px;left:-7px;z-index:2}.woman-hair:before{content:"";position:absolute;top:25px;right:-15px;width:25px;height:30px;background:#2c2c2c;border-radius:50%;transform:rotate(45deg)}.woman-body{width:80px;height:90px;background:coral;border-radius:40px 40px 20px 20px;position:absolute;top:35px;left:-17px;z-index:1}.woman-legs{width:70px;height:40px;background:#87ceeb;border-radius:35px 35px 15px 15px;position:absolute;top:115px;left:-12px}.book{position:absolute;right:10px;top:60px;z-index:4}.book-pages{width:35px;height:45px;background:#fff;border:2px solid #ddd;border-radius:3px;position:relative}.book-cover{width:32px;height:42px;background:#90ee90;border-radius:3px;position:absolute;top:1px;left:1px;transform:perspective(100px) rotateY(-15deg)}.floating-elements{position:absolute;width:100%;height:100%}.leaf{position:absolute;width:12px;height:8px;background:#90ee90;border-radius:50% 10px;animation:float 3s ease-in-out infinite}.leaf-1{top:10px;right:80px;animation-delay:-1s}.leaf-2{top:40px;right:120px;animation-delay:-2s;transform:rotate(45deg)}.sparkle{position:absolute;width:8px;height:8px;background:gold;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);animation:sparkle 2s ease-in-out infinite}.sparkle-1{top:180px;left:20px;animation-delay:-.5s}.sparkle-2{top:200px;right:30px;animation-delay:-1.5s}.hero-text{flex:1}.interactive-title{font-size:3rem;font-weight:800;color:#2c3e50;line-height:1.2;margin:0;letter-spacing:-.02em}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}.feature-card{background:#e8f5e8;border-radius:20px;padding:40px 30px;text-align:center;transition:transform .3s ease;display:flex;flex-direction:column;align-items:center}.feature-card:hover{transform:translateY(-8px)}.feature-illustration{height:120px;margin-bottom:30px;position:relative;display:flex;align-items:center;justify-content:center}.feature-img{max-height:100%;max-width:100%;width:100px;object-fit:contain}.learning-icon{position:relative;width:100px;height:100px}.book-stack{position:absolute;left:20px;top:30px}.book{width:40px;height:50px;border-radius:4px;position:absolute}.book-blue{background:#4a90e2;transform:rotate(-10deg);z-index:1}.book-purple{background:#7b68ee;transform:rotate(5deg);top:-5px;left:5px;z-index:2}.letter-a{position:absolute;right:15px;top:10px;width:35px;height:35px;background:#6c5ce7;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;z-index:3}.progress-circle{position:absolute;bottom:10px;left:10px;width:25px;height:25px;border:3px solid #74b9ff;border-top:3px solid transparent;border-radius:50%;z-index:3}.floating-shapes .shape{position:absolute;border-radius:50%}.shape-pink{width:15px;height:15px;background:#fd79a8;top:0;right:0}.shape-orange{width:20px;height:20px;background:#fdcb6e;bottom:0;right:10px;border-radius:20%}.analytics-icon{position:relative;width:100px;height:100px}.chat-bubble{position:absolute;left:15px;top:15px;width:40px;height:35px;background:#ff7675;border-radius:50%;display:flex;align-items:center;justify-content:center}.happy-face{width:20px;height:20px;background:#ffeaa7;border-radius:50%;position:relative}.happy-face:before{content:"";position:absolute;top:6px;left:5px;width:2px;height:2px;background:#2d3436;border-radius:50%;box-shadow:6px 0 #2d3436}.happy-face:after{content:"";position:absolute;bottom:4px;left:6px;width:8px;height:4px;border:1px solid #2d3436;border-top:none;border-radius:0 0 8px 8px}.chart-container{position:absolute;right:10px;top:20px;width:50px;height:50px}.pie-chart{width:40px;height:40px;border-radius:50%;position:relative;overflow:hidden}.pie-slice{position:absolute;width:50%;height:50%;transform-origin:right bottom}.slice-1{background:#00b894;transform:rotate(0);border-radius:40px 0 0}.slice-2{background:#74b9ff;transform:rotate(120deg);border-radius:40px 0 0}.slice-3{background:#a29bfe;transform:rotate(240deg);border-radius:40px 0 0}.analytics-icon .floating-elements .element{position:absolute;border-radius:50%}.element-1{width:12px;height:12px;background:#00cec9;top:5px;right:5px}.element-2{width:8px;height:8px;background:#e17055;bottom:5px;left:5px}.search-icon{position:relative;width:100px;height:100px}.document{position:absolute;left:10px;top:10px;width:50px;height:60px;background:#74b9ff;border-radius:8px;padding:8px}.doc-lines{width:100%;height:20px;background:repeating-linear-gradient(transparent,transparent 2px,rgba(255,255,255,.3) 2px,rgba(255,255,255,.3) 4px);margin-bottom:8px}.doc-graph{position:relative;height:20px}.graph-line{position:absolute;bottom:0;left:0;right:0;height:2px;background:#fff;transform:rotate(15deg)}.graph-dots{display:flex;justify-content:space-between;align-items:end;height:100%;padding:0 5px}.dot{width:4px;height:4px;background:#fff;border-radius:50%}.magnifier{position:absolute;right:5px;bottom:15px}.magnifier-glass{width:30px;height:30px;border:3px solid #fdcb6e;border-radius:50%;position:relative}.magnifier-handle{position:absolute;bottom:-8px;right:-8px;width:15px;height:3px;background:#fdcb6e;border-radius:2px;transform:rotate(45deg)}.floating-circle{position:absolute;top:0;right:15px;width:15px;height:15px;background:#a29bfe;border-radius:50%}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes sparkle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}@media (max-width: 768px){.interactive-content{padding:40px 20px}.hero-section{flex-direction:column;text-align:center;gap:30px}.hero-illustration{flex:none}.interactive-title{font-size:2.2rem}.features-grid{grid-template-columns:1fr;gap:20px}.feature-card{padding:30px 20px}}@media (max-width: 480px){.interactive-title{font-size:1.8rem}.feature-illustration{height:100px}}@media (max-width: 900px){.il-hero-row{flex-direction:column;align-items:center;gap:20px;text-align:center}.il-title{font-size:2rem;justify-content:center}.il-cards-row{flex-direction:column;align-items:center;gap:24px}.il-card{width:90%;min-width:0}}.education-banner{background-image:url(src/assets/Image/Rectangle3.png);background-color:#3b8068;position:relative;height:60vh;margin-block:50vh}.education-content{display:flex;align-items:center;height:100%;justify-content:space-between}.images-section{flex:1;position:relative;width:40%;height:100%;display:flex;align-items:center;justify-content:center}.image-grid{height:80%;width:45%;display:flex;flex-direction:column;justify-content:center}.image-card{border-radius:20px;box-shadow:0 15px 40px #0003;overflow:hidden}.image-card img{border-radius:12px;width:100%;height:100%;object-fit:cover;display:block}.card-1{align-self:flex-end;transform:scale(2.1) translateY(-30%) rotate(45deg)}.card-2{transform:scale(1.5) translateY(30%) rotate(45deg)}.card-3{align-self:flex-end;transform:scale(2.3) translateY(30%) rotate(45deg)}.card-rotated{overflow:hidden;position:relative;border-radius:2em;box-shadow:0 2px 8px #0002;width:7vw;height:7vw;display:flex;justify-content:center;align-items:center}.card-rotated img{width:150%;height:150%;object-fit:cover;transform:rotate(-45deg)}.content-section{flex:1;display:flex;align-items:center}.content-wrapper{width:100%;display:flex;padding:2rem 0;flex-direction:column;gap:2em}.main-title{font-size:3.5rem;font-weight:700;line-height:1.2;color:#fff;margin-bottom:30px;width:fit-content;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.highlighted-text{background:linear-gradient(45deg,#ffc107,#ff9800);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;display:inline-block}.highlighted-text:after{content:"";position:absolute;bottom:0;left:0;right:0;height:.2em;background:linear-gradient(45deg,#ffc107,#ff9800)}.description{color:#ffffffe6;font-size:1.2rem;line-height:1.6;margin-bottom:40px;max-width:40ch}.join-btn{background:#fff;color:#4a9b8f;border:none;border-radius:.5em;padding:20px 40px;font-weight:600;font-size:1.2rem;letter-spacing:.5px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #00000026;text-transform:uppercase;width:15em}.join-btn a{text-decoration:none;color:#fff}.join-btn:hover{transform:translateY(-3px);box-shadow:0 12px 35px #0003}.join-btn:active{transform:translateY(-1px)}#join-panel{position:fixed;bottom:20px;right:4.2vw;border-radius:16px;display:flex;align-items:center;padding:12px 16px;z-index:9999;max-width:280px;font-family:Poppins,sans-serif;transform:translate(200%);transition:all .3s ease}.slide-in{animation:showPanel .5s ease forwards}.slide-out{transform:translate(200%)}@keyframes showPanel{to{transform:translate(0)}}.join-panel-content{display:flex;align-items:center;position:relative}.join-character{width:10em;height:auto;margin-right:10px}.join-text p{margin:0 0 6px;font-size:14px;font-weight:500;color:#333}.join-text{height:12vh;display:flex;background:#fefefe;flex-direction:column;align-items:center;justify-content:center;box-shadow:2px 1px 20px 9px #00000026;padding:1em;border-radius:12px}.join-btn{background:linear-gradient(135deg,#00c18c,#00e6a1);color:#fff;border:none;border-radius:8px;padding:6px 14px;cursor:pointer;font-size:14px;transition:transform .2s ease}.join-btn:hover{transform:scale(1.05)}.close-panel{position:absolute;top:3em;right:0;cursor:pointer;font-size:20px;color:#fff;background:#696969;border-radius:50%;width:22px;height:22px;text-align:center;line-height:22px;box-shadow:0 2px 5px #0000001a;transition:.2s ease all}.close-panel:hover{background:#000;transform:scale(1.1)}.diamond{position:absolute;background:linear-gradient(135deg,#87d9a7,#6bc995);border-radius:12px}.diamond-1{width:3vw;height:3vw;top:-5%;left:10%;animation:scroll 5s linear 0s infinite;z-index:2}.diamond-2{width:6vw;height:6vw;bottom:-5%;right:5%;animation:scroll 5s linear 0s infinite;z-index:2}@media (max-width: 1024px){.education-content{gap:40px}.main-title{font-size:3rem}.card-1{width:160px;height:160px}.card-2{width:140px;height:140px}.card-3{width:200px;height:200px}}@media (max-width: 768px){.education-banner{min-height:100vh}.education-content{flex-direction:column;gap:60px;padding:40px 0}.images-section{order:2;height:400px}.content-section{order:1;text-align:center}.main-title{font-size:2.5rem}.image-grid{height:400px}.card-1{width:7em;height:7em;top:-50%;left:40%;z-index:3}.card-2{width:6em;height:6em;bottom:-35%;left:30%;z-index:2}.card-3{width:8em;height:8em;bottom:0%;right:50%;z-index:1}.diamond-1{width:50px;height:50px}.diamond-2{width:60px;height:60px}}@media (max-width: 480px){.education-container{padding:0 15px}.main-title{font-size:2rem}.description{font-size:1rem}.join-btn{padding:12px 30px;font-size:14px}}.testimonials-section{background-color:#fff;padding:80px 0;position:relative}.testimonials-container{max-width:1200px;margin:0 auto;padding:0 20px;position:relative}.testimonials-header{text-align:center;margin-bottom:60px}.section-title{font-weight:700;font-size:2.5rem;color:#333;margin-bottom:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.section-subtitle{font-size:1.1rem;color:#6c757d;max-width:500px;margin:0 auto;line-height:1.6}.testimonials-content{position:relative}.testimonials-content.single-slide{display:flex;justify-content:center;align-items:center;min-height:300px}.testimonials-grid{display:none}.testimonial-item{flex:1;max-width:500px;transition:all .5s ease}.testimonial-item.inactive{opacity:.3;transform:scale(.95)}.testimonial-item.active{opacity:1;transform:scale(1)}.testimonial-card{border:1px solid #e9ecef;border-radius:12px;background:#fff;padding:50px 30px 30px;position:relative;transition:all .3s ease;box-shadow:0 2px 8px #0000000d;min-height:280px;display:flex;flex-direction:column}.testimonial-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.quote-icon{width:50px;height:50px;background-color:#00d4aa;color:#fff;position:absolute;top:-25px;left:30px;border-radius:12px;transform:rotate(45deg);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00d4aa4d}.quote-symbol{transform:rotate(-45deg);font-size:2rem;font-weight:700;display:flex;justify-content:center;align-items:center;text-align:center}.testimonial-text{font-size:15px;color:#495057;line-height:1.7;margin-bottom:30px;flex-grow:1;font-weight:400}.testimonial-author{margin-top:auto}.author-name{font-weight:600;font-size:16px;color:#212529;margin:0 0 4px}.author-title{font-size:14px;color:#6c757d;font-weight:400}.testimonial-arrow{position:absolute;top:50%;transform:translateY(-50%);background:#fff;border:2px solid #e9ecef;border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:18px;color:#6c757d;box-shadow:0 2px 8px #0000001a;z-index:10}.testimonial-arrow:hover{background:#00d4aa;color:#fff;border-color:#00d4aa;transform:translateY(-50%) scale(1.1)}.testimonial-arrow:active{transform:translateY(-50%) scale(.95)}.left-arrow{left:-25px}.right-arrow{right:-25px}.testimonial-item.fade{opacity:1;transition:opacity .3s ease}.testimonial-item.fade-out{opacity:0}.testimonial-item.fade-in{opacity:1}@media (max-width: 1024px){.left-arrow{left:10px}.right-arrow{right:10px}}@media (max-width: 768px){.testimonials-section{padding:60px 0}.section-title{font-size:2rem}.testimonials-grid{flex-direction:column;gap:20px;align-items:center}.testimonial-item{max-width:100%}.testimonial-item.inactive{display:none}.testimonial-card{padding:40px 25px 25px;min-height:auto}.left-arrow{left:20px}.right-arrow{right:20px}.testimonial-arrow{width:45px;height:45px;font-size:16px}}@media (max-width: 480px){.testimonials-container{padding:0 15px}.section-title{font-size:1.8rem}.testimonial-card{padding:35px 20px 20px}.testimonial-text{font-size:14px}}.footer{background-color:#fff;padding:60px 0;color:#333}.logo-footer-section{display:flex;justify-content:center;align-items:center;gap:1em;margin-bottom:.5em}.footer-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;gap:40px}.footer-section{flex:1}.footer-section.brand{flex:1.5;max-width:300px}.footer-logo{width:4em;height:4em}.footer-section.brand p{font-size:14px;line-height:1.6;color:#666;margin-bottom:20px}.copyright{font-size:12px;color:#888}.footer-section h3{color:#43937b;font-size:16px;font-weight:600;margin-bottom:0}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section ul li{font-size:14px;margin-bottom:12px;color:#444;cursor:pointer}.footer-section.social{flex:1.2}.social-icons{display:flex;gap:15px;margin-bottom:30px}.social-icons a{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:#f5f5f5;border-radius:50%;color:#43937b;transition:all .3s ease}.social-icons a:hover{background-color:#43937b;color:#fff}.language-select{position:relative;width:180px}.language-select select{width:100%;padding:10px 40px 10px 15px;border:1px solid #e0e0e0;border-radius:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;color:#43937b;font-size:14px;cursor:pointer}.globe-icon{position:absolute;right:15px;top:50%;transform:translateY(-50%);color:#43937b;pointer-events:none}@media (max-width: 1024px){.footer-container{flex-wrap:wrap}.footer-section{flex:1 1 200px}.footer-section.brand{flex:1 1 100%;max-width:100%;margin-bottom:40px}}@media (max-width: 768px){.footer-section{flex:1 1 calc(50% - 20px)}}@media (max-width: 480px){.footer-section{flex:1 1 100%}}:root{--primary-color: #10b981;--secondary-color: #059669;--light-green: #d1fae5;--dark-green: #047857;--text-dark: #1f2937;--text-light: #6b7280;--white: #ffffff;--light-bg: #f9fafb}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;line-height:1.6;background:var(--light-bg);color:var(--text-dark);display:block;overflow-x:hidden}#root{width:100%;overflow-x:hidden}img,video,canvas,svg{max-width:100%}table{width:100%}input,textarea,select,button{max-width:100%}.landing-page{overflow-x:hidden;background-color:#fff}.section{height:90vh;display:flex;justify-content:center;align-items:center;padding-inline:10vw;margin-bottom:10vh}@keyframes bounce-gentle{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #1dafa14d}50%{box-shadow:0 0 40px #1dafa180}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes confetti{0%{transform:scale(0) rotate(0);opacity:1}to{transform:scale(1.5) rotate(720deg);opacity:0}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.animate-bounce-gentle{animation:bounce-gentle 3s ease-in-out infinite}.animate-shake{animation:shake .5s ease-in-out}.animate-pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.animate-slide-up{animation:slide-up .4s ease-out}.animate-pop{animation:pop .3s ease-out}.animate-confetti{animation:confetti .6s ease-out}.animate-fade-in{animation:fade-in .3s ease-out}.auth{width:100vw;min-height:100vh;display:flex;justify-content:center;align-items:center;background-image:url(/assets/bg-Auth-4AbWK17M.jpg);background-size:cover;background-repeat:no-repeat;position:relative;overflow:hidden;padding:1rem}.auth-box{width:90vw;max-width:1200px;min-height:70vh;border-radius:var(--radius-lg);background-color:#def6e4;box-shadow:0 0 1.5rem #a0a0a0;display:flex;position:relative;color:#000}.auth-box.multi-step{min-height:80vh}.auth:before{content:"";position:absolute;width:90vw;max-width:1200px;min-height:70vh;border-radius:var(--radius-xl);background-color:var(--pastel-green);transform:rotate(165deg);z-index:0}.left-side{display:flex;justify-content:center;align-items:center;flex-direction:column;width:50%;min-width:200px;z-index:1}.logo-auth{width:18vw;max-width:200px;margin-bottom:2vw}.right-side{background:#fff;width:60%;padding:2.5vw 3vw;border-top-right-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);min-width:220px;z-index:1}.left-side .diamond{width:4vw;height:4vw;max-width:60px;max-height:60px;border-radius:20%;rotate:1deg;position:absolute;transform-origin:center;animation:scroll 2s linear 0s infinite;min-width:32px;min-height:32px}.left-side .diamond:nth-child(1){top:-2%;left:25%;animation:scroll 1.4s linear 0s infinite}.left-side .diamond:nth-child(2){left:-5%;width:6vw;height:6vw;max-width:90px;max-height:90px;animation:scroll 1.7s linear .4s infinite}.left-side .diamond:nth-child(3){left:20%;bottom:-10%;width:7.5vw;height:7.5vw;max-width:112.5px;max-height:112.5px;display:none;animation:scroll 2.1s linear .8s infinite}.left-side-text{font-size:1.2rem;text-align:center;color:#000}.top{width:100%;display:flex;justify-content:space-between;align-items:center}.path-link{text-decoration:none;color:var(--secondary);position:relative;right:2vw;font-size:1rem;width:fit-content}.path-link:before{content:"";position:absolute;right:-2vw;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAJAAAACQCAYAAADnRuK4AAAACXBIWXMAACxLAAAsSwGlPZapAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAASnSURBVHgB7d09bxxVFIDhs7YLStMhUdj+By5XSKwWpAREFTo6/sJUUMapEDiSU9JBSxc6EgtBUm0XSkobGkpKJMwu9zg7zn7M7Hzd2b33nvdtZla2G/vRmZk73h0RKm30OHs4+iZ7KFTavlBhikdmciYDGR/dG8r15eSF0FoAKugOTx6ISgPQSmt48kBUGIAWKsWTB6K1ADSvEk8eiJYCkDTAkweiu8wDaownD0S3mQbUGk8eiOwC6ownzzgik4C84ckzjMgcIO948owiMgXo/cfZg8FMvpW+MojIFKA/nk9+P7o/PHG7p9JXxhCZO4S5P+xTEPnL5Ek0iPxl9jIeRH4yvZAIou4NhGR0nr2SPhFpbung5RdPHkli7QnJ3oF84Da/SZ8N5CzFf4/lbrzr6tnkn5NPhj/MpvKxe/mO9FWChzMAzQNRuwC0EIiaB6CVQNQsABUEovoBqCQQ1QtAGwJRdQCqCESbA1CNQFQegGoGouIA1CAQrQeghoFoOe7Gt2x8kR1O/5VX7jd4LH0W+F18JlDLbifRh8MfZwN54BAdSl8FPokA1KGrnyd/W0cEoI5ZRwQgD1lGBCBPWUUEII9ZRAQgz1lDBKAesoQIQD1lBRGAeswCIgD1XOqIALSFUkYEoC2VKiIAbbEUEQFoy6WGCEA7KCVEANpRqSAC0A5LARGAdlzsiAAUQDEjAlAgxYoIQAEVIyIABVZsiAAUYDEhAlCgxYIIQAEXAyIABV7oiAAUQYro3XvDF3sD+cy9fEv6qgUiAEXSn5eTvxyiZ6EhAlBEhYhoMDrPZkJUVI2PluFhK1RejQfEAIg2V4EIQFTdBkQAonqVIAIQ1a8AEYCoWSuIAETNW0DEOhC1z60TMYGofTMZAIjaNZVHL798wgSiFs3x6C6AqFkLeDQAUf1W8GgAonoV4NEARNWV4NEARJvbgEcDEJVXgUfjgXOR9d5Fdnrwn/ziFvH6e4eGVgOPBqCICg2PBqBIChGPBqAIChWPBqDACxmPBqCACx2PBqBAiwGPBqAAiwWPBqDAigmPBqCAig2PBqBAihGPBqAAihWPBqAdFzMeDUA7LHY8GoB2VAp4NADtoFTwaADacinh0QC0xVLDowFoS6WIRwPQFkoVjwagnksZjwagHksdjwagnrKARwNQD1nBowHIc5bwaADymDU8GoA8ZRGPBiAPWcWjAahjlvFoAOqQdTwagFoGntcBqEXgeROAGgae5QDUIPCsB6Cagac4ANUIPOUBqCLwbA5AGwJPdQAqCTz1AlBB4KkfgFYCT7MAtBB4mgegeeBpF4AEPF0yDwg83TINCDzdMwsIPH4yCQg8/jIHCDx+MwUIPP47EEMd3Mh3bgMej5l6ZurejXzqps+V9JUxPJq5c6DxV9nxdN8dxgZyLD4ziEczeRU2vsgOpzcOkcip+MgoHs3sOpA3RIbxaKZXojsjMo5H42aqa3Sefe82nzf5GfC8bl9Iri8nT4/uD0+k7iQCz10AmlcbEXiWAtBCt4g+Gr7tdoeF3wCetQC00vXzyU9uEum54XjpC+ApDEAFuUn06xIi8FCb3NXZ2ejr7EyotP8BnkZm9d/WtL4AAAAASUVORK5CYII=);width:1.5vw;height:1vw;background-size:contain;background-repeat:no-repeat}h1{font-size:2.2rem;position:relative;width:max-content;z-index:10}h1:after{content:"";position:absolute;left:0;bottom:15%;width:60%;height:24%;background-color:#def6e4;z-index:-1;border-radius:2px}h2{font-size:2rem;margin-top:0;letter-spacing:.05em;font-weight:500;margin-bottom:.5rem}h3{font-size:1.3rem;margin-top:0;letter-spacing:.05em;font-weight:500}h4{color:#00000076;font-size:1.1rem;text-align:center;position:relative;display:flex;align-items:center;justify-content:center;font-weight:500}h4:after,h4:before{content:"";height:1px;width:5vw;background-color:#00000076}h4:after{right:-1vw;position:relative}h4:before{left:-1vw;position:relative}.form{margin-top:5vh;display:flex;flex-direction:column;position:relative;gap:.5rem}.form>*{width:100%;box-sizing:border-box}.form .button{width:100%;align-self:center;margin-top:2vh}.password-row{display:flex;gap:1vw;width:100%;justify-content:space-between}.password-row>*{flex:1 1 0;min-width:0;margin-bottom:0}@keyframes scroll{0%{transform:translateY(0) rotate(45deg)}25%{transform:translateY(-1vw) rotate(45deg)}50%{transform:translateY(0) rotate(45deg)}75%{transform:translateY(1vw) rotate(45deg)}to{transform:translateY(0) rotate(45deg)}}@media (min-width: 1920px){.auth-box,.auth:before{max-width:1400px;min-height:60vh}.logo-auth{width:15vw;max-width:250px}.left-side .diamond{width:3vw;height:3vw;max-width:80px;max-height:80px}.left-side .diamond:nth-child(2){width:4.5vw;height:4.5vw;max-width:120px;max-height:120px}.left-side .diamond:nth-child(3){width:6vw;height:6vw;max-width:150px;max-height:150px}.right-side{padding:2vw 2.5vw}h1{font-size:3.5rem}h2{font-size:2.2rem}.form{margin-top:4vh}}@media (min-width: 1440px) and (max-width: 1919px){.auth-box,.auth:before{max-width:1300px}.logo-auth{width:16vw;max-width:220px}.right-side{padding:2.2vw 2.8vw}h1{font-size:2.3rem}h2{font-size:2.1rem}}@media (min-width: 1200px) and (max-width: 1439px){.auth-box,.auth:before{width:85vw;max-width:1100px}.logo-auth{width:17vw;max-width:200px}.right-side{padding:2.3vw 2.8vw}}@media (min-width: 1024px) and (max-width: 1199px){.auth-box,.auth:before{width:88vw;max-width:1000px;min-height:75vh}.left-side{width:45%}.right-side{width:55%;padding:2.5vw 3vw}.logo-auth{width:20vw;max-width:180px}h1{font-size:2rem}h2{font-size:1.8rem}.left-side-text{font-size:1.1rem}}@media (min-width: 768px) and (max-width: 1023px){.auth-box,.auth:before{width:95vw;min-height:80vh;flex-direction:column}.left-side{width:100%;min-height:30vh;padding:2rem 1.5rem}.right-side{width:100%;padding:2rem 2.5rem;border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top-right-radius:0}.logo-auth{width:15vw;max-width:140px;margin-bottom:1.5rem}.left-side .diamond{width:5vw;height:5vw;max-width:50px;max-height:50px}.left-side .diamond:nth-child(1){border:.6vw solid #3e8b70}.left-side .diamond:nth-child(2){width:7vw;height:7vw;max-width:70px;max-height:70px;border:.8vw solid #3e8b70}.left-side .diamond:nth-child(3){width:9vw;height:9vw;max-width:90px;max-height:90px;border:1vw solid #3e8b70}h1{font-size:1.8rem}h2{font-size:1.6rem}h3{font-size:1.2rem}h4{font-size:1rem}.form{margin-top:3vh}.password-row{gap:1.5vw}}@media (min-width: 600px) and (max-width: 767px){.auth{padding:1rem}.auth-box,.auth:before{width:100%;min-height:85vh;flex-direction:column;border-radius:var(--radius-md)}.left-side{width:100%;min-height:25vh;padding:1.5rem 1rem}.right-side{width:100%;padding:1.5rem 2rem;border-radius:0 0 var(--radius-md) var(--radius-md);border-top-right-radius:0}.logo-auth{width:20vw;max-width:120px;margin-bottom:1rem}.left-side .diamond{width:6vw;height:6vw;max-width:45px;max-height:45px}.left-side .diamond:nth-child(1){border:.7vw solid #3e8b70}.left-side .diamond:nth-child(2){width:8vw;height:8vw;max-width:60px;max-height:60px;border:.9vw solid #3e8b70}.left-side .diamond:nth-child(3){width:10vw;height:10vw;max-width:75px;max-height:75px;border:1.1vw solid #3e8b70}h1{font-size:1.6rem}h2{font-size:1.4rem}h3{font-size:1.1rem}h4{font-size:.95rem}h4:after,h4:before{width:8vw}.left-side-text{font-size:1rem}.form{margin-top:2.5vh}.password-row{flex-direction:column;gap:1rem}.top{flex-direction:column;gap:1rem;align-items:center}.path-link{right:0;order:-1}}@media (min-width: 480px) and (max-width: 599px){.auth{padding:.5rem}.auth-box,.auth:before{width:100%;min-height:90vh;flex-direction:column;border-radius:var(--radius-sm)}.left-side{width:100%;min-height:20vh;padding:1rem .5rem}.right-side{width:100%;padding:1rem 1.5rem;border-radius:0 0 var(--radius-sm) var(--radius-sm);border-top-right-radius:0}.logo-auth{width:25vw;max-width:100px;margin-bottom:.5rem}.left-side .diamond{width:8vw;height:8vw;max-width:35px;max-height:35px}.left-side .diamond:nth-child(1){border:1vw solid #3e8b70}.left-side .diamond:nth-child(2){width:10vw;height:10vw;max-width:45px;max-height:45px;border:1.2vw solid #3e8b70}.left-side .diamond:nth-child(3){width:12vw;height:12vw;max-width:55px;max-height:55px;border:1.4vw solid #3e8b70}h1{font-size:1.4rem}h2{font-size:1.2rem}h3{font-size:1rem}h4{font-size:.9rem}h4:after,h4:before{width:10vw}.left-side-text{font-size:.9rem}.form{margin-top:2vh}.password-row{flex-direction:column;gap:.8rem}.top{flex-direction:column;gap:.8rem;align-items:center}.path-link{right:0;font-size:.9rem}.path-link:before{width:3vw;height:3vw;right:-4vw}}@media (min-width: 375px) and (max-width: 479px){.auth{padding:0}.auth-box,.auth:before{width:100vw;min-height:100vh;flex-direction:column;border-radius:0;box-shadow:none}.left-side{width:100vw;min-height:18vh;padding:.8rem .5rem}.right-side{width:100vw;padding:.8rem 1rem;border-radius:0;flex:1}.logo-auth{width:30vw;max-width:90px;margin-bottom:.3rem}.left-side .diamond{width:10vw;height:10vw;max-width:30px;max-height:30px}.left-side .diamond:nth-child(2){width:12vw;height:12vw;max-width:40px;max-height:40px}.left-side .diamond:nth-child(3){width:14vw;height:14vw;max-width:50px;max-height:50px}h1{font-size:1.3rem}h2{font-size:1.1rem}h3{font-size:.95rem}h4{font-size:.85rem}h4:after,h4:before{width:12vw}.left-side-text{font-size:.85rem}.form{margin-top:1.5vh;gap:.7rem}.password-row{flex-direction:column;gap:.7rem}.top{flex-direction:column;gap:.5rem;align-items:center}.path-link{right:0;font-size:.85rem}.path-link:before{width:4vw;height:4vw;right:-5vw}}@media (min-width: 320px) and (max-width: 374px){.auth{padding:0}.auth-box,.auth:before{width:100vw;min-height:100vh;flex-direction:column;border-radius:0;box-shadow:none}.left-side{width:100vw;min-height:15vh;padding:.5rem .3rem}.right-side{width:100vw;padding:.5rem .8rem;border-radius:0;flex:1}.logo-auth{width:35vw;max-width:80px;margin-bottom:.2rem}.left-side .diamond{display:none}h1{font-size:1.2rem}h2{font-size:1rem}h3{font-size:.9rem}h4{font-size:.8rem}h4:after,h4:before{width:15vw}.left-side-text{font-size:.8rem}.form{margin-top:1vh;gap:.5rem}.password-row{flex-direction:column;gap:.5rem}.top{flex-direction:column;gap:.3rem;align-items:center}.path-link{right:0;font-size:.8rem}.path-link:before{width:5vw;height:5vw;right:-6vw}}@media (max-width: 319px){.auth{padding:0}.auth-box,.auth:before{width:100vw;min-height:100vh;flex-direction:column;border-radius:0;box-shadow:none}.left-side{width:100vw;min-height:12vh;padding:.3rem .2rem}.right-side{width:100vw;padding:.3rem .5rem;border-radius:0;flex:1}.logo-auth{width:40vw;max-width:70px;margin-bottom:.1rem}.left-side .diamond{display:none}h1{font-size:1.1rem}h2{font-size:.95rem}h3{font-size:.85rem}h4{font-size:.75rem}h4:after,h4:before{width:18vw}.left-side-text{font-size:.75rem}.form{margin-top:.5vh;gap:.3rem}.password-row{flex-direction:column;gap:.3rem}.top{flex-direction:column;gap:.2rem;align-items:center}.path-link{right:0;font-size:.75rem}.path-link:before{width:6vw;height:6vw;right:-7vw}}@media (max-width: 767px) and (orientation: landscape){.auth-box,.auth:before{min-height:95vh}.left-side{min-height:15vh;padding:.5rem}.right-side{padding:.5rem 1rem}.logo-auth{width:15vw;max-width:60px;margin-bottom:.2rem}.left-side-text{font-size:.8rem}.form{margin-top:.5vh;gap:.3rem}.left-side .diamond{display:none}h1{font-size:1rem}h2{font-size:.9rem}h3{font-size:.8rem}h4{font-size:.7rem;margin:.5rem 0}}@media (min-aspect-ratio: 21/9){.auth-box,.auth:before{max-width:1600px}.left-side{width:40%}.right-side{width:60%}}@media (aspect-ratio: 1/1){.auth-box,.auth:before{flex-direction:column;max-width:90vmin;min-height:90vmin}.left-side,.right-side{width:100%}.left-side{min-height:30%}.right-side{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top-right-radius:0}}@media (max-aspect-ratio: 3/4){.auth-box,.auth:before{flex-direction:column;min-height:85vh}.left-side{min-height:25vh}.right-side{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top-right-radius:0}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.path-link:before{background-image:url(../assets/icons/CloseIcon@2x.png)}}@media print{.auth{background:#fff;padding:0}.auth-box{box-shadow:none;border:1px solid #ccc;flex-direction:column}.auth:before{display:none}.left-side .diamond{display:none}.left-side,.right-side{width:100%;border-radius:0}.logo-auth{width:100px}}@media (prefers-reduced-motion: reduce){.left-side .diamond{animation:none}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){.auth-box{border:2px solid #000}.left-side .diamond{border-color:#000}h1:after{background-color:#000}h4:after,h4:before{background-color:#000}}.step-indicator{display:flex;justify-content:center;align-items:center;margin-bottom:2rem;gap:1rem}.step{display:flex;flex-direction:column;align-items:center;position:relative}.step-circle{width:40px;height:40px;border-radius:50%;background-color:#e5e7eb;color:#9ca3af;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;transition:all .3s ease}.step.active .step-circle{background-color:var(--primary);color:#fff}.step-label{margin-top:.5rem;font-size:.8rem;color:#6b7280;text-align:center}.step.active .step-label{color:var(--primary);font-weight:600}.step:not(:last-child):after{content:"";position:absolute;top:20px;left:50px;width:60px;height:2px;background-color:#e5e7eb;transition:all .3s ease}.step.active:not(:last-child):after{background-color:var(--primary)}.name-row,.password-row,.info-row{display:flex;gap:1rem;margin-bottom:1rem}.name-row .input-box,.password-row .input-box,.info-row .input-box{flex:1}.role-selection,.language-selection{margin-bottom:1.5rem}.role-selection label,.language-selection label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-dark)}.role-select,.language-select{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:var(--radius-sm);background-color:#fff;font-size:1rem;color:var(--text-dark);transition:border-color .3s ease}.role-select:focus,.language-select:focus{outline:none;border-color:var(--primary)}.social-links{margin-bottom:1.5rem}.social-links h5{margin-bottom:1rem;color:var(--text-dark);font-weight:600}.form-buttons{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}.form-buttons .button{flex:1;max-width:150px}.error{display:block;color:var(--error);font-size:.8rem;margin-top:.25rem;margin-bottom:1rem}.error-message{background-color:#fee2e2;color:#dc2626;padding:.75rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.9rem;text-align:center}.demo-credentials{margin-top:2rem;padding:1rem;background-color:#ffffff1a;border-radius:var(--radius-sm);font-size:.85rem}.demo-credentials p{margin:.25rem 0}.forgot-password{text-align:right;margin-bottom:1rem}.forgot-link{color:var(--primary);text-decoration:none;font-size:.9rem;transition:color .3s ease}.forgot-link:hover{color:var(--primary-light);text-decoration:underline}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center}.empty-state p{margin-bottom:1rem;color:var(--text-dark);font-size:1.1rem}.explore-courses-btn{background-color:var(--primary);color:#fff;padding:.75rem 1.5rem;border:none;border-radius:var(--radius-sm);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .3s ease}.explore-courses-btn:hover{background-color:var(--primary-light)}@media (max-width: 1024px){.auth-box{max-width:900px;min-height:75vh}.step-indicator{gap:.5rem}.step:not(:last-child):after{width:40px;left:40px}}@media (max-width: 768px){.auth{padding:.5rem}.auth-box{flex-direction:column;width:95vw;min-height:85vh}.left-side{width:100%;min-height:200px;padding:1rem}.left-side-text h2{font-size:1.5rem}.left-side-text h3{font-size:1rem}.logo-auth{width:80px;height:80px}.right-side{width:100%;padding:1rem}.step-indicator{flex-direction:row;justify-content:center;margin-bottom:1.5rem}.step{flex-direction:row;align-items:center;gap:.5rem}.step-circle{width:30px;height:30px;font-size:.8rem}.step-label{margin-top:0;font-size:.7rem}.step:not(:last-child):after{display:none}.name-row,.password-row,.info-row{flex-direction:column;gap:0}.form-buttons{flex-direction:column;gap:.5rem}.form-buttons .button{max-width:100%}.demo-credentials{font-size:.75rem;padding:.75rem}}@media (max-width: 480px){.auth{padding:.25rem}.auth-box{width:98vw;min-height:90vh;border-radius:var(--radius-sm)}.left-side{min-height:150px;padding:.75rem}.right-side{padding:.75rem}.step-indicator{gap:.25rem;margin-bottom:1rem}.step-circle{width:25px;height:25px;font-size:.7rem}.step-label{font-size:.65rem}.form h4{font-size:1rem;margin-bottom:1rem}.role-select,.language-select{padding:.5rem .75rem;font-size:.9rem}}@media (max-width: 1200px){.course-grid.fixed-three{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.course-grid.fixed-three{grid-template-columns:1fr}.course-grid-section{padding:1rem}.title-section-course{text-align:center;margin-bottom:2rem}.section-title-course{font-size:1.5rem}.section-subtitle-course{font-size:.9rem}}.verification-code-input{display:flex;gap:12px;justify-content:center;margin:16px 0}.code-input{width:50px;height:50px;border:2px solid #43937b;border-radius:8px;text-align:center;font-size:18px;font-weight:700;color:#fff;outline:none;transition:border-color .3s ease}.code-input:focus{border-color:#3ca381}.welcome-banner{background-color:#f4fbf7;border-radius:10px;display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.welcome-left{display:flex;flex-direction:column}.welcome-title{font-size:2.5rem;font-weight:700;color:#1f2937;margin:0}.wave-emoji{margin-left:.4rem;font-size:3rem}.welcome-subtitle{font-size:1rem;color:#6b7280;margin-top:.4rem}.welcome-right{display:flex;gap:1rem;justify-content:flex-end;align-items:center;height:7em}.icon-box{position:relative;width:5em;height:5em;background-color:#fff;border:1px solid #d1e7dd;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000000d;cursor:pointer;transition:.5s}.icon-box:hover{transform:translateY(-.5em);box-shadow:0 2px 6px #00000060}.icon{z-index:2;width:2em;height:2em}.notification-dot{display:none}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.modal-content{background:#fff;border-radius:var(--radius-xl);max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease-out}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl) var(--space-xl) 0;border-bottom:1px solid var(--border-light);margin-bottom:var(--space-lg)}.modal-header h2{margin:0;font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-dark)}.modal-close{background:none;border:none;font-size:var(--text-2xl);cursor:pointer;color:var(--text-muted);transition:var(--transition-normal);padding:var(--space-xs);border-radius:var(--radius-md);width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background-color:var(--background-muted);color:var(--text-dark)}.notification-modal-body{grid-template-columns:repeat(1,minmax(0,1fr))!important}.modal-body{padding:0 var(--space-xl) var(--space-lg);color:var(--text-muted);line-height:var(--leading-relaxed)}.modal-footer{display:flex;gap:var(--space-md);padding:var(--space-lg) var(--space-xl) var(--space-xl);justify-content:flex-end;border-top:1px solid var(--border-light)}.modal-button{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;transition:var(--transition-normal);border:1px solid var(--border-light)}.modal-button.cancel{background:#fff;color:var(--text-muted)}.modal-button.cancel:hover:not(:disabled){background-color:var(--background-muted);color:var(--text-dark)}.modal-button:disabled{opacity:.5;cursor:not-allowed}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.modal-content{width:95%;margin:var(--space-lg)}.modal-header,.modal-body,.modal-footer{padding-left:var(--space-lg);padding-right:var(--space-lg)}.modal-footer{flex-direction:column-reverse}.modal-button{width:100%}}.notification-list{max-height:400px;overflow-y:auto;padding:var(--space-sm)}.notification-item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);border:1px solid var(--border-light);position:relative;transition:var(--transition-normal)}.notification-item:hover{background-color:var(--background-muted)}.notification-item.unread{background-color:#2e97800d;border-color:#2e978033}.notification-icon{font-size:var(--text-xl);flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--background-muted)}.notification-content{flex:1}.notification-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-dark);margin:0 0 var(--space-xs) 0}.notification-message{font-size:var(--text-sm);color:var(--text-muted);margin:0 0 var(--space-xs) 0;line-height:var(--leading-relaxed)}.notification-time{font-size:var(--text-xs);color:var(--text-light)}.notification-badge{width:8px;height:8px;border-radius:50%;background:var(--primary);position:absolute;top:var(--space-md);right:var(--space-md)}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:var(--background-muted);border-radius:var(--radius-sm)}.notification-list::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:var(--radius-sm)}.notification-list::-webkit-scrollbar-thumb:hover{background:var(--primary)}.chat-container{display:flex;flex-direction:column;height:500px;background:var(--background-light);border-radius:var(--radius-lg);flex-direction:row}.message-list{flex:1;overflow-y:auto;padding:var(--space-md);border-bottom:1px solid var(--border-light);background:#fff;scroll-behavior:smooth}.message-item{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);align-items:flex-start;animation:slideIn .3s ease-out}.message-item.own-message{flex-direction:row-reverse}.message-avatar{position:relative;flex-shrink:0}.message-avatar img{width:40px;height:40px;border-radius:50%;object-fit:cover}.instructor-badge,.group-badge{position:absolute;bottom:-2px;right:-2px;font-size:12px;background:#fff;border-radius:50%;padding:2px}.message-content{flex:1;max-width:70%}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs)}.message-sender{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-dark)}.message-time{font-size:var(--text-xs);color:var(--text-light)}.message-text{background:var(--background-muted);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-xl);margin:0;font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--text-dark);box-shadow:0 2px 8px #00000014;word-wrap:break-word;max-width:100%}.own-message .message-text{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-bottom-right-radius:var(--radius-sm);box-shadow:0 2px 12px #2e97804d}.message-item:not(.own-message) .message-text{border-bottom-left-radius:var(--radius-sm)}.message-input-container{padding:var(--space-lg);background:#fff;border-top:1px solid var(--border-light);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.message-input-box{display:flex;gap:var(--space-sm);align-items:flex-end}.message-input{flex:1;border:2px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--space-md) var(--space-lg);font-family:inherit;font-size:var(--text-base);line-height:var(--leading-relaxed);resize:none;outline:none;transition:all .3s ease;background:var(--background-light);min-height:44px;max-height:120px}.message-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2e978026;background:#fff}.send-button{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:var(--text-base);box-shadow:0 2px 8px #2e97804d}.send-button:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:0 4px 16px #2e978066}.send-button:disabled{opacity:.5;cursor:not-allowed;transform:none;background:var(--background-muted);box-shadow:none}.message-list::-webkit-scrollbar{width:6px}.message-list::-webkit-scrollbar-track{background:var(--background-muted);border-radius:var(--radius-sm)}.message-list::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:var(--radius-sm)}.message-list::-webkit-scrollbar-thumb:hover{background:var(--primary)}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xs);opacity:.7}.message-sender{font-size:var(--text-sm);font-weight:600;color:var(--text-dark)}.message-time{font-size:var(--text-xs);color:var(--text-light);font-weight:500}.own-message .message-header{flex-direction:row-reverse}.own-message .message-content{text-align:right}.message-list:empty:before{content:"No messages yet. Start a conversation!";display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-light);font-style:italic}@media (max-width: 768px){.chat-container{height:400px}.message-content{max-width:85%}.message-text{font-size:var(--text-sm);padding:var(--space-sm) var(--space-md)}.message-input{font-size:var(--text-sm)}.send-button{width:44px;height:44px}}.stats-container{display:flex;gap:8%;flex-wrap:wrap;padding-bottom:1rem;background-color:#f4faf4;justify-content:center}.stat-card{flex:1;min-width:280px;padding:24px;border-radius:12px;border:1px solid;display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.stat-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon .icon{font-size:24px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.stat-icon img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.stat-content{display:flex;flex-direction:column;align-items:center;gap:8px}.stat-value{font-size:32px;font-weight:700;color:#2d3748;margin:0;line-height:1.2}.stat-label{font-size:14px;color:#718096;margin:0;font-weight:500;line-height:1.4}@media (max-width: 768px){.stats-container{gap:16px;padding:0 16px}.stat-card{min-width:100%;padding:20px}.stat-value{font-size:28px}.stat-label{font-size:13px}}@media (max-width: 480px){.stats-container{gap:12px;padding:0 12px}.stat-card{padding:16px;gap:12px}.stat-icon{width:40px;height:40px}.stat-icon .icon{font-size:20px}.stat-value{font-size:24px}.stat-label{font-size:12px}}.learn-steps{display:flex;justify-content:space-between;align-items:center;padding:80px 60px;position:relative;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:500px;width:100%}.learn-steps-left{flex:1;max-width:50%;padding-right:40px;display:flex;flex-direction:column;justify-content:space-between;height:45vh}.learn-steps-subtitle{font-size:2.5rem;color:#666;margin-bottom:8px;font-weight:400;letter-spacing:.5px}.learn-steps-title{font-size:48px;font-weight:800;color:#2c3e50;letter-spacing:2px}.learn-steps-steps{display:flex;align-items:center;position:relative}.curve-step-container{position:relative;display:flex;flex-direction:column;align-items:center;width:20%}.curve-step{font-size:18px;font-weight:600;color:#7f8c8d;padding:8px 0;transition:all .3s ease;position:relative}.curve-step.active{color:#2ecc71}.step-underline{width:40px;height:3px;background:#e0e0e0;border-radius:2px;margin-top:8px;transition:all .3s ease}.step-underline.active{background:#2ecc71}.learn-steps-steps{display:flex;align-items:flex-start;justify-content:flex-start;gap:10px}.curve-step-container{display:flex;flex-direction:column;align-items:center;position:relative}.curve-step{font-size:1.2rem;font-weight:600;color:#4a4a4a}.connector-curve1{margin-top:3.5rem;display:flex;align-items:flex-start}.curve-step-container:nth-child(1) .png-curve{width:100%;left:20%;bottom:-70%;position:absolute}.curve-step-container:nth-child(2) .png-curve{width:100%;right:-30%;top:-70%;position:absolute}.connector-curve2{margin-bottom:7.5rem;display:flex;align-items:flex-end}.curve-img2{width:150px;height:3em;object-fit:contain;display:block}.progress-indicator{display:flex;gap:8px;margin-top:35%}.step-progress-bar{width:40px;height:4px;border-radius:2px;background:#e0e0e0;transition:all .3s ease}.step-progress-bar.active{background:#2ecc71}.learn-steps-right{flex:1;position:relative;display:flex;justify-content:center;align-items:center;height:500px}.student-container{position:relative;z-index:3;display:flex;justify-content:center;align-items:center}.student-img{width:75%;object-fit:cover;border-radius:8px;position:relative;z-index:3;padding-left:4rem}@media (max-width: 768px){.learn-steps{flex-direction:column;padding:40px 30px;text-align:center}.learn-steps-left{max-width:100%;padding-right:0;margin-bottom:40px}.learn-steps-title{font-size:36px}.learn-steps-steps{flex-direction:column;gap:20px}.connector{transform:rotate(90deg)}.learn-steps-right{height:400px}.student-img{width:250px;height:300px}}.curve-step:hover{color:#2ecc71;transform:translateY(-2px);cursor:default}.curve-step:hover+.step-underline{background:#2ecc71;width:50px}.circle.white:hover{transform:scale(1.1);box-shadow:0 6px 25px #00000026}.icon:hover{transform:scale(1.2)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.learn-steps-left>*{animation:fadeInUp .6s ease-out}.performance-section{text-align:center;background-color:#f4faf4;padding:40px 20px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.performance-title{font-size:32px;font-weight:700;position:relative;display:inline-block;margin-bottom:10px}.performance-title:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:8px;background-color:#d9f2dc;z-index:-1;border-radius:4px}.performance-description{font-size:18px;color:#666;max-width:600px;margin:0 auto}.progress-chart-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background-color:#f4faf4;font-family:Inter,sans-serif}.chart-circle-wrapper{position:relative;width:160px;height:160px;margin-bottom:2rem}.chart-svg{width:100%;height:100%}.chart-circle-bg{fill:none;stroke:#91c8ba;stroke-width:15}.chart-circle-progress{fill:none;stroke:#4bb991;stroke-width:15;transition:stroke-dashoffset .5s ease-in-out;stroke-linecap:round}.chart-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.8rem;font-weight:700;padding-left:5rem;color:#8e918e}.chart-legend{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;width:100%;max-width:250px;margin-left:30rem;padding-left:2rem}.legend-item{display:flex;align-items:flex-start;gap:.75rem}.legend-color{width:4rem;height:.5rem;border-radius:.25rem;flex-shrink:0;margin-top:1rem}.legend-color-completed{background-color:#4bb991}.legend-color-remaining{background-color:#91c8ba}.legend-text{display:flex;flex-direction:column;align-items:flex-start}.legend-label{margin:0;font-size:.95rem;color:#555;font-weight:500;line-height:1.2}.legend-value{margin:0;font-size:.85rem;color:#777;line-height:1.2}@media (min-width: 640px){.chart-circle-wrapper{width:200px;height:200px}.chart-percentage{font-size:2.2rem}.chart-legend{max-width:300px;padding-left:3rem}.legend-label{font-size:1rem}.legend-value{font-size:.9rem}}@media (min-width: 1024px){.chart-circle-wrapper{width:240px;height:240px}.chart-percentage{font-size:2.5rem}.chart-legend{max-width:350px;padding-left:4rem}.legend-label{font-size:1.05rem}.legend-value{font-size:.95rem}}.upcoming-classes-container{display:flex;flex-direction:column;padding:2rem;background-color:#fff;border-radius:1rem;box-shadow:0 4px 12px #0000000d;font-family:Inter,sans-serif;max-width:400px;width:100%;margin:2rem auto}.upcoming-classes-title{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:1.5rem;text-align:left;padding-left:.5rem}.class-list{display:flex;flex-direction:column;gap:1rem}.class-item{display:flex;align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:.75rem;padding:1rem;box-shadow:0 2px 4px #00000008;transition:transform .2s ease-in-out;cursor:pointer}.class-item:hover{transform:translateY(-2px)}.class-date-circle{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;background-color:#e6f7ed;border-radius:.5rem;font-size:1.2rem;font-weight:600;color:#4bb991;flex-shrink:0;margin-right:1rem}.class-details{flex-grow:1;display:flex;flex-direction:column;text-align:left}.class-title{margin:0;font-size:1rem;font-weight:500;color:#333;line-height:1.3}.class-time{margin:0;font-size:.85rem;color:#777;line-height:1.3}.class-arrow{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;flex-shrink:0;margin-left:1rem}@media (min-width: 640px){.upcoming-classes-container{padding:2.5rem;max-width:450px}.upcoming-classes-title{font-size:1.75rem;margin-bottom:2rem}.class-date-circle{width:3.5rem;height:3.5rem;font-size:1.3rem}.class-title{font-size:1.1rem}.class-time{font-size:.9rem}}@media (min-width: 768px){.upcoming-classes-container{max-width:500px}}.cp-wrapper{padding:2.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 10px #0000000d;margin:2rem auto}.cp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.cp-title{font-size:24px;font-weight:700;color:#0f172a}.cp-action-btn{padding:10px 20px;border:none;background:linear-gradient(90deg,var(--primary-dark),var(--primary-light) 90%);color:#fff;border-radius:8px;font-weight:600;cursor:pointer;transition:.3s}.cp-action-btn:hover{opacity:.9}.cp-no-data{text-align:center;color:#64748b;font-size:16px}.cp-table{width:100%;border-collapse:collapse;margin-top:10px}.cp-table th{background:#f8fafc;color:#0f172a;text-align:left;padding:12px;font-weight:700;font-size:14px;border-bottom:2px solid #e2e8f0}.cp-table td{padding:12px;border-bottom:1px solid #e2e8f0;font-size:14px}.cp-course-img{width:80px;height:50px;object-fit:cover;border-radius:6px}.cp-consult-btn{padding:6px 14px;background:#0ea5e9;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:.2s}.cp-consult-btn:hover{background:#0284c7}.cp-loading{text-align:center;font-size:18px;color:#64748b}.home-layout{display:flex;flex-direction:column;gap:1rem;padding:2rem;background-color:#fff;min-height:100vh}.red{background-color:#ef4444}.purple{background-color:#6366f1}.sub-blocks{display:flex;gap:1rem}.sub-block{flex:1;padding:2rem;border-radius:10px;color:#fff;font-size:1.2rem;text-align:center;font-weight:700}.yellow{background-color:#facc15}.learning-layout{display:flex;flex-direction:column;gap:1rem;padding:2rem;min-height:100vh}.block{padding:2rem;border-radius:10px;color:#fff;font-size:1.5rem;text-align:center;font-weight:700}.teal{background-color:#0ea5e9}.course-search-banner{background-color:#3e8b70;background-image:url(/assets/Rectangle3-BATsWoN3.png);position:relative;width:100%;height:60vh;border-radius:1rem;display:flex;align-items:center;justify-content:space-evenly;flex-direction:column;margin-block:3em}.course-search-banner h1{font-weight:700}.course-search-banner h1:after{bottom:10%;width:80%;height:10%}.text-group{text-align:center;font-family:Lato,sans-serif;font-size:6vw;font-weight:700;line-height:1.2;color:#fff;z-index:3}.search-bar{width:40%;height:7.5vh;z-index:3}.search-input{background:#fff;border-radius:100vw;height:100%;display:flex;align-items:center;padding:1vw 2vw;box-sizing:border-box}.search-icon{width:2.5vw;height:2.5vw;min-width:24px;min-height:24px;margin-right:1vw}.course-search-banner h1{color:#fff}.course-search-banner h1:after{background-color:#eab308}.search-placeholder{color:#3e8b70!important;font-family:Montserrat,sans-serif;font-size:1.5rem;font-weight:500;white-space:nowrap;background:transparent;border:none}.search-placeholder:focus{outline:none}.course-search-banner .diamond{bottom:-10%;right:10%;width:6vw;height:6vw;border-radius:20%;transform:rotate(45deg);position:absolute;box-shadow:2px 2px 5px 2px #00000086}.course-search-banner .diamond:nth-child(2){left:10%;top:-8%;width:3vw;height:3vw}.course-search-banner .diamond:nth-child(3){left:14%;top:2%;width:5vw;height:5vw}.course-search-banner .diamond:nth-child(4){left:10%;top:18%;width:3vw;height:3vw}@media (max-width: 768px){.text-group{font-size:8vw}.search-placeholder{font-size:4vw}.search-bar{width:80%}}.banner-cta{position:relative;width:100%;min-height:480px;background:#def6e4;margin:40px 0;overflow:hidden;display:flex;align-items:center;justify-content:center}.banner-content{display:flex;align-items:center;justify-content:center;width:90%;max-width:1600px;margin:0 auto;z-index:2;position:relative;padding:60px 0}.banner-image-box{position:relative;width:540px;height:320px;margin-right:60px;flex-shrink:0;display:flex}.banner-image-border{position:absolute;width:100%;height:100%;border:1px solid #68DCA3;border-radius:70px;z-index:1;top:-5%;left:3%}.banner-image{position:absolute;width:100%;height:100%;object-fit:cover;border-radius:70px;z-index:2;top:0;left:0}.banner-text{display:flex;flex-direction:column;align-items:flex-start;gap:50px;width:550px;min-width:300px}.banner-title{font-family:Public Sans,Lato,Arial,sans-serif;font-style:normal;font-weight:600;font-size:40px;line-height:48px;color:#06241b;margin-bottom:0}.banner-title .highlight{color:#3b8068}.banner-subtitle{font-family:Public Sans,Lato,Arial,sans-serif;font-style:normal;font-weight:400;font-size:24px;line-height:32px;color:#06241b;margin-bottom:0}.banner-btn{display:flex;align-items:center;justify-content:center;padding:12px 24px;gap:10px;width:211px;height:48px;background:#3b8068;border-radius:8px;border:none;font-family:Public Sans,Lato,Arial,sans-serif;font-weight:500;font-size:16px;line-height:24px;color:#fff;cursor:pointer;transition:background .2s}.banner-btn:hover{background:#2e9780}.banner-ellipse{position:absolute;border-radius:50%;z-index:1}.ellipse-green{width:20.5px;height:20px;left:3%;bottom:12%;background:#3b8068}.ellipse-yellow{width:18.45px;height:18px;left:30%;top:8%;background:#eab308}.ellipse-mint{width:49.2px;height:48px;left:42%;bottom:10%;background:#68dca3}.banner-star{position:absolute;left:-37.5%;top:18%;z-index:3}.banner-vector{position:absolute;left:35%;top:0%;z-index:1}.banner-vector3{position:absolute;width:97.58px;height:126.32px;left:42%;top:0;border:none;transform:matrix(-.77,-.64,.66,-.75,0,0);z-index:2;pointer-events:none;-webkit-user-select:none;user-select:none;rotate:136deg}@media (max-width: 1200px){.banner-content{flex-direction:column;align-items:center;gap:32px;padding:40px 0}.banner-image-box{margin-right:0;margin-bottom:32px}.banner-text{width:90vw;max-width:534px;align-items:center;text-align:center}}@media (max-width: 700px){.banner-content{flex-direction:column;padding:24px 0}.banner-image-box{width:90vw;height:180px;margin-bottom:24px}.banner-title{font-size:28px;line-height:36px}.banner-subtitle{font-size:18px;line-height:26px}.banner-btn{width:100%;min-width:0;font-size:15px;height:44px}}.courses-layout{display:flex;flex-direction:column;gap:1rem;padding:2rem;background-color:#f8fafc;min-height:100vh}.block{padding:2rem;border-radius:12px;color:#fff;font-size:1.5rem;text-align:center;font-weight:700}.blue{background-color:#3b82f6}.purple{background-color:#8b5cf6}.green{background-color:#22c55e}.teal{background-color:#14b8a6}.yellow{background-color:#eab308}.orange{background-color:#f97316}.light{background-color:#cbd5e1;color:#1e293b}.global-carousel-wrapper{position:relative;overflow:hidden;width:100%;margin:auto}.global-carousel-wrapper .carousel-container{overflow:hidden;width:100%}.carousel-inner{display:flex;transition:transform .6s ease-in-out;width:100%}.carousel-item{flex:0 0 100%;display:flex;justify-content:center;align-items:center}.left-arrow{left:10px}.right-arrow{right:10px}.carousel-dots{display:flex;justify-content:center;margin-top:12px;gap:8px;position:absolute;bottom:2.5em}.dot{width:10px;height:10px;border-radius:50%;background:#fff;cursor:pointer;transition:background .3s}.dot.active{background:#81dc9c}.course-hero-card{width:100%;height:60vh;background-size:cover;background-repeat:no-repeat;background-position:center;position:relative;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:flex-start;padding:1rem 5rem;color:#fff}.course-hero-card:after{content:"";width:100%;height:100%;background:linear-gradient(90deg,#000,#0000 30%);left:0;position:absolute;z-index:10}.overlay{border-radius:12px;width:100%;height:100%;display:flex;flex-direction:column;justify-content:space-evenly}.category-badge{color:#fff;font-weight:600;font-size:.8rem;padding:.5rem .9rem;letter-spacing:1.5px;border-radius:6px;align-self:flex-start;width:fit-content;margin-bottom:1rem;background:linear-gradient(90deg,#62d49f,#52c196);box-shadow:0 0 15px #81dc9c;text-shadow:0 0 1px #fff;z-index:11}.course-title{font-size:3.5rem;font-weight:700;max-width:24ch;margin:0;line-height:1.2;z-index:11}.overlay .rating{margin-block:1em;z-index:11}.course-subtitle{font-size:1.5rem;font-weight:400;margin:.5rem 0 1.2rem}.rating{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.rating-people p{margin:0;font-size:.9rem}.get-course-button{color:#fff;font-weight:700;padding:1rem 2.5rem;border:none;border-radius:3px;cursor:pointer;align-self:flex-start;transition:background-color .3s ease;width:fit-content;background:linear-gradient(120deg,#2e9780,#81dc9c);transition:.3s;z-index:11}.get-course-button:hover{transform:translateY(-1em)}.filters-container{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem;width:50vw}.filter-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:#f7fdf9;border-radius:12px;cursor:pointer;transition:all .2s ease;width:10vw}.search-by-name{display:flex;width:50vw;align-items:center;gap:1em;margin-block:3em 2em}.search-by-name h2{color:#333;width:fit-content}.search-by-name .search-bar{border:2px solid #3e8b70;border-radius:50px;width:60%}.filter-item:hover{background-color:#d4f5e5;transform:translateY(-2px)}.shine{background:linear-gradient(90deg,#62d49f,#52c196);box-shadow:0 0 18px #81dc9c}.filter-icon{width:24px;height:24px}.filter-label{font-size:.95rem;font-weight:500;color:#333}.chat-container{display:flex;height:calc(100vh - 110px);min-height:560px;font-family:Arial,sans-serif;gap:0;overflow:hidden}.sidebar-chat{width:min(340px,32%);min-width:260px;border-right:1px solid #ccc;padding:1rem;background-color:#f8f8f8;overflow-y:auto}.user-info-chat{width:70%;min-width:0}.section-chat h4{margin-top:1rem;margin-bottom:.5rem}.user-item{display:flex;align-items:center;gap:.7rem;padding:.5rem;cursor:pointer;border-radius:6px}.user-item:hover,.user-item.active{background-color:#e1f5e1}.last-message{font-size:.9rem;font-weight:400;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.name{font-size:1rem;font-weight:bolder;color:#000;letter-spacing:.2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-chat{background-color:#4caf50;display:flex;align-items:center;justify-content:center;width:3em;height:3em;border-radius:50%;font-weight:bolder;font-size:1.2rem;position:relative}.avatar-chat-img{border-radius:50%;width:100%;height:100%}.chat-panel{flex:1;display:flex;flex-direction:column;padding:1rem;background-color:#fcfcfc;min-width:0;overflow:hidden}.ring-wraper{width:3em;height:3em;position:absolute;top:0;transform:scale(1);background-size:cover}.messages{flex:1;overflow-y:auto;margin-bottom:1rem;display:flex;flex-direction:column;gap:1rem}.message{max-width:75%;width:fit-content;padding:.6rem 1rem;border-radius:8px;font-size:.95rem;word-break:break-word}.incoming{background:linear-gradient(135deg,#eafce9,#d3f5d8);align-self:flex-start;border-radius:16px 16px 16px 4px;color:#1a1a1a}.outgoing{background:linear-gradient(135deg,#4caf50,#81c784);align-self:flex-end;border-radius:16px 16px 4px;color:#fff}.message-read-receipt{align-self:flex-end;margin-top:-.6rem;font-size:.75rem;color:#6b7280}.input-area{display:flex;gap:.5rem;align-items:center;border-top:1px solid #cccccc;padding-top:.75rem;min-height:70px}.input-area img{width:2.2rem;height:2.2rem}.input-area input,.input-text-area-chat{flex:1;padding:.7rem;font-size:1rem;border-radius:8px;border:none;background:#fff;color:#000}.input-area input:focus,.input-text-area-chat:focus{outline:none}.input-area button{background-color:transparent;border:1px solid #3e8b70;padding:.5rem;border-radius:8px;color:#fff;cursor:pointer;width:3rem;height:3rem}.input-area button img{width:1.2rem;height:1.2rem}.no-chat{font-size:1.2rem;color:gray;margin-top:2rem}.header-chat{min-height:56px;border-bottom:1px solid #cccccc;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.header-chat .user-item:hover{background:#fff;cursor:default}.chat-back-btn{border:1px solid #3e8b70;background:#fff;color:#2f6e55;border-radius:8px;padding:.4rem .75rem}@media (max-width: 1200px){.sidebar-chat{width:34%;min-width:240px}}@media (max-width: 900px){.chat-container{height:calc(100vh - 130px);min-height:420px}.chat-mobile{display:block}.sidebar-chat,.chat-panel{width:100%;min-width:0;height:100%}.sidebar-chat-hidden-mobile,.chat-panel-hidden-mobile{display:none}.message{max-width:88%}}@media (max-width: 520px){.sidebar-chat{padding:.75rem}.chat-panel{padding:.65rem}.name{font-size:.95rem}.last-message{font-size:.8rem}}.settings-container{padding:2rem}.tab-bar{display:flex;justify-content:center;gap:2rem;position:relative;padding-bottom:.5rem;margin-bottom:1em}.tab-button{background:none;border:none;cursor:pointer;font-size:1rem;font-weight:500;color:#6ba6a6;position:relative;padding:.5rem 0;transition:color .3s ease}.tab-button:hover,.tab-button.active{color:#419e9e}.tab-button:after{content:"";position:absolute;bottom:-6px;left:0;width:100%;height:2px;background-color:#419e9e;transform:scaleX(0);transform-origin:center;transition:transform .3s ease}.tab-button.active:after{transform:scaleX(1)}.tab-content{background-color:#fff;border-radius:1rem;padding:2rem;box-shadow:0 2px 10px #0000000d}.certificates-section{padding:1rem 2rem;color:#2c7a7b;font-family:Arial,sans-serif;margin-bottom:20vh}.certificates-section h3{text-align:start;margin-bottom:5vh}.certificates-grid{display:flex;gap:1rem;flex-wrap:wrap}.certificate-card{width:200px;border:1px solid #d0d0d0;border-radius:10px;overflow:hidden;background:#fff;box-shadow:0 2px 5px #0000001a}.certificate-image{position:relative;height:40%}.certificate-image img:first-child{width:100%;height:100%;object-fit:cover}.profile-icon{position:absolute;bottom:-15px;left:10px;width:32px;height:32px;border-radius:50%;border:2px solid white}.certificate-title{padding:1.5rem .5rem .5rem;font-size:.9rem;color:#444;font-weight:500}.certificate-btn{margin:.5rem;width:calc(100% - 1rem);background:#8fd19e;border:none;padding:.5rem;border-radius:6px;cursor:pointer;font-weight:700;color:#fff;font-size:.85rem;display:flex;align-items:center;justify-content:center}.certificate-btn:hover{background-color:#75c487}.platform-section .course-search-banner{display:flex;flex-direction:row;padding-inline:3em}.support-content{display:flex;flex-direction:column;align-self:flex-end;gap:1em;margin-bottom:8%}.support-content h3{color:#fff;font-size:2.5rem;font-weight:700}.support-content p{color:#fff}.button-support{display:flex;gap:2em}.button-support .outline-button{border:2px solid #fff;color:#fff}.platform-section .course-search-banner img{width:55%;align-self:flex-start;margin-top:5%}.cover-section{margin-top:2rem}.cover-preview{width:100%}.cover-image{width:100%;height:200px;border-radius:16px;background-size:cover;background-position:center;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.cover-overlay{background:#0006;border-radius:8px;padding:8px 16px}.change-cover-btn{background:#ffffffe6;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.change-cover-btn:hover{background:#fff;transform:translateY(-2px)}.budget-section{display:grid;gap:1.5rem}.budget-item{display:flex;flex-direction:column;gap:.5rem}.budget-item label{font-weight:600;color:#374151;font-size:14px}.budget-input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:16px;transition:all .3s ease;background:#fff}.budget-input:focus{outline:none;border-color:#2f6e55;box-shadow:0 0 0 3px #2f6e551a}.budget-progress{background:#f9fafb;padding:1.5rem;border-radius:12px;border:1px solid #e5e7eb}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-weight:600;color:#374151}.progress-bar{width:100%;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#2f6e55,#34d399);transition:width .3s ease;border-radius:4px}.certificates-section{min-height:200px}.certificates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.certificate-card{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;transition:all .3s ease;position:relative;overflow:hidden}.certificate-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#2f6e55,#34d399)}.certificate-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.certificate-icon{font-size:2.5rem;margin-bottom:1rem}.certificate-info h4{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.certificate-info p{color:#6b7280;margin:.25rem 0;font-size:.875rem}.download-btn{background:linear-gradient(135deg,#2f6e55,#34d399);color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:600;margin-top:1rem;transition:all .3s ease;font-size:.875rem}.download-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2f6e554d}.no-certificates{display:flex;align-items:center;justify-content:center;min-height:200px}.empty-state{text-align:center;padding:2rem}.empty-icon{font-size:3rem;margin-bottom:1rem;display:block}.empty-state h4{font-size:1.25rem;font-weight:600;color:#374151;margin-bottom:.5rem}.empty-state p{color:#6b7280;font-size:.875rem;max-width:300px;margin:0 auto}.save-confirmation{text-align:center}.changes-list{list-style:none;padding:0;margin:1rem 0;text-align:left;background:#f8fafc;border-radius:8px;padding:1rem}.changes-list li{padding:.25rem 0;color:#374151;font-size:.875rem}.privacy-settings h2{font-size:22px;margin-bottom:20px;color:#333}.setting-row{display:flex;justify-content:space-between;align-items:center;margin-block:2em;font-size:16px;color:#555}.row-line{width:100%;margin-block:2em;height:1px;background:#a7a8af;display:block}.account-settin-private{display:flex;flex-direction:column;gap:2em}.account-settin-private .fill-button{background:#2f6e55;border:1px solid #2f6e55;color:#fff;margin-top:1em}.switch{position:relative;display:inline-block;width:50px;height:26px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ccc;border-radius:26px;transition:.4s}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:3px;background-color:#fff;border-radius:50%;transition:.4s}input:checked+.slider{background-color:#3e8b70}input:checked+.slider:before{transform:translate(24px)}.slider.round{border-radius:26px}.edit-profile-container{margin-bottom:var(--space-xl);padding:var(--space-lg);background:#fff;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000001a}.avatar-section{margin-bottom:var(--space-lg)}.avatar-preview{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.avatar-image{width:80px;height:80px;border-radius:50%;object-fit:cover}.change-avatar-btn{background:var(--primary);color:#fff;border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm);transition:var(--transition-normal);width:fit-content}.change-avatar-btn:hover{background:var(--primary-dark)}.edit-profile-container .button-box{display:flex;justify-content:flex-end;margin-block:3em;gap:2em}.edit-profile-container .button-box .outline-button{border:1px solid #2f6e55;color:#2f6e55}.edit-profile-container .button-box .fill-button{background:#2f6e55;color:#fff;border:none}.save-btn:hover{background-color:#2f6e55}@media (max-width: 600px){.edit-profile-container{padding:20px}.title{font-size:20px}}.coupons-section{margin-top:20px}.coupons-container{display:flex;flex-wrap:wrap;gap:20px;padding-inline:10%;justify-content:center}.coupons-section h3{font-size:1.5rem;margin-block:2em}.coupon-card{background-image:url(/assets/conpon-HUzRS0w1.png);width:22vw;height:15vh;display:flex;justify-content:space-between;background-size:cover;align-items:center;box-shadow:0 0 15p;padding-inline:3em;margin:1em;gap:20%;padding-block:1em}.coupon-card .co-icon{width:60px;height:60px;background:#f5f5f5;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:#505050}.coupon-card .content{flex-grow:1;height:100%}.coupon-card .content .discount{font-family:Montserrat,sans-serif;font-size:20px;font-weight:600;color:#3c1698}.coupon-card .content .description{font-size:14px;color:#737373;margin-bottom:2em;font-weight:500}.coupon-card .content .validity{font-size:12px;color:#8a8a8a}.user-bar-profile{display:flex;flex-direction:column}.cover-container{position:relative;border-radius:1em;height:35vh;overflow:hidden}.cover{border-radius:1em;height:35vh;width:100%;object-fit:cover;transition:all .3s ease}.profile-head{display:flex;justify-content:space-between}.avatar-settings{width:20%;transform:translateY(-40%);padding-left:2em}.avatar-img{width:5em;position:relative;display:flex;align-content:center;justify-content:center;border-radius:50%;overflow:hidden}.profile-info h5{font-size:1.2rem}.social-media-box{width:12%;margin-top:2%}.title{color:#737c88}.social{display:flex}.social img{width:1.5em}.no-social-links{color:#6b7280;font-size:.875rem;font-style:italic;margin:0}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes floaty{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.course-details-container{padding:var(--space-xxl) var(--space-xl) var(--space-xl);color:var(--text-dark);background:var(--background-light);min-height:100dvh}.page-wrap{max-width:90vw;margin:0 auto;animation:fadeSlideUp .5s ease both;padding:2em}.course-details-header{display:flex;align-items:center;gap:var(--space-xl);margin-bottom:var(--space-md)}.back-link{text-decoration:none;color:var(--primary);font-size:var(--text-base);display:inline-flex;align-items:center;gap:var(--space-sm);border-radius:999px;width:fit-content;transition:.2s ease}.back-link:hover{transform:scale(1.1);color:#063}.course-title{font-size:var(--text-lg);line-height:1.1;font-weight:800;letter-spacing:.2px;max-width:fit-content}.course-details-body{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:var(--space-xl);align-items:start}@media (max-width: 1080px){.course-details-body{grid-template-columns:1fr}}.course-video{position:relative;border-radius:32px;overflow:hidden;box-shadow:var(--shadow-md);background:#000}.course-video img{display:block;aspect-ratio:16/9;object-fit:cover;transform:scale(1.01)}.course-video .overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#00000073,#00000014 35%,#0000 60%)}.instructor-info-video{position:absolute;bottom:12px;left:12px;display:flex;align-items:center;gap:10px;background:#fffc;color:var(--text-dark);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:6px 12px;border-radius:16px;border:1px solid rgba(0,0,0,.06);width:fit-content}.instructor-avatar{width:40px;height:40px;border-radius:10px;object-fit:cover}.play-btn{position:absolute;right:12px;bottom:12px;background:var(--primary);color:#fff;border:none;border-radius:999px;padding:10px 18px;font-weight:700;cursor:pointer;box-shadow:var(--shadow-sm)}.play-btn:hover{filter:brightness(.98)}.thumbnail-float{animation:floaty 9s ease-in-out infinite}.media-meta{display:flex;justify-content:flex-end;gap:8px;margin-top:10px;color:var(--text-mid);font-weight:600}.media-meta small{font-size:var(--text-sm);color:var(--text-mid)}.course-tabs{margin:var(--space-lg) 0 var(--space-md);display:flex;gap:var(--space-md);border-bottom:1px solid #e2e8f0;position:relative}.tab-link{background:none;border:none;color:var(--text-mid);padding:12px 0;cursor:pointer;font-size:var(--text-md);font-weight:700;position:relative}.tab-link.active{color:var(--text-dark)}.tab-underline{position:absolute;bottom:-1px;height:3px;width:var(--w, 0);left:var(--x, 0);background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:3px;transition:.25s ease}.section-card{background:var(--surface);border:1px solid #e6f4ec;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.section-card+.section-card{margin-top:var(--space-md)}.instructor-details{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md);margin-top:var(--space-md)}.stat{background:#f1fbf6;border:1px solid #e6f4ec;border-radius:var(--radius-sm);padding:var(--space-md)}.stat .k{font-size:1.1rem;font-weight:800;color:var(--primary)}.stat .l{color:var(--text-mid);font-weight:600;font-size:.95rem}.course-purchase-card{position:sticky;top:14px;background:var(--surface);border:1px solid #e6f4ec;border-radius:var(--radius-md);padding:var(--space-lg);box-shadow:var(--shadow-md)}.price{font-size:1.75rem;font-weight:900;color:var(--secondary)}.old-price{text-decoration:line-through;color:#94a3b8;margin-left:.5rem}.discount{background:#e8f8ee;color:var(--primary);padding:.2rem .5rem;border-radius:999px;margin-left:.5rem;border:1px solid #d7f1e1;font-weight:800}.buy-now-btn{width:100%;padding:14px 16px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:1rem;cursor:pointer;margin:14px 0;font-weight:800;box-shadow:0 10px 20px #2e97802e}.buy-now-btn:hover{filter:brightness(.98)}.rating{color:var(--text-mid);font-weight:700}.publisher-info{display:flex;align-items:center;gap:12px;margin-top:12px}.publisher-avatar{width:48px;height:48px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow-sm)}@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}.exercices-side-bar{width:280px;min-width:250px;padding:var(--space-xl) 0;background:linear-gradient(135deg,#2e978060,#1f6b5c60);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);position:sticky;top:var(--space-xl);max-height:calc(100vh - var(--space-4xl));overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.exercices-side-bar::-webkit-scrollbar{display:none}.exercices-side-bar ul{list-style:none;padding:0;margin:0}.exercices-side-bar li{padding:var(--space-lg) var(--space-xl);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;display:flex;color:#fffc;align-items:center;transition:var(--transition-normal);border-radius:var(--radius-md);margin:var(--space-xs) var(--space-md);gap:var(--space-sm);position:relative;justify-content:space-between;width:fit-content}.exercise-number{width:24px;height:24px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-bold);flex-shrink:0}.exercise-title{flex:1;text-align:left}.exercise-status-icon{font-size:var(--text-base);flex-shrink:0}.exercices-side-bar li.locked{opacity:.5;color:#fff6}.exercices-side-bar li.locked .exercise-number{background:#ffffff1a}.exercices-side-bar li.completed .exercise-number{background:#22c55ecc}.exercices-side-bar li.attempted .exercise-number{background:#f59e0bcc}.exercices-side-bar li:hover:not(.locked){background:#ffffff1a;color:#fff;transform:translate(4px)}.exercices-side-bar li.locked:hover{transform:none}.exercices-side-bar li.active{background:#fff3;color:#fff;font-weight:var(--font-semibold);box-shadow:var(--shadow-md)}.exercices-side-bar li.active .exercise-number{background:#ffffffe6;color:var(--primary)}.exercise-type-badge{background:#fff3;color:#fff;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-medium);margin-left:auto}@media (max-width: 1024px){.exercices-side-bar{width:240px;min-width:220px}.exercices-side-bar li{padding:var(--space-md) var(--space-lg);font-size:var(--text-sm)}.exercices-side-bar li:before{width:1.5rem;height:1.5rem}}@media (max-width: 768px){.exercices-side-bar{width:100%;min-width:unset;position:static;max-height:none;margin-bottom:var(--space-xl)}.exercices-side-bar ul{display:flex;flex-direction:row;overflow-x:auto;padding:var(--space-sm);gap:var(--space-sm)}.exercices-side-bar li{flex-shrink:0;min-width:200px;margin:0}}@media (max-width: 480px){.exercices-side-bar li{min-width:160px;padding:var(--space-sm) var(--space-md);font-size:var(--text-xs)}.exercices-side-bar li:before{width:1rem;height:1rem}.exercise-type-badge{display:none}}.result-modal-content{text-align:center;padding:2rem}.result-icon-large{font-size:4rem;margin-bottom:1.5rem;animation:bounceIn .6s ease-out}.result-icon-large.correct{animation:bounceIn .6s ease-out,pulse 2s infinite .6s}.result-title{font-size:2rem;font-weight:700;margin-bottom:1rem;color:var(--text-dark)}.result-details{margin-bottom:2rem}.result-message{font-size:1.2rem;color:var(--text-muted);margin-bottom:1.5rem;line-height:1.6}.result-explanation,.result-hint{background:var(--background-light);padding:1.5rem;border-radius:var(--radius-lg);margin-bottom:1rem;border-left:4px solid var(--primary)}.result-explanation h4,.result-hint h4{font-size:1.1rem;font-weight:600;margin-bottom:.5rem;color:var(--text-dark);display:flex;align-items:center;gap:.5rem}.result-explanation p,.result-hint p{margin:0;color:var(--text-muted);line-height:1.5}.result-hint{border-left-color:#f59e0b}.result-actions{display:flex;flex-direction:column;gap:1rem;align-items:center}.next-lesson-modal-btn{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;padding:1rem 2rem;border-radius:var(--radius-lg);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #2e97804d;min-width:200px}.next-lesson-modal-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2e978066}.close-modal-btn{background:var(--background-muted);color:var(--text-dark);border:2px solid var(--border-light);padding:.8rem 2rem;border-radius:var(--radius-lg);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;min-width:200px}.close-modal-btn:hover{background:var(--background-dark);border-color:var(--border-dark)}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media (max-width: 768px){.result-modal-content{padding:1.5rem}.result-icon-large{font-size:3rem;margin-bottom:1rem}.result-title{font-size:1.5rem}.result-message{font-size:1rem}.result-explanation,.result-hint{padding:1rem}.next-lesson-modal-btn,.close-modal-btn{width:100%;min-width:unset}}.sparkles-container{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:9999;overflow:hidden}.sparkle{position:absolute;font-size:1.5rem;animation:sparkleAnimation 2s ease-out forwards;filter:drop-shadow(0 0 6px rgba(255,215,0,.8))}@keyframes sparkleAnimation{0%{opacity:0;transform:translateY(20px) scale(0)}10%{opacity:1;transform:translateY(0) scale(1)}20%{opacity:1;transform:translateY(-10px) scale(1.2) rotate(180deg)}to{opacity:0;transform:translateY(-50px) scale(.8) rotate(360deg)}}.sparkle:nth-child(2n){animation-name:sparkleAnimationReverse}@keyframes sparkleAnimationReverse{0%{opacity:0;transform:translateY(-20px) scale(0) rotate(0)}10%{opacity:1;transform:translateY(0) scale(1) rotate(90deg)}20%{opacity:1;transform:translateY(10px) scale(1.2) rotate(270deg)}to{opacity:0;transform:translateY(50px) scale(.8) rotate(360deg)}}.sparkle:nth-child(3n){animation-name:sparkleAnimationSpin}@keyframes sparkleAnimationSpin{0%{opacity:0;transform:scale(0) rotate(0)}15%{opacity:1;transform:scale(1.5) rotate(180deg)}50%{opacity:1;transform:scale(1) rotate(360deg)}to{opacity:0;transform:scale(0) rotate(720deg)}}.sparkle:nth-child(5n){color:#ff69b4;filter:drop-shadow(0 0 6px rgba(255,105,180,.8))}.sparkle:nth-child(7n){color:#00bfff;filter:drop-shadow(0 0 6px rgba(0,191,255,.8))}.sparkle:nth-child(11n){color:#32cd32;filter:drop-shadow(0 0 6px rgba(50,205,50,.8))}.quiz-exercise{max-width:800px;margin:0 auto;padding:2rem}.quiz-header{text-align:center}.question-number{display:inline-block;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:.5rem 1.5rem;border-radius:50px;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1.5rem}.quiz-question{font-size:1.75rem;font-weight:700;color:#1f2937;line-height:1.4;max-width:700px;margin:0 auto}.quiz-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.option-button{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-radius:16px;background:linear-gradient(180deg,#fae5b6,#f1d294);cursor:pointer;transition:all .3s ease;text-align:left;font-size:1rem;position:relative;overflow:hidden;border:1px solid #6d6d6d}.option-button:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#000,gray);opacity:0;transition:opacity .3s ease}.option-button:hover:not(.disabled){border-color:#000;transform:translateY(-2px)}.option-button:hover:not(.disabled):before{opacity:.05}.option-button.selected{border-color:#000;transform:translateY(-2px)}.option-button.correct{border-color:#10b981;background:#f0fdf4;color:#065f46}.option-button.incorrect{border-color:#ef4444;background:#fef2f2;color:#991b1b}.option-button.correct-answer{border-color:#10b981;background:#f0fdf4;animation:highlight .5s ease-in-out}@keyframes highlight{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.option-button.disabled{cursor:not-allowed;opacity:.8}.option-letter{width:40px;height:40px;border-radius:50%;background:#f3f4f6;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;color:#6b7280;flex-shrink:0;transition:all .3s ease;position:relative;z-index:1}.option-button.selected .option-letter{background:#000;color:#fff}.option-button.correct .option-letter{background:#10b981;color:#fff}.option-button.incorrect .option-letter{background:#ef4444;color:#fff}.option-button.correct-answer .option-letter{background:#10b981;color:#fff}.option-text{flex:1;font-weight:500;color:#374151;line-height:1.5;position:relative;z-index:1}.option-button.selected .option-text{color:#1f2937;font-weight:600}.option-indicator{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.125rem;font-weight:700;position:relative;z-index:1}.quiz-actions{text-align:center;margin:2rem 0}.submit-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:1rem 3rem;border:none;border-radius:50px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #6366f14d}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6366f166}.submit-btn:active{transform:translateY(0)}.quiz-result{margin-top:2rem;padding:2rem;background:#f9fafb;border-radius:16px;border:1px solid #e5e7eb;text-align:center}.result-badge{display:inline-block;padding:.75rem 2rem;border-radius:50px;font-size:1.125rem;font-weight:700;margin-bottom:1rem}.result-badge.correct{background:#10b981;color:#fff}.result-badge.incorrect{background:#ef4444;color:#fff}.result-explanation{font-size:1rem;color:#6b7280;margin-bottom:1rem;line-height:1.6}.hint-section{background:#fffbeb;border:1px solid #fbbf24;border-radius:12px;padding:1rem;color:#92400e;font-size:.875rem;line-height:1.5;margin-top:1rem}.drag-and-drop-exercise{max-width:54vw;margin:0 auto;padding:2rem;border-radius:20px}.drag-and-drop-exercise h2{font-size:1.75rem;font-weight:700;color:#1f2937;text-align:center;padding-bottom:1rem}.dnd-container{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:2rem}.dnd-section{padding:2rem;border-radius:16px;min-height:400px}.section-title{font-size:1.25rem;font-weight:700;color:#374151;margin-bottom:1.5rem;text-align:center}.dnd-items{display:flex;flex-direction:column;gap:1rem}.dnd-item{background:#fff;padding:1rem 1.5rem;border-radius:12px;border:2px solid #e5e7eb;cursor:grab;transition:all .3s ease;font-weight:500;color:#374151;box-shadow:0 2px 8px #0000000d}.dnd-item:hover:not(.disabled){border-color:#3d3d3d;transform:translateY(-2px);box-shadow:0 4px 15px #6366f133}.dnd-item.dragging{opacity:.5;cursor:grabbing;transform:rotate(5deg)}.dnd-item.disabled{opacity:.6;cursor:not-allowed;background:#f3f4f6}.dnd-zones{display:flex;gap:1rem}.dnd-zone{min-height:80px;border:2px dashed #d1d5db;border-radius:12px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;transition:all .3s ease;position:relative}.dnd-zone.filled{border-style:solid;border-color:#6366f1;background:#f0f0ff}.dnd-zone.correct{border-color:#10b981;background:#f0fdf4}.dnd-zone.incorrect{border-color:#ef4444;background:#fef2f2}.zone-label{font-weight:600;color:#6b7280;font-size:.875rem;margin-bottom:.5rem}.dropped-item{display:flex;align-items:center;justify-content:space-between;width:100%;background:#fff;padding:.75rem 1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;position:relative}.item-text{font-weight:500;color:#374151;flex:1}.remove-item{background:#ef4444;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:.875rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.remove-item:hover{background:#dc2626;transform:scale(1.1)}.match-indicator{font-size:1.125rem;font-weight:700;position:absolute;right:-8px;top:-8px;background:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003}.empty-zone{color:#9ca3af;font-style:italic;font-size:.875rem}.exercise-controls{text-align:center;margin-top:2rem}.exercise-controls .submit-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:1rem 3rem;border:none;border-radius:50px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #10b9814d}.exercise-controls .submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #10b98166}.exercise-controls .submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.fill-blanks-exercise{max-width:50vw;margin:0 auto;padding:2rem;border-radius:20px}.fill-blanks-exercise h2{font-size:1.75rem;font-weight:700;color:#1f2937;text-align:center;margin-bottom:3rem;display:none;padding-bottom:1rem}.passage-container{background:#f9fafb;padding:2rem;border-radius:16px;border:1px solid #e5e7eb;margin-bottom:2rem;line-height:1.8;font-size:1.125rem;color:#374151}.blank-input{display:inline-block;min-width:120px;padding:.5rem 1rem;border:2px solid #d1d5db;border-radius:8px;background:#fff;font-size:1rem;font-weight:500;text-align:center;margin:0 .25rem;transition:all .3s ease}.blank-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.blank-input.correct{border-color:#10b981;background:#f0fdf4;color:#065f46}.blank-input.incorrect{border-color:#ef4444;background:#fef2f2;color:#991b1b}.blank-input:disabled{background:#f3f4f6;cursor:not-allowed}@media (max-width: 768px){.quiz-exercise,.drag-and-drop-exercise,.fill-blanks-exercise{padding:1.5rem;margin:1rem}.quiz-question{font-size:1.5rem}.option-button{padding:1.25rem;gap:.75rem}.option-letter{width:32px;height:32px;font-size:1rem}.dnd-container{grid-template-columns:1fr;gap:2rem}.dnd-section{min-height:300px;padding:1.5rem}.submit-btn{padding:.875rem 2rem;font-size:1rem}}@media (max-width: 480px){.quiz-question{font-size:1.25rem}.option-button{padding:1rem;gap:.5rem}.option-text{font-size:.875rem}.dnd-section{padding:1rem}}.exercise-controls{padding:2rem;border-radius:16px;margin-top:3rem}.progress-section{margin-bottom:2rem}.progress-info{display:flex;flex-direction:column;gap:1rem;align-items:center}.progress-text{font-size:1rem;font-weight:600;color:#6b7280}.progress-bar{width:200px;height:8px;background:#e5e7eb;border-radius:20px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:20px;transition:width .5s ease;position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.exercise-controls .submit-btn.disabled{background:#9ca3af!important;color:#fff!important;cursor:not-allowed!important;transform:none!important;box-shadow:0 2px 8px #9ca3af33!important;opacity:.8}.submission-status{display:flex;flex-direction:column;align-items:center;gap:1rem}.status-badge{padding:.75rem 2rem;border-radius:50px;font-size:1.125rem;font-weight:700}.status-badge.correct{background:#10b981;color:#fff}.status-badge.incorrect{background:#ef4444;color:#fff}.score-info{font-size:1rem;color:#6b7280;font-weight:500}.course-content-page{min-height:100vh;width:100%;display:flex;flex-direction:column;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-image:url(/assets/bg-B_A5BAZ8.png)}.course-content-page .sand{position:absolute;top:1%;right:1%;width:5em;animation:rotateSand 3s infinite ease-in-out}.course-content-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem}.course-content-header .user-info{display:flex;align-items:center;gap:1rem;width:fit-content;margin:0}.course-content-header .user-info div{width:5em}.course-content-header .user-info .user-name{font-weight:700;font-size:1rem}.user-avatar{width:50px;height:50px;border-radius:50%;display:block;object-fit:cover}.course-progress-info{display:flex;align-items:center;gap:var(--space-md);width:fit-content;align-self:center}.progress-text,.progress-percentage{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-dark);white-space:nowrap}.outline-progress{width:fit-content;padding:6px;border:8px solid #8f420f;border-radius:20px;background:#ffdca5}.progress-bar-container{width:25em;height:1em;background:#ffdca5;border-radius:4px;overflow:hidden}.progress-bar{height:100%;background:#fe9b26;border-radius:4px;transition:width .3s ease-in-out;will-change:width;contain:layout}.course-content-body{display:flex;flex-grow:1;gap:var(--space-lg);padding:0 var(--space-lg)}.exercise-container{flex-grow:1;display:flex;justify-content:center;align-items:center;padding:2rem;min-height:400px;position:relative}.exercise-content{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.exercise-content img{width:15em;position:absolute;right:5%;bottom:10%}.exercise-placeholder{display:flex;justify-content:center;align-items:center;min-height:300px;color:var(--text-muted);font-size:var(--text-lg)}.course-content-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border-light)}.exit-course-btn{background:var(--background-muted);color:#fff;border:1px solid var(--border-light);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-lg);text-decoration:none;font-weight:var(--font-medium);transition:var(--transition-normal);width:fit-content}.exit-course-btn:hover{background:var(--background-dark);color:#fff}.next-lesson-btn{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;padding:var(--space-sm) var(--space-xl);border-radius:var(--radius-lg);font-weight:var(--font-medium);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #2e97804d}.next-lesson-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2e978066}.next-lesson-btn:disabled{background:var(--background-muted);color:var(--text-light);cursor:not-allowed;transform:none;box-shadow:none}.course-content-footer button{padding:.8rem 1.5rem;border:none;border-radius:var(--radius-lg);width:fit-content;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;cursor:pointer;transition:all .3s ease;font-weight:var(--font-medium);box-shadow:0 4px 12px #2e97804d}.course-content-footer button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2e978066}.course-content-footer button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.quiz-exercise{width:100%;max-width:600px;text-align:center;min-height:400px;contain:layout}.quiz-exercise h2{margin-bottom:2rem;font-size:1.5rem}.options button{display:block;width:100%;padding:1rem;font-size:1.5rem;margin-bottom:1rem;background:linear-gradient(180deg,#fae5b6,#f1d294);border:1px solid #6d6d6d72;border-radius:10px;cursor:pointer;box-shadow:0 0 15px #000;color:#000;transition:transform .2s ease,box-shadow .2s ease;will-change:transform}.options button:hover{transform:translate(-10px);box-shadow:4px 0 15px #000}.options button.selected{border-color:#007bff}.options button.correct{background-color:#d4edda;border-color:#c3e6cb}.options button.incorrect{background:linear-gradient(180deg,#f8d7da,#f5c6cb);border-color:#f5c6cb}.options button.disabled{opacity:.7;cursor:not-allowed}.options button:disabled:hover{transform:none;box-shadow:0 0 15px #000}.submit-answer-btn{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);font-size:var(--text-base);font-weight:var(--font-medium);cursor:pointer;margin-top:var(--space-lg);transition:all .3s ease;box-shadow:0 4px 12px #2e97804d}.submit-answer-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2e978066}.feedback{margin-top:var(--space-lg);font-size:var(--text-lg);font-weight:var(--font-medium);text-align:center}.success-feedback{color:var(--success);padding:var(--space-md);background:#22c55e1a;border-radius:var(--radius-lg);border:1px solid rgba(34,197,94,.3)}.error-feedback{color:#dc2626;padding:var(--space-md);background:#dc26261a;border-radius:var(--radius-lg);border:1px solid rgba(220,38,38,.3)}.reading-complete{position:absolute;bottom:var(--space-xl);right:var(--space-xl);background:var(--success);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);font-weight:var(--font-medium);box-shadow:0 4px 12px #22c55e4d}.exercise-header{text-align:center;margin-bottom:var(--space-xl)}.exercise-header h2{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-dark);margin-bottom:var(--space-sm)}.exercise-instruction{font-size:var(--text-lg);color:var(--text-muted);margin:0;display:none}.section-title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--text-dark);margin-bottom:var(--space-md);text-align:center}.words-section .section-title{display:none}.exercise-controls{display:flex;justify-content:center;margin-top:var(--space-xl)}.submit-btn{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;padding:var(--space-md) var(--space-2xl);border-radius:var(--radius-lg);font-size:var(--text-lg);font-weight:var(--font-semibold);cursor:pointer;transition:all .3s ease;width:fit-content;box-shadow:0 4px 12px #2e97804d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2e978066}.submit-btn:disabled{cursor:not-allowed;transform:none;box-shadow:none}.result-feedback{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-xl);border-radius:var(--radius-xl);margin-top:var(--space-xl);animation:slideIn .5s ease-out}.result-feedback.correct{background:linear-gradient(135deg,#22c55e1a,#22c55e0d);border:2px solid rgba(34,197,94,.3)}.result-feedback.incorrect{background:linear-gradient(135deg,#dc26261a,#dc26260d);border:2px solid rgba(220,38,38,.3)}.result-icon{font-size:var(--text-3xl);flex-shrink:0}.result-content h3{font-size:var(--text-xl);font-weight:var(--font-bold);margin:0 0 var(--space-sm) 0}.result-content p{margin:0 0 var(--space-sm) 0;color:var(--text-muted);line-height:var(--leading-relaxed)}.result-explanation{font-style:italic;background:#ffffff80;padding:var(--space-sm);border-radius:var(--radius-md)}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.drag-and-drop-exercise{width:100%;max-width:70vw;margin:0 auto;min-height:500px;contain:layout}.dnd-container{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2xl);margin-top:var(--space-xl)}.dnd-section{padding:var(--space-xl);border-radius:var(--radius-xl)}.dnd-items{display:flex;flex-direction:column;gap:var(--space-md)}.dnd-zones{display:flex;gap:var(--space-md)}.dnd-item{padding:var(--space-md);background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-radius:var(--radius-lg);cursor:grab;transition:all .3s ease;box-shadow:0 2px 8px #2e978033;-webkit-user-select:none;user-select:none;font-weight:var(--font-medium);text-align:center}.dnd-item:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 4px 16px #2e97804d}.dnd-item.dragging{transform:rotate(5deg) scale(1.02);opacity:1;box-shadow:0 6px 20px #2e978066;z-index:1000}.dnd-item.disabled{background:var(--background-muted);color:var(--text-light);cursor:not-allowed}.dnd-zone{padding:var(--space-lg);border:2px dashed var(--border-light);border-radius:var(--radius-lg);min-height:120px;background:var(--background-light);transition:all .3s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm)}.dnd-zone.drag-over{border-color:var(--primary);background:#2e97801a;transform:scale(1.02)}.dnd-zone.filled{border-color:var(--success);background:#22c55e1a}.dnd-zone.correct{border-color:var(--success);background:#22c55e26}.dnd-zone.incorrect{border-color:#dc2626;background:#dc26261a}.zone-label{font-size:var(--text-base);color:var(--text-dark);font-weight:var(--font-semibold);text-align:center;margin-bottom:var(--space-sm)}.empty-zone{color:var(--text-light);font-style:italic;font-size:var(--text-sm)}.dropped-item{background:var(--success);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--space-sm);font-weight:var(--font-medium);position:relative}.item-text{flex:1}.match-indicator{font-size:var(--text-lg);font-weight:var(--font-bold)}.remove-item{background:#ffffff4d;border:none;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--text-sm);transition:var(--transition-normal)}.remove-item:hover{background:#ffffff80}.fill-blanks-exercise{width:100%;max-width:50vw;margin:0 auto;min-height:500px;contain:layout}.sentences-section{background:radial-gradient(#fff5de,#f1d294);padding:var(--space-2xl);border-radius:var(--radius-xl);margin-bottom:var(--space-xl);border:1px solid #6d6d6d72;box-shadow:0 4px 15px 4px #3d3d3d}.sentences-container{display:flex;flex-direction:column;gap:var(--space-lg)}.sentence-with-blanks{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-xs);font-size:var(--text-lg);line-height:var(--leading-relaxed);padding:var(--space-md);border-radius:var(--radius-lg)}.sentence-text{color:var(--text-dark);width:fit-content}.blank-slot{display:inline-flex;align-items:center;min-width:120px;min-height:40px;border-radius:var(--radius-md);background:linear-gradient(90deg,#fae4b643,#f1d29446);box-shadow:0 0 5px 1px #3d3d3d7e;transition:all .3s ease;position:relative;width:fit-content}.blank-slot.filled{border-color:var(--primary);background:#2e97800d}.blank-slot.correct{border-color:var(--success);background:#22c55e1a}.blank-slot.incorrect{border-color:#dc2626;background:#dc26261a}.selected-word{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-weight:var(--font-medium);width:100%;justify-content:center}.word-text{flex:1;text-align:center}.word-indicator{font-size:var(--text-lg);font-weight:var(--font-bold)}.remove-word{background:#ffffff4d;border:none;color:#fff;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--text-xs);transition:var(--transition-normal)}.remove-word:hover{background:#ffffff80}.empty-blank{width:100%;text-align:center;color:var(--text-light);font-style:italic;font-size:var(--text-sm);padding:var(--space-xs)}.words-section{padding:var(--space-md);border-radius:var(--radius-xl)}.word-bank{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-md);max-width:100%}.word-item{padding:var(--space-sm) var(--space-md);background:linear-gradient(180deg,#fae5b6,#f1d294);color:#000;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #6366f133;-webkit-user-select:none;user-select:none;font-weight:var(--font-medium);width:fit-content;padding:.8em 2em;border:1px solid #6d6d6d;box-shadow:0 1px 5px 1px #3d3d3d}.word-item:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 4px 16px #6366f14d}.word-item.dragging{opacity:1;transform:scale(1.05) rotate(3deg);box-shadow:0 6px 20px #6366f166;z-index:1000}.word-item.disabled{background:var(--background-muted);color:var(--text-light);cursor:not-allowed}.reading-exercise{width:50%;background-image:url(/assets/book-QyP1gPad.png);background-size:contain;background-repeat:no-repeat;display:flex;padding:1em;min-height:600px;aspect-ratio:4 / 3;contain:layout}.reading-exercise p{column-width:18ch;padding:3% 10%;column-gap:6em;max-height:100%;line-height:1.6;margin:0;height:55%}.course-content-page *{box-sizing:border-box}.course-content-page{contain:layout style}.exercise-container,.quiz-exercise,.reading-exercise,.drag-and-drop-exercise,.fill-blanks-exercise{content-visibility:auto;contain-intrinsic-size:400px}.options button,.next-lesson-btn,.submit-btn,.progress-bar{transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.course-content-body{transform:translateZ(0)}.reading-exercise:before{content:"";position:absolute;width:0;height:0;background:url(/assets/book-QyP1gPad.png);background-size:0 0}@keyframes rotateSand{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 1024px){.course-content-header{padding:1rem;flex-direction:column;gap:var(--space-md)}.progress-bar-container{width:100%;max-width:400px}.course-content-body{flex-direction:column;padding:0 var(--space-md)}.reading-exercise{width:100%;padding:6em 4em}.reading-exercise p{column-width:20ch;column-gap:3em}}@media (max-width: 768px){.course-content-header{padding:var(--space-md)}.user-info{justify-content:center;text-align:center}.course-content-body{padding:0 var(--space-sm)}.exercise-container{padding:var(--space-lg)}.course-content-footer{padding:var(--space-md);position:sticky;bottom:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border-light)}.reading-exercise{padding:3em 2em}.reading-exercise p{column-width:100%;column-gap:0;columns:1}.quiz-exercise{max-width:100%}.options button{font-size:1.2rem;padding:.8rem}.drag-and-drop-exercise{max-width:100%}.dnd-container{flex-direction:column;align-items:center;gap:var(--space-lg)}.dnd-items,.dnd-zones{width:100%;max-width:400px}}@media (max-width: 480px){.course-content-header{padding:var(--space-sm)}.user-avatar{width:40px;height:40px}.progress-bar-container{height:16px}.course-content-footer{padding:var(--space-sm)}.course-content-footer button{padding:.6rem 1rem;font-size:var(--text-sm)}.reading-exercise{padding:2em 1em}.quiz-exercise h2{font-size:1.2rem;margin-bottom:1rem}.options button{font-size:1rem;padding:.7rem}}.dashboard-layout{display:flex;min-height:100vh;background-color:var(--background-light)}.sidebar-dashboard{width:280px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:0;position:fixed;height:100vh;left:0;top:0;z-index:var(--z-fixed);box-shadow:var(--shadow-lg);transition:var(--transition-normal)}.main-content{flex:1;margin-left:280px;padding:var(--space-xl);background-color:var(--background-light);min-height:100vh;width:calc(100% - 280px);transition:margin-left .3s ease,width .3s ease}.main-content.full-width{margin-left:0;width:100%;padding:0}.main-content.main-content--workshop-focus{min-height:100vh;overflow:auto}.mobile-nav-toggle{display:none;position:fixed;top:var(--space-lg);left:var(--space-lg);z-index:calc(var(--z-fixed) + 1);background-color:var(--primary);color:#fff;border:none;padding:var(--space-md);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--text-lg);box-shadow:var(--shadow-md);transition:var(--transition-normal)}.mobile-nav-toggle:hover{background-color:var(--primary-dark);box-shadow:var(--shadow-lg)}.mobile-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:calc(var(--z-fixed) - 1);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 1024px){.sidebar-dashboard{width:250px}.main-content{margin-left:250px;width:calc(100% - 250px);padding:var(--space-lg)}.main-content.full-width{margin-left:0;width:100%}}@media (max-width: 768px){.mobile-nav-toggle{display:block}.sidebar-dashboard{width:280px;transform:translate(-100%);transition:transform var(--transition-normal)}.sidebar-dashboard.open{transform:translate(0)}.main-content{margin-left:0;width:100%;padding:var(--space-lg) var(--space-md);padding-top:calc(var(--space-4xl) + 60px)}.main-content.main-content--workshop-focus{padding:0}}@media (max-width: 480px){.main-content{padding:var(--space-md) var(--space-sm);padding-top:calc(var(--space-3xl) + 60px)}.mobile-nav-toggle{padding:var(--space-sm);font-size:var(--text-base)}}.dashboard-container{display:flex;min-height:100vh}.sidebar{width:280px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:var(--space-lg);position:fixed;height:100%;display:flex;flex-direction:column}.main{padding:var(--space-xl);background-color:var(--background-light);width:calc(100% - 280px);margin-left:280px}.user-info{text-align:center;margin-bottom:var(--space-xl)}.avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid rgba(255,255,255,.2)}.menu-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);text-decoration:none;color:#ffffffe6;transition:var(--transition-normal);font-weight:var(--font-medium)}.menu-item img{width:24px;height:24px;filter:brightness(0) invert(1);transition:var(--transition-normal)}.menu-item.active,.menu-item:hover{background-color:#ffffff26;color:#fff;transform:translate(4px)}.menu-item.active img,.menu-item:hover img{filter:brightness(0) invert(1)}.menu-item.logout{color:#fffc;margin-top:auto;position:absolute;bottom:var(--space-xl);left:var(--space-lg);right:var(--space-lg);width:-webkit-fill-available}.menu-item.logout:hover{background-color:#ef444433;color:#fecaca}.user-item-slider{display:flex;justify-content:space-between}.user-item-slider .user-info-chat{text-align:left}.user-item-slider .user-info-chat .last-message{color:#0006}.progress-bar-user{padding-block:2em 1em;border-bottom:1px solid #e2e8f0}.progress-label{display:flex;color:#fff}.progress-label .level{font-weight:bolder}.logo-white{width:10em;align-self:center}.menu-item{word-break:break-word}@media (max-width: 768px){.user-item-slider{gap:.75rem}.user-item-slider .user-info-chat{min-width:0}.user-item-slider .user-info-chat .name,.user-item-slider .user-info-chat .last-message{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.td-wrapper{padding:24px;max-width:1200px;margin:0 auto;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:#0f172a}.td-header{margin-bottom:20px}.td-header-title{font-size:28px;font-weight:800;margin:0}.td-wave{padding:0 6px}.td-header-sub{margin:0;color:#64748b}.td-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}.td-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.td-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.td-card-icon{font-size:24px}.td-card-title{margin:0;font-size:22px}.td-stat{margin-top:6px;font-size:16px}.td-stat-label{color:#64748b}.td-split-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:16px}.td-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.td-panel-title{margin-bottom:12px;font-size:18px}.td-chart{width:100%;height:300px}.td-table{width:100%;border-collapse:collapse}.td-th{border-bottom:1px solid #e2e8f0;padding:8px;text-align:left;font-weight:700;font-size:14px;background:#f8fafc}.td-td{border-bottom:1px solid #f1f5f9;padding:8px;font-size:14px}.td-progress-track{position:relative;height:10px;background:#f1f5f9;border-radius:6px}.td-progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#22d3ee);border-radius:6px 0 0 6px}.td-progress-label{position:absolute;right:8px;top:-18px;font-size:12px;color:#64748b}select{width:100%;padding:10px 14px;font-size:14px;color:#222;background-color:#fff;border:1px solid #8de7a6;border-radius:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;cursor:pointer;transition:border-color .25s ease,box-shadow .25s ease,background-color .25s ease;background-image:url("data:image/svg+xml;utf8,<svg fill='%23666' height='12' width='12' xmlns='http://www.w3.org/2000/svg'><path d='M2 4l4 4 4-4z'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:12px 12px}select:focus{border-color:#54d18a;box-shadow:0 0 0 4px #54d18a33;background-color:#fcfffb}@keyframes dropdown-pop{0%{transform:scaleY(.9);opacity:.8}to{transform:scaleY(1);opacity:1}}select:open{animation:dropdown-pop .2s ease-out}.sp-container{max-width:100%;margin:0;padding:24px}.sp-title{font-size:28px;font-weight:800;letter-spacing:.2px}.sp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sp-controls{display:flex;gap:12px;align-items:center}.sp-date-input{padding:8px 12px;border:1px solid #e5e7eb;border-radius:12px;color:#111827;background:#fff;box-shadow:0 6px 30px #171e3c14}.sp-btn{padding:10px 14px;border-radius:12px;border:0;color:#111827;cursor:pointer;font-weight:600;transition:.2s transform,.2s box-shadow,.2s background}.sp-btn.ghost{background:#fff;box-shadow:0 6px 30px #171e3c14}.sp-btn.ghost:hover{transform:translateY(-1px);box-shadow:0 8px 32px #171e3c1f}.sp-btn.primary{background:#3b82f6;color:#fff}.sp-btn.primary:disabled{opacity:.5;cursor:not-allowed}.segmented{display:flex;background:#fff;border-radius:12px;box-shadow:0 6px 30px #171e3c14;overflow:hidden}.seg-item{padding:10px 14px;border:0;background:transparent;cursor:pointer;font-weight:600;color:#111827}.seg-item.active{background:#e3efff;color:#3b82f6}.subhead{display:flex;align-items:center;justify-content:space-between;margin:6px 0 18px}.teacher-chip{font-weight:700}.chip{background:#fff;border-radius:999px;padding:6px 10px;margin-left:8px;box-shadow:0 6px 30px #171e3c14;font-weight:600;color:#6b7280}.nav-day{display:flex;align-items:center;gap:10px}.nav-icon{width:36px;height:36px;border-radius:999px;border:0;background:#fff;box-shadow:0 6px 30px #171e3c14;font-size:18px;cursor:pointer;display:grid;place-items:center;color:#6b7280;transition:.2s transform}.nav-icon:hover{transform:translateY(-1px)}.date-title{font-weight:800}.sp-layout{display:grid;grid-template-columns:1fr 320px;gap:20px}.sp-main{background:#fff;border-radius:18px;box-shadow:0 6px 30px #171e3c14;padding:16px;min-height:520px}.timeline{position:relative;display:grid;grid-template-columns:72px 1fr;gap:8px;height:640px}.timeline-hours{position:relative}.hour-row{height:10%;position:relative;border-bottom:1px dashed #eef1f7}.hour-label{position:absolute;top:-10px;left:0;font-size:12px;color:#6b7280}.timeline-track{position:relative;border-left:2px solid #eef1f7}.timeline-item{position:absolute;left:16px;right:16px}.class-card{height:100%;border-radius:12px;padding:12px;box-shadow:0 6px 30px #171e3c14;display:flex;flex-direction:column;gap:6px;transform-origin:bottom left;transition:.2s transform,.2s box-shadow,.2s filter}.class-card:hover{transform:translateY(-2px);filter:saturate(1.02)}.class-card-head{display:flex;align-items:center;justify-content:space-between}.class-subject{font-weight:800}.pill{padding:2px 8px;font-size:12px;border-radius:999px;background:#fff;color:#6b7280;box-shadow:0 6px 30px #171e3c14}.pill-live{background:#ffecec;color:#e11d48}.class-meta{color:#6b7280;font-size:12px}.class-time{font-weight:700}.join-btn{margin-top:auto;align-self:flex-start;padding:8px 10px;border:0;border-radius:10px;background:#111827;color:#fff;cursor:pointer;transition:.2s transform,.2s box-shadow}.join-btn:hover{transform:translateY(-1px);box-shadow:0 8px 28px #1e293b2e}.join-btn.pulse{animation:pulse 1.4s infinite}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}.week-col{background:#fff;border-radius:14px;box-shadow:0 6px 30px #171e3c14;padding:10px;min-height:120px}.week-col-head{font-weight:700;margin-bottom:6px}.muted{color:#6b7280}.empty-note{color:#6b7280;font-size:12px}.mini-class{width:100%;text-align:left;border:0;background:#f8fafc;border-radius:10px;padding:8px 10px;margin:6px 0;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:8px}.mini-class .dot{width:8px;height:8px;border-radius:999px;display:inline-block}.hover-lift{transition:.2s transform,.2s box-shadow}.hover-lift:hover{transform:translateY(-2px);box-shadow:0 6px 30px #171e3c14}.sp-sidebar{display:flex;flex-direction:column;gap:16px}.sidebar-card{background:#fff;border-radius:18px;box-shadow:0 6px 30px #171e3c14;padding:16px}.sidebar-title{font-weight:800;margin-bottom:10px}.teacher-calendar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.teacher-calendar-title{font-weight:800}.teacher-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;align-items:center}.teacher-calendar-dow{font-size:12px;color:#6b7280;text-align:center;padding:6px 0}.teacher-calendar-cell{border:0;border-radius:10px;background:#f8fafc;padding:8px 0;color:#111827;cursor:pointer;transition:.15s background,.15s transform}.teacher-calendar-cell:hover{background:#eef2ff;transform:translateY(-1px)}.teacher-calendar-cell.selected{background:#3b82f6;color:#fff;box-shadow:0 0 0 6px #3b82f614}.teacher-calendar-cell.empty{visibility:hidden}.upcoming-list{display:flex;flex-direction:column;gap:10px}.upcoming-item{background:#fff;border-radius:12px;box-shadow:0 6px 30px #171e3c14;padding:10px 12px;border-left:4px solid #dbeafe}.u-title{font-weight:700}.u-meta,.u-time{font-size:12px;color:#6b7280}.fab{position:fixed;right:26px;bottom:26px;width:56px;height:56px;border-radius:50%;border:0;background:#3b82f6;color:#fff;font-size:28px;line-height:0;box-shadow:0 12px 28px #3b82f657;cursor:pointer;display:grid;place-items:center;transition:.2s transform,.2s box-shadow}.fab:hover{transform:translateY(-2px);box-shadow:0 16px 36px #3b82f670}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a61;display:grid;place-items:center;z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:min(520px,92vw);background:#fff;border-radius:18px;box-shadow:0 30px 80px #0f172a59;overflow:hidden;animation-duration:.28s}.modal-head,.modal-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}.modal-title{font-weight:800}.modal-body{padding:0 16px 16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.icon-btn{border:0;background:transparent;cursor:pointer;font-size:18px}.form-row{display:flex;flex-direction:column;gap:6px;min-width:0}.form-row--full{grid-column:1 / -1}.form-row input,.form-row select{padding:10px 12px;border:1px solid #e5e7eb;border-radius:12px;background:#fff;color:#111827}.compact-grid{grid-column:1 / -1}.form-error{color:#dc2626;font-size:12px}.class-select{position:relative}.class-select__trigger{width:100%;border:1px solid #e5e7eb;border-radius:12px;background:#fff;min-height:42px;padding:8px 10px;display:flex;align-items:center;gap:8px;cursor:pointer}.class-select__placeholder{color:#6b7280}.class-select__menu{position:absolute;top:calc(100% + 6px);left:0;right:0;max-height:240px;overflow:auto;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 12px 28px #171e3c1f;z-index:30}.class-select__item{width:100%;border:0;background:#fff;padding:8px 10px;text-align:left;display:flex;align-items:center;gap:8px;cursor:pointer}.class-select__item:hover{background:#f8fafc}.class-select__img,.class-select__fallback{width:28px;height:28px;border-radius:999px;object-fit:cover}.class-select__fallback{display:inline-grid;place-items:center;background:#e5e7eb;color:#374151;font-weight:700}.class-select__empty{padding:10px;color:#6b7280;font-size:13px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}@media (max-width: 680px){.modal-body,.grid-2,.grid-3{grid-template-columns:1fr}}@keyframes slideInUp{0%{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%{box-shadow:0 0}}.input-box{position:relative;margin-bottom:10px;display:flex;justify-content:center;width:100%}.input{padding:var(--space-lg) var(--space-xl);outline:none;background:transparent;border-radius:.3rem;width:100%;color:var(--text-dark);border:2px solid var(--pastel-green);font-size:var(--text-base);position:relative;box-sizing:border-box}.input-box .label{position:absolute;left:1.5rem;padding:.8rem 1.2rem;pointer-events:none;font-size:var(--text-base);transition:.4s cubic-bezier(.05,.81,0,.93);color:var(--text-dark);letter-spacing:.1em;width:fit-content}.input-box .input:focus~.label,.input-box .input:not(:placeholder-shown)~.label{font-size:var(--text-sm);transform:translate(.8rem) translateY(-.5rem);padding:0 .5rem;border-radius:2px;background:#fff;color:var(--pastel-green);letter-spacing:0em}@media (max-width: 600px){.input-box{margin-block:var(--space-md)}.input-box .input{padding:var(--space-md) var(--space-lg);font-size:1rem}.input-box .label{left:1rem;padding:.6rem 1rem;font-size:1rem}}.button{font-size:var(--text-base);font-weight:var(--font-medium);padding:var(--space-md) var(--space-lg);border:none;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;gap:var(--space-sm);cursor:pointer;transition:var(--transition-normal);min-height:44px;line-height:var(--leading-normal)}.button:hover{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.button:active{transform:translateY(0);box-shadow:var(--shadow-md)}.button:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.button:disabled:hover{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%)}.outline-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--primary);background:transparent;border:2px solid var(--primary);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-normal);min-height:44px}.outline-button:hover{background:var(--primary);color:#fff;transform:translateY(-2px);border:2px solid var(--primary);box-shadow:var(--shadow-lg)}.fill-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--primary);background:#fff;border:2px solid white;border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-normal);box-shadow:var(--shadow-md);min-height:44px}.fill-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--background-light)}.fill-button .arrow{font-size:var(--text-lg);line-height:1;transition:var(--transition-normal)}.fill-button:hover .arrow{transform:translate(2px)}.btn-quiz-option{display:block;width:100%;padding:var(--space-lg);margin-bottom:var(--space-md);text-align:left;background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-normal);font-size:var(--text-base);color:var(--text-dark)}.btn-quiz-option:hover{border-color:var(--primary-light);background:var(--background-light);transform:translate(4px)}.btn-quiz-option.selected{border-color:var(--primary);background:#2e97801a;color:var(--primary-dark)}.btn-quiz-option.correct{border-color:var(--success);background:#3eb8701a;color:var(--success)}.btn-quiz-option.incorrect{border-color:var(--error);background:#ef44441a;color:var(--error)}.btn-secondary{background:var(--background-gray);color:var(--text-dark);border:2px solid var(--border-gray)}.btn-secondary:hover{background:var(--border-light);border-color:var(--text-gray)}.btn-success{background:linear-gradient(135deg,var(--success) 0%,#4ade80 100%);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#16a34a 0%,var(--success) 100%)}.btn-small{padding:var(--space-sm) var(--space-md);font-size:var(--text-sm);min-height:36px}.btn-large{padding:var(--space-lg) var(--space-2xl);font-size:var(--text-lg);min-height:56px}.modal-ov{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000075;display:flex;align-items:center;justify-content:center;z-index:90;animation:fade .22s both}.modal{width:min(1180px,96vw);max-height:94vh;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000002e;overflow:hidden;animation:pop .22s both;display:flex;flex-direction:column;position:relative}.hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(180deg,#22c55e,#16a34a);color:#fff}.steps{display:flex;gap:8px;padding:8px 10px;background:#eef6ef;border-bottom:1px solid #e5eee8}.step{padding:8px 12px;border-radius:999px;background:#e8f6ee;color:#0a0a0a;font-weight:700;font-size:13px;opacity:.6}.step.on{opacity:1;background:#c8f0da;box-shadow:0 8px 18px #00000014}.body{height:70vh;gap:12px;padding:12px;background:#f7fbf8;min-height:0;display:grid}.body.step1{grid-template-columns:1fr}.body.step2{grid-template-columns:280px 1fr}.col{background:#fff;border-radius:12px;box-shadow:0 10px 26px #0000000f;padding:12px;overflow-y:auto}.sidebar-title{font-weight:800;font-size:1.2rem;color:#667085;margin:6px}.sidebar-list{list-style:none;margin:0;padding:0;max-height:calc(74vh - 200px);overflow:auto}.item{width:15em;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;margin:8px 6px;background:linear-gradient(180deg,#fff,#f7fdf9);border:1px solid #e9f4ee;border-left:4px solid transparent;border-radius:12px;cursor:pointer;transition:transform .22s,box-shadow .22s,border-color .22s}.item:hover{transform:translateY(-1px);box-shadow:0 10px 26px #0000000f}.item.on{border-left-color:#22c55e}.kv{display:grid;grid-template-columns:1fr 1fr;gap:10px}.toolbar{display:flex;justify-content:space-between;gap:10px;padding:10px 14px;border-top:1px solid #eef2f1;background:#fbfffd}.preview-float{position:absolute;right:12px;bottom:12px;width:260px;background:#fff;border:1px solid #eef2f1;border-radius:14px;box-shadow:0 12px 30px #0000001f;padding:10px;z-index:5}.preview-float img{width:72px;height:72px;border-radius:10px;object-fit:cover}.sublist{margin:10px 6px 0;padding:8px;border:1px dashed #e5e7eb;border-radius:12px;background:#fcfffd}.sublist .sub-head{display:flex;align-items:center;justify-content:space-between;font-weight:800;color:#475467;margin-bottom:4px}.sublist ul{list-style:none;margin:0;padding:0;max-height:40vh;overflow:auto}.sublist li{padding:8px 10px;margin:6px 0;border:1px solid #ecf3ee;border-radius:10px;display:flex;justify-content:space-between;align-items:center;background:#fff;cursor:pointer}.sublist li.on{border-color:#22c55e;background:#f0fff7}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{transform:scale(.96) translateY(10px)}to{transform:scale(1) translateY(0)}}@media (max-width:1100px){.preview-float{display:none}.body.step2{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#2e978026,#81dc9c26),#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease-out}.modal-content{background:linear-gradient(180deg,#fff,#f8fffe);border-radius:16px;width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px #2e97804d,0 0 0 1px #3e8b701a;animation:slideUp .4s cubic-bezier(.16,1,.3,1);overflow:hidden}.modal-content.fullscreen{width:95vw;max-width:none;height:95vh;max-height:95vh;border-radius:20px}@keyframes slideUp{0%{transform:translateY(40px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 2rem;border-bottom:2px solid rgba(104,220,163,.2);background:linear-gradient(135deg,#2e9780,#3e8b70);position:relative;overflow:hidden}.modal-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent 0%,rgba(104,220,163,.1) 100%);pointer-events:none}.modal-title{font-size:1.75rem;font-weight:700;color:#232323;margin:0;position:relative;text-shadow:0 2px 4px rgba(0,0,0,.1);letter-spacing:-.02em}.modal-close{background:#ffffff26;border:2px solid rgba(255,255,255,.2);cursor:pointer;color:#fff;padding:.625rem;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.modal-close:hover{background:#ffffff40;border-color:#fff6;transform:rotate(90deg) scale(1.1)}.modal-close:active{transform:rotate(90deg) scale(.95)}.modal-body{padding:2rem;overflow-y:auto;flex:1;max-height:calc(90vh - 280px);background:linear-gradient(180deg,#fff,#f8fffe)}.modal-body::-webkit-scrollbar{width:10px}.modal-body::-webkit-scrollbar-track{background:#b0ec981a;border-radius:10px}.modal-body::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#68dca3,#81dc9c);border-radius:10px;border:2px solid transparent;background-clip:padding-box}.modal-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#2e9780,#3e8b70);background-clip:padding-box}.modal-content.fullscreen .modal-body{max-height:calc(95vh - 260px);padding:0}.stepper{display:flex;justify-content:center;gap:3rem;padding:2rem;border-bottom:2px solid rgba(104,220,163,.2);background:linear-gradient(180deg,#f0fdf9,#fff);position:relative}.stepper:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:4px;background:linear-gradient(90deg,#68dca34d,#81dc9c4d);border-radius:10px;z-index:0}.stepper-item{display:flex;align-items:center;gap:.875rem;color:#6b7280;font-weight:600;position:relative;z-index:1;transition:all .3s ease}.stepper-item.active{color:#2e9780;transform:scale(1.05)}.stepper-item.completed{color:#81dc9c}.stepper-circle{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e5e7eb,#f3f4f6);color:#6b7280;font-weight:700;font-size:1.125rem;transition:all .4s cubic-bezier(.16,1,.3,1);border:3px solid transparent;box-shadow:0 4px 12px #00000014}.stepper-item.active .stepper-circle{background:linear-gradient(135deg,#2e9780,#3e8b70);color:#fff;border-color:#68dca3;box-shadow:0 8px 24px #2e978066,0 0 0 4px #68dca333;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.stepper-item.completed .stepper-circle{background:linear-gradient(135deg,#81dc9c,#b0ec98);color:#fff;border-color:#b0ec98;box-shadow:0 6px 20px #81dc9c66}@keyframes pulse{0%,to{box-shadow:0 8px 24px #2e978066,0 0 0 4px #68dca333}50%{box-shadow:0 8px 24px #2e978066,0 0 0 8px #68dca31a}}.step-container{animation:fadeIn .4s ease-out}.lessons-layout{display:flex;height:100%;overflow:hidden;background:linear-gradient(180deg,#fff,#f0fdf9)}.lessons-sidebar{width:320px;border-right:2px solid rgba(104,220,163,.2);background:linear-gradient(180deg,#2e9780,#3e8b70);overflow-y:auto;max-height:calc(95vh - 200px);position:relative}.lessons-sidebar:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(104,220,163,.1),transparent);pointer-events:none}.lessons-sidebar::-webkit-scrollbar{width:8px}.lessons-sidebar::-webkit-scrollbar-track{background:#0000001a}.lessons-sidebar::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.lessons-sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff80}.lessons-sidebar-header{padding:2rem 1.5rem;border-bottom:2px solid rgba(104,220,163,.2);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:linear-gradient(180deg,#2e9780,#2e9780fa);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.lessons-sidebar-header h3{font-size:1.25rem;font-weight:700;color:#fff;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.1)}.btn-icon{background:#ffffff26;border:2px solid rgba(255,255,255,.2);cursor:pointer;padding:.625rem;border-radius:10px;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;justify-content:center;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-icon:hover{background:#ffffff40;border-color:#fff6;transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.btn-icon:active{transform:translateY(0)}.btn-icon.btn-danger{background:#ef444426;color:#fff;border-color:#ef44444d}.btn-icon.btn-danger:hover{background:#ef444440;border-color:#ef444480}.lesson-editor{flex:1;padding:2.5rem;overflow-y:auto;max-height:calc(95vh - 200px);background:linear-gradient(180deg,#fff,#f0fdf9)}.lesson-editor::-webkit-scrollbar{width:10px}.lesson-editor::-webkit-scrollbar-track{background:#b0ec981a;border-radius:10px}.lesson-editor::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#68dca3,#81dc9c);border-radius:10px;border:2px solid transparent;background-clip:padding-box}.lesson-list{padding:0;position:relative}.lesson-item{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(104,220,163,.15);cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;justify-content:space-between;align-items:center;background:transparent;position:relative}.lesson-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,#81dc9c,#b0ec98);opacity:0;transition:opacity .3s ease}.lesson-item:hover{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lesson-item:hover:before{opacity:.5}.lesson-item.selected{background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom-color:#68dca34d}.lesson-item.selected:before{opacity:1;box-shadow:0 0 20px #81dc9c99}.lesson-item-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.lesson-item-title{font-weight:700;color:#fff;font-size:1rem;text-shadow:0 1px 2px rgba(0,0,0,.1)}.lesson-type-badge{display:inline-block;padding:.375rem .875rem;background:linear-gradient(135deg,#68dca340,#81dc9c40);color:#fff;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:capitalize;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a}.lesson-status{color:#fff9;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.lesson-status.active{color:#b0ec98;filter:drop-shadow(0 0 8px rgba(176,236,152,.6))}.btn-add-lesson{width:calc(100% - 3rem);margin:1.5rem;padding:1rem;background:linear-gradient(135deg,#81dc9c,#b0ec98);color:#2e9780;border:none;border-radius:14px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;justify-content:center;gap:.625rem;box-shadow:0 8px 24px #81dc9c4d;position:relative;overflow:hidden}.btn-add-lesson:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-add-lesson:hover:before{width:300px;height:300px}.btn-add-lesson:hover{transform:translateY(-3px);box-shadow:0 12px 32px #81dc9c80}.btn-add-lesson:active{transform:translateY(-1px)}.form-group{margin-bottom:1.75rem}.modal-body .form-row{display:grid;gap:1.75rem}.form-group label{display:block;font-weight:600;color:#2e9780;margin-bottom:.625rem;font-size:.9375rem;letter-spacing:-.01em}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.875rem 1rem;border:2px solid rgba(104,220,163,.3);border-radius:12px;background:#fff;color:#1f2937;font-size:1rem;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 8px #2e97800d}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#2e9780;box-shadow:0 0 0 4px #2e978026,0 4px 16px #2e97801a;background:#fff;transform:translateY(-2px)}.form-group textarea{min-height:120px;resize:vertical;font-family:inherit}.form-error{color:#dc2626;font-size:.875rem;margin-top:.5rem;font-weight:500}.toggle-switch{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.toggle-switch input[type=checkbox]{width:56px;height:28px;position:relative;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:linear-gradient(135deg,#d1d5db,#e5e7eb);border-radius:28px;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);border:2px solid transparent}.toggle-switch input[type=checkbox]:checked{background:linear-gradient(135deg,#81dc9c,#b0ec98);box-shadow:0 4px 16px #81dc9c66,0 0 0 4px #b0ec9833}.toggle-switch input[type=checkbox]:before{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;top:1px;left:2px;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 8px #0003}.toggle-switch input[type=checkbox]:checked:before{transform:translate(28px);box-shadow:0 4px 12px #00000026}.dynamic-array{margin-top:.75rem}.array-item{display:flex;gap:.75rem;margin-bottom:.875rem}.array-item input{flex:1}.btn-remove{padding:.875rem 1.25rem;background:linear-gradient(135deg,#ef44441a,#dc26261a);color:#dc2626;border:2px solid rgba(239,68,68,.3);border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s cubic-bezier(.16,1,.3,1);white-space:nowrap}.btn-remove:hover{background:linear-gradient(135deg,#ef444433,#dc262633);border-color:#ef444480;transform:translateY(-2px);box-shadow:0 6px 16px #ef444433}.btn-add{padding:.875rem 1.5rem;background:linear-gradient(135deg,#68dca3,#81dc9c);color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:600;margin-top:.75rem;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:.625rem;box-shadow:0 4px 12px #68dca34d}.btn-add:hover{transform:translateY(-2px);box-shadow:0 8px 20px #68dca366}.exercise-editor{background:linear-gradient(135deg,#fff,#f0fdf9);border:3px solid #3E8B70;border-radius:16px;padding:2rem;margin-bottom:2rem;box-shadow:0 8px 24px #2e978026;position:relative;overflow:hidden}.exercise-editor:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#2e9780,#68dca3,#81dc9c,#b0ec98);background-size:200% 100%;animation:shimmer 3s linear infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.exercise-editor h4{color:#2e9780;margin-bottom:1.75rem;font-size:1.25rem;font-weight:700}.exercise-list{margin-top:1.75rem}.exercise-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:linear-gradient(135deg,#68dca314,#81dc9c14);border-radius:12px;margin-bottom:1rem;border:2px solid rgba(104,220,163,.2);transition:all .3s cubic-bezier(.16,1,.3,1);cursor:pointer}.exercise-item:hover{background:linear-gradient(135deg,#68dca326,#81dc9c26);border-color:#68dca3;transform:translate(4px);box-shadow:0 6px 20px #68dca333}.exercise-item-content{display:flex;align-items:center;gap:1rem}.exercise-type-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#2e9780,#3e8b70);color:#fff;border-radius:20px;font-size:.8125rem;font-weight:600;box-shadow:0 4px 12px #2e97804d}.btn-edit-exercise{padding:.75rem 1.25rem;background:linear-gradient(135deg,#2e9780,#3e8b70);color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:.625rem;box-shadow:0 4px 12px #2e97804d}.btn-edit-exercise:hover{transform:translateY(-2px);box-shadow:0 8px 20px #2e978066}.btn-add-exercise{width:100%;padding:1rem;background:linear-gradient(135deg,#81dc9c,#b0ec98);color:#2e9780;border:none;border-radius:12px;font-weight:700;cursor:pointer;margin-top:1.5rem;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;justify-content:center;gap:.625rem;box-shadow:0 6px 20px #81dc9c4d}.btn-add-exercise:hover{transform:translateY(-3px);box-shadow:0 10px 28px #81dc9c73}.btn-remove-exercise{width:100%;padding:1.25rem;background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;margin-top:2.5rem;font-size:1.0625rem;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;justify-content:center;gap:.75rem;box-shadow:0 6px 20px #dc26264d}.btn-remove-exercise:hover{transform:translateY(-3px);box-shadow:0 10px 28px #dc262673}.btn-secondary{padding:.875rem 1.5rem;background:linear-gradient(135deg,#68dca3,#81dc9c);color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:600;margin-top:.75rem;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:.625rem;box-shadow:0 4px 12px #68dca34d}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #68dca366}.file-chips{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.chip{display:inline-flex;align-items:center;padding:.625rem 1rem;background:linear-gradient(135deg,#68dca326,#81dc9c26);color:#2e9780;border-radius:20px;font-size:.9375rem;font-weight:600;border:2px solid rgba(104,220,163,.3);transition:all .3s ease}.chip:hover{background:linear-gradient(135deg,#68dca340,#81dc9c40);border-color:#68dca3;transform:translateY(-2px);box-shadow:0 4px 12px #68dca333}.chip a{color:#2e9780;text-decoration:none;display:flex;align-items:center;gap:.625rem;font-weight:600}.chip a:hover{color:#3e8b70}.chip button{background:#ef44441a;border:none;color:#dc2626;cursor:pointer;padding:.375rem;margin-left:.625rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .3s ease}.chip button:hover{background:#ef444433;transform:scale(1.1)}.upload-button-container{margin-top:.75rem}.upload-button{display:inline-flex;align-items:center;gap:.875rem;padding:1rem 1.75rem;background:linear-gradient(135deg,#81dc9c,#b0ec98);color:#2e9780;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 6px 20px #81dc9c4d;position:relative;overflow:hidden}.upload-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff6;transform:translate(-50%,-50%);transition:width .6s,height .6s}.upload-button:hover:before{width:300px;height:300px}.upload-button:hover{transform:translateY(-3px);box-shadow:0 10px 28px #81dc9c80}.upload-button:active{transform:translateY(-1px)}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1.75rem 2rem;border-top:2px solid rgba(104,220,163,.2);background:linear-gradient(180deg,#fff,#f0fdf9)}.modal-footer-left{color:#dc2626;font-size:.9375rem;font-weight:600}.modal-footer-actions{display:flex;gap:1rem}.btn-modal{padding:.875rem 2rem;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);border:none;position:relative;overflow:hidden}.btn-modal:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-modal:hover:before{width:300px;height:300px}.btn-modal-primary{background:linear-gradient(135deg,#2e9780,#3e8b70);color:#fff;box-shadow:0 6px 20px #2e97804d}.btn-modal-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 28px #2e978073}.btn-modal-primary:active:not(:disabled){transform:translateY(-1px)}.btn-modal-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-modal-secondary{background:linear-gradient(135deg,#68dca326,#81dc9c26);color:#2e9780;border:2px solid rgba(104,220,163,.3);box-shadow:0 4px 12px #68dca326}.btn-modal-secondary:hover{background:linear-gradient(135deg,#68dca340,#81dc9c40);border-color:#68dca3;transform:translateY(-3px);box-shadow:0 8px 20px #68dca340}.editor-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1.5rem;color:#6b7280;text-align:center}.editor-empty-text{font-size:1.125rem;font-weight:500;color:#9ca3af}.lesson-editor-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 8px 24px #2e97801a;border:2px solid rgba(104,220,163,.2)}.lesson-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid rgba(104,220,163,.2)}.lesson-editor-title{font-size:1.5rem;font-weight:700;color:#2e9780;margin:0}.toggle-wrapper{display:flex;align-items:center;gap:.75rem}.toggle-wrapper span{font-weight:600;color:#6b7280}.form-grid{display:grid;grid-template-columns:1fr;gap:1.75rem}.form-grid.two-col{grid-template-columns:1fr 1fr}.form-group.full-width{grid-column:1 / -1}.exercises-section{margin-top:2rem;padding-top:2rem;border-top:2px solid rgba(104,220,163,.2)}.exercises-section-title{font-size:1.25rem;font-weight:700;color:#2e9780;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.exercises-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.exercise-item-info{display:flex;align-items:center;gap:1rem}.exercise-item-number{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#2e9780,#3e8b70);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9375rem;box-shadow:0 4px 12px #2e97804d}.exercise-item-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#68dca326,#81dc9c26);color:#2e9780;border-radius:20px;font-size:.8125rem;font-weight:600;border:2px solid rgba(104,220,163,.3)}.exercise-editor-card{margin-top:1.5rem}.exercise-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(104,220,163,.2)}.exercise-editor-type{font-size:1.125rem;font-weight:700;color:#2e9780;text-transform:capitalize}.form-select{padding:.75rem 1rem;border:2px solid rgba(104,220,163,.3);border-radius:12px;background:#fff;color:#1f2937;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.form-select:focus{outline:none;border-color:#2e9780;box-shadow:0 0 0 4px #2e978026}.form-input,.form-textarea{font-family:inherit}.array-container{display:flex;flex-direction:column;gap:1rem}.drag-drop-item{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.75rem;align-items:center}.btn-remove-item{padding:.75rem 1rem;background:#ef44441a;color:#dc2626;border:2px solid rgba(239,68,68,.3);border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s ease;white-space:nowrap}.btn-remove-item:hover{background:#ef444433;border-color:#ef444480;transform:translateY(-2px)}.btn-add-item{padding:.875rem 1.5rem;background:linear-gradient(135deg,#68dca3,#81dc9c);color:#fff;border:none;border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s ease;display:flex;align-items:center;gap:.625rem;box-shadow:0 4px 12px #68dca34d;align-self:flex-start}.btn-add-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px #68dca366}.form-help{font-size:.875rem;color:#6b7280;margin-top:.5rem;font-style:italic}.chips-container{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.form-label .required{color:#dc2626;font-weight:700;margin-left:.25rem}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.modal-content.fullscreen{width:100%;height:100vh;max-height:100vh;border-radius:0}.form-row,.form-grid.two-col{grid-template-columns:1fr}.lessons-layout{flex-direction:column}.lessons-sidebar{width:100%;max-height:200px;border-right:none;border-bottom:2px solid rgba(104,220,163,.2)}.lesson-editor{max-height:calc(95vh - 400px)}.stepper{flex-direction:column;gap:1rem;align-items:flex-start}.stepper:before{display:none}.modal-footer{flex-direction:column;gap:1rem;align-items:stretch}.modal-footer-actions{flex-direction:column}.btn-modal{width:100%}.drag-drop-item{grid-template-columns:1fr}.array-item{flex-direction:column}.btn-remove,.btn-remove-item{width:100%}}:root{--primary:#22c55e;--text-mid:#475467}.course-details-container{background:#fff}.page-wrap{padding:16px;max-width:75vw;margin-left:16vw}.course-details-header{display:flex;align-items:center;gap:12px}.back-link{color:var(--primary);text-decoration:none;font-weight:700;cursor:pointer;background:none;border:none}.course-title{font-size:22px;font-weight:900}.course-details-body{display:grid;grid-template-columns:1fr 320px;gap:14px;margin-top:12px}.course-details-left .section-card{background:#fff;border:1px solid #eef2f1;border-radius:12px;padding:12px}.course-details-right .course-purchase-card{position:sticky;top:12px;background:#fff;border:1px solid #eef2f1;border-radius:12px;padding:12px}.course-video{position:relative;border-radius:12px;overflow:hidden}.course-video img{display:block}.instructor-info-video{position:absolute;left:12px;bottom:12px;display:flex;gap:10px;align-items:center;background:#ffffffe6;padding:8px;border-radius:999px}.instructor-avatar{width:36px;height:36px;border-radius:50%}.media-meta{display:flex;align-items:center;gap:8px;margin:8px 0}.course-tabs{display:flex;gap:10px;position:relative}.tab-link{border:none;background:#eef2f1;padding:8px 10px;border-radius:10px}.tab-link.active{background:#d1fadf;color:#065f46}.tab-underline{position:absolute;bottom:-2px;left:var(--x,0);width:var(--w,0);height:2px;background:var(--primary);transition:.22s}.buy-now-btn{width:100%;padding:10px 12px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-weight:800}.publisher-info{display:flex;gap:10px;align-items:center}.publisher-avatar{width:40px;height:40px;border-radius:50%}.curr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.curr-card{border:1px solid #eef2f1;border-radius:12px;padding:10px}.curr-item{padding:6px;border-radius:8px;cursor:pointer}.curr-item.active{background:#e8f8ee;border:1px solid #b8e6cb}:root{--pri:#22c55e}.page{padding:18px;background:#f6fbf7;min-height:100vh}.head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.title{font-size:22px;font-weight:800;color:#0f172a}.sub{color:#6b7280}.actions{display:flex;gap:10px}.card{background:#fff;border-radius:16px;box-shadow:0 8px 28px #0000000f;padding:12px}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:10px;border-bottom:1px solid #eef2f1}.thumb{width:56px;height:56px;border-radius:12px;object-fit:cover;margin-right:10px}.row{display:flex;align-items:center;gap:12px}.badge{font-size:12px;padding:.2rem .6rem;border-radius:999px;background:#fef3c7}.empty{text-align:center;color:#6b7280;padding:20px 0}.row-actions{display:flex;gap:8px}@media (max-width: 840px){.table th:nth-child(3),.table td:nth-child(3),.table th:nth-child(4),.table td:nth-child(4){display:none}}:root{--ink:#0f172a;--muted:#667085;--line:#e5e7eb}.cm9-wrap{border:1px solid #edf3ef;background:#f8fbf9;border-radius:16px;padding:16px;display:grid;gap:14px}.cm9-head{display:flex;align-items:center;justify-content:space-between}.cm9-grid{display:grid;grid-template-columns:repeat(4,minmax(240px,1fr));gap:14px}@media (max-width:1220px){.cm9-grid{grid-template-columns:repeat(3,minmax(220px,1fr))}}@media (max-width:900px){.cm9-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media (max-width:560px){.cm9-grid{grid-template-columns:1fr}}.card9{border:1px solid #eef2f1;border-radius:18px;background:#fff;box-shadow:0 10px 24px #0000000f;overflow:hidden;display:flex;flex-direction:column}.card9-top{position:relative;height:118px;display:flex;align-items:flex-end;padding:12px}.card9-top .name{font-weight:900;color:#fff;text-shadow:0 3px 8px rgba(0,0,0,.35)}.curve{position:absolute;right:-40px;top:-40px;width:150px;height:150px;border-radius:40% 60%;opacity:.9}.color-dot{position:absolute;right:12px;top:12px;width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.8);box-shadow:0 3px 12px #0003}.card9-body{padding:12px;color:var(--muted);display:grid;gap:8px}.card9-row{display:flex;align-items:center;justify-content:space-between;gap:6px}.iconbox{position:absolute;left:12px;top:12px;width:40px;height:40px;border-radius:14px;background:#ffffff38;display:grid;place-items:center;color:#fff;font-weight:900}.m9-ov{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.m9{width:min(1100px,96vw);height:min(86vh,920px);background:#fff;border-radius:18px;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto;box-shadow:0 18px 60px #00000038}.m9-hd{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(180deg,#22c55e,#16a34a);color:#fff}.m9-bd{display:flex}@media (max-width:980px){.m9-bd{grid-template-columns:240px 1fr}.m9-col-right{display:none}}.m9-col-left{border-right:1px solid #f0f3f2;background:#fbfffd;overflow:auto;width:35%;padding:.5em 0}.student{display:flex;gap:10px;padding:10px 12px;border-bottom:1px dashed #eef2f1}.student img{width:3em;height:3em;border-radius:999px}.student .nm{font-weight:800;color:var(--ink)}.student .mail{font-size:12px;color:#98a2b3}.m9-col-mid{padding:14px;display:flex;gap:17px;flex-direction:column}.m9-col-right{border-left:1px solid #f0f3f2;padding:10px;display:grid;gap:10px}.palette{display:flex;justify-content:flex-start;gap:12px;margin-left:1em;margin-top:8px}.color-pill{width:3.5em;height:3.5em;border-radius:999px;box-shadow:0 6px 14px #00000026;cursor:pointer;border:3px solid #fff;transition:all .2s;position:relative}.color-pill:hover{transform:scale(1.1);box-shadow:0 8px 18px #0003}.color-pill.on{border:3px solid #22c55e;outline:3px solid rgba(34,197,94,.4);outline-offset:2px;transform:scale(1.1)}.help{position:absolute;bottom:16em;font-size:12px;color:#667085}.m9-ft{display:flex;gap:8px;justify-content:flex-end;padding:12px;background:#fbfffd;border-top:1px solid #eef2f1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;border-radius:.375rem;font-size:.875rem;font-weight:500;transition:var(--transition-smooth);cursor:pointer;border:none}.btn:focus-visible{outline:2px solid hsl(var(--ring));outline-offset:2px}.btn:disabled{pointer-events:none;opacity:.5}.btn svg{pointer-events:none;width:1rem;height:1rem;flex-shrink:0}.btn-default{background-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.btn-default:hover{background-color:hsl(var(--primary) / .9)}.btn-destructive{background-color:hsl(var(--destructive));color:hsl(var(--destructive-foreground))}.btn-destructive:hover{background-color:hsl(var(--destructive) / .9)}.btn-outline{border:1px solid hsl(var(--input));background-color:hsl(var(--background))}.btn-outline:hover{background-color:hsl(var(--accent));color:hsl(var(--accent-foreground))}.btn-secondary{background-color:hsl(var(--secondary));color:hsl(var(--secondary-foreground))}.btn-secondary:hover{background-color:hsl(var(--secondary) / .8)}.btn-ghost:hover{background-color:hsl(var(--accent));color:hsl(var(--accent-foreground))}.btn-link{color:hsl(var(--primary));text-decoration:underline;text-underline-offset:4px}.btn-link:hover{text-decoration:underline}.btn-default-size{height:2.5rem;padding:.5rem 1rem}.btn-sm{height:2.25rem;border-radius:.375rem;padding:0 .75rem}.btn-lg{height:2.75rem;border-radius:.375rem;padding:0 2rem}.btn-icon{height:2.5rem;width:2.5rem}.card{border-radius:.5rem;border:1px solid hsl(var(--border));background-color:hsl(var(--card));color:hsl(var(--card-foreground));box-shadow:var(--shadow-sm)}.card-header{display:flex;flex-direction:column;gap:.375rem;padding:1.5rem}.card-title{font-size:1.5rem;font-weight:600;line-height:1;letter-spacing:-.025em}.card-description{font-size:.875rem;color:hsl(var(--muted-foreground))}.card-content{padding:1.5rem;padding-top:0}.card-footer{display:flex;align-items:center;padding:1.5rem;padding-top:0}.overview-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}@media (min-width: 768px){.overview-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.overview-grid{grid-template-columns:repeat(4,1fr)}}.overview-card{padding:1.5rem;transition:var(--transition-smooth);border:1px solid hsl(var(--border) / .5)}.overview-card:hover{box-shadow:var(--shadow-lg)}.overview-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.overview-icon{padding:.75rem;border-radius:.75rem}.overview-icon svg{width:1.5rem;height:1.5rem;color:#fff}.overview-title{font-size:.875rem;font-weight:500;color:hsl(var(--muted-foreground));margin-bottom:.25rem}.overview-value{font-size:1.875rem;font-weight:700;color:hsl(var(--foreground))}.course-list{display:flex;flex-direction:column;gap:1rem}.course-item{padding:1rem;border-radius:.5rem;border:1px solid hsl(var(--border));transition:var(--transition-smooth)}.course-item:hover{border-color:hsl(var(--primary) / .5);box-shadow:var(--shadow-md)}.course-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.course-info{display:flex;align-items:center;gap:.75rem}.course-thumbnail{font-size:1.875rem}.course-title{font-weight:600;color:hsl(var(--foreground))}.course-instructor{font-size:.875rem;color:hsl(var(--muted-foreground))}.course-progress-text{text-align:right}.course-progress-value{font-size:1.5rem;font-weight:700;color:hsl(var(--primary))}.course-last-access{font-size:.75rem;color:hsl(var(--muted-foreground))}.progress-bar-container{position:relative;width:100%;height:.5rem;background-color:hsl(var(--muted));border-radius:9999px;overflow:hidden}.progress-bar-fill{position:absolute;left:0;top:0;height:100%;background:var(--gradient-primary);transition:width 1s ease-out;transform-origin:left}.badges-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (min-width: 768px){.badges-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.badges-grid{grid-template-columns:repeat(5,1fr)}}.badge-item{display:flex;flex-direction:column;align-items:center;padding:1rem;border-radius:.5rem;border:1px solid hsl(var(--border));transition:var(--transition-smooth);cursor:pointer}.badge-item:hover{border-color:hsl(var(--primary) / .5);transform:scale(1.05);box-shadow:var(--shadow-lg)}.badge-image{font-size:3rem;margin-bottom:.75rem}.badge-title{font-size:.875rem;font-weight:600;text-align:center;color:hsl(var(--foreground));margin-bottom:.25rem}.badge-description{font-size:.75rem;text-align:center;color:hsl(var(--muted-foreground))}.activity-list{display:flex;flex-direction:column;gap:1rem}.activity-item{display:flex;gap:1rem;align-items:flex-start;padding:.75rem;border-radius:.5rem;transition:var(--transition-smooth)}.activity-item:hover{background-color:hsl(var(--muted) / .5)}.activity-icon{flex-shrink:0;width:2.5rem;height:2.5rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.activity-content{flex:1;min-width:0}.activity-text{font-size:.875rem;color:hsl(var(--foreground))}.activity-action{font-weight:600}.activity-time{font-size:.75rem;color:hsl(var(--muted-foreground));margin-top:.25rem}.parent-chart-container{height:300px;width:100%}.chart-title{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:1.5rem}.exercise-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}@media (min-width: 768px){.exercise-stats-grid{grid-template-columns:repeat(4,1fr)}}.exercise-stat{text-align:center}.exercise-stat-label{font-size:.875rem;color:hsl(var(--muted-foreground))}.exercise-stat-value{font-size:1.125rem;font-weight:600}.donut-grid{display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width: 768px){.donut-grid{grid-template-columns:repeat(2,1fr)}}.donut-section-title{text-align:center;font-size:.875rem;font-weight:500;color:hsl(var(--muted-foreground));margin-bottom:1rem}.donut-value{text-align:center;margin-top:.5rem}.donut-value-text{font-size:1.875rem;font-weight:700}.donut-value-text.primary{color:hsl(var(--primary))}.donut-value-text.accent{color:hsl(var(--accent))}.parent-dashboard-container{min-height:100vh;background-color:hsl(var(--background))}.parent-dashboard-header{background-color:hsl(var(--card));border-bottom:1px solid hsl(var(--border));position:sticky;top:0;z-index:10;box-shadow:var(--shadow-sm)}.parent-dashboard-header-content{max-width:80rem;margin:0 auto;padding:1rem}@media (min-width: 640px){.parent-dashboard-header-content{padding:1rem 1.5rem}}@media (min-width: 1024px){.parent-dashboard-header-content{padding:1rem 2rem}}.parent-dashboard-header-inner{display:flex;align-items:center;justify-content:space-between}.parent-dashboard-header-left{display:flex;align-items:center;gap:1rem}.parent-dashboard-avatar{width:3rem;height:3rem;border-radius:9999px;border:2px solid hsl(var(--primary))}.parent-dashboard-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground))}.parent-dashboard-subtitle{font-size:.875rem;color:hsl(var(--muted-foreground))}.parent-dashboard-header-actions{display:flex;gap:.75rem}.parent-dashboard-main{max-width:80rem;margin:0 auto;padding:2rem 1rem}@media (min-width: 640px){.parent-dashboard-main{padding:2rem 1.5rem}}@media (min-width: 1024px){.parent-dashboard-main{padding:2rem}}.parent-dashboard-charts-row{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}@media (min-width: 1024px){.parent-dashboard-charts-row{grid-template-columns:repeat(2,1fr)}}.parent-dashboard-exercise-section{margin-bottom:2rem}.parent-dashboard-course-activity-row{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}@media (min-width: 1024px){.parent-dashboard-course-activity-row{grid-template-columns:repeat(2,1fr)}}.parent-dashboard-footer{background-color:hsl(var(--card));border-top:1px solid hsl(var(--border));margin-top:3rem}.parent-dashboard-footer-content{max-width:80rem;margin:0 auto;padding:1.5rem 1rem}@media (min-width: 640px){.parent-dashboard-footer-content{padding:1.5rem}}@media (min-width: 1024px){.parent-dashboard-footer-content{padding:1.5rem 2rem}}.parent-dashboard-footer-text{text-align:center;font-size:.875rem;color:hsl(var(--muted-foreground))}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background-color:#000c;animation:fadeIn .15s ease-out}.dialog-content{position:fixed;left:50%;top:50%;z-index:50;display:grid;width:100%;max-width:32rem;translate:-50% -50%;gap:1rem;border:1px solid hsl(var(--border));background-color:hsl(var(--background));padding:1.5rem;box-shadow:var(--shadow-lg);animation:scaleIn .2s ease-out;border-radius:var(--radius)}.dialog-content:focus-visible{outline:none}.dialog-close{position:absolute;right:1rem;top:1rem;border-radius:.125rem;opacity:.7;transition:opacity .2s;cursor:pointer;background:none;border:none;padding:.25rem;color:hsl(var(--foreground))}.dialog-close:hover{opacity:1}.dialog-close:focus-visible{outline:2px solid hsl(var(--ring));outline-offset:2px}.dialog-header{display:flex;flex-direction:column;gap:.375rem;text-align:center}@media (min-width: 640px){.dialog-header{text-align:left}}.dialog-footer{display:flex;flex-direction:column-reverse;gap:.5rem}@media (min-width: 640px){.dialog-footer{flex-direction:row;justify-content:flex-end}}.dialog-title{font-size:1.125rem;font-weight:600;line-height:1;letter-spacing:-.025em;color:hsl(var(--foreground))}.dialog-description{font-size:.875rem;color:hsl(var(--muted-foreground))}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.calendar-container{min-height:100vh;background:hsl(var(--background));padding:2rem}.calendar-header{margin-bottom:2rem}.calendar-title{font-size:2rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:1.5rem}.calendar-nav{display:flex;align-items:center;justify-content:space-between;background:hsl(var(--card));padding:1rem;border-radius:.75rem;border:1px solid hsl(var(--border));box-shadow:var(--shadow-sm)}.calendar-nav-button{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:var(--transition-smooth)}.calendar-nav-button:hover{opacity:.9;transform:translateY(-1px)}.calendar-nav-button:active{transform:translateY(0)}.calendar-nav-button svg{width:1rem;height:1rem}.calendar-current-date{font-size:1.125rem;font-weight:600;color:hsl(var(--foreground))}.calendar-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:1.5rem}@media (min-width: 1024px){.calendar-grid{grid-template-columns:2fr 1fr}}.day-view-card{background:hsl(var(--card));border-radius:.75rem;border:1px solid hsl(var(--border));overflow:hidden;box-shadow:var(--shadow-md)}.day-view-header{background:hsl(var(--muted));padding:1rem;border-bottom:1px solid hsl(var(--border));text-align:center}.day-view-header-text{font-size:1.125rem;font-weight:600;color:hsl(var(--foreground))}.day-view-grid{display:grid;grid-template-columns:100px 1fr;position:relative}.time-slot-group{display:contents}.time-slot-label{padding:.75rem;border-bottom:1px solid hsl(var(--border));border-right:1px solid hsl(var(--border));background:hsl(var(--muted) / .3);display:flex;align-items:flex-start}.time-slot-text{font-size:.875rem;color:hsl(var(--muted-foreground));font-weight:500}.time-slot-content{position:relative;border-bottom:1px solid hsl(var(--border));min-height:80px;transition:background-color .2s}.time-slot-content:hover{background:hsl(var(--muted) / .2)}.class-blocks-container{grid-column-start:2;grid-row-start:1;grid-row-end:-1;position:relative;pointer-events:none}.class-block{position:absolute;left:.5rem;right:.5rem;border-radius:.5rem;padding:.75rem;box-shadow:0 2px 8px #0000001a;animation:scaleIn .4s ease-out forwards;cursor:pointer;transition:transform .2s;pointer-events:auto}.class-block:hover{transform:scale(1.02)}.class-block-title{color:#fff;font-weight:600;font-size:1rem;margin-bottom:.25rem}.class-block-time{color:#fff;font-size:.875rem;opacity:.9;margin-bottom:.25rem}.class-block-room{color:#fff;font-size:.875rem;opacity:.8}.class-block-teacher{color:#fff;font-size:.75rem;opacity:.75;margin-top:.25rem}.no-classes-message{padding:2rem;text-align:center;color:hsl(var(--muted-foreground))}.attendance-section{display:flex;flex-direction:column;gap:1.5rem}.attendance-list-card{background:hsl(var(--card));padding:1.5rem;border-radius:.75rem;border:1px solid hsl(var(--border));box-shadow:var(--shadow-sm);animation:fadeInUp .5s ease-out}.attendance-list-title{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:1rem}.attendance-items{display:flex;flex-direction:column;gap:.75rem}.attendance-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-radius:.5rem;border:1px solid hsl(var(--border));background:hsl(var(--card));transition:var(--transition-smooth);animation:slideInRight .5s ease-out forwards}.attendance-item:hover{border-color:hsl(var(--primary) / .3);box-shadow:var(--shadow-sm)}.attendance-item-left{display:flex;align-items:center;gap:.75rem}.attendance-item-title{font-weight:600;color:hsl(var(--foreground));margin-bottom:.125rem}.attendance-item-time{font-size:.875rem;color:hsl(var(--muted-foreground))}.attendance-status-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.attendance-status-badge svg{width:1rem;height:1rem}.attendance-status-present{background:hsl(var(--success) / .15);color:hsl(var(--success))}.attendance-status-absent{background:hsl(var(--destructive) / .15);color:hsl(var(--destructive))}.attendance-status-late{background:hsl(var(--warning) / .15);color:hsl(var(--warning))}.attendance-status-excused{background:hsl(var(--secondary) / .15);color:hsl(var(--secondary))}.no-attendance-message{padding:2rem;text-align:center;color:hsl(var(--muted-foreground))}.attendance-legend{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem;background:hsl(var(--muted) / .3);border-radius:.5rem;border:1px solid hsl(var(--border))}.legend-item{display:flex;align-items:center;gap:.5rem;animation:fadeInUp .5s ease-out forwards}.legend-item svg{width:1rem;height:1rem}.legend-item-text{font-size:.875rem;color:hsl(var(--foreground))}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.calendar-container{min-height:100vh;background-color:hsl(var(--background))}.calendar-header{background-color:hsl(var(--card));border-bottom:1px solid hsl(var(--border));position:sticky;top:0;z-index:20;box-shadow:var(--shadow-sm)}.calendar-header-content{max-width:80rem;margin:0 auto;padding:1rem}@media (min-width: 640px){.calendar-header-content{padding:1rem 1.5rem}}@media (min-width: 1024px){.calendar-header-content{padding:1rem 2rem}}.calendar-header-inner{display:flex;align-items:center;justify-content:space-between}.calendar-header-left{display:flex;align-items:center;gap:1rem}.calendar-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground))}.calendar-subtitle{font-size:.875rem;color:hsl(var(--muted-foreground))}.calendar-nav-controls{display:flex;align-items:center;gap:.75rem}.calendar-date-display{text-align:center;min-width:200px}.calendar-date-text{font-size:1.125rem;font-weight:600;color:hsl(var(--foreground))}.calendar-main{max-width:80rem;margin:0 auto;padding:2rem 1rem}@media (min-width: 640px){.calendar-main{padding:2rem 1.5rem}}@media (min-width: 1024px){.calendar-main{padding:2rem}}.calendar-stats-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem}@media (min-width: 768px){.calendar-stats-grid{grid-template-columns:repeat(4,1fr)}}.calendar-stat-card{padding:1.5rem;animation:fadeInUp .5s ease-out forwards}.calendar-stat-title{font-size:.875rem;font-weight:500;color:hsl(var(--muted-foreground));margin-bottom:.5rem}.calendar-stat-value{font-size:1.875rem;font-weight:700}.calendar-stat-value.primary{color:hsl(var(--primary))}.calendar-stat-value.success{color:hsl(var(--success))}.calendar-stat-value.destructive{color:hsl(var(--destructive))}.calendar-stat-value.warning{color:hsl(var(--warning))}.calendar-legend-container{margin-bottom:1.5rem;animation:fadeInUp .5s ease-out forwards}.calendar-schedule-section{margin-bottom:2rem;animation:fadeInUp .5s ease-out forwards}.calendar-schedule-card{padding:1.5rem}.calendar-schedule-title{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:1.5rem}.calendar-attendance-section{animation:fadeInUp .5s ease-out forwards}.calendar-attendance-card{padding:1.5rem}.calendar-attendance-title{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:1.5rem}.dialog-color-bar{width:100%;height:.5rem;border-radius:9999px}.dialog-details{display:flex;flex-direction:column;gap:.5rem}.dialog-detail-row{display:flex;justify-content:space-between}.dialog-detail-label{color:hsl(var(--muted-foreground))}.dialog-detail-value{font-weight:600;color:hsl(var(--foreground))}.idb-page{min-height:100vh;background:linear-gradient(to bottom,var(--color-background, #f8fafc),var(--color-muted, #eef2f7));padding:24px}.idb-page-inner{max-width:1400px;margin:0 auto;width:100%}.idb-header-title{font-size:2rem;font-weight:700}.idb-header-subtitle{font-size:.95rem;color:#667085}.idb-stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:16px;margin-bottom:24px}.idb-stat-card{border-radius:16px;padding:20px;border:1px solid rgba(148,163,184,.4);background:#fff;box-shadow:0 8px 20px #0f172a0a}.idb-stat-card-main{display:flex;align-items:center;gap:16px}.idb-stat-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center}.idb-stat-value{font-size:1.5rem;font-weight:700}.idb-stat-label{font-size:.875rem;color:#667085}.idb-tabs-root{width:100%}.idb-tabs-list{display:inline-flex;padding:4px;border-radius:12px;margin-bottom:24px;background-color:#e5e7eb}.idb-tabs-trigger{display:inline-flex;align-items:center;gap:8px;border-radius:10px;padding:8px 16px;font-size:14px}.idb-card{border-radius:16px;border:1px solid rgba(148,163,184,.35);background-color:#fff;box-shadow:0 8px 20px #0f172a0a;overflow:hidden}.idb-card-header{padding:16px;border-bottom:1px solid rgba(148,163,184,.35)}.idb-card-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.idb-card-title{font-size:1rem;font-weight:600}.idb-card-toolbar{display:flex;align-items:center;gap:12px}.idb-search-row{display:flex;flex-direction:column;gap:12px}.idb-search-main{display:flex;align-items:center;gap:16px;flex:1}.idb-search-input-wrapper{position:relative;flex:1;max-width:320px}.idb-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af}.idb-search-input{padding-left:32px}.idb-status-select-trigger{width:160px}.idb-selected-summary{display:flex;align-items:center;gap:8px;font-size:13px;color:#667085}.idb-student-name-cell{display:flex;align-items:center;gap:12px}.idb-student-avatar{width:32px;height:32px;border-radius:999px;display:flex;align-items:center;justify-content:center;background-color:#38bdf826}.idb-student-name{font-weight:500}.idb-student-email{color:#0ea5e9;font-size:13px}.idb-badges-row{display:flex;flex-wrap:wrap;gap:4px}.idb-progress-row{display:flex;align-items:center;gap:8px}.idb-progress-bar{width:64px;height:8px;border-radius:9999px;background-color:#e5e7eb;overflow:hidden}.idb-progress-fill{height:100%;border-radius:inherit;background-color:#0ea5e9;transition:width .2s ease}.idb-last-activity{font-size:13px;color:#667085}.idb-empty-state{text-align:center;padding:32px 0;font-size:14px;color:#6b7280}.idb-dropdown-panel{background-color:#fff;border:1px solid rgba(148,163,184,.5);z-index:9999!important}@media (max-width: 1024px){.idb-stats-grid{grid-template-columns:1fr}}@media (min-width: 768px){.idb-search-row{flex-direction:row;align-items:center;justify-content:space-between}}.class-modal-content{max-width:32rem;max-height:90vh;overflow-y:auto}.class-modal-form{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.class-modal-field{display:flex;flex-direction:column;gap:.5rem}.class-modal-label{font-size:.875rem;font-weight:500;color:#111827}.class-modal-input{width:100%}.class-modal-textarea{width:100%;min-height:4rem}.class-modal-section{display:flex;flex-direction:column;gap:.5rem}.class-modal-list-container{border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem;max-height:8rem;overflow-y:auto;background:#fff}.class-modal-list-empty{font-size:.875rem;color:#6b7280;text-align:center;padding:.5rem 0}.class-modal-list-item{display:flex;align-items:center;gap:.5rem;padding:.25rem 0}.class-modal-list-label{font-size:.875rem;font-weight:400;cursor:pointer;color:#111827;flex:1}.class-modal-footer{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.class-modal-theme-picker{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-top:.25rem}.class-modal-theme-btn{width:2.5rem;height:2.5rem;min-width:2.5rem;min-height:2.5rem;border-radius:9999px;border:2px solid #ffffff;cursor:pointer;transition:all .2s ease;position:relative;outline:none;box-shadow:0 2px 6px #0000001f;flex-shrink:0}.class-modal-theme-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #0003}.class-modal-theme-btn--selected{transform:scale(1.15);box-shadow:0 0 0 2px #fff,0 0 0 4px #1dafa1;z-index:1;border-color:#fff}.class-modal-theme-btn--selected:hover{transform:scale(1.2)}.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;font-family:inherit;transition:background-color .15s,color .15s,border-color .15s,opacity .15s;cursor:pointer;border:none;outline:none;text-decoration:none;line-height:1}.ui-btn:focus-visible{outline:2px solid var(--color-ring);outline-offset:2px}.ui-btn:disabled{pointer-events:none;opacity:.5}.ui-btn svg{pointer-events:none;width:1rem;height:1rem;flex-shrink:0}.ui-btn--default{background:var(--color-primary);color:var(--color-primary-foreground)}.ui-btn--default:hover{opacity:.9}.ui-btn--destructive{background:var(--color-destructive);color:var(--color-destructive-foreground)}.ui-btn--destructive:hover{opacity:.9}.ui-btn--outline{border:1px solid var(--color-border);background:var(--background-light);color:var(--color-foreground)}.ui-btn--outline:hover{background:var(--color-muted)}.ui-btn--secondary{background:var(--color-secondary);color:var(--color-secondary-foreground)}.ui-btn--secondary:hover{opacity:.85}.ui-btn--ghost{background:transparent;color:var(--color-foreground)}.ui-btn--ghost:hover{background:var(--color-muted)}.ui-btn--link{background:transparent;color:var(--color-primary);text-decoration-line:underline;text-underline-offset:4px}.ui-btn--md{height:2.5rem;padding:.5rem 1rem}.ui-btn--sm{height:2.25rem;padding:.5rem .75rem;border-radius:var(--radius-sm)}.ui-btn--lg{height:2.75rem;padding:.5rem 2rem;border-radius:var(--radius-md)}.ui-btn--icon{height:2.5rem;width:2.5rem;padding:0}.ui-input{display:flex;height:2.5rem;width:100%;border-radius:var(--radius-md);border:1px solid var(--color-input);background:var(--background-light);color:var(--color-foreground);padding:.5rem .75rem;font-size:.875rem;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none}.ui-input::placeholder{color:var(--color-muted-foreground)}.ui-input:focus{border-color:var(--color-ring);box-shadow:0 0 0 2px #1dafa126}.ui-textarea{display:flex;min-height:5rem;width:100%;border-radius:var(--radius-md);border:1px solid var(--color-input);background:var(--background-light);color:var(--color-foreground);padding:.5rem .75rem;font-size:.875rem;font-family:inherit;transition:border-color .15s,box-shadow .15s;outline:none;resize:vertical}.ui-textarea::placeholder{color:var(--color-muted-foreground)}.ui-textarea:focus{border-color:var(--color-ring);box-shadow:0 0 0 2px #1dafa126}.ui-label{font-size:.875rem;font-weight:500;line-height:1;color:var(--color-foreground)}.ui-badge{display:inline-flex;align-items:center;border-radius:9999px;padding:.125rem .625rem;font-size:.75rem;font-weight:600;line-height:1.5;transition:background-color .15s;white-space:nowrap}.ui-badge--default{background:var(--color-primary);color:var(--color-primary-foreground)}.ui-badge--secondary{background:var(--color-secondary);color:var(--color-secondary-foreground)}.ui-badge--destructive{background:var(--color-destructive);color:var(--color-destructive-foreground)}.ui-badge--outline{border:1px solid var(--color-border);color:var(--color-foreground);background:transparent}.ui-card{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--background-light);color:var(--background-light-foreground);box-shadow:var(--shadow-card)}.ui-card__title{font-size:1.5rem;font-weight:600;line-height:1;letter-spacing:-.01em}.ui-card__description{font-size:.875rem;color:var(--color-muted-foreground)}.ui-table-wrapper{position:relative;width:100%;overflow-x:auto;overflow-y:visible}.ui-table{width:100%;caption-side:bottom;font-size:.875rem;border-collapse:collapse}.ui-table thead tr{border-bottom:1px solid var(--color-border)}.ui-table tbody tr:last-child{border-bottom:none}.ui-table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color .15s}.ui-table tbody tr:hover{background:#f2f5f880}.ui-table th{height:3rem;padding:0 1rem;text-align:left;vertical-align:middle;font-weight:500;color:var(--color-muted-foreground)}.ui-table td{padding:1rem;vertical-align:middle}.ui-table caption{margin-top:1rem;font-size:.875rem;color:var(--color-muted-foreground)}.ui-tabs__list{display:inline-flex;height:2.5rem;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--color-muted);padding:.25rem;color:var(--color-muted-foreground)}.ui-tabs__trigger{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;border-radius:var(--radius-sm);padding:.375rem .75rem;font-size:.875rem;font-weight:500;background:transparent;color:var(--color-muted-foreground);border:none;cursor:pointer;transition:all .15s}.ui-tabs__trigger:hover{color:var(--color-foreground)}.ui-tabs__trigger--active{background:var(--background-light);color:var(--color-foreground);box-shadow:0 1px 3px #00000014}.ui-tabs__content{margin-top:.5rem}.ui-tabs__content[hidden]{display:none}.ui-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#000c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:uiFadeIn .2s ease}.ui-dialog-content{position:fixed;left:50%;top:50%;z-index:51;transform:translate(-50%,-50%);display:grid;width:100%;max-width:32rem;gap:1rem;border:1px solid #e5e7eb;background:#fff;padding:1.5rem;border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000040;animation:uiSlideIn .2s ease;max-height:90vh;overflow-y:auto}.ui-dialog-close{position:absolute;right:1rem;top:1rem;border-radius:var(--radius-sm);opacity:.7;background:transparent;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--color-foreground);transition:opacity .15s}.ui-dialog-close:hover{opacity:1}.ui-dialog__header{display:flex;flex-direction:column;gap:.375rem;text-align:left}.ui-dialog__title{font-size:1.125rem;font-weight:600;line-height:1.2;letter-spacing:-.01em}.ui-dialog__description{font-size:.875rem;color:#6b7280}.ui-dialog__footer{display:flex;flex-direction:row;justify-content:flex-end;gap:.5rem}@keyframes uiFadeIn{0%{opacity:0}to{opacity:1}}@keyframes uiSlideIn{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.ui-select-wrapper{position:relative;display:inline-block;width:100%}.ui-select-trigger{display:flex;height:2.5rem;width:100%;align-items:center;justify-content:space-between;border-radius:var(--radius-md);border:1px solid var(--color-input);background:var(--background-light);color:var(--color-foreground);padding:.5rem .75rem;font-size:.875rem;font-family:inherit;cursor:pointer;outline:none;transition:border-color .15s}.ui-select-trigger:focus{border-color:var(--color-ring);box-shadow:0 0 0 2px #1dafa126}.ui-select-trigger:disabled{cursor:not-allowed;opacity:.5}.ui-select-trigger svg{width:1rem;height:1rem;opacity:.5;flex-shrink:0}.ui-select-content{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;min-width:8rem;max-height:24rem;overflow-y:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--background-light);padding:.25rem;box-shadow:0 10px 25px #0000001f;animation:uiSelectIn .15s ease}.ui-select-item{position:relative;display:flex;width:100%;align-items:center;border-radius:var(--radius-sm);padding:.5rem .5rem .5rem 2rem;font-size:.875rem;cursor:pointer;background:transparent;border:none;color:var(--color-foreground);text-align:left;font-family:inherit;transition:background-color .1s}.ui-select-item:hover,.ui-select-item--selected{background:var(--color-muted)}.ui-select-item__check{position:absolute;left:.5rem;width:1rem;height:1rem;display:flex;align-items:center;justify-content:center}@keyframes uiSelectIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ui-checkbox{display:inline-flex;align-items:center;justify-content:center;width:1rem;height:1rem;flex-shrink:0;border-radius:.25rem;border:1px solid var(--color-primary);background:transparent;cursor:pointer;transition:all .15s;padding:0;color:var(--color-primary-foreground)}.ui-checkbox--checked{background:var(--color-primary);color:var(--color-primary-foreground)}.ui-checkbox:disabled{cursor:not-allowed;opacity:.5}.ui-checkbox svg{width:.75rem;height:.75rem}.ui-switch{position:relative;display:inline-flex;height:1.5rem;width:2.75rem;flex-shrink:0;cursor:pointer;align-items:center;border-radius:9999px;border:2px solid transparent;background:var(--color-input);transition:background-color .2s;padding:0}.ui-switch--checked{background:var(--color-primary)}.ui-switch__thumb{pointer-events:none;display:block;height:1.25rem;width:1.25rem;border-radius:9999px;background:var(--background-light);box-shadow:0 2px 4px #00000026;transition:transform .2s;transform:translate(0)}.ui-switch--checked .ui-switch__thumb{transform:translate(1.25rem)}.ui-dropdown{position:relative;display:inline-block}.ui-dropdown__content{position:fixed;z-index:99999;min-width:12rem;overflow:hidden;border-radius:var(--radius-md);border:1px solid #e5e7eb;background:#fff;padding:.5rem;box-shadow:0 10px 25px #00000026;animation:uiSelectIn .15s ease}.ui-dropdown__item{position:relative;display:flex;width:100%;align-items:center;border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.875rem;cursor:pointer;background:transparent;border:none;color:#22247a;text-align:left;font-family:inherit;transition:background-color .1s;gap:.5rem}.ui-dropdown__item:hover{background:#f3f4f6}.ui-dropdown__item--destructive{color:#dc2626}.ui-dropdown__item--destructive:hover{background:#fee2e2}.ui-scroll-area{position:relative;overflow:auto}.ui-progress{position:relative;height:1rem;width:100%;overflow:hidden;border-radius:9999px;background:var(--color-secondary)}.ui-progress__bar{height:100%;width:100%;flex:1;background:var(--color-primary);transition:transform .3s ease;border-radius:9999px}.ui-skeleton{border-radius:var(--radius-md);background:var(--color-muted);animation:uiPulse 2s ease-in-out infinite}@keyframes uiPulse{0%,to{opacity:1}50%{opacity:.5}}.lessonCard{background-color:var(--background-light);border-radius:1rem;padding:1.5rem;box-shadow:var(--shadow-card);transition:all .3s ease;cursor:pointer}.lessonCard:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px)}.lessonCard--locked{background-color:var(--color-muted);border-radius:1rem;padding:1.5rem;opacity:.6;cursor:not-allowed}.lessonCard--hidden{opacity:.5;pointer-events:none}.lessonCard--completed{background-color:#20c55d0d;border:2px solid hsla(142,72%,45%,.2)}.lessonCard__content{display:flex;align-items:flex-start;gap:1rem}.lessonCard__number{width:2rem;height:2rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--font-fredoka);font-size:.875rem}.lessonCard__number--active{background-color:#1dafa11a;color:var(--color-primary)}.lessonCard__number--locked{background-color:#b6bcc84d;color:var(--color-locked-foreground)}.lessonCard__number--completed{background-color:#20c55d33;color:var(--color-success)}.lessonCard__icon{width:3.5rem;height:3.5rem;border-radius:1rem;display:flex;align-items:center;justify-content:center;transition:transform .2s ease}.lessonCard:hover .lessonCard__icon{transform:scale(1.1)}.lessonCard__icon--video{background-color:#1dafa11a;color:var(--color-primary)}.lessonCard__icon--text{background-color:#0d80f21a;color:#0d80f2}.lessonCard__icon--image{background-color:#f20d801a;color:#f20d80}.lessonCard__icon--meeting{background-color:#f56e3d1a;color:var(--color-accent)}.lessonCard__icon--workshop{background-color:#20c55d1a;color:var(--color-success)}.lessonCard__icon--locked{background-color:#b6bcc84d;color:var(--color-locked-foreground)}.lessonCard__icon--completed{background-color:#20c55d33;color:var(--color-success)}.lessonCard__body{flex:1}.lessonCard__meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.lessonCard__type{font-size:.75rem;font-weight:500;padding:.125rem .5rem;border-radius:9999px}.lessonCard__type--video{background-color:#1dafa11a;color:var(--color-primary)}.lessonCard__type--text{background-color:#0d80f21a;color:#0d80f2}.lessonCard__type--image{background-color:#f20d801a;color:#f20d80}.lessonCard__type--meeting{background-color:#f56e3d1a;color:var(--color-accent)}.lessonCard__type--workshop{background-color:#20c55d1a;color:var(--color-success)}.lessonCard__type--locked{background-color:#b6bcc84d;color:var(--color-locked-foreground)}.lessonCard__badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;padding:.125rem .5rem;border-radius:9999px;background-color:var(--color-muted);color:var(--color-muted-foreground)}.lessonCard__duration{font-size:.75rem;color:var(--color-muted-foreground)}.lessonCard__title{font-family:var(--font-fredoka);font-size:1.125rem;margin-bottom:.25rem;transition:color .2s ease}.lessonCard:hover .lessonCard__title{color:var(--color-primary)}.lessonCard--locked .lessonCard__title{color:var(--color-locked-foreground)}.lessonCard__description{font-size:.875rem;color:var(--color-muted-foreground)}.lessonCard--locked .lessonCard__description{color:#636d83b3}.lessonCard__footer{margin-top:.75rem;display:flex;align-items:center;justify-content:space-between}.lessonCard__action{display:flex;align-items:center;gap:.5rem;color:var(--color-primary);font-size:.875rem;font-weight:500}.lessonCard__action svg{fill:currentColor}.lessonCard__status{font-size:.875rem;font-weight:500;color:var(--color-success)}.progressBar{width:100%}.progressBar__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.progressBar__label{font-size:.875rem;font-weight:500;color:var(--color-muted-foreground)}.progressBar__value{font-size:.875rem;font-weight:700;color:var(--color-primary)}.progressBar__track{border-radius:9999px;background-color:var(--color-secondary);overflow:hidden}.progressBar__track--sm{height:.5rem}.progressBar__track--md{height:.75rem}.progressBar__track--lg{height:1rem}.progressBar__fill{height:100%;border-radius:9999px;background:var(--gradient-primary);transition:width .5s ease-out}.scenarioDialogue{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:flex-end;cursor:pointer;background-size:cover;background-position:center}.scenarioDialogue__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.9),rgba(0,0,0,.4),transparent);pointer-events:none}.scenarioDialogue__character{position:absolute;left:0;bottom:0;height:70vh;display:flex;align-items:flex-end}.scenarioDialogue__characterImg{height:100%;width:auto;object-fit:contain;object-position:bottom;max-height:500px;filter:drop-shadow(0 25px 25px rgba(0,0,0,.5))}.scenarioDialogue__content{width:100%;padding-bottom:2rem;padding-left:2rem;padding-right:2rem;position:relative;z-index:10}.scenarioDialogue__inner{max-width:56rem;margin-left:300px}.scenarioDialogue__scenarioTag{display:inline-block;background-color:hsla(var(--muted),.8);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:hsl(var(--muted-foreground));padding:.25rem 1rem;border-radius:.5rem .5rem 0 0;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.scenarioDialogue__nameTag{display:inline-block;background-color:var(--primary);color:hsl(var(--primary-foreground));padding:.5rem 1.5rem;border-radius:.75rem .75rem 0 0;font-family:Fredoka,sans-serif;font-size:1.25rem;box-shadow:0 10px 15px -3px #0000001a}.scenarioDialogue__box{background-color:#f9fafb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:0 1rem 1rem;padding:1.5rem;box-shadow:0 25px 50px -12px #00000040;border:1px solid hsla(var(--border),.5)}.scenarioDialogue__displayImage{margin-bottom:1rem;display:flex}.scenarioDialogue__displayImage--left{justify-content:flex-start}.scenarioDialogue__displayImage--center{justify-content:center}.scenarioDialogue__displayImage--right{justify-content:flex-end}.scenarioDialogue__displayImageImg{border-radius:.75rem;box-shadow:0 10px 15px -3px #0000001a;object-fit:contain}.scenarioDialogue__displayImageImg--small{max-height:6rem}.scenarioDialogue__displayImageImg--medium{max-height:12rem}.scenarioDialogue__displayImageImg--large{max-height:16rem}.scenarioDialogue__text{font-size:1.25rem;line-height:1.75;min-height:80px;font-weight:500;color:hsl(var(--foreground))}.scenarioDialogue__cursor{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;color:hsl(var(--primary))}.scenarioDialogue__footer{margin-top:1rem;display:flex;align-items:center;justify-content:space-between}.scenarioDialogue__dots{display:flex;gap:.5rem}.scenarioDialogue__dot{width:.625rem;height:.625rem;border-radius:50%;transition:all .3s;background-color:hsl(var(--muted))}.scenarioDialogue__dot--active{background-color:hsl(var(--primary));transform:scale(1.25)}.scenarioDialogue__dot--past{background-color:hsla(var(--primary),.5)}.scenarioDialogue__hint{font-size:.875rem;color:hsl(var(--muted-foreground));animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.pointsBadge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;background-color:#ffbf0033;font-weight:700}.pointsBadge--sm{font-size:.875rem;padding:.25rem .5rem}.pointsBadge--md{font-size:1rem;padding:.375rem .75rem}.pointsBadge--lg{font-size:1.125rem;padding:.5rem 1rem}.pointsBadge__icon{fill:currentColor;color:#e6ac00}.pointsBadge__icon--sm{width:14px;height:14px}.pointsBadge__icon--md{width:16px;height:16px}.pointsBadge__icon--lg{width:20px;height:20px}.pointsBadge__value{color:#806000;font-weight:700}.pointsBadge--animate{animation:pop .3s ease-out}.sandTimer{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.75rem;background-color:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dark .sandTimer{background-color:#0f1729cc}.sandTimer--low{background-color:#ef434333;animation:pulse 1s ease-in-out infinite}.sandTimer__hourglass{position:relative;width:2rem;height:2.5rem}.sandTimer__glass{position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid currentColor;border-radius:.125rem;overflow:hidden}.sandTimer__sand{position:absolute;bottom:0;left:0;right:0;transition:height 1s linear;background-color:var(--color-primary)}.sandTimer__sand--low{background-color:var(--color-destructive)}.sandTimer__fall{position:absolute;top:50%;left:50%;transform:translate(-50%);width:.125rem;height:.5rem;background-color:currentColor;opacity:.5}.sandTimer__display{display:flex;align-items:center;gap:.25rem}.sandTimer__icon{color:var(--color-muted-foreground)}.sandTimer__icon--low{color:var(--color-destructive)}.sandTimer__time{font-family:monospace;font-weight:700;font-size:1.125rem}.sandTimer__time--low{color:var(--color-destructive)}.feedbackModal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background-color:#0009;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.feedbackModal__content{background-color:#fff;border-radius:1rem;padding:1.5rem;max-width:24rem;width:90%;text-align:center;box-shadow:0 25px 50px -12px #00000040;animation:scaleIn .2s ease}.feedbackModal__content--incorrect{border:4px solid hsl(var(--error))}.feedbackModal__sparkles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.feedbackModal__sparkle{position:absolute;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.feedbackModal__mascot{position:relative;display:inline-block}.feedbackModal__mascotImg{width:8rem;height:8rem;margin:0 auto;object-fit:contain}.feedbackModal__mascotImg--happy{animation:bounceGentle 2s ease-in-out infinite}.feedbackModal__mascotImg--angry{animation:shake .5s ease-in-out}.feedbackModal__pointsBadge{position:absolute;top:-.25rem;right:-.25rem;display:flex;align-items:center;gap:.25rem;background:linear-gradient(to right,#ffbf00,#e69900);padding:.25rem .75rem;border-radius:9999px;box-shadow:0 10px 15px -3px #0000001a;animation:pop .3s ease}.feedbackModal__pointsIcon{color:#fff}.feedbackModal__pointsText{font-size:.875rem;font-weight:700;color:#fff}.feedbackModal__title--correct{font-family:Fredoka,sans-serif;font-size:1.875rem;color:hsl(var(--success));margin-top:1rem}.feedbackModal__title--incorrect{font-family:Fredoka,sans-serif;font-size:1.5rem;color:hsl(var(--error));margin-top:1rem}.feedbackModal__message{color:hsl(var(--muted-foreground));margin-top:.5rem;font-size:1.125rem}.feedbackModal__bar{margin-top:1.5rem;height:.375rem;border-radius:9999px;margin-left:2rem;margin-right:2rem}.feedbackModal__bar--correct{background:linear-gradient(to right,hsl(var(--success)),hsl(var(--primary)),#ffbf00)}.feedbackModal__bar--incorrect{background:linear-gradient(to right,hsl(var(--error)),hsla(var(--error),.6),hsla(var(--error),.3))}.feedbackModal__actions{margin-top:1rem;display:flex;gap:.5rem;justify-content:center}.feedbackModal__btn{padding:.5rem 1rem;border-radius:.5rem;font-weight:500;font-size:.875rem;cursor:pointer;border:none;transition:all .2s}.feedbackModal__btn--primary{background:#22c55e;color:hsl(var(--primary-foreground))}.feedbackModal__btn--primary:hover{opacity:.9}.feedbackModal__btn--outline{background:transparent;border:1px solid hsl(var(--border));color:hsl(var(--foreground))}.feedbackModal__btn--outline:hover{background-color:hsl(var(--muted))}.feedbackModal__btn--destructive{background-color:hsl(var(--error));color:#fff}.feedbackModal__btn--destructive:hover{opacity:.9}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes pop{0%{transform:scale(0)}80%{transform:scale(1.1)}to{transform:scale(1)}}.errorAlert{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:1rem;background-color:#0f172966;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50}.errorAlert__card{background-color:var(--background-light);border-radius:1.5rem;padding:2rem;max-width:28rem;width:100%;box-shadow:0 25px 50px -12px #00000040;border:4px solid hsla(0,84%,60%,.3);animation:pop .3s ease-out}.errorAlert__content{display:flex;flex-direction:column;align-items:center;text-align:center}.errorAlert__character{width:8rem;height:8rem;margin-bottom:1rem;animation:shake .5s ease-in-out}.errorAlert__character img{width:100%;height:100%;object-fit:contain}.errorAlert__title{font-family:var(--font-fredoka);font-size:1.5rem;color:var(--color-destructive);margin-bottom:.5rem}.errorAlert__message{color:var(--color-muted-foreground);margin-bottom:1.5rem}.errorAlert__button{padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;font-size:1.125rem;background-color:var(--color-destructive);color:var(--color-destructive-foreground);transition:filter .2s ease;transform:scale(1);transition:transform .2s ease}.errorAlert__button:hover{filter:brightness(1.1)}.errorAlert__button:active{transform:scale(.95)}.quizExercise{display:flex;flex-direction:column;gap:1.5rem}.quizExercise__question{background-color:#e2f3f180;border-radius:1rem;padding:1.5rem}.quizExercise__questionText{font-family:var(--font-fredoka);font-size:1.25rem;color:var(--color-foreground);margin-bottom:.5rem}.quizExercise__options{display:grid;gap:.75rem}.quizExercise__option{width:100%;text-align:left;padding:1rem;border-radius:.75rem;border:2px solid var(--color-border);background-color:var(--background-light);transition:all .2s ease;cursor:pointer}.quizExercise__option:hover:not(:disabled){border-color:#1dafa180;background-color:#1dafa10d}.quizExercise__option--selected{border-color:var(--color-primary);background-color:#1dafa11a}.quizExercise__option--correct{border-color:var(--color-success);background-color:#20c55d1a;color:var(--color-success)}.quizExercise__option:disabled{cursor:default}.quizExercise__optionContent{display:flex;align-items:center;gap:.75rem}.quizExercise__optionLetter{width:2rem;height:2rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;background-color:var(--color-muted);color:var(--color-muted-foreground)}.quizExercise__option--selected .quizExercise__optionLetter{background-color:var(--color-primary);color:var(--color-primary-foreground)}.quizExercise__option--correct .quizExercise__optionLetter{background-color:var(--color-success);color:var(--color-success-foreground)}.quizExercise__optionText{font-weight:500}.quizExercise__optionCheck{margin-left:auto;color:var(--color-success)}.quizExercise__submitBtn{width:100%;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;font-size:1.125rem;background-color:var(--color-primary);color:var(--color-primary-foreground);box-shadow:0 10px 15px -3px #1dafa14d;transition:all .2s ease}.quizExercise__submitBtn:hover:not(:disabled){filter:brightness(1.1)}.quizExercise__submitBtn:active:not(:disabled){transform:scale(.95)}.quizExercise__submitBtn:disabled{opacity:.5;cursor:not-allowed}.quizExercise__result{display:flex;align-items:center;justify-content:center;gap:1rem;animation:pop .3s ease-out}.quizExercise__resultText{font-family:var(--font-fredoka);font-size:1.25rem;color:var(--color-success)}.dragDropExercise{display:flex;flex-direction:column;gap:1.5rem}.dragDropExercise__availableArea{background-color:#e2f3f180;border-radius:1rem;padding:1rem}.dragDropExercise__label{font-size:.875rem;color:var(--color-muted-foreground);margin-bottom:.75rem}.dragDropExercise__items{display:flex;flex-wrap:wrap;gap:.5rem}.dragDropExercise__item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;background-color:#1dafa11a;border:2px solid hsla(174,72%,40%,.3);cursor:grab;transition:all .2s ease;font-weight:500}.dragDropExercise__item:active{cursor:grabbing}.dragDropExercise__item:hover{background-color:#1dafa133;border-color:#1dafa180}.dragDropExercise__itemIcon{color:var(--color-muted-foreground)}.dragDropExercise__emptyMsg{color:var(--color-muted-foreground);font-style:italic}.dragDropExercise__targets{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (max-width: 768px){.dragDropExercise__targets{grid-template-columns:1fr}}.dragDropExercise__targetTitle{font-family:var(--font-fredoka);font-size:1.125rem;color:var(--color-primary);margin-bottom:.5rem}.dragDropExercise__dropZone{min-height:3.75rem;padding:1rem;border-radius:.5rem;border:2px dashed hsla(174,72%,40%,.4);background-color:#1dafa10d;transition:all .2s ease}.dragDropExercise__dropZone--active{border-color:var(--color-primary);background-color:#1dafa11a}.dragDropExercise__placedItems{display:flex;flex-wrap:wrap;gap:.5rem;min-height:2.5rem}.dragDropExercise__placedItem{padding:.375rem .75rem;border-radius:.5rem;cursor:pointer;transition:all .2s ease;font-weight:500}.dragDropExercise__placedItem--default{background-color:#1dafa133;color:var(--color-primary);border:1px solid hsla(174,72%,40%,.3)}.dragDropExercise__placedItem--default:hover{background-color:#ef434333;color:var(--color-destructive)}.dragDropExercise__placedItem--correct{background-color:#20c55d33;color:var(--color-success);border:1px solid hsla(142,72%,45%,.3)}.dragDropExercise__checkIcon{display:inline;margin-left:.25rem}.dragDropExercise__submitBtn{width:100%;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;font-size:1.125rem;background-color:var(--color-primary);color:var(--color-primary-foreground);box-shadow:0 10px 15px -3px #1dafa14d;transition:all .2s ease}.dragDropExercise__submitBtn:hover:not(:disabled){filter:brightness(1.1)}.dragDropExercise__submitBtn:active:not(:disabled){transform:scale(.95)}.dragDropExercise__submitBtn:disabled{opacity:.5;cursor:not-allowed}.dragDropExercise__result{display:flex;align-items:center;justify-content:center;gap:1rem;animation:pop .3s ease-out}.dragDropExercise__resultText{font-family:var(--font-fredoka);font-size:1.25rem;color:var(--color-success)}.fillBlankExercise{display:flex;flex-direction:column;gap:1.5rem}.fillBlankExercise__sentence{background-color:#e2f3f180;border-radius:1rem;padding:1.5rem}.fillBlankExercise__text{font-size:1.25rem;line-height:2;font-weight:500}.fillBlankExercise__blank{display:inline-block;margin:0 .25rem;padding:.25rem .75rem;border-radius:.5rem;border:2px dashed;min-width:5rem;text-align:center;transition:all .2s ease}.fillBlankExercise__blank--empty{background-color:var(--color-muted);border-color:#65758b4d}.fillBlankExercise__blank--filled{background-color:#1dafa133;border-color:var(--color-primary);color:var(--color-primary)}.fillBlankExercise__blank--correct{background-color:#20c55d33;border-color:var(--color-success);color:var(--color-success)}.fillBlankExercise__options{display:flex;flex-direction:column;gap:.75rem}.fillBlankExercise__optionsLabel{font-size:.875rem;color:var(--color-muted-foreground)}.fillBlankExercise__optionsList{display:flex;flex-wrap:wrap;gap:.5rem}.fillBlankExercise__option{padding:.5rem 1rem;border-radius:.75rem;border:2px solid hsla(174,72%,40%,.3);background-color:var(--background-light);font-weight:500;transition:all .2s ease;cursor:pointer}.fillBlankExercise__option:hover:not(:disabled){border-color:var(--color-primary);background-color:#1dafa11a}.fillBlankExercise__option--used{background-color:#f2f5f880;border-color:var(--color-muted);color:var(--color-muted-foreground);opacity:.5;cursor:default}.fillBlankExercise__option:disabled{cursor:default}.fillBlankExercise__reset{font-size:.875rem;color:var(--color-muted-foreground);text-decoration:underline;cursor:pointer;background:none;border:none;padding:0}.fillBlankExercise__reset:hover{color:var(--color-foreground)}.fillBlankExercise__submitBtn{width:100%;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;font-size:1.125rem;background-color:var(--color-primary);color:var(--color-primary-foreground);box-shadow:0 10px 15px -3px #1dafa14d;transition:all .2s ease}.fillBlankExercise__submitBtn:hover:not(:disabled){filter:brightness(1.1)}.fillBlankExercise__submitBtn:active:not(:disabled){transform:scale(.95)}.fillBlankExercise__submitBtn:disabled{opacity:.5;cursor:not-allowed}.fillBlankExercise__result{display:flex;align-items:center;justify-content:center;gap:1rem;animation:pop .3s ease-out}.fillBlankExercise__resultText{font-family:var(--font-fredoka);font-size:1.25rem;color:var(--color-success)}.wordMatchExercise{display:flex;flex-direction:column;gap:1.5rem}.wordMatchExercise__words{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}@media (max-width: 768px){.wordMatchExercise__words{grid-template-columns:repeat(2,1fr)}}.wordMatchExercise__wordBtn{padding:1rem;border-radius:.75rem;border:2px solid var(--color-border);background-color:var(--background-light);font-weight:500;transition:all .2s ease;cursor:pointer;text-align:center}.wordMatchExercise__wordBtn:hover:not(:disabled){border-color:#1dafa180}.wordMatchExercise__wordBtn--selected{border-color:var(--color-primary);background-color:#1dafa133;box-shadow:0 0 0 3px #1dafa14d}.wordMatchExercise__wordBtn--matched{border-color:var(--color-accent);background-color:#f56e3d1a}.wordMatchExercise__wordBtn--correct{border-color:var(--color-success);background-color:#20c55d1a}.wordMatchExercise__wordBtn:disabled{cursor:default}.wordMatchExercise__checkIcon{display:inline;margin-left:.5rem;color:var(--color-success)}.wordMatchExercise__hint{text-align:center;color:var(--color-muted-foreground)}.wordMatchExercise__hintActive{color:var(--color-primary);font-weight:500}.wordMatchExercise__images{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}@media (max-width: 768px){.wordMatchExercise__images{grid-template-columns:repeat(2,1fr)}}.wordMatchExercise__imageBtn{padding:1.5rem;border-radius:.75rem;border:2px solid var(--color-border);background-color:var(--background-light);font-size:2.5rem;transition:all .2s ease;cursor:pointer;text-align:center}.wordMatchExercise__imageBtn:hover:not(:disabled){border-color:#1dafa180;background-color:#1dafa10d}.wordMatchExercise__imageBtn--matched{border-color:var(--color-accent);background-color:#f56e3d1a}.wordMatchExercise__imageBtn--correct{border-color:var(--color-success);background-color:#20c55d1a}.wordMatchExercise__imageBtn--inactive{background-color:#f2f5f880}.wordMatchExercise__imageBtn:disabled{cursor:default}.wordMatchExercise__resetBtn{color:var(--color-muted-foreground);text-decoration:underline;font-size:.875rem;cursor:pointer;background:none;border:none}.wordMatchExercise__resetBtn:hover{color:var(--color-foreground)}.wordMatchExercise__submitBtn{width:100%;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;font-size:1.125rem;background-color:var(--color-primary);color:var(--color-primary-foreground);box-shadow:0 10px 15px -3px #1dafa14d;transition:all .2s ease}.wordMatchExercise__submitBtn:hover:not(:disabled){filter:brightness(1.1)}.wordMatchExercise__submitBtn:active:not(:disabled){transform:scale(.95)}.wordMatchExercise__submitBtn:disabled{opacity:.5;cursor:not-allowed}.wordMatchExercise__result{display:flex;align-items:center;justify-content:center;gap:1rem;animation:pop .3s ease-out}.wordMatchExercise__resultText{font-family:var(--font-fredoka);font-size:1.25rem;color:var(--color-success)}.storyReadingExercise{display:flex;flex-direction:column;gap:1.5rem}.storyReadingExercise__story{background-color:#e2f3f180;border-radius:1rem;overflow:hidden}.storyReadingExercise__storyToggle{width:100%;padding:1rem;display:flex;align-items:center;gap:.75rem;transition:background-color .2s ease;cursor:pointer;background:none;border:none;text-align:left}.storyReadingExercise__storyToggle:hover{background-color:#e2f3f1b3}.storyReadingExercise__storyIcon{color:var(--color-primary)}.storyReadingExercise__storyTitle{font-family:var(--font-fredoka);font-size:1.25rem}.storyReadingExercise__storyHint{margin-left:auto;font-size:.875rem;color:var(--color-muted-foreground)}.storyReadingExercise__storyContent{padding:0 1.5rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.storyReadingExercise__storyImage{border-radius:.75rem;overflow:hidden;margin-bottom:1rem}.storyReadingExercise__storyImage img{width:100%;height:12rem;object-fit:cover}.storyReadingExercise__paragraph{color:var(--color-foreground);line-height:1.75}.storyReadingExercise__question{background-color:var(--background-light);border-radius:1rem;padding:1.5rem;border:1px solid var(--color-border)}.storyReadingExercise__questionHeader{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.storyReadingExercise__questionBadge{background-color:var(--color-primary);color:var(--color-primary-foreground);padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:700}.storyReadingExercise__questionText{font-size:1.125rem;font-weight:500;margin-bottom:1rem}.storyReadingExercise__input{width:100%;padding:.75rem 1rem;border-radius:.75rem;border:2px solid var(--color-border);background-color:var(--color-background);font-family:inherit;font-size:1rem;transition:border-color .2s ease}.storyReadingExercise__input:focus{outline:none;border-color:var(--color-primary)}.storyReadingExercise__submitBtn{width:100%;margin-top:1rem;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;font-size:1.125rem;background-color:var(--color-primary);color:var(--color-primary-foreground);box-shadow:0 10px 15px -3px #1dafa14d;transition:all .2s ease}.storyReadingExercise__submitBtn:hover:not(:disabled){filter:brightness(1.1)}.storyReadingExercise__submitBtn:active:not(:disabled){transform:scale(.95)}.storyReadingExercise__submitBtn:disabled{opacity:.5;cursor:not-allowed}.storyReadingExercise__result{display:flex;align-items:center;justify-content:center;gap:1rem;animation:pop .3s ease-out}.storyReadingExercise__resultText{font-family:var(--font-fredoka);font-size:1.25rem;color:var(--color-success)}.ui-revise-map{display:flex;justify-content:center;padding:1.25rem}.ui-revise-map__card{width:min(960px,100%);background:#f9fafb;border:1px solid #d1fae5;border-radius:1rem;box-shadow:0 10px 30px #0000000f;padding:1.25rem}@media (min-width: 640px){.ui-revise-map__card{padding:1.5rem}}.ui-revise-map__header{display:flex;gap:.75rem;align-items:center}.ui-revise-map__badge{width:2.75rem;height:2.75rem;border-radius:.875rem;display:grid;place-items:center;background:#10b9811f;border:1px solid rgba(16,185,129,.18);color:#10b981;flex:0 0 auto}.ui-revise-map__badge-icon{width:1.25rem;height:1.25rem}.ui-revise-map__header-text{min-width:0}.ui-revise-map__title{font-size:1.125rem;font-weight:700;color:#1f2937;line-height:1.2}.ui-revise-map__subtitle{margin-top:.125rem;font-size:.875rem;color:#6b7280}.ui-revise-map__intro{margin-top:.75rem;font-size:.95rem;color:#1f2937;background:#d1fae559;border:1px solid #d1fae5;padding:.75rem .875rem;border-radius:.75rem}.ui-revise-map__topic{margin-top:.75rem;display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:999px;background:#d1fae540;border:1px solid #d1fae5;color:#1f2937}.ui-revise-map__topic-icon{width:1rem;height:1rem;color:#10b981}.ui-revise-map__topic-label{font-size:.75rem;color:#6b7280;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.ui-revise-map__topic-value{font-size:.875rem;font-weight:700}.ui-revise-map__content{margin-top:1rem;display:grid;gap:1rem}.ui-revise-map__graph{border-radius:1rem;border:1px solid #d1fae5;background:linear-gradient(180deg,#d1fae573,#f9fafb);overflow:hidden}.ui-revise-map__graph-inner{position:relative;height:min(520px,55vh);min-height:360px}.ui-revise-map__central-node{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);padding:.85rem 1.1rem;border-radius:.9rem;background:linear-gradient(135deg,#10b981,#10b981d9);color:#fff;font-weight:800;text-align:center;min-width:160px;box-shadow:0 10px 18px #0000001a;z-index:3}.ui-revise-map__svg-lines{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.ui-revise-map__word-node{position:absolute;width:min(210px,36vw);max-width:220px;border-radius:.9rem;border:1px solid #d1fae5;background:#fff;color:#1f2937;padding:.7rem .75rem;box-shadow:0 10px 18px #0000000f;z-index:2}.ui-revise-map__word-label{display:block;font-weight:800;font-size:.95rem;line-height:1.2}.ui-revise-map__word-def{display:block;margin-top:.25rem;font-size:.8rem;color:#6b7280;line-height:1.35}.ui-revise-map__node-color-0{border-left:5px solid #19a7e8}.ui-revise-map__node-color-1{border-left:5px solid #20c264}.ui-revise-map__node-color-2{border-left:5px solid #f56b21}.ui-revise-map__node-color-3{border-left:5px solid #e92f8d}.ui-revise-map__node-color-4{border-left:5px solid #e8af08}.ui-revise-map__node-color-5{border-left:5px solid #1db09d}.ui-revise-map__node-color-6{border-left:5px solid #7c2df0}.ui-revise-map__node-color-7{border-left:5px solid #3366cc}.ui-revise-map__input-panel{border:1px solid #d1fae5;border-radius:1rem;background:#f9fafb;padding:1rem}.ui-revise-map__feedback{margin-bottom:.75rem;padding:.65rem .75rem;border-radius:.75rem;font-size:.875rem;border:1px solid #d1fae5;background:#d1fae559}.ui-revise-map__feedback--correct{border-color:#22c55e59;background:#22c55e1a}.ui-revise-map__feedback--wrong{border-color:#ef444459;background:#ef44441a}.ui-revise-map__feedback--duplicate{border-color:#f59e0b59;background:#f59e0b1a}.ui-revise-map__input-row{display:grid;grid-template-columns:1fr;gap:.75rem}@media (min-width: 640px){.ui-revise-map__input-row{grid-template-columns:1fr auto;align-items:center}}.ui-revise-map__input{height:2.75rem;width:100%;border-radius:.75rem;border:1px solid #d1fae5;background:#f9fafb;padding:0 .95rem;font-size:.95rem}.ui-revise-map__input:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #10b981,0 0 0 4px #f9fafb}.ui-revise-map__status{margin-top:.75rem;display:grid;gap:.75rem}@media (min-width: 640px){.ui-revise-map__status{grid-template-columns:1fr 1fr auto;align-items:center}}.ui-revise-map__status-item{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.5rem .75rem;border-radius:.75rem;border:1px dashed #d1fae5;background:#d1fae540}.ui-revise-map__status-label{font-size:.75rem;color:#6b7280;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.ui-revise-map__status-value{font-size:.95rem;font-weight:800}.ui-revise-map__status-value--met{color:#22c55e}.ui-revise-map__actions{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end}.ui-revise-map__button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;height:2.75rem;padding:0 1rem;border-radius:.75rem;font-weight:800;font-size:.95rem;border:1px solid transparent;transition:background-color .15s ease,border-color .15s ease,transform 80ms ease,opacity .15s ease}.ui-revise-map__button:active:not(:disabled){transform:translateY(1px)}.ui-revise-map__button:disabled{opacity:.55;cursor:not-allowed}.ui-revise-map__button--primary{background:#10b981;color:#fff}.ui-revise-map__button--primary:hover:not(:disabled){filter:brightness(.98)}.ui-revise-map__button--secondary{background:#059669;color:#fff;border-color:#d1fae5}.ui-revise-map__button--secondary:hover:not(:disabled){background:#d1fae5}.ui-revise-map__hint-button{width:100%}@media (min-width: 640px){.ui-revise-map__hint-button{width:auto}}.ui-revise-map__hint-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:grid;place-items:center;padding:1.25rem;z-index:50}.ui-revise-map__hint-card{width:min(520px,100%);background:#f9fafb;border:1px solid #d1fae5;border-radius:1rem;box-shadow:0 22px 60px #00000047;padding:1.25rem;text-align:center}.ui-revise-map__hint-icon{width:3rem;height:3rem;border-radius:999px;display:grid;place-items:center;margin:0 auto .75rem;background:#f59e0b1f;color:#f59e0b;border:1px solid rgb(245 158 11 / .22)}.ui-revise-map__hint-title{font-size:1.05rem;font-weight:900;margin:0;color:#1f2937}.ui-revise-map__hint-text{margin:.5rem 0 1rem;color:#6b7280;line-height:1.45}.ui-revise-map__hint-close{width:100%}.ui-revise-map__result{margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.25rem .5rem .25rem}.ui-revise-map__result-text{font-size:1.15rem;font-weight:900;color:#22c55e}.wordScrambleExercise{display:flex;flex-direction:column;gap:1.5rem}.wordScrambleExercise__hintToggle{display:flex;align-items:center;justify-content:center;gap:.5rem}.wordScrambleExercise__hintBtn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;color:var(--color-accent);font-size:.875rem;cursor:pointer}.wordScrambleExercise__hintBtn:hover{opacity:.8}.wordScrambleExercise__hint{text-align:center;padding:.75rem;background-color:#f56e3d1a;border-radius:.5rem;color:var(--color-accent);animation:fade-in .3s ease-out}.wordScrambleExercise__answerArea{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;min-height:3.75rem;padding:1rem;background-color:#f2f5f880;border-radius:.75rem;border:2px dashed var(--color-border)}.wordScrambleExercise__answerPlaceholder{color:var(--color-muted-foreground);align-self:center}.wordScrambleExercise__answerLetter{width:3rem;height:3rem;background-color:var(--color-primary);color:var(--color-primary-foreground);font-family:var(--font-fredoka);font-size:1.25rem;border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease;animation:pop .3s ease-out}.wordScrambleExercise__answerLetter:hover{transform:scale(.95)}.wordScrambleExercise__scrambledArea{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;padding:1rem}.wordScrambleExercise__scrambledLetter{width:3rem;height:3rem;background-color:var(--background-light);border:2px solid var(--color-border);font-family:var(--font-fredoka);font-size:1.25rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.wordScrambleExercise__scrambledLetter:hover{border-color:var(--color-primary);transform:scale(1.1)}.wordScrambleExercise__actions{display:flex;justify-content:center;gap:.75rem}.wordScrambleExercise__actionBtn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;border:1px solid var(--color-border);background-color:var(--background-light);cursor:pointer;transition:all .2s ease}.wordScrambleExercise__actionBtn:hover{background-color:var(--color-muted)}.wordScrambleExercise__submitBtn{padding:.5rem 2rem;border-radius:.5rem;font-weight:500;background-color:var(--color-primary);color:var(--color-primary-foreground);border:none;cursor:pointer;transition:all .2s ease}.wordScrambleExercise__submitBtn:hover:not(:disabled){filter:brightness(1.1)}.wordScrambleExercise__submitBtn:disabled{opacity:.5;cursor:not-allowed}.ui-dialog__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background-color:#000c}.ui-dialog__overlay[data-state=open]{animation:ui-dialog-fade-in .15s ease-out}.ui-dialog__overlay[data-state=closed]{animation:ui-dialog-fade-out .15s ease-in}.ui-dialog__content{position:fixed;left:50%;top:50%;z-index:50;display:grid;width:100%;max-width:32rem;transform:translate(-50%,-50%);gap:1rem;border:1px solid hsl(var(--border));background-color:hsl(var(--background));padding:1.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;transition-duration:.2s}.ui-dialog__content[data-state=open]{animation:ui-dialog-content-in .2s ease-out}.ui-dialog__content[data-state=closed]{animation:ui-dialog-content-out .2s ease-in}@media (min-width: 640px){.ui-dialog__content{border-radius:.5rem}}.ui-dialog__close{position:absolute;top:.5rem;right:.5rem;height:1.8rem;padding:.25rem .5rem;font-size:.75rem;gap:.25rem;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;border-radius:.375rem;font-size:.875rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;border:1px solid #d1d5db;transition:opacity .15s ease}.ui-dialog__close:hover{opacity:1}.ui-dialog__header{display:flex;flex-direction:column;gap:.375rem;text-align:center}@media (min-width: 640px){.ui-dialog__header{text-align:left}}.ui-dialog__footer{display:flex;flex-direction:column-reverse;gap:.5rem}@media (min-width: 640px){.ui-dialog__footer{flex-direction:row;justify-content:flex-end;gap:.5rem}}.ui-dialog__title{font-size:1.125rem;font-weight:600;line-height:1;letter-spacing:-.025em}.ui-dialog__description{font-size:.875rem;color:hsl(var(--muted-foreground))}@keyframes ui-dialog-fade-in{0%{opacity:0}to{opacity:1}}@keyframes ui-dialog-fade-out{0%{opacity:1}to{opacity:0}}@keyframes ui-dialog-content-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes ui-dialog-content-out{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.95)}}.ui-dialog__content[data-state=closed]{animation:ui-dialog-content-out .2s ease-in,ui-dialog-slide-out .2s ease-in}.ui-dialog__content[data-state=open]{animation:ui-dialog-content-in .2s ease-out,ui-dialog-slide-in .2s ease-out}@keyframes ui-dialog-slide-in{0%{transform:translate(-50%,-62%)}to{transform:translate(-50%,-50%)}}@keyframes ui-dialog-slide-out{0%{transform:translate(-50%,-50%)}to{transform:translate(-50%,-62%)}}.articleReadingExercise{text-align:center;display:flex;flex-direction:column;gap:1rem;align-items:center}.articleReadingExercise__preview{width:100%;max-width:28rem;border-radius:1rem;overflow:hidden;box-shadow:0 10px 15px -3px #0000001a}.articleReadingExercise__previewImg{width:100%;height:12rem;object-fit:cover}.articleReadingExercise__emoji{width:6rem;height:6rem;margin:0 auto;background-color:#1dafa11a;border-radius:1rem;display:flex;align-items:center;justify-content:center;font-size:2.5rem}.articleReadingExercise__title{font-family:var(--font-fredoka);font-size:1.25rem}.articleReadingExercise__desc{color:var(--color-muted-foreground)}.articleReadingExercise__startBtn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;background-color:var(--color-primary);color:var(--color-primary-foreground);transition:all .2s ease;cursor:pointer}.articleReadingExercise__startBtn:hover{filter:brightness(1.1)}.articleReadingExercise__content{display:flex;flex-direction:column;gap:1rem}.articleReadingExercise__articleImage{border-radius:.75rem;overflow:hidden}.articleReadingExercise__articleImage img{width:100%;height:14rem;object-fit:cover}.articleReadingExercise__text{max-height:40vh;overflow-y:auto;padding-right:1rem}.articleReadingExercise__paragraph{color:var(--color-foreground);line-height:1.75;margin-bottom:1rem}.articleReadingExercise__finishBtn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;background-color:var(--color-primary);color:var(--color-primary-foreground);cursor:pointer;transition:all .2s ease}.articleReadingExercise__questionCount{text-align:center;font-size:.875rem;color:var(--color-muted-foreground);margin-bottom:1rem}.articleReadingExercise__questionTitle{font-family:var(--font-fredoka);font-size:1.25rem;text-align:center;margin-bottom:1rem}.articleReadingExercise__options{display:grid;gap:.75rem}.articleReadingExercise__optionBtn{padding:1rem;border-radius:.75rem;border:2px solid var(--color-border);text-align:left;transition:all .2s ease;cursor:pointer;background-color:var(--background-light)}.articleReadingExercise__optionBtn:hover{border-color:#1dafa180}.articleReadingExercise__optionBtn--selected{border-color:var(--color-primary);background-color:#1dafa11a}.articleReadingExercise__submitAnswerBtn{width:100%;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;background-color:var(--color-primary);color:var(--color-primary-foreground);cursor:pointer;transition:all .2s ease}.articleReadingExercise__submitAnswerBtn:disabled{opacity:.5;cursor:not-allowed}.articleReadingExercise__character{position:fixed;bottom:1rem;right:1rem;z-index:50}.articleReadingExercise__characterImg{width:6rem;height:6rem;object-fit:contain;animation:bounce-gentle 3s ease-in-out infinite}.listeningExercise{display:flex;flex-direction:column;gap:1.5rem}.listeningExercise__player{background:linear-gradient(135deg,#1dafa133,#f56e3d33);border-radius:1rem;padding:1.5rem}.listeningExercise__playerRow{display:flex;align-items:center;gap:1rem}.listeningExercise__playBtn{width:4rem;height:4rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;cursor:pointer;border:none;flex-shrink:0}.listeningExercise__playBtn--idle{background-color:var(--color-primary)}.listeningExercise__playBtn--idle:hover{transform:scale(1.05)}.listeningExercise__playBtn--playing{background-color:#1dafa180;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.listeningExercise__playIcon{color:var(--color-primary-foreground)}.listeningExercise__info{flex:1}.listeningExercise__infoTitle{font-weight:500}.listeningExercise__infoStatus{font-size:.875rem;color:var(--color-muted-foreground)}.listeningExercise__visualizer{display:flex;align-items:center;justify-content:center;gap:.125rem;margin-top:1rem}.listeningExercise__bar{width:.25rem;background-color:var(--color-primary);border-radius:9999px;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.listeningExercise__transcriptBtn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:none;border:none;cursor:pointer;color:var(--color-muted-foreground);font-size:.875rem}.listeningExercise__transcriptBtn:hover{color:var(--color-foreground)}.listeningExercise__transcript{padding:1rem;background-color:#f2f5f880;border-radius:.75rem;font-size:.875rem;font-style:italic;animation:fade-in .3s ease-out}.listeningExercise__questions{display:flex;flex-direction:column;gap:1rem;animation:fade-in .3s ease-out}.listeningExercise__questionCount{text-align:center;font-size:.875rem;color:var(--color-muted-foreground)}.listeningExercise__questionTitle{font-family:var(--font-fredoka);font-size:1.125rem;text-align:center}.listeningExercise__options{display:grid;gap:.5rem}.listeningExercise__optionBtn{padding:.75rem;border-radius:.75rem;border:2px solid var(--color-border);text-align:left;transition:all .2s ease;cursor:pointer;background-color:var(--background-light)}.listeningExercise__optionBtn:hover{border-color:#1dafa180}.listeningExercise__optionBtn--selected{border-color:var(--color-primary);background-color:#1dafa11a}.listeningExercise__submitBtn{width:100%;padding:.75rem 1.5rem;border-radius:.75rem;font-weight:700;background-color:var(--color-primary);color:var(--color-primary-foreground);cursor:pointer;transition:all .2s ease}.listeningExercise__submitBtn:disabled{opacity:.5;cursor:not-allowed}.workshopView{min-height:100vh;display:flex;position:relative;background-size:cover;background-position:center}.workshopView__sidebar{position:fixed;left:0;top:0;height:100vh;width:18rem;z-index:30;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.workshopView__sidebarHeader{padding:1rem;border-bottom:1px solid rgba(255,255,255,.2)}.workshopView__exitBtn{padding:.5rem;border-radius:50%;background:transparent;border:none;color:#fff;cursor:pointer;transition:background .2s}.workshopView__exitBtn:hover{background:#fff3}.workshopView__title{font-family:Fredoka,sans-serif;font-size:1.25rem;margin-top:.5rem;color:#fff}.workshopView__sidebarProgress{margin-top:.75rem}.workshopView__exerciseList{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.workshopView__exerciseItem{width:100%;padding:.75rem;border-radius:.75rem;text-align:left;display:flex;align-items:center;gap:.75rem;transition:all .2s;border:none;cursor:pointer;font-size:.875rem;font-weight:500}.workshopView__exerciseItem--active{background:#fff;color:hsl(var(--foreground));box-shadow:0 10px 15px -3px #0000001a}.workshopView__exerciseItem--completed{background:#ffffff4d;color:#fff}.workshopView__exerciseItem--locked{opacity:.5;cursor:not-allowed;color:#fff9;background:transparent}.workshopView__exerciseItem--default{background:transparent;color:#fff}.workshopView__exerciseItem--default:hover{background:#fff3}.workshopView__exerciseNum{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;flex-shrink:0}.workshopView__exerciseNum--completed{background:hsl(var(--success));color:#fff}.workshopView__exerciseNum--active{background:hsl(var(--primary));color:#fff}.workshopView__exerciseNum--default{background:#fff3;color:#fff}.workshopView__exerciseLabel{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workshopView__resources{padding:1rem;border-top:1px solid rgba(255,255,255,.2)}.workshopView__resourcesBtn{width:100%;text-align:left;font-size:.875rem;font-weight:500;color:#fff;background:transparent;border:none;cursor:pointer}.workshopView__resourceList{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.workshopView__resourceLink{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#fffc;text-decoration:none}.workshopView__resourceLink:hover{color:#fff;text-decoration:underline}.workshopView__main{flex:1;margin-left:18rem;display:flex;flex-direction:column;min-height:100vh}.workshopView__header{position:sticky;top:0;z-index:20;padding:1rem;border-bottom:1px solid hsla(var(--border),.5);display:flex;align-items:center;justify-content:space-between;background:hsla(var(--card),.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 1px 3px #0000001a}.workshopView__headerLeft{display:flex;align-items:center;gap:1rem}.workshopView__headerProgress{flex:1;max-width:28rem}.workshopView__headerProgressLabel{font-size:.75rem;color:hsl(var(--muted-foreground));margin-bottom:.25rem}.workshopView__body{flex:1;overflow-y:auto;padding:2rem;position:relative}.workshopView__exerciseContainer{max-width:42rem;margin:0 auto}.workshopView__exerciseCard{background:hsl(var(--card));border-radius:1rem;padding:1.5rem;box-shadow:0 10px 15px -3px #0000001a;border:1px solid hsla(var(--border),.5)}.workshopView__readingMascot{position:fixed;bottom:1.5rem;right:1.5rem;width:8rem;height:8rem;object-fit:contain;filter:drop-shadow(0 10px 8px rgba(0,0,0,.1));z-index:10}.workshopView__completed{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 0}.workshopView__completedCard{background:hsla(var(--card),.95);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:1.5rem;padding:2rem;box-shadow:0 25px 50px -12px #00000040;border:1px solid hsla(var(--border),.5);text-align:center;max-width:28rem}.workshopView__completedIcon{width:5rem;height:5rem;margin:0 auto 1rem;border-radius:50%;background:hsla(var(--success),.2);display:flex;align-items:center;justify-content:center;color:hsl(var(--success))}.workshopView__completedTitle{font-family:Fredoka,sans-serif;font-size:1.875rem;color:hsl(var(--foreground));margin-bottom:.5rem}.workshopView__completedText{color:hsl(var(--muted-foreground));font-size:1.125rem}.workshopView__completedPoints{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid hsla(var(--border),.5)}.workshopView__completedPointsLabel{font-size:.875rem;color:hsl(var(--muted-foreground));margin-bottom:.5rem}.workshopView__completedPointsValue{display:flex;align-items:center;justify-content:center;gap:.5rem}.workshopView__completedMascot{margin-top:2rem}.workshopView__completedMascotImg{width:10rem;height:10rem;object-fit:contain;filter:drop-shadow(0 10px 8px rgba(0,0,0,.1));animation:bounceGentle 2s ease-in-out infinite}.resourceModal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0009;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.resourceModal__content{background:hsl(var(--card));border-radius:1rem;max-width:42rem;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040;animation:scaleIn .2s ease}.resourceModal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid hsl(var(--border))}.resourceModal__headerLeft{display:flex;align-items:center;gap:.75rem}.resourceModal__icon{width:3rem;height:3rem;border-radius:.75rem;background:hsla(var(--primary),.2);display:flex;align-items:center;justify-content:center;color:hsl(var(--primary))}.resourceModal__title{font-family:Fredoka,sans-serif;font-size:1.5rem}.resourceModal__closeBtn{padding:.5rem;border-radius:.375rem;border:none;background:transparent;cursor:pointer;color:hsl(var(--muted-foreground));transition:opacity .2s}.resourceModal__closeBtn:hover{opacity:.7}.resourceModal__body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.resourceModal__videoPlaceholder{aspect-ratio:16/9;background:hsl(var(--muted));border-radius:.75rem;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.resourceModal__videoOverlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,hsla(var(--primary),.2),hsla(var(--accent),.2))}.resourceModal__videoCenter{position:relative;z-index:10;text-align:center}.resourceModal__playBtn{width:5rem;height:5rem;border-radius:50%;background:hsla(var(--primary),.2);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;cursor:pointer;transition:transform .2s;border:none;color:hsl(var(--primary))}.resourceModal__playBtn:hover{transform:scale(1.1)}.resourceModal__textContent{background:hsla(var(--muted),.3);border-radius:.75rem;padding:1.5rem}.resourceModal__imageContent{border-radius:.75rem;overflow:hidden}.resourceModal__imageContent img{width:100%;height:auto;object-fit:cover;max-height:400px}.resourceModal__info{display:flex;align-items:center;gap:1rem;font-size:.875rem}.resourceModal__infoTag{padding:.25rem .75rem;background:hsla(var(--primary),.1);color:hsl(var(--primary));border-radius:9999px;font-size:.75rem;font-weight:500}.resourceModal__infoDuration,.resourceModal__infoPoints{display:flex;align-items:center;gap:.5rem}.resourceModal__topic{background:hsla(var(--muted),.5);border-radius:.75rem;padding:1rem}.resourceModal__topicTitle{font-weight:600;margin-bottom:.5rem}.resourceModal__topicText{color:hsl(var(--muted-foreground))}.resourceModal__actions{display:flex;gap:.75rem}.resourceModal__completeBtn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:.5rem;border:none;background:hsl(var(--primary));color:hsl(var(--primary-foreground));font-weight:500;cursor:pointer;transition:opacity .2s}.resourceModal__completeBtn:hover{opacity:.9}.resourceModal__closeAction{padding:.75rem 1rem;border-radius:.5rem;border:1px solid hsl(var(--border));background:transparent;cursor:pointer;font-weight:500;transition:background .2s}.resourceModal__closeAction:hover{background:hsl(var(--muted))}.meetingModal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0009;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.meetingModal__content{background:hsl(var(--card));border-radius:1rem;max-width:32rem;width:90%;box-shadow:0 25px 50px -12px #00000040;animation:scaleIn .2s ease}.meetingModal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid hsl(var(--border))}.meetingModal__headerLeft{display:flex;align-items:center;gap:.75rem}.meetingModal__icon{width:3rem;height:3rem;border-radius:.75rem;background:hsla(var(--accent),.2);display:flex;align-items:center;justify-content:center;color:hsl(var(--accent))}.meetingModal__title{font-family:Fredoka,sans-serif;font-size:1.5rem}.meetingModal__closeBtn{padding:.5rem;border-radius:.375rem;border:none;background:transparent;cursor:pointer;color:hsl(var(--muted-foreground))}.meetingModal__closeBtn:hover{opacity:.7}.meetingModal__body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.meetingModal__banner{background:linear-gradient(to right,hsla(var(--accent),.2),hsla(var(--primary),.2));border-radius:.75rem;padding:1.5rem;text-align:center}.meetingModal__bannerIcon{width:4rem;height:4rem;border-radius:50%;background:hsla(var(--background),.5);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;color:hsl(var(--accent))}.meetingModal__bannerTitle{font-family:Fredoka,sans-serif;font-size:1.25rem;margin-bottom:.5rem}.meetingModal__bannerText{color:hsl(var(--muted-foreground));font-size:.875rem}.meetingModal__details{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.meetingModal__detailCard{background:hsla(var(--muted),.5);border-radius:.75rem;padding:1rem;text-align:center}.meetingModal__detailValue{font-weight:500;margin-top:.5rem}.meetingModal__detailLabel{font-size:.75rem;color:hsl(var(--muted-foreground))}.meetingModal__topic{background:hsla(var(--muted),.5);border-radius:.75rem;padding:1rem}.meetingModal__topicTitle{font-weight:600;margin-bottom:.5rem}.meetingModal__topicText{color:hsl(var(--muted-foreground));font-size:.875rem}.meetingModal__actions{display:flex;gap:.75rem}.meetingModal__joinBtn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:.5rem;border:none;background:hsl(var(--accent));color:#fff;font-weight:500;cursor:pointer;transition:opacity .2s}.meetingModal__joinBtn:hover{opacity:.9}.meetingModal__laterBtn{padding:.75rem 1rem;border-radius:.5rem;border:1px solid hsl(var(--border));background:transparent;cursor:pointer;font-weight:500}.meetingModal__laterBtn:hover{background:hsl(var(--muted))}.courseView{min-height:100vh;background:linear-gradient(to bottom,hsl(var(--background)),hsla(var(--muted),.3))}.courseView__hero{position:relative;height:420px;overflow:hidden}.courseView__heroCover{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.courseView__heroOverlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,hsl(var(--background)),hsla(var(--background),.7),transparent)}.courseView__heroCenter{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;z-index:10}.courseView__avatar{width:7rem;height:7rem;border-radius:50%;background:hsl(var(--card));border:4px solid hsl(var(--primary));box-shadow:0 20px 25px -5px #0000001a;overflow:hidden;margin-bottom:1rem}.courseView__avatarImg{width:100%;height:100%;object-fit:cover}.courseView__heroTitle{font-family:Fredoka,sans-serif;font-size:1.875rem;color:#fff;text-shadow:0 4px 6px rgba(0,0,0,.5);text-align:center;margin-bottom:.75rem}.courseView__heroProgressCard{width:20rem;max-width:90vw;background:hsla(var(--card),.8);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:1rem;padding:1rem;box-shadow:0 20px 25px -5px #0000001a}.courseView__heroProgressHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.courseView__heroProgressLabel{font-size:.875rem;font-weight:500;color:hsl(var(--foreground))}.courseView__heroProgressValue{font-size:.875rem;color:hsl(var(--muted-foreground))}.courseView__heroProgressSub{font-size:.75rem;text-align:center;color:hsl(var(--muted-foreground));margin-top:.5rem}.courseView__certBadge{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:.5rem;background:#ffaa00e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:.5rem .75rem;border-radius:9999px;box-shadow:0 10px 15px -3px #0000001a;font-size:.875rem;font-weight:500}.courseView__main{max-width:80rem;margin:0 auto;padding:2rem 1rem}.courseView__layout{display:flex;gap:2rem}.courseView__content{flex:1;min-width:0}.courseView__about{background:hsl(var(--card));border-radius:1rem;padding:1.5rem;box-shadow:0 10px 15px -3px #0000001a;margin-bottom:1.5rem;border:1px solid hsla(var(--border),.5)}.courseView__aboutTitle{font-family:Fredoka,sans-serif;font-size:1.25rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.courseView__aboutDesc{color:hsl(var(--muted-foreground));line-height:1.75}.courseView__aboutMeta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid hsl(var(--border))}.courseView__aboutMetaItem{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.courseView__tabs{width:100%}.courseView__tabList{display:flex;gap:.5rem;background:hsla(var(--muted),.5);padding:.25rem;border-radius:.75rem;margin-bottom:1rem}.courseView__tabBtn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.5rem;border:none;background:transparent;cursor:pointer;font-size:.875rem;font-weight:500;color:hsl(var(--muted-foreground));transition:all .2s}.courseView__tabBtn--active{background:hsl(var(--card));color:hsl(var(--foreground));box-shadow:0 1px 3px #0000001a}.courseView__tabHidden{font-size:.75rem;background:hsla(var(--muted-foreground),.2);color:hsl(var(--muted-foreground));padding:.125rem .375rem;border-radius:9999px}.courseView__tabContent{display:flex;flex-direction:column;gap:.75rem}.courseView__sidebar{width:20rem;flex-shrink:0}.courseView__widget{background:hsl(var(--card));border-radius:1rem;padding:1.5rem;box-shadow:0 10px 15px -3px #0000001a;border:1px solid hsla(var(--border),.5);position:sticky;top:1rem}.courseView__widgetTitle{font-family:Fredoka,sans-serif;font-size:1.125rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.courseView__widgetItems{display:flex;flex-direction:column;gap:1rem}.courseView__widgetItem{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:hsla(var(--muted),.5);border-radius:.75rem}.courseView__widgetItemLeft{display:flex;align-items:center;gap:.75rem}.courseView__widgetItemIcon{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center}.courseView__widgetItemLabel{font-size:.875rem;font-weight:500}.courseView__widgetItemValue{font-family:Fredoka,sans-serif;font-size:1.125rem}.courseView__instructor{margin-top:1.5rem;padding-top:1rem;border-top:1px solid hsl(var(--border));display:flex;align-items:center;gap:.75rem}.courseView__instructorAvatar{width:3rem;height:3rem;border-radius:50%;background:hsl(var(--muted));overflow:hidden}.courseView__instructorAvatarImg{width:100%;height:100%;object-fit:cover}.courseView__instructorLabel{font-weight:500;font-size:.875rem}.courseView__instructorName{font-size:.75rem;color:hsl(var(--muted-foreground))}@media (max-width: 1024px){.courseView__layout{flex-direction:column}.courseView__sidebar{width:100%}}@media (max-width: 768px){.courseView__heroTitle{font-size:1.5rem}}.exercise-wizard-page{min-height:100vh;background:linear-gradient(to bottom,#fff,#f3f4f6);padding:1.5rem}.exercise-wizard-container{max-width:75rem;margin:0 auto}.exercise-wizard-header{margin-bottom:2rem}.exercise-wizard-title{font-family:var(--font-fredoka);font-size:1.875rem;color:#1dafa1;margin-bottom:.5rem;font-weight:600}.exercise-wizard-subtitle{color:#6b7280;font-size:.875rem}.exercise-wizard-step-indicator{display:flex;align-items:center;gap:.5rem}.exercise-wizard-step-dot{width:2rem;height:2rem;border-radius:9999px;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:500}.exercise-wizard-step-dot--active{background:#1dafa1;color:#fff}.exercise-wizard-step-dot--inactive{background:#f3f4f6;color:#6b7280}.exercise-wizard-step-line{width:2rem;height:.125rem;background:#e5e7eb}.exercise-wizard-card{background:#fff;border-radius:1rem;border:1px solid rgba(229,231,235,.5);box-shadow:0 1px 3px #0000001a;padding:1.5rem;overflow:hidden}.exercise-wizard-step1{display:flex;flex-direction:column;gap:1.5rem}.exercise-wizard-step1-header{text-align:center;margin-bottom:2rem}.exercise-wizard-step1-title{font-family:var(--font-fredoka);font-size:1.5rem;color:#111827;margin-bottom:.5rem;font-weight:600}.exercise-wizard-step1-subtitle{color:#6b7280;font-size:.875rem}.exercise-wizard-type-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.exercise-wizard-type-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.exercise-wizard-type-grid{grid-template-columns:repeat(3,1fr)}}.exercise-wizard-type-card{cursor:pointer;transition:all .2s;border:2px solid;height:100%;border-radius:.75rem;background:#fff}.exercise-wizard-type-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.exercise-wizard-type-card--selected{box-shadow:0 0 0 2px #1dafa1}.exercise-wizard-type-card-content{padding:1rem}.exercise-wizard-type-card-header{display:flex;align-items:flex-start;gap:.75rem}.exercise-wizard-type-icon{padding:.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.exercise-wizard-type-icon--selected{background:#1dafa1;color:#fff}.exercise-wizard-type-icon--unselected{background:#f3f4f6;color:#6b7280}.exercise-wizard-type-icon svg{width:1.25rem;height:1.25rem}.exercise-wizard-type-info{flex:1}.exercise-wizard-type-label{font-weight:500;color:#111827;margin-bottom:.25rem}.exercise-wizard-type-description{font-size:.875rem;color:#6b7280;margin-top:.25rem}.exercise-wizard-type-check{background:#1dafa1;border-radius:9999px;padding:.25rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.exercise-wizard-type-check svg{color:#fff;width:.875rem;height:.875rem}.exercise-wizard-step2{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.exercise-wizard-step2{grid-template-columns:repeat(2,1fr)}}.exercise-wizard-builder-panel{display:flex;flex-direction:column;gap:1.5rem}.exercise-wizard-type-header{display:flex;align-items:center;gap:.75rem;padding-bottom:1rem;border-bottom:1px solid #e5e7eb}.exercise-wizard-type-header-icon{padding:.5rem;border-radius:.5rem;background:#1dafa11a;display:flex;align-items:center;justify-content:center}.exercise-wizard-type-header-icon svg{color:#1dafa1;width:1.25rem;height:1.25rem}.exercise-wizard-type-header-info{flex:1}.exercise-wizard-type-header-title{font-family:var(--font-fredoka);font-size:1.125rem;color:#111827;margin-bottom:.25rem}.exercise-wizard-type-header-description{font-size:.875rem;color:#6b7280}.exercise-wizard-form-section{display:flex;flex-direction:column;gap:1rem}.exercise-wizard-form-field{display:flex;flex-direction:column;gap:.5rem}.exercise-wizard-form-label{font-size:.875rem;font-weight:500;color:#374151}.exercise-wizard-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.exercise-wizard-background-section{display:flex;flex-direction:column;gap:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.exercise-wizard-background-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:#374151}.exercise-wizard-background-label svg{color:#1dafa1}.exercise-wizard-color-presets{display:flex;flex-wrap:wrap;gap:.5rem}.exercise-wizard-color-btn{width:2rem;height:2rem;border-radius:9999px;border:2px solid;cursor:pointer;transition:all .2s;position:relative;outline:none}.exercise-wizard-color-btn:hover{transform:scale(1.1)}.exercise-wizard-color-btn--selected{box-shadow:0 0 0 2px #1dafa1,0 0 0 4px #fff;border-color:transparent}.exercise-wizard-color-btn--default{background:#fff;display:flex;align-items:center;justify-content:center;border-color:#e5e7eb}.exercise-wizard-color-btn--default svg{color:#6b7280;width:.75rem;height:.75rem}.exercise-wizard-preview-panel{position:sticky;top:1.5rem}.exercise-wizard-preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.exercise-wizard-preview-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:#374151}.exercise-wizard-preview-label svg{color:#1dafa1}.exercise-wizard-preview-container{border:1px solid #e5e7eb;border-radius:.75rem;padding:1rem;background:#f3f4f64d;min-height:400px}.exercise-wizard-preview-empty{border:1px solid #e5e7eb;border-radius:.75rem;padding:2rem;background:#f3f4f64d;min-height:400px;display:flex;align-items:center;justify-content:center}.exercise-wizard-preview-empty-text{color:#6b7280;text-align:center;line-height:1.6}.exercise-wizard-footer{margin-top:1.5rem;display:flex;justify-content:space-between}.exercise-wizard-footer-actions{display:flex;gap:.75rem}.exercise-wizard-option-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:.5rem;border:1px solid;background:#fff;transition:all .2s}.exercise-wizard-option-item--correct{border-color:#10b981;background:#10b9811a}.exercise-wizard-option-item--incorrect{border-color:#e5e7eb}.exercise-wizard-option-grip{cursor:grab;color:#6b7280}.exercise-wizard-option-grip:active{cursor:grabbing}.exercise-wizard-option-grip svg{color:#6b7280}.exercise-wizard-option-input{flex:1;border:none;background:transparent;padding:0;outline:none}.exercise-wizard-option-correct-btn{padding:.375rem;border-radius:9999px;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.exercise-wizard-option-correct-btn--active{background:#10b981;color:#fff}.exercise-wizard-option-correct-btn--inactive{background:#f3f4f6;color:#6b7280}.exercise-wizard-option-correct-btn--inactive:hover{background:#6b728033}.exercise-wizard-option-correct-btn svg{width:.875rem;height:.875rem}.exercise-wizard-option-remove-btn{padding:.375rem;border-radius:9999px;border:none;background:transparent;cursor:pointer;color:#6b7280;transition:all .2s;display:flex;align-items:center;justify-content:center}.exercise-wizard-option-remove-btn:hover{background:#dc26261a;color:#dc2626}.exercise-wizard-option-remove-btn svg{width:.875rem;height:.875rem}.exercise-wizard-type-card--quiz{border-color:#3b82f64d;background:#3b82f61a}.exercise-wizard-type-card--quiz:hover{border-color:#3b82f6}.exercise-wizard-type-card--fill-blank{border-color:#a855f74d;background:#a855f71a}.exercise-wizard-type-card--fill-blank:hover{border-color:#a855f7}.exercise-wizard-type-card--drag-drop{border-color:#10b9814d;background:#10b9811a}.exercise-wizard-type-card--drag-drop:hover{border-color:#10b981}.exercise-wizard-type-card--word-scramble{border-color:#f973164d;background:#f973161a}.exercise-wizard-type-card--word-scramble:hover{border-color:#f97316}.exercise-wizard-type-card--word-match{border-color:#ec48994d;background:#ec48991a}.exercise-wizard-type-card--word-match:hover{border-color:#ec4899}.exercise-wizard-type-card--article-reading{border-color:#06b6d44d;background:#06b6d41a}.exercise-wizard-type-card--article-reading:hover{border-color:#06b6d4}.exercise-wizard-type-card--story-reading{border-color:#6366f14d;background:#6366f11a}.exercise-wizard-type-card--story-reading:hover{border-color:#6366f1}.exercise-wizard-type-card--listening{border-color:#14b8a64d;background:#14b8a61a}.exercise-wizard-type-card--listening:hover{border-color:#14b8a6}.exercise-wizard-type-card--journal{border-color:#f59e0b4d;background:#f59e0b1a}.exercise-wizard-type-card--journal:hover{border-color:#f59e0b}.exercise-wizard-image-upload{display:flex;flex-direction:column;gap:.5rem}.exercise-wizard-image-upload-label{font-size:.75rem;color:#6b7280}.exercise-wizard-image-upload-controls{display:flex;align-items:center;gap:.75rem}.exercise-wizard-image-remove-btn{padding:.5rem;border-radius:.5rem;background:#dc26261a;color:#dc2626;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.exercise-wizard-image-remove-btn:hover{background:#dc262633}.exercise-wizard-image-remove-btn svg{color:#dc2626}.exercise-wizard-image-preview{height:5rem;border-radius:.5rem;background-size:cover;background-position:center;border:1px solid #e5e7eb}.exercise-wizard-pairs-container{display:flex;flex-direction:column;gap:.75rem}.exercise-wizard-pairs-header{display:flex;align-items:center;justify-content:space-between}.exercise-wizard-pair-item{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-radius:.5rem;border:1px solid #e5e7eb;background:#fff}.exercise-wizard-pair-inputs{flex:1;display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.exercise-wizard-pair-remove-btn{padding:.375rem;background:transparent;border:none;cursor:pointer;color:#6b7280;transition:all .2s;border-radius:.25rem}.exercise-wizard-pair-remove-btn:hover{background:#dc26261a;color:#dc2626}.exercise-wizard-pair-remove-btn svg{color:inherit}.exercise-wizard-pairs-empty{font-size:.875rem;color:#6b7280;text-align:center;padding:1rem 0;border:1px solid #e5e7eb;border-radius:.5rem;border-style:dashed}.exercise-wizard-category-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-radius:.375rem;border:1px solid #e5e7eb;background:#fff;font-size:.875rem}.exercise-wizard-category-grip{cursor:grab;color:#6b7280}.exercise-wizard-category-grip:active{cursor:grabbing}.exercise-wizard-category-grip svg{color:#6b7280}.exercise-wizard-category-input{flex:1;height:1.75rem;border:none;background:transparent;padding:0;outline:none;font-size:.875rem}.exercise-wizard-category-badge{font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem;background:#f3f4f6;color:#374151}.exercise-wizard-category-remove-btn{padding:.25rem;background:transparent;border:none;cursor:pointer;color:#6b7280;transition:all .2s;border-radius:.25rem;display:flex;align-items:center;justify-content:center}.exercise-wizard-category-remove-btn:hover{background:#dc26261a;color:#dc2626}.exercise-wizard-category-remove-btn svg{color:inherit;width:.875rem;height:.875rem}.exercise-wizard-header-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.exercise-wizard-back-button{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem}.exercise-wizard-preview-column{display:none}@media (min-width: 1024px){.exercise-wizard-preview-column{display:block}}.exercise-wizard-section-block{display:flex;flex-direction:column;gap:1rem}.exercise-wizard-inline-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.exercise-wizard-field-note{font-size:.75rem;color:#6b7280}.exercise-wizard-list{display:flex;flex-direction:column;gap:.5rem}.exercise-wizard-button-row{display:flex;flex-wrap:wrap;gap:.5rem}.exercise-wizard-tag-box{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;border-radius:.5rem;border:1px solid #e5e7eb;background:#f3f4f680;min-height:60px;align-items:center}.exercise-wizard-tag{display:inline-flex;align-items:center;gap:.375rem}.exercise-wizard-small-input{width:96px}.exercise-wizard-chip-list{display:flex;flex-wrap:wrap;gap:.5rem}.exercise-wizard-category-chip{display:flex;align-items:center;gap:.25rem;padding:.5rem;border-radius:.5rem;border:1px solid #e5e7eb;background:#fff}.exercise-wizard-category-chip-input{width:112px;min-height:28px;border:none;background:transparent;padding:0;outline:none;box-shadow:none}.exercise-wizard-category-chip-remove{border:none;background:transparent;color:#6b7280;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.exercise-wizard-category-chip-remove:hover{color:#dc2626}.exercise-wizard-question-card{padding:.75rem;border-radius:.75rem;border:1px solid #e5e7eb;background:#fff;display:flex;flex-direction:column;gap:.75rem}.exercise-wizard-question-card-header{display:flex;align-items:center;justify-content:space-between}.exercise-wizard-question-index{font-size:.75rem;font-weight:600;color:#6b7280}.exercise-wizard-question-remove-btn{border:none;background:transparent;color:#6b7280;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.exercise-wizard-question-remove-btn:hover{color:#dc2626}.exercise-wizard-option-list{display:flex;flex-direction:column;gap:.5rem}.exercise-wizard-radio-option-row{display:flex;align-items:center;gap:.5rem}.exercise-wizard-radio-circle{width:20px;height:20px;border-radius:9999px;border:2px solid #9ca3af;background:#fff;color:transparent;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer}.exercise-wizard-radio-circle--active{border-color:#10b981;background:#10b981;color:#fff}.exercise-wizard-empty-box{font-size:.875rem;color:#6b7280;text-align:center;padding:1rem;border:1px dashed #d1d5db;border-radius:.5rem}.exercise-wizard-pairs-list{display:flex;flex-direction:column;gap:.5rem}.exercise-wizard-option-item--dragging,.exercise-wizard-category-item--dragging{opacity:.5;z-index:50}.exercise-wizard-type-card--revise-map{border-color:#8b5cf64d;background:#8b5cf61a}.exercise-wizard-type-card--revise-map:hover{border-color:#8b5cf6}.ui-button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap;border-radius:.375rem;font-size:.875rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;border:none}.ui-button:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #10b981,0 0 0 4px #f9fafb}.ui-button:disabled{pointer-events:none;opacity:.5}.ui-button svg{pointer-events:none;width:1rem;height:1rem;flex-shrink:0}.ui-button--default{background-color:#22c55e;color:#fff}.ui-button--default:hover{background-color:#1e9048;cursor:pointer}.ui-button--destructive{background-color:#dc2626;color:#fff}.ui-button--destructive:hover{background-color:#b91c1c;cursor:pointer}.ui-button--outline{border:1px solid #d1d5db;background-color:#fff;color:#1f2937}.ui-button--outline:hover{background-color:#f3f4f6;color:#111827;cursor:pointer}.ui-button--secondary{background-color:#f3f4f6;color:#1f2937}.ui-button--secondary:hover{background-color:#e5e7eb;cursor:pointer}.ui-button--ghost{background-color:transparent;color:#1f2937}.ui-button--ghost:hover{background-color:#f3f4f6;color:#111827;cursor:pointer}.ui-button--link{background-color:transparent;color:#10b981;text-underline-offset:4px;padding:0;height:auto}.ui-button--link:hover{text-decoration:underline;cursor:pointer}.ui-button--size-default{height:2.5rem;padding:.5rem 1rem}.ui-button--size-sm{height:2.25rem;border-radius:.375rem;padding:0 .75rem}.ui-button--size-lg{height:2.75rem;border-radius:.375rem;padding:0 2rem}.ui-button--size-icon{height:2.5rem;width:2.5rem}.ui-input{display:flex;height:2.5rem;width:100%;border-radius:.375rem;border:1px solid hsl(var(--input));background-color:hsl(var(--background));padding:.5rem .75rem;font-size:.875rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ui-input:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px hsl(var(--ring)),0 0 0 4px hsl(var(--ring-offset))}.ui-input:disabled{cursor:not-allowed;opacity:.5}.ui-input::placeholder{color:hsl(var(--muted-foreground))}.ui-input[type=file]{border:0;background-color:transparent;font-size:.875rem;font-weight:500;color:hsl(var(--foreground))}@media (min-width: 768px){.ui-input{font-size:.875rem}}.ui-label{font-size:.875rem;font-weight:500;line-height:1}.ui-label:has(+*:disabled){cursor:not-allowed;opacity:.7}.ui-textarea{display:flex;min-height:5rem;width:100%;border-radius:.375rem;border:1px solid hsl(var(--input));background-color:hsl(var(--background));padding:.5rem .75rem;font-size:.875rem;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ui-textarea:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px hsl(var(--ring)),0 0 0 4px hsl(var(--ring-offset))}.ui-textarea:disabled{cursor:not-allowed;opacity:.5}.ui-textarea::placeholder{color:hsl(var(--muted-foreground))}.ui-card{border-radius:.5rem;border:1px solid hsl(var(--border));background-color:hsl(var(--card));color:hsl(var(--card-foreground));box-shadow:0 1px 2px #0000000d}.ui-card__header{display:flex;flex-direction:column;gap:.375rem;padding:1.5rem}.ui-card__title{font-size:1.5rem;font-weight:600;line-height:1;letter-spacing:-.025em}.ui-card__description{font-size:.875rem;color:hsl(var(--muted-foreground))}.ui-card__content{padding:1.5rem;padding-top:0}.ui-card__footer{display:flex;align-items:center;padding:1.5rem;padding-top:0}.ui-badge{display:inline-flex;align-items:center;border-radius:9999px;border:1px solid transparent;padding:.125rem .625rem;font-size:.75rem;font-weight:600;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ui-badge:focus{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px hsl(var(--ring)),0 0 0 4px hsl(var(--ring-offset))}.ui-badge--default{border-color:transparent;background-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.ui-badge--default:hover{background-color:hsl(var(--primary) / .8)}.ui-badge--secondary:hover{background-color:hsl(var(--secondary) / .8)}.ui-badge--destructive{border-color:transparent;background-color:hsl(var(--destructive));color:hsl(var(--destructive-foreground))}.ui-badge--destructive:hover{background-color:hsl(var(--destructive) / .8)}.ui-badge--outline{color:hsl(var(--foreground))}.ui-switch{display:inline-flex;height:1.5rem;width:2.75rem;flex-shrink:0;cursor:pointer;align-items:center;border-radius:9999px;border:2px solid transparent;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ui-switch:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px hsl(var(--ring)),0 0 0 4px hsl(var(--ring-offset))}.ui-switch:disabled{cursor:not-allowed;opacity:.5}.ui-switch[data-state=checked]{background-color:hsl(var(--primary))}.ui-switch[data-state=unchecked]{background-color:hsl(var(--input))}.ui-switch__thumb{pointer-events:none;display:block;height:1.25rem;width:1.25rem;border-radius:9999px;background-color:hsl(var(--background));box-shadow:0 1px 2px #0000000d,0 1px 3px #0000001a;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;ring-width:0}.ui-switch__thumb[data-state=checked]{transform:translate(1.25rem)}.ui-switch__thumb[data-state=unchecked]{transform:translate(0)}.exercise-preview-card{border:none;box-shadow:none;overflow:hidden;background:transparent}.exercise-preview-content-wrapper{border-radius:.5rem;padding:1rem}.exercise-preview-content-wrapper--with-bg{background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.exercise-preview-header{padding-bottom:.75rem}.exercise-preview-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.exercise-preview-title-section{display:flex;align-items:center;gap:.5rem}.exercise-preview-icon{padding:.375rem;border-radius:.5rem;background:#1dafa11a;display:flex;align-items:center;justify-content:center}.exercise-preview-icon svg{color:#1dafa1;width:1rem;height:1rem}.exercise-preview-title{font-size:1rem;font-weight:600;color:#111827}.exercise-preview-meta{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:#6b7280}.exercise-preview-meta-item{display:flex;align-items:center;gap:.25rem}.exercise-preview-meta-item svg{color:inherit;width:.875rem;height:.875rem}.exercise-preview-meta-time,.exercise-preview-meta-points{color:#6b7280}.exercise-preview-meta-points svg{color:#f59e0b}.exercise-preview-instruction{font-size:.875rem;color:#6b7280;margin-top:.5rem}.exercise-preview-quiz{display:flex;flex-direction:column;gap:1rem}.exercise-preview-quiz-question{font-weight:500;color:#111827;font-size:1rem}.exercise-preview-quiz-options{display:flex;flex-direction:column;gap:.5rem}.exercise-preview-quiz-option{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:.5rem;border:1px solid;transition:all .2s}.exercise-preview-quiz-option--correct{border-color:#10b981;background:#10b9811a}.exercise-preview-quiz-option--incorrect{border-color:#e5e7eb;background:#fff}.exercise-preview-quiz-option--incorrect:hover{background:#f3f4f680}.exercise-preview-quiz-option-label{flex:1;cursor:pointer;color:#111827}.exercise-preview-quiz-correct-badge{background:#10b98133;color:#059669;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.exercise-preview-quiz-empty{color:#6b7280;font-size:.875rem;font-style:italic}.exercise-preview-fill-blank{display:flex;flex-direction:column;gap:1rem}.exercise-preview-fill-blank-sentence{line-height:1.75;color:#111827;font-size:1rem}.exercise-preview-fill-blank-gap{display:inline-block;width:6rem;margin:0 .25rem;border-bottom:2px dashed hsl(174,72%,40%);text-align:center;color:#6b7280;padding-bottom:.25rem}.exercise-preview-word-bank{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;border-radius:.5rem;background:#f3f4f680}.exercise-preview-word-bank-label{font-size:.75rem;color:#6b7280;margin-right:.5rem}.exercise-preview-word-bank-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;border-radius:.375rem;background:#fff;border:1px solid #e5e7eb;color:#374151;font-size:.875rem;cursor:grab}.exercise-preview-word-bank-badge svg{color:#6b7280;width:.75rem;height:.75rem}.exercise-preview-word-bank-empty{font-size:.75rem;color:#6b7280;font-style:italic}.exercise-preview-drag-drop{display:flex;flex-direction:column;gap:1rem}.exercise-preview-drag-drop-targets{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.exercise-preview-drag-drop-target{padding:1rem;border-radius:.5rem;border:2px dashed #d1d5db;background:#f3f4f64d;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center}.exercise-preview-drag-drop-target-title{font-weight:500;text-align:center;margin-bottom:.5rem;color:#111827;font-size:.875rem}.exercise-preview-drag-drop-target-hint{font-size:.75rem;color:#6b7280;text-align:center}.exercise-preview-drag-drop-items{display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem;border-radius:.5rem;background:#f3f4f680}.exercise-preview-drag-drop-items-label{font-size:.75rem;color:#6b7280;margin-right:.5rem}.exercise-preview-drag-drop-item{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;border-radius:.375rem;border:1px solid #e5e7eb;background:#fff;color:#374151;font-size:.875rem;cursor:grab}.exercise-preview-drag-drop-item svg{color:#6b7280;width:.75rem;height:.75rem}.exercise-preview-drag-drop-empty{font-size:.75rem;color:#6b7280;font-style:italic}.exercise-preview-word-scramble{display:flex;flex-direction:column;gap:1rem;text-align:center}.exercise-preview-scramble-letters{display:flex;justify-content:center;gap:.5rem}.exercise-preview-scramble-letter{width:2.5rem;height:2.5rem;border-radius:.5rem;background:#1dafa11a;border:1px solid hsla(174,72%,40%,.3);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.125rem;color:#1dafa1}.exercise-preview-scramble-hint{font-size:.875rem;color:#6b7280;font-style:italic}.exercise-preview-scramble-answer-slots{display:flex;justify-content:center;gap:.5rem}.exercise-preview-scramble-slot{width:2.5rem;height:2.5rem;border-radius:.5rem;border:2px dashed #d1d5db;background:#f3f4f64d}.exercise-preview-word-match{display:flex;flex-direction:column;gap:.75rem}.exercise-preview-word-match-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.exercise-preview-word-match-column{display:flex;flex-direction:column;gap:.5rem}.exercise-preview-word-match-item{padding:.75rem;border-radius:.5rem;border:1px solid #e5e7eb;text-align:center;font-weight:500;color:#111827}.exercise-preview-word-match-item--word{background:#fff}.exercise-preview-word-match-item--match{background:#f3f4f680}.exercise-preview-word-match-empty{color:#6b7280;font-size:.875rem;font-style:italic;text-align:center;padding:1rem 0}.exercise-preview-reading{display:flex;flex-direction:column;gap:1rem}.exercise-preview-reading-title{font-family:var(--font-fredoka);font-size:1.25rem;color:#111827;font-weight:600}.exercise-preview-reading-content{color:#6b7280;font-size:.875rem;line-height:1.6;max-width:none}.exercise-preview-reading-empty{font-style:italic;color:#6b7280}.exercise-preview-listening{display:flex;flex-direction:column;gap:1rem;text-align:center}.exercise-preview-listening-icon{width:4rem;height:4rem;margin:0 auto;border-radius:9999px;background:#1dafa11a;display:flex;align-items:center;justify-content:center}.exercise-preview-listening-icon svg{color:#1dafa1;width:2rem;height:2rem}.exercise-preview-listening-description{font-weight:500;color:#111827}.exercise-preview-listening-button{margin:0 auto}.exercise-preview-revise-map{display:flex;flex-direction:column;gap:1rem}.exercise-preview-revise-map-prompt{font-weight:500;color:#111827}.exercise-preview-revise-map-topic{text-align:center;font-size:.875rem;color:#6b7280}.exercise-preview-revise-map-canvas{border:2px dashed #d1d5db;border-radius:.5rem;padding:2rem;text-align:center;color:#6b7280;background:#f3f4f64d}.exercise-preview-empty{color:#6b7280;text-align:center;padding:2rem 0}.scenario-editor-container{display:flex;flex-direction:column;gap:1rem}.scenario-item{border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden;background:#f3f4f64d}.scenario-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#f3f4f680;transition:background .2s}.scenario-header:hover{background:#f3f4f6b3}.scenario-header-left{display:flex;align-items:center;gap:.75rem}.scenario-grip{cursor:grab;color:#6b7280}.scenario-grip:active{cursor:grabbing}.scenario-grip svg{color:#6b7280}.scenario-title-section{cursor:pointer;display:flex;align-items:center;gap:.75rem}.scenario-title{font-weight:500;color:#111827}.scenario-lines-count{font-size:.875rem;color:#6b7280}.scenario-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;border:1px solid}.scenario-badge--start{background:#1dafa11a;color:#1dafa1;border-color:#1dafa133}.scenario-badge--start svg{color:#1dafa1;fill:currentColor}.scenario-badge--after{background:#e7b0081a;color:#d97706;border-color:#e7b00833}.scenario-badge--after svg{color:#d97706}.scenario-header-right{display:flex;align-items:center;gap:.5rem}.scenario-chevron{cursor:pointer;color:#6b7280}.scenario-chevron svg{color:#6b7280}.scenario-content{padding:1rem;display:flex;flex-direction:column;gap:1rem}.scenario-field{display:flex;flex-direction:column;gap:.5rem}.scenario-field-label{font-size:.875rem;font-weight:500;color:#374151}.scenario-field-hint{font-size:.75rem;color:#6b7280;margin-top:.25rem}.scenario-lines-container{display:flex;flex-direction:column;gap:.75rem}.scenario-line-item{padding:.75rem;border:1px solid #e5e7eb;border-radius:.5rem;background:#fff;display:flex;flex-direction:row;gap:.75rem;align-items:flex-start}.scenario-line-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:3rem;padding-top:.25rem}.scenario-line-number{font-size:.75rem;font-weight:600;color:#1dafa1;background:#1dafa11a;padding:.25rem .5rem;border-radius:.25rem}.scenario-line-actions{display:flex;gap:.25rem;width:100%;justify-content:center}.scenario-line-action-btn{padding:.25rem;border:none;background:transparent;cursor:pointer;border-radius:.25rem;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all .2s}.scenario-line-action-btn:hover{background:#f3f4f6;color:#111827}.scenario-line-action-btn svg{color:inherit}.scenario-line-action-btn--delete{color:#dc2626}.scenario-line-action-btn--delete:hover{background:#fee2e2;color:#dc2626}.scenario-line-action-btn--delete svg{color:#dc2626}.scenario-add-line-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem;border:1px dashed #d1d5db;border-radius:.5rem;background:transparent;cursor:pointer;color:#6b7280;font-size:.875rem;transition:all .2s}.scenario-add-line-btn:hover{border-color:#1dafa1;background:#1dafa10d;color:#1dafa1}.scenario-add-line-btn svg{color:inherit}.scenario-add-scenario-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border:1px dashed #d1d5db;border-radius:.5rem;background:transparent;cursor:pointer;color:#6b7280;font-weight:500;transition:all .2s;width:100%;justify-content:center}.scenario-add-scenario-btn:hover{border-color:#1dafa1;background:#1dafa10d;color:#1dafa1}.scenario-add-scenario-btn svg{color:inherit}.scenario-image-preview{width:100%;max-width:200px;height:120px;object-fit:cover;border-radius:.5rem;border:1px solid #e5e7eb}.scenario-image-actions{display:flex;gap:.5rem;margin-top:.5rem}.scenario-image-action-btn{padding:.375rem .75rem;border:1px solid #e5e7eb;border-radius:.375rem;background:#fff;cursor:pointer;font-size:.875rem;color:#374151;transition:all .2s;display:flex;align-items:center;gap:.375rem}.scenario-image-action-btn:hover{background:#f3f4f6;border-color:#d1d5db}.scenario-image-action-btn svg{color:inherit}.scenario-image-action-btn--remove{color:#dc2626;border-color:#fecaca}.scenario-image-action-btn--remove:hover{background:#fee2e2;border-color:#fca5a5}.scenario-display-image-section{padding:.75rem;border-radius:.5rem;background:#1dafa10d;border:1px solid hsla(174,72%,40%,.2);display:flex;flex-direction:column;gap:.75rem}.scenario-display-image-controls{display:flex;align-items:center;gap:.5rem}.scenario-display-image-preview{display:flex;align-items:center;gap:.5rem;flex:1}.scenario-display-image-thumb{width:4rem;height:3rem;border-radius:.375rem;object-fit:cover;border:1px solid #e5e7eb}.scenario-display-image-label{font-size:.75rem;color:#1dafa1;flex:1;font-weight:500}.scenario-display-image-upload-label{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#1dafa1;cursor:pointer;transition:color .2s}.scenario-display-image-upload-label:hover{color:#1dafa1cc}.scenario-display-image-upload-label svg{color:inherit}.scenario-display-image-options{display:flex;align-items:center;gap:1rem;padding-top:.5rem;border-top:1px solid hsla(174,72%,40%,.1)}.scenario-display-image-option-group{display:flex;align-items:center;gap:.5rem}.scenario-display-image-option-label{font-size:.75rem;color:#6b7280}.scenario-display-image-option-buttons{display:flex;gap:.25rem}.scenario-display-image-option-btn{height:1.75rem;padding:0 .5rem;font-size:.75rem;text-transform:capitalize;border:1px solid #e5e7eb;border-radius:.375rem;background:#fff;cursor:pointer;transition:all .2s;color:#374151}.scenario-display-image-option-btn:hover{background:#f3f4f6;border-color:#d1d5db}.scenario-display-image-option-btn--active{background:#1dafa1;color:#fff;border-color:#1dafa1}.scenario-background-image-controls{display:flex;align-items:center;gap:.5rem}.scenario-background-image-preview{display:flex;align-items:center;gap:.5rem;flex:1}.scenario-background-image-thumb{width:4rem;height:2.5rem;border-radius:.375rem;background-size:cover;background-position:center;border:1px solid #e5e7eb}.scenario-background-image-label{font-size:.75rem;color:#6b7280;flex:1}.scenario-background-image-upload-label{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#6b7280;cursor:pointer;transition:color .2s}.scenario-background-image-upload-label:hover{color:#111827}.scenario-background-image-upload-label svg{color:inherit}.scenario-line-content{display:flex;flex-direction:column;gap:.5rem;flex:1}.scenario-line-delete-btn{height:2rem;width:2rem;flex-shrink:0;background:transparent;border:none;cursor:pointer;border-radius:.25rem;color:#6b7280;display:flex;align-items:center;justify-content:center;transition:all .2s;align-self:flex-start;margin-top:.25rem}.scenario-line-delete-btn:hover{background:#fee2e2;color:#dc2626}.scenario-line-delete-btn:disabled{opacity:.5;cursor:not-allowed}.scenario-line-delete-btn svg{color:inherit}.scenario-input-margin,.scenario-select-wrapper{margin-top:.25rem}.scenario-select-content{background:#fff;border:1px solid #e5e7eb;z-index:50}.workshop-editor-page{min-height:100vh;background:linear-gradient(to bottom,#fff,#f3f4f6);padding:1.5rem}.workshop-editor-container{max-width:80rem;margin:0 auto}.workshop-editor-header{margin-bottom:2rem}.workshop-editor-title{font-family:var(--font-fredoka);font-size:1.875rem;color:#1dafa1;margin-bottom:.5rem;font-weight:600}.workshop-editor-subtitle{color:#6b7280}.workshop-editor-section{margin-top:1rem;padding:1rem;background:#fff;border-radius:.75rem;border:1px solid #e5e7eb}.workshop-editor-section-title{font-weight:600;font-size:1rem;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#111827}.workshop-editor-section-title svg{color:#1dafa1;flex-shrink:0}.workshop-editor-grid{display:grid;gap:1rem}.workshop-editor-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (min-width: 768px){.workshop-editor-grid-2{grid-template-columns:repeat(2,1fr)}}.workshop-editor-field{display:flex;flex-direction:column;gap:.25rem}.workshop-editor-field-label{font-size:.875rem;font-weight:500;margin-bottom:.25rem;display:block;color:#374151}.workshop-editor-theme-picker{display:flex;align-items:center;gap:.75rem}.workshop-editor-theme-btn{width:2.5rem;height:2.5rem;border-radius:9999px;border:none;cursor:pointer;transition:all .2s ease;position:relative;outline:none}.workshop-editor-theme-btn:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.workshop-editor-theme-btn--selected{transform:scale(1.2);box-shadow:0 0 0 2px #fff,0 0 0 4px #1dafa1;z-index:1}.workshop-editor-theme-selected-text{font-size:.75rem;color:#6b7280;margin-top:.5rem}.workshop-editor-background-section{margin-top:1rem;padding:1rem;background:#fff;border-radius:.75rem;border:1px solid #e5e7eb}.workshop-editor-background-label{font-size:.875rem;font-weight:500;margin-bottom:.5rem;display:block}.workshop-editor-background-preview{display:flex;align-items:center;gap:1rem}.workshop-editor-background-image{width:8rem;height:5rem;border-radius:.5rem;background-size:cover;background-position:center;border:1px solid #e5e7eb}.workshop-editor-background-actions{display:flex;gap:.5rem}.workshop-editor-upload-area{display:flex;align-items:center;gap:.75rem;padding:1rem;border:2px dashed #e5e7eb;border-radius:.5rem;cursor:pointer;transition:border-color .2s}.workshop-editor-upload-area:hover{border-color:#1dafa1}.workshop-editor-upload-icon{width:2.5rem;height:2.5rem;border-radius:9999px;background:#1dafa11a;display:flex;align-items:center;justify-content:center;color:#1dafa1}.workshop-editor-upload-icon svg{color:#1dafa1}.workshop-editor-upload-text{font-size:.875rem;font-weight:500}.workshop-editor-upload-hint{font-size:.75rem;color:#6b7280}.workshop-editor-tabs-container{width:100%}.workshop-editor-tabs-list{background:#f3f4f680;padding:.25rem;border-radius:.75rem;margin-bottom:1rem;width:100%;display:flex;justify-content:flex-start;gap:.5rem}.workshop-editor-tab-trigger{display:flex;align-items:center;gap:.5rem;border-radius:.5rem;padding:.5rem 1.5rem;font-size:.875rem;font-weight:500;background:transparent;border:none;cursor:pointer;transition:all .2s;color:#6b7280}.workshop-editor-tab-trigger svg{color:#6b7280;flex-shrink:0}.workshop-editor-tab-trigger:hover{color:#111827;background:#ffffff80}.workshop-editor-tab-trigger:hover svg{color:#111827}.workshop-editor-tab-trigger[data-state=active],.workshop-editor-tab-trigger.ui-tabs__trigger--active{background:#fff;box-shadow:0 1px 3px #0000001a;color:#1dafa1;font-weight:600}.workshop-editor-tab-trigger[data-state=active] svg,.workshop-editor-tab-trigger.ui-tabs__trigger--active svg{color:#1dafa1}.workshop-editor-tab-content{margin-top:0}.workshop-editor-card{background:#fff;border-radius:1rem;border:1px solid rgba(229,231,235,.5);box-shadow:0 1px 3px #0000001a;padding:1.5rem}.workshop-editor-exercises-header{padding:1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.workshop-editor-exercises-title{font-family:var(--font-fredoka);font-size:1.125rem;color:#111827;font-weight:600}.workshop-editor-exercises-actions{display:flex;align-items:center;gap:.5rem}.workshop-editor-view-toggle{display:flex;border-radius:.5rem;border:1px solid #e5e7eb;overflow:hidden}.workshop-editor-view-btn{border-radius:0;height:2rem;padding:0 .75rem;background:transparent;border:none;cursor:pointer;transition:all .2s}.workshop-editor-view-btn{color:#6b7280}.workshop-editor-view-btn svg{color:#6b7280}.workshop-editor-view-btn:hover{background:#f3f4f6;color:#111827}.workshop-editor-view-btn:hover svg{color:#111827}.workshop-editor-view-btn--active{background:#1dafa1;color:#fff}.workshop-editor-view-btn--active svg{color:#fff}.workshop-editor-exercises-content{padding:1rem}.workshop-editor-grid-view{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.workshop-editor-grid-view{grid-template-columns:repeat(2,1fr)}}.workshop-editor-exercise-card{border-radius:.75rem;overflow:hidden;transition:all .2s;border:1px solid rgba(229,231,235,.5);background:#fff}.workshop-editor-exercise-card-content{padding:1rem}.workshop-editor-exercise-card-content--with-bg{background:#ffffffe6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.workshop-editor-exercise-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}.workshop-editor-exercise-card-left{display:flex;align-items:center;gap:.5rem}.workshop-editor-exercise-icon{padding:.5rem;border-radius:.5rem;background:#1dafa11a;color:#1dafa1;display:flex;align-items:center;justify-content:center}.workshop-editor-exercise-icon svg{color:#1dafa1}.workshop-editor-exercise-title{font-weight:500;color:#111827}.workshop-editor-exercise-meta{font-size:.75rem;color:#6b7280;text-transform:capitalize}.workshop-editor-exercise-actions{display:flex;align-items:center;gap:.25rem}.workshop-editor-exercise-action-btn{height:2rem;width:2rem;background:transparent;border:none;cursor:pointer;border-radius:.25rem;display:flex;align-items:center;justify-content:center;transition:background .2s;color:#6b7280}.workshop-editor-exercise-action-btn svg{color:#6b7280}.workshop-editor-exercise-action-btn:hover{background:#f3f4f6;color:#111827}.workshop-editor-exercise-action-btn:hover svg{color:#111827}.workshop-editor-empty-state{text-align:center;padding:3rem 0;color:#6b7280}.workshop-editor-preview-section{border-top:1px solid #e5e7eb;padding-top:.75rem;margin-top:.5rem;overflow:hidden}.workshop-editor-not-found{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff}.workshop-editor-not-found-title{font-size:1.5rem;font-family:var(--font-fredoka);margin-bottom:1rem}.course-editor-page{min-height:100vh;background:linear-gradient(to bottom,#f8fafc,#eef2f7);padding:24px}.course-editor-container{max-width:1152px;margin:0 auto}.course-editor-header{margin-bottom:32px}.course-editor-title{font-size:30px;font-weight:600;color:#111827;margin-bottom:8px}.course-editor-subtitle{color:#6b7280}.course-editor-tabs-container{width:100%}.course-editor-tabs-list{background:#f3f4f680;padding:.25rem;border-radius:.75rem;margin-bottom:1.5rem;display:flex;gap:.5rem}.course-editor-tab-trigger{display:flex;align-items:center;gap:.5rem;border-radius:.5rem;padding:.5rem 1.5rem;font-size:.875rem;background:transparent;border:none;cursor:pointer;transition:all .2s;color:#6b7280}.course-editor-tab-trigger:hover{color:#111827}.course-editor-tab-trigger[data-state=active],.course-editor-tab-trigger.ui-tabs__trigger--active{background:#fff;color:#111827}.course-editor-tab-content{margin-top:0}.course-editor-card{background:#fff;border-radius:1rem;border:1px solid rgba(229,231,235,.5);box-shadow:0 1px 3px #0000001a;overflow:hidden}.course-editor-card-header{padding:1rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.course-editor-card-title{font-family:var(--font-fredoka);font-size:1.125rem}.course-editor-table-cell-center{text-align:center}.course-editor-table-cell-right{text-align:right}.course-editor-table-cell-bold{font-weight:500}.course-editor-icon-group{display:flex;align-items:center;gap:.5rem}.course-editor-capitalize{text-transform:capitalize}.course-editor-empty-state{text-align:center;padding:2rem 0;color:#6b7280}.course-editor-truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#6b7280}.course-editor-grip{color:#6b7280;cursor:grab}.course-editor-modal-content{display:flex;flex-direction:column;gap:1rem;padding:1rem 0}.course-editor-modal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.course-editor-modal-field,.idb-field-group{display:flex;flex-direction:column;gap:.5rem}.idb-theme-color-picker{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.idb-theme-color-btn{width:2.5rem;height:2.5rem;border-radius:.5rem;border:2px solid transparent;box-shadow:0 1px 2px #00000014;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.idb-theme-color-btn:hover{transform:translateY(-1px);box-shadow:0 3px 8px #0000001f}.idb-theme-color-btn:focus-visible{outline:none;border-color:#111827;box-shadow:0 0 0 2px #1118272e}.idb-theme-color-btn--selected,.idb-theme-color-btn-selected{border-color:#111827;box-shadow:0 0 0 2px #1118271f}.ui-calendar{padding:.75rem;background:#f9fafb;border:1px solid #d1fae5;border-radius:1rem;box-shadow:0 10px 24px #0000000f;color:#1f2937;width:fit-content}.rdp-month_grid thead{display:flex;flex-direction:column;width:100%}.rdp-weekdays{display:flex;gap:1rem}.rdp-day_button{width:100%!important;height:100%!important;background:transparent!important;border:none!important;cursor:pointer}.rdp-selected{background:#d1fae599!important;border-color:#10b98159!important}.rdp-weekdays th{width:2.5rem;height:2.5rem;border-radius:.75rem;border:1px solid transparent;background:transparent;color:#1f2937;font-size:.95rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.ui-calendar__months{display:flex;position:relative;flex-direction:column;gap:1rem}.rdp-week{display:flex;gap:1rem;padding-block:.2rem}@media (min-width: 640px){.ui-calendar__months{flex-direction:row;gap:1.25rem}}.ui-calendar__month{display:flex;flex-direction:column;gap:.75rem}.ui-calendar__caption,.rdp-month_caption{display:flex;align-items:center;justify-content:center;position:relative;padding:.25rem 2.5rem;min-height:2.5rem}.ui-calendar__caption-label{font-size:.95rem;font-weight:800;letter-spacing:.01em;color:#1f2937}.ui-calendar__nav{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-start;justify-content:space-between;padding:0 .25rem;z-index:2;height:10%}.ui-calendar__nav-button{width:2.25rem;height:2.25rem;border-radius:.75rem;border:1px solid #d1fae5;background:#fff;color:#065f46;display:inline-flex;align-items:center;justify-content:center;transition:background-color .15s ease,transform 80ms ease,border-color .15s ease}.ui-calendar__caption-label{position:relative;z-index:1}.ui-calendar__nav-button:hover{background:#d1fae599;border-color:#10b98159}.ui-calendar__nav-button:active{transform:translateY(1px)}.ui-calendar__nav-button:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #10b981,0 0 0 4px #f9fafb}.ui-calendar__nav-button-prev,.ui-calendar__nav-button-next{position:static}.ui-calendar__nav-icon{width:1rem;height:1rem}.ui-calendar__table{width:100%;border-collapse:separate;border-spacing:0;display:block}.ui-calendar__table thead,.ui-calendar__table tbody{display:block}.ui-calendar__head-row,.ui-calendar__row{display:grid!important;grid-template-columns:repeat(7,2.5rem);gap:.35rem;justify-content:center}.ui-calendar__head-cell{height:2rem;display:block;border-radius:.6rem;font-size:.78rem;font-weight:800;color:#6b7280;text-transform:uppercase;letter-spacing:.06em;text-align:center;line-height:2rem}.ui-calendar__cell{height:2.5rem;width:2.5rem;padding:0;display:block}.ui-calendar__cell:focus-within{position:relative;z-index:10}.ui-calendar__day{width:2.5rem;height:2.5rem;border-radius:50%;border:1px solid transparent;background:transparent;color:#1f2937;font-size:.95rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer!important;transition:background-color .15s ease,border-color .15s ease,color .15s ease}.ui-calendar__day:hover{background:#d1fae599;border-color:#10b98140;cursor:pointer!important}.class-view-theme-1 .ui-calendar__day:hover{border-color:#3b82f6;background:#3b83f68b}.class-view-theme-2 .ui-calendar__day:hover{background:#f973168b;border-color:#f97316}.class-view-theme-3 .ui-calendar__day:hover{background:#10b9818b;border-color:#10b981}.class-view-theme-4 .ui-calendar__day:hover{background:#a855f78b;border-color:#a855f7}.class-view-theme-5 .ui-calendar__day:hover{background:#ec48998b;border-color:#ec4899}.class-view-theme-6 .ui-calendar__day:hover{background:#64748b8b;border-color:#64748b}.ui-calendar__day:focus-visible{outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #10b981,0 0 0 4px #f9fafb}.class-view-theme-1 .rdp-selected{border-color:#3b82f6!important;background:#3b83f68b!important}.class-view-theme-2 .rdp-selected{background:#f973168b!important;border-color:#f97316!important}.class-view-theme-3 .rdp-selected{background:#10b9818b!important;border-color:#10b981!important}.class-view-theme-4 .rdp-selected{background:#a855f78b!important;border-color:#a855f7!important}.class-view-theme-5 .rdp-selected{background:#ec48998b!important;border-color:#ec4899!important}.class-view-theme-6 .rdp-selected{background:#64748b8b!important;border-color:#64748b!important}.ui-calendar__day--today{border-color:#10b98180;background:#10b9811f;color:#065f46}.ui-calendar__day--outside{color:#9ca3af}.ui-calendar__day--outside:hover{background:#e5e7eb8c;border-color:#d1d5dbcc}.ui-calendar__day--disabled{color:#cbd5e1;opacity:.8;cursor:not-allowed}.ui-calendar__day--disabled:hover{background:transparent;border-color:transparent}.ui-calendar__day--range-middle[aria-selected=true]{background:#10b9812e;color:#065f46;border-radius:.5rem}.ui-calendar__day--range-start[aria-selected=true],.ui-calendar__day--range-end[aria-selected=true]{background:#10b981;color:#fff}.ui-calendar__day--range-start[aria-selected=true]{border-top-right-radius:.5rem;border-bottom-right-radius:.5rem}.ui-calendar__day--range-end[aria-selected=true]{border-top-left-radius:.5rem;border-bottom-left-radius:.5rem}.ui-calendar__day--hidden{visibility:hidden}.class-view-page{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#d1fae52e);color:#1f2937}.class-view-page--empty{display:flex;align-items:center;justify-content:center;padding:2rem 1.25rem}.class-view-container{width:100%;max-width:1120px;margin:0 auto;padding:0 1.5rem}.class-view-hero{position:relative;overflow:hidden}.class-view-hero__bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.92}.class-view-hero__pattern{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.28;background-image:url(data:image/svg+xml,%3Csvg%20width%3D%2260%22%20height%3D%2260%22%20viewBox%3D%220%200%2060%2060%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%20fill-rule%3D%22evenodd%22%3E%3Cg%20fill%3D%22%23ffffff%22%20fill-opacity%3D%220.12%22%3E%3Cpath%20d%3D%22M36%2034v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6%2034v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6%204V0H4v4H0v2h4v4h2V6h4V4H6z%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E)}.class-view-hero__inner{position:relative;padding-top:2.25rem;padding-bottom:2.25rem}.class-view-back-btn{margin-bottom:1.25rem;gap:.5rem;color:#ffffffeb}.class-view-back-btn:hover{background:#ffffff2e;color:#fff}.class-view-hero__row{display:flex;gap:1.5rem;align-items:flex-start}.class-view-hero__meta{flex:1;min-width:0}.class-view-hero__title-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.class-view-title{font-size:2.25rem;font-weight:800;letter-spacing:-.02em;color:#fff;line-height:1.15}.class-view-subtitle{color:#ffffffd1;max-width:720px;line-height:1.45;margin-bottom:1.25rem}.class-view-badge{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.28)}.class-view-badge__icon{margin-right:.25rem}.class-view-stats{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.class-view-stat-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .9rem;border-radius:999px;background:#fff3;border:1px solid rgba(255,255,255,.22);color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:.875rem}.class-view-stat-pill__strong{font-weight:700}.class-view-theme-1 .class-view-hero__bg{background:linear-gradient(90deg,#2563eb,#06b6d4)}.class-view-theme-2 .class-view-hero__bg{background:linear-gradient(90deg,#ea580c,#f59e0b)}.class-view-theme-3 .class-view-hero__bg{background:linear-gradient(90deg,#059669,#22c55e)}.class-view-theme-4 .class-view-hero__bg{background:linear-gradient(90deg,#7c3aed,#8b5cf6)}.class-view-theme-5 .class-view-hero__bg{background:linear-gradient(90deg,#db2777,#f43f5e)}.class-view-theme-6 .class-view-hero__bg{background:linear-gradient(90deg,#475569,#6b7280)}.class-view-content{padding-top:2rem;padding-bottom:2.25rem}.class-view-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 1024px){.class-view-grid{grid-template-columns:2fr 1fr;align-items:start}}.class-view-main,.class-view-sidebar{display:grid;gap:1.5rem}.class-view-actions-bar{display:flex;flex-wrap:wrap;gap:.75rem}.class-view-action-btn{gap:.5rem}.class-view-action-btn--primary{background:#10b981;color:#fff;box-shadow:0 12px 20px #10b98133}.class-view-action-btn--primary:hover{background:#059669}.class-view-action-btn--secondary{border:1px solid rgba(16,185,129,.35);color:#065f46}.class-view-action-btn--secondary:hover{background:#d1fae573}.class-view-theme-1 .class-view-action-btn--primary{background:#3b82f6;box-shadow:0 12px 20px #3b82f638}.class-view-theme-1 .class-view-action-btn--primary:hover{background:#2563eb}.class-view-theme-1 .class-view-action-btn--secondary{border-color:#3b82f659;color:#1d4ed8}.class-view-theme-1 .class-view-action-btn--secondary:hover{background:#3b82f61a}.class-view-theme-2 .class-view-action-btn--primary{background:#f97316;box-shadow:0 12px 20px #f9731638}.class-view-theme-2 .class-view-action-btn--primary:hover{background:#ea580c}.class-view-theme-2 .class-view-action-btn--secondary{border-color:#f9731659;color:#c2410c}.class-view-theme-2 .class-view-action-btn--secondary:hover{background:#f973161a}.class-view-theme-4 .class-view-action-btn--primary{background:#a855f7;box-shadow:0 12px 20px #a855f738}.class-view-theme-4 .class-view-action-btn--primary:hover{background:#7c3aed}.class-view-theme-4 .class-view-action-btn--secondary{border-color:#a855f759;color:#6d28d9}.class-view-theme-4 .class-view-action-btn--secondary:hover{background:#a855f71a}.class-view-theme-5 .class-view-action-btn--primary{background:#ec4899;box-shadow:0 12px 20px #ec489938}.class-view-theme-5 .class-view-action-btn--primary:hover{background:#db2777}.class-view-theme-5 .class-view-action-btn--secondary{border-color:#ec489959;color:#be185d}.class-view-theme-5 .class-view-action-btn--secondary:hover{background:#ec48991a}.class-view-theme-6 .class-view-action-btn--primary{background:#64748b;box-shadow:0 12px 20px #64748b38}.class-view-theme-6 .class-view-action-btn--primary:hover{background:#475569}.class-view-theme-6 .class-view-action-btn--secondary{border-color:#64748b59;color:#334155}.class-view-theme-6 .class-view-action-btn--secondary:hover{background:#64748b1a}.class-view-card{overflow:hidden;border:1px solid #e5e7eb;border-radius:1rem;background:#fff;box-shadow:0 10px 24px #0000000d}.class-view-card__header{padding:1.1rem 1.1rem .9rem;border-bottom:1px solid #e5e7eb;background:linear-gradient(90deg,#d1fae58c,#f8fafce6)}.class-view-theme-1 .class-view-card__header{background:linear-gradient(90deg,#3b83f6cf,#f8fafce6)}.class-view-theme-2 .class-view-card__header{background:linear-gradient(90deg,#f97316cf,#f8fafce6)}.class-view-theme-3 .class-view-card__header{background:linear-gradient(90deg,#10b981cf,#f8fafce6)}.class-view-theme-4 .class-view-card__header{background:linear-gradient(90deg,#a855f7cf,#f8fafce6)}.class-view-theme-5 .class-view-card__header{background:linear-gradient(90deg,#ec4899cf,#f8fafce6)}.class-view-theme-6 .class-view-card__header{background:linear-gradient(90deg,#64748bcf,#f8fafce6)}.class-view-card__title{display:inline-flex;align-items:center;gap:.5rem}.class-view-card__content{padding:1rem}.class-view-icon{color:#fff}.class-view-courses-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.class-view-courses-grid{grid-template-columns:repeat(2,1fr)}}.class-view-course{position:relative;overflow:hidden;border-radius:.9rem;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:.15s ease}.class-view-course:hover{box-shadow:0 16px 30px #00000014;transform:translateY(1px)}.class-view-course__cover{height:6.25rem;position:relative;background:linear-gradient(135deg,#10b981,#10b981d9)}.class-view-theme-1 .class-view-course__cover{background:linear-gradient(135deg,#3b82f6,#3b82f6db)}.class-view-theme-2 .class-view-course__cover{background:linear-gradient(135deg,#f97316,#f97316db)}.class-view-theme-3 .class-view-course__cover{background:linear-gradient(135deg,#10b981,#10b981db)}.class-view-theme-4 .class-view-course__cover{background:linear-gradient(135deg,#a855f7,#a855f7db)}.class-view-theme-5 .class-view-course__cover{background:linear-gradient(135deg,#ec4899,#ec4899db)}.class-view-theme-6 .class-view-course__cover{background:linear-gradient(135deg,#64748b,#64748bdb)}.class-view-theme-1 .class-view-course:hover{border:1px solid rgba(59,130,246,.86)}.class-view-theme-2 .class-view-course:hover{border:1px solid rgba(249,115,22,.86)}.class-view-theme-3 .class-view-course:hover{border:1px solid rgba(16,185,129,.86)}.class-view-theme-4 .class-view-course:hover{border:1px solid rgba(168,85,247,.86)}.class-view-theme-5 .class-view-course:hover{border:1px solid rgba(236,72,153,.86)}.class-view-theme-6 .class-view-course:hover{border:1px solid rgba(100,116,139,.86)}.class-view-course__cover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000002e}.class-view-course__cover-text{position:absolute;left:.75rem;right:3.5rem;bottom:.75rem}.class-view-course__title{color:#fff;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-view-course__instructor{color:#ffffffbd;font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-view-course__view-btn{position:absolute;top:.5rem;right:.5rem;height:1.8rem;padding:0 .5rem;font-size:.75rem;gap:.25rem;opacity:0;transition:opacity .15s ease}.class-view-course:hover .class-view-course__view-btn{opacity:1}.class-view-course__info{padding:.75rem}.class-view-course__badges{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.class-view-mini-badge{font-size:.75rem;gap:.25rem}.class-view-empty-block{text-align:center;padding:3rem 1rem;color:#6b7280}.class-view-empty-block__icon{opacity:.35;margin-bottom:.75rem}.class-view-empty-block__text{margin-bottom:1rem}.class-view-btn-icon{margin-right:.5rem}.class-view-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (min-width: 768px){.class-view-stats-grid{grid-template-columns:repeat(4,1fr)}}.class-view-stat-card{overflow:hidden;border-radius:1rem;border:1px solid #e5e7eb;background:#fff}.class-view-stat-card__bar{height:4px;background:linear-gradient(90deg,#10b981,#10b981a6)}.class-view-theme-1 .class-view-stat-card__bar{background:linear-gradient(90deg,#3b82f6,#3b82f6a6)}.class-view-theme-2 .class-view-stat-card__bar{background:linear-gradient(90deg,#f97316,#f97316a6)}.class-view-theme-3 .class-view-stat-card__bar{background:linear-gradient(90deg,#10b981,#10b981a6)}.class-view-theme-4 .class-view-stat-card__bar{background:linear-gradient(90deg,#a855f7,#a855f7a6)}.class-view-theme-5 .class-view-stat-card__bar{background:linear-gradient(90deg,#ec4899,#ec4899a6)}.class-view-theme-6 .class-view-stat-card__bar{background:linear-gradient(90deg,#64748b,#64748ba6)}.class-view-stat-card__content{padding-top:1rem;padding-bottom:1rem;text-align:center}.class-view-stat-card__icon{width:2.5rem;height:2.5rem;border-radius:.85rem;display:inline-flex;align-items:center;justify-content:center;background:#d1fae58c;margin:0 auto .5rem}.class-view-theme-1 .class-view-stat-card__icon{background:#3b82f6}.class-view-theme-2 .class-view-stat-card__icon{background:#f97316}.class-view-theme-3 .class-view-stat-card__icon{background:#10b981}.class-view-theme-4 .class-view-stat-card__icon{background:#a855f7}.class-view-theme-5 .class-view-stat-card__icon{background:#ec4899}.class-view-theme-6 .class-view-stat-card__icon{background:#64748b}.class-view-stat-card__value{font-size:1.6rem;font-weight:800;color:#1f2937;line-height:1.1}.class-view-stat-card__label{font-size:.75rem;color:#6b7280;margin-top:.25rem}.class-view-panel{border-radius:1rem;border:1px solid #e5e7eb;background:#ffffffd9;box-shadow:0 10px 24px #0000000d}.class-view-theme-1 .class-view-panel{border:1px solid rgba(59,130,246,.86)}.class-view-theme-2 .class-view-panel{border:1px solid rgba(249,115,22,.86)}.class-view-theme-3 .class-view-panel{border:1px solid rgba(16,185,129,.86)}.class-view-theme-4 .class-view-panel{border:1px solid rgba(168,85,247,.86)}.class-view-theme-5 .class-view-panel{border:1px solid rgba(236,72,153,.86)}.class-view-theme-6 .class-view-panel{border:1px solid rgba(100,116,139,.86)}.class-view-panel__title{display:inline-flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:800}.class-view-theme-1 .class-view-panel__title-icon{background:#3b82f6}.class-view-theme-2 .class-view-panel__title-icon{background:#f97316}.class-view-theme-3 .class-view-panel__title-icon{background:#10b981}.class-view-theme-4 .class-view-panel__title-icon{background:#a855f7}.class-view-theme-5 .class-view-panel__title-icon{background:#ec4899}.class-view-theme-6 .class-view-panel__title-icon{background:#64748b}.class-view-calendar{width:100%}.class-view-calendar.ui-calendar{width:100%;max-width:100%}.class-view-calendar .ui-calendar__months,.class-view-calendar .ui-calendar__month,.class-view-calendar .ui-calendar__table{width:100%}.class-view-calendar .ui-calendar__head-row,.class-view-calendar .ui-calendar__row{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.35rem;justify-content:stretch}.class-view-calendar .ui-calendar__cell,.class-view-calendar .ui-calendar__day{width:100%}.class-view-calendar .ui-calendar__cell{height:2.35rem}.class-view-calendar .ui-calendar__day{height:2.35rem;font-size:.9rem;cursor:pointer;border:1px solid transparent}.class-view-calendar .ui-calendar__day:disabled,.class-view-calendar .ui-calendar__day[disabled]{cursor:not-allowed}.class-view-calendar .ui-calendar__caption{padding-left:2.75rem;padding-right:2.75rem}.class-view-calendar .ui-calendar__caption-label{font-size:1rem}.class-view-calendar .ui-calendar__head-cell{font-size:.74rem}.class-view-calendar .ui-calendar__nav-button{cursor:pointer}.class-view-calendar__meeting-day:after{box-shadow:0 0 0 2px #ffffffeb}.class-view-theme-1 .class-view-calendar.ui-calendar{border-color:#3b82f640}.class-view-theme-1 .class-view-calendar .ui-calendar__nav-button{color:#1d4ed8;border-color:#3b82f638}.class-view-theme-1 .class-view-calendar .ui-calendar__nav-button:hover{background:#3b82f61a;border-color:#3b82f659}.class-view-theme-1 .class-view-calendar .ui-calendar__nav-button:focus-visible{box-shadow:0 0 0 2px #3b82f6,0 0 0 4px #f9fafb}.class-view-theme-1 .class-view-calendar .ui-calendar__day:hover{background:#3b82f61a;border-color:#3b82f638}.class-view-theme-1 .class-view-calendar .ui-calendar__day--selected{background:#3b82f6}.class-view-theme-1 .class-view-calendar .ui-calendar__day--selected:hover{background:#2563eb}.class-view-theme-1 .class-view-calendar .ui-calendar__day--today{background:#3b82f61a;border-color:#3b82f666;color:#1d4ed8}.class-view-theme-1 .class-view-calendar__meeting-day:after{background:#3b82f6}.class-view-theme-1 .class-view-calendar .ui-calendar__day--range-middle[aria-selected=true]{background:#3b82f629;color:#1d4ed8}.class-view-theme-1 .class-view-calendar .ui-calendar__day--range-start[aria-selected=true],.class-view-theme-1 .class-view-calendar .ui-calendar__day--range-end[aria-selected=true]{background:#3b82f6}.class-view-theme-2 .class-view-calendar.ui-calendar{border-color:#f9731640}.class-view-theme-2 .class-view-calendar .ui-calendar__nav-button{color:#c2410c;border-color:#f9731638}.class-view-theme-2 .class-view-calendar .ui-calendar__nav-button:hover{background:#f973161a;border-color:#f9731659}.class-view-theme-2 .class-view-calendar .ui-calendar__nav-button:focus-visible{box-shadow:0 0 0 2px #f97316,0 0 0 4px #f9fafb}.class-view-theme-2 .class-view-calendar .ui-calendar__day:hover{background:#f973161a;border-color:#f9731638}.class-view-theme-2 .class-view-calendar .ui-calendar__day--selected{background:#f97316}.class-view-theme-2 .class-view-calendar .ui-calendar__day--selected:hover{background:#ea580c}.class-view-theme-2 .class-view-calendar .ui-calendar__day--today{background:#f973161a;border-color:#f9731666;color:#c2410c}.class-view-theme-2 .class-view-calendar__meeting-day:after{background:#f97316}.class-view-theme-2 .class-view-calendar .ui-calendar__day--range-middle[aria-selected=true]{background:#f9731629;color:#c2410c}.class-view-theme-2 .class-view-calendar .ui-calendar__day--range-start[aria-selected=true],.class-view-theme-2 .class-view-calendar .ui-calendar__day--range-end[aria-selected=true]{background:#f97316}.class-view-theme-3 .class-view-calendar.ui-calendar{border-color:#10b98140}.class-view-theme-3 .class-view-calendar .ui-calendar__nav-button{color:#065f46;border-color:#10b98138}.class-view-theme-3 .class-view-calendar .ui-calendar__nav-button:hover{background:#10b9811a;border-color:#10b98159}.class-view-theme-3 .class-view-calendar .ui-calendar__nav-button:focus-visible{box-shadow:0 0 0 2px #10b981,0 0 0 4px #f9fafb}.class-view-theme-3 .class-view-calendar .ui-calendar__day:hover{background:#10b9811a;border-color:#10b98138}.class-view-theme-3 .class-view-calendar .ui-calendar__day--selected{background:#10b981}.class-view-theme-3 .class-view-calendar .ui-calendar__day--selected:hover{background:#059669}.class-view-theme-3 .class-view-calendar .ui-calendar__day--today{background:#10b9811a;border-color:#10b98166;color:#065f46}.class-view-theme-3 .class-view-calendar__meeting-day:after{background:#10b981}.class-view-theme-3 .class-view-calendar .ui-calendar__day--range-middle[aria-selected=true]{background:#10b98129;color:#065f46}.class-view-theme-3 .class-view-calendar .ui-calendar__day--range-start[aria-selected=true],.class-view-theme-3 .class-view-calendar .ui-calendar__day--range-end[aria-selected=true]{background:#10b981}.class-view-theme-4 .class-view-calendar.ui-calendar{border-color:#a855f740}.class-view-theme-4 .class-view-calendar .ui-calendar__nav-button{color:#6d28d9;border-color:#a855f738}.class-view-theme-4 .class-view-calendar .ui-calendar__nav-button:hover{background:#a855f71a;border-color:#a855f759}.class-view-theme-4 .class-view-calendar .ui-calendar__nav-button:focus-visible{box-shadow:0 0 0 2px #a855f7,0 0 0 4px #f9fafb}.class-view-theme-4 .class-view-calendar .ui-calendar__day:hover{background:#a855f71a;border-color:#a855f738}.class-view-theme-4 .class-view-calendar .ui-calendar__day--selected{background:#a855f7}.class-view-theme-4 .class-view-calendar .ui-calendar__day--selected:hover{background:#7c3aed}.class-view-theme-4 .class-view-calendar .ui-calendar__day--today{background:#a855f71a;border-color:#a855f766;color:#6d28d9}.class-view-theme-4 .class-view-calendar__meeting-day:after{background:#a855f7}.class-view-theme-4 .class-view-calendar .ui-calendar__day--range-middle[aria-selected=true]{background:#a855f729;color:#6d28d9}.class-view-theme-4 .class-view-calendar .ui-calendar__day--range-start[aria-selected=true],.class-view-theme-4 .class-view-calendar .ui-calendar__day--range-end[aria-selected=true]{background:#a855f7}.class-view-theme-5 .class-view-calendar.ui-calendar{border-color:#ec489940}.class-view-theme-5 .class-view-calendar .ui-calendar__nav-button{color:#be185d;border-color:#ec489938}.class-view-theme-5 .class-view-calendar .ui-calendar__nav-button:hover{background:#ec48991a;border-color:#ec489959}.class-view-theme-5 .class-view-calendar .ui-calendar__nav-button:focus-visible{box-shadow:0 0 0 2px #ec4899,0 0 0 4px #f9fafb}.class-view-theme-5 .class-view-calendar .ui-calendar__day:hover{background:#ec48991a;border-color:#ec489938}.class-view-theme-5 .class-view-calendar .ui-calendar__day--selected{background:#ec4899}.class-view-theme-5 .class-view-calendar .ui-calendar__day--selected:hover{background:#db2777}.class-view-theme-5 .class-view-calendar .ui-calendar__day--today{background:#ec48991a;border-color:#ec489966;color:#be185d}.class-view-theme-5 .class-view-calendar__meeting-day:after{background:#ec4899}.class-view-theme-5 .class-view-calendar .ui-calendar__day--range-middle[aria-selected=true]{background:#ec489929;color:#be185d}.class-view-theme-5 .class-view-calendar .ui-calendar__day--range-start[aria-selected=true],.class-view-theme-5 .class-view-calendar .ui-calendar__day--range-end[aria-selected=true]{background:#ec4899}.class-view-theme-6 .class-view-calendar.ui-calendar{border-color:#64748b47}.class-view-theme-6 .class-view-calendar .ui-calendar__nav-button{color:#334155;border-color:#64748b38}.class-view-theme-6 .class-view-calendar .ui-calendar__nav-button:hover{background:#64748b1a;border-color:#64748b59}.class-view-theme-6 .class-view-calendar .ui-calendar__nav-button:focus-visible{box-shadow:0 0 0 2px #64748b,0 0 0 4px #f9fafb}.class-view-theme-6 .class-view-calendar .ui-calendar__day:hover{background:#64748b1a;border-color:#64748b38}.class-view-theme-6 .class-view-calendar .ui-calendar__day--selected{background:#64748b}.class-view-theme-6 .class-view-calendar .ui-calendar__day--selected:hover{background:#475569}.class-view-theme-6 .class-view-calendar .ui-calendar__day--today{background:#64748b1a;border-color:#64748b66;color:#334155}.class-view-theme-6 .class-view-calendar__meeting-day:after{background:#64748b}.class-view-theme-6 .class-view-calendar .ui-calendar__day--range-middle[aria-selected=true]{background:#64748b29;color:#334155}.class-view-theme-6 .class-view-calendar .ui-calendar__day--range-start[aria-selected=true],.class-view-theme-6 .class-view-calendar .ui-calendar__day--range-end[aria-selected=true]{background:#64748b}.class-view-calendar__meeting-day:after{content:"";position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:999px;background:#10b981}.class-view-meetings{margin-top:1.25rem;padding-top:1rem;border-top:1px solid rgba(229,231,235,.9)}.class-view-meeting{padding:.75rem;border-radius:.9rem;background:#d1fae540;border:1px solid rgba(209,213,219,.65);transition:background-color .15s ease}.class-view-meeting:hover{background:#d1fae566}.class-view-theme-1 .class-view-meeting__icon{background:#3b82f6}.class-view-theme-2 .class-view-meeting__icon{background:#f97316}.class-view-theme-3 .class-view-meeting__icon{background:#10b981}.class-view-theme-4 .class-view-meeting__icon{background:#a855f7}.class-view-theme-5 .class-view-meeting__icon{background:#ec4899}.class-view-theme-6 .class-view-meeting__icon{background:#64748b}.class-view-meetings__empty-icon{width:2.5rem;height:2.5rem;border-radius:999px;background:#e5e7ebb3;display:inline-flex;align-items:center;justify-content:center;margin-bottom:.5rem}.class-view-theme-1 .class-view-meetings__empty-icon{background:#3b82f6}.class-view-theme-2 .class-view-meetings__empty-icon{background:#f97316}.class-view-theme-3 .class-view-meetings__empty-icon{background:#10b981}.class-view-theme-4 .class-view-meetings__empty-icon{background:#a855f7}.class-view-theme-5 .class-view-meetings__empty-icon{background:#ec4899}.class-view-theme-6 .class-view-meetings__empty-icon{background:#64748b}.class-view-students-card{overflow:hidden;border-radius:1rem;border:1px solid #e5e7eb;background:#fff;box-shadow:0 10px 24px #0000000d}.class-view-students-card__bar{height:4px;background:linear-gradient(90deg,#10b981,#10b981a6)}.class-view-theme-1 .class-view-students-card__bar{background:#3b82f6}.class-view-theme-2 .class-view-students-card__bar{background:#f97316}.class-view-theme-3 .class-view-students-card__bar{background:#10b981}.class-view-theme-4 .class-view-students-card__bar{background:#a855f7}.class-view-theme-5 .class-view-students-card__bar{background:#ec4899}.class-view-theme-6 .class-view-students-card__bar{background:#64748b}.class-view-students-card__header{padding:1rem 1.1rem .4rem}.class-view-students-card__title{display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:1rem;font-weight:800}.class-view-students-card__title-left{display:inline-flex;align-items:center;gap:.5rem}.class-view-students-card__content{padding:.75rem 1.1rem 1.1rem}.class-view-students-list{display:grid;gap:.6rem;max-height:280px;overflow-y:auto;padding-right:4px}.class-view-student{display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:.9rem;background:#d1fae540;border:1px solid rgba(229,231,235,.9);transition:background-color .15s ease}.class-view-student:hover{background:#d1fae561}.class-view-student__avatar{width:2.25rem;height:2.25rem;border-radius:999px;background:#10b981;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 14px #10b9812e;flex:0 0 auto}.class-view-theme-1 .class-view-student__avatar{background:#3b82f6;box-shadow:0 8px 14px #3b82f633}.class-view-theme-2 .class-view-student__avatar{background:#f97316;box-shadow:0 8px 14px #f9731633}.class-view-theme-3 .class-view-student__avatar{background:#10b981;box-shadow:0 8px 14px #10b9812e}.class-view-theme-4 .class-view-student__avatar{background:#a855f7;box-shadow:0 8px 14px #a855f733}.class-view-theme-5 .class-view-student__avatar{background:#ec4899;box-shadow:0 8px 14px #ec489933}.class-view-theme-6 .class-view-student__avatar{background:#64748b;box-shadow:0 8px 14px #64748b33}.class-view-theme-1 .class-view-student__progress-value--active{stroke:#3b82f6}.class-view-theme-2 .class-view-student__progress-value--active{stroke:#f97316}.class-view-theme-4 .class-view-student__progress-value--active{stroke:#a855f7}.class-view-theme-5 .class-view-student__progress-value--active{stroke:#ec4899}.class-view-theme-6 .class-view-student__progress-value--active{stroke:#64748b}.class-view-student__avatar-icon{color:#fff}.class-view-student__meta{flex:1;min-width:0}.class-view-student__name{font-size:.9rem;font-weight:800;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-view-student__email{margin-top:.1rem;font-size:.75rem;color:#6b7280;display:inline-flex;align-items:center;gap:.35rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-view-student__progress{position:relative;width:2.5rem;height:2.5rem;flex:0 0 auto}.class-view-student__progress-svg{width:2.5rem;height:2.5rem;transform:rotate(-90deg)}.class-view-student__progress-track{stroke:#e5e7ebf2}.class-view-student__progress-value{stroke:#9ca3afcc;transition:stroke .2s ease,stroke-dasharray .2s ease}.class-view-student__progress-value--active{stroke:#10b981}.class-view-student__progress-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;color:#6b7280}.class-view-students-empty{text-align:center;padding:1.5rem .5rem;color:#6b7280}.class-view-students-empty__icon{opacity:.35;margin:0 auto .5rem;display:block}.class-view-students-empty__text{font-size:.9rem}.class-view-modal{max-width:560px}.class-view-modal__title{display:inline-flex;align-items:center;gap:.5rem}.class-view-modal__body{padding:1rem 0;display:grid;gap:1rem}.class-view-modal__field{display:grid;gap:.5rem}.class-view-modal__grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 640px){.class-view-modal__grid{grid-template-columns:1fr 1fr}}.class-view-modal__primary-btn{gap:.5rem;background:#10b981;color:#fff}.class-view-modal__primary-btn:hover{background:#059669}.class-view-empty{text-align:center;padding:2rem 1.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:1rem;box-shadow:0 10px 24px #0000000f}.class-view-empty__title{font-size:1.5rem;font-weight:900;color:#1f2937;margin-bottom:1rem}@media (max-width: 860px){.class-view-hero__row{flex-direction:column}}.class-view-panel{border-radius:1rem;border:1px solid #d1fae5;background:#fff;box-shadow:0 10px 24px #0000000d}.class-view-panel__header{padding:1.1rem 1.1rem .25rem}.class-view-panel__title{display:inline-flex;align-items:center;gap:.75rem;font-size:1rem;font-weight:800;color:#064e3b}.class-view-panel__title-icon{width:2.1rem;height:2.1rem;border-radius:.75rem;display:inline-flex;align-items:center;justify-content:center;background:#10b981}.class-view-panel__title-icon-svg{color:#fff}.class-view-panel__content{padding:.9rem .9rem 1.1rem}.class-view-calendar{width:100%;border:1px solid #d1fae5;border-radius:1rem;background:linear-gradient(180deg,#f0fdf4,#fff);padding:.85rem;box-sizing:border-box}.class-view-calendar .rdp{width:100%;margin:0}.class-view-calendar .rdp-months{display:flex;justify-content:center}.class-view-calendar .rdp-month{width:100%}.class-view-calendar .rdp-caption{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem;padding:.15rem .15rem .5rem}.class-view-calendar .rdp-caption_label{font-size:1rem;font-weight:800;color:#065f46}.class-view-calendar .rdp-nav{display:flex;align-items:center;gap:.35rem}.rdp-button_previous,.rdp-button_next{width:2rem;height:2rem;border:1px solid #a7f3d0;border-radius:.65rem;background:#fff;color:#059669;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,transform .15s ease}.rdp-chevron{fill:#fff}.class-view-theme-1 .rdp-button_next{background:#3b82f6f0;border:1px solid rgba(59,130,246,.42)}.class-view-theme-2 .rdp-button_next{background:#f97316f0;border:1px solid rgba(249,115,22,.42)}.class-view-theme-3 .rdp-button_next{background:#10b981f0;border:1px solid rgba(16,185,129,.42)}.class-view-theme-4 .rdp-button_next{background:#a855f7f0;border:1px solid rgba(168,85,247,.42)}.class-view-theme-5 .rdp-button_next{background:#ec4899f0;border:1px solid rgba(236,72,153,.42)}.class-view-theme-6 .rdp-button_next{background:#64748bf0;border:1px solid rgba(100,116,139,.42)}.class-view-theme-1 .rdp-button_previous{background:#3b82f6f0;border:1px solid rgba(59,130,246,.42)}.class-view-theme-2 .rdp-button_previous{background:#f97316f0;border:1px solid rgba(249,115,22,.42)}.class-view-theme-3 .rdp-button_previous{background:#10b981f0;border:1px solid rgba(16,185,129,.42)}.class-view-theme-4 .rdp-button_previous{background:#a855f7f0;border:1px solid rgba(168,85,247,.42)}.class-view-theme-5 .rdp-button_previous{background:#ec4899f0;border:1px solid rgba(236,72,153,.42)}.class-view-theme-6 .rdp-button_previous{background:#64748bf0;border:1px solid rgba(100,116,139,.42)}.rdp-button_previous:hover,.rdp-button_next:hover{transform:scale(1.1)}.class-view-theme-1 .rdp-button_next:hover{background:#3b82f6;border:1px solid rgba(59,130,246,.86)}.class-view-theme-2 .rdp-button_next:hover{background:#f97316;border:1px solid rgba(249,115,22,.86)}.class-view-theme-3 .rdp-button_next:hover{background:#10b981;border:1px solid rgba(16,185,129,.86)}.class-view-theme-4 .rdp-button_next:hover{background:#a855f7;border:1px solid rgba(168,85,247,.86)}.class-view-theme-5 .rdp-button_next:hover{background:#ec4899;border:1px solid rgba(236,72,153,.86)}.class-view-theme-6 .rdp-button_next:hover{background:#64748b;border:1px solid rgba(100,116,139,.86)}.class-view-theme-1 .rdp-button_previous:hover{background:#3b82f6;border:1px solid rgba(59,130,246,.86)}.class-view-theme-2 .rdp-button_previous:hover{background:#f97316;border:1px solid rgba(249,115,22,.86)}.class-view-theme-3 .rdp-button_previous:hover{background:#10b981;border:1px solid rgba(16,185,129,.86)}.class-view-theme-4 .rdp-button_previous:hover{background:#a855f7;border:1px solid rgba(168,85,247,.86)}.class-view-theme-5 .rdp-button_previous:hover{background:#ec4899;border:1px solid rgba(236,72,153,.86)}.class-view-theme-6 .rdp-button_previous:hover{background:#64748b;border:1px solid rgba(100,116,139,.86)}.class-view-calendar .rdp-table{width:100%;border-collapse:collapse}.class-view-calendar .rdp-head_row,.class-view-calendar .rdp-row{display:grid;grid-template-columns:repeat(7,1fr)}.class-view-calendar .rdp-head_cell{text-align:center;font-size:.75rem;font-weight:800;color:#6b7280;padding:.45rem 0}.class-view-calendar .rdp-cell{display:flex;justify-content:center;align-items:center;padding:.18rem 0}.class-view-calendar .rdp-day{width:2.35rem;height:2.35rem;border:none;outline:none;border-radius:.75rem;background:transparent;color:#1f2937;font-size:.875rem;font-weight:600;cursor:pointer;position:relative;transition:all .15s ease}.class-view-calendar .rdp-day:hover{background:#d1fae5;color:#065f46}.class-view-calendar .rdp-day_selected,.class-view-calendar .rdp-day_selected:hover{background:#10b981;color:#fff;box-shadow:0 8px 18px #10b98138}.class-view-calendar .rdp-day_today{background:#ecfdf5;color:#059669;font-weight:800;border:1px solid #a7f3d0}.class-view-calendar .rdp-day_outside{color:#cbd5e1;opacity:.65}.class-view-calendar .rdp-day_disabled{color:#d1d5db;opacity:.45;cursor:not-allowed}.class-view-calendar__meeting-day{position:relative}.class-view-calendar__meeting-day:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:999px;background:#059669}.class-view-calendar .rdp-day_selected.class-view-calendar__meeting-day:after{background:#fff}.class-view-meetings{margin-top:1.25rem;padding-top:1rem;border-top:1px solid rgba(209,250,229,.95)}.class-view-theme-1 .class-view-meetings{border-top:1px solid rgba(59,130,246,.86)}.class-view-theme-2 .class-view-meetings{border-top:1px solid rgba(249,115,22,.86)}.class-view-theme-3 .class-view-meetings{border-top:1px solid rgba(16,185,129,.86)}.class-view-theme-4 .class-view-meetings{border-top:1px solid rgba(168,85,247,.86)}.class-view-theme-5 .class-view-meetings{border-top:1px solid rgba(236,72,153,.86)}.class-view-theme-6 .class-view-meetings{border-top:1px solid rgba(100,116,139,.86)}.class-view-meetings__header{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.class-view-meetings__date{font-size:.9rem;font-weight:700;color:#1f2937}.class-view-meetings__count{font-size:.75rem;color:#6b7280}.class-view-meetings__list{display:grid;gap:.6rem}.class-view-meeting{padding:.75rem;border-radius:.9rem;background:#d1fae54d;border:1px solid #d1fae5;transition:background-color .15s ease}.class-view-meeting:hover{background:#d1fae57a}.class-view-meeting__row{display:flex;align-items:center;gap:.6rem}.class-view-meeting__icon{width:1.5rem;height:1.5rem;border-radius:.5rem;background:#10b981;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.class-view-meeting__icon-svg{color:#fff}.class-view-meeting__title{font-size:.9rem;font-weight:700;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.class-view-meeting__meta{margin-top:.35rem;margin-left:2.1rem;font-size:.75rem;color:#6b7280}.class-view-meetings__empty{padding:1.4rem .5rem;text-align:center}.class-view-meetings__empty-icon{width:2.5rem;height:2.5rem;border-radius:999px;background:#ecfdf5;display:inline-flex;align-items:center;justify-content:center;margin-bottom:.5rem}.class-view-meetings__empty-icon-svg{color:#fff}.class-view-meetings__empty-title{font-size:.9rem;color:#6b7280}.class-view-meetings__empty-subtitle{font-size:.75rem;color:#6b7280bf;margin-top:.15rem}
