.header-search{flex:1 1 auto;max-width:28rem;margin-left:1.5rem;margin-right:1.5rem;position:relative}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:var(--color-education-gray)}.input{width:100%;height:2.5rem;border:1px solid var(--color-border);border-radius:8px;padding:0 .75rem 0 2.125rem;outline:none;color:var(--color-text);background:#fff;transition:border-color .15s ease,box-shadow .15s ease;box-sizing:border-box}.input::placeholder{color:var(--color-education-gray)}.input:focus{border-color:var(--color-education-blue);box-shadow:0 0 0 3px #2563eb26}:root{--color-header-bg: #ffffff;--color-header-topbar: #0f172a;--color-header-nav: #f8fafc;--color-education-blue: #2563eb;--color-education-gray: #64748b;--color-border: #e5e7eb;--color-text: #0f172a;--color-text-muted: #64748b;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--radius: 8px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--container-max: 80rem}.bg-header-bg{background-color:var(--color-header-bg)}.bg-header-topbar{background-color:var(--color-header-topbar)}.bg-header-nav{background-color:var(--color-header-nav)}.border-border{border-color:var(--color-border)}.text-education-blue{color:var(--color-education-blue)}.text-education-gray{color:var(--color-education-gray)}.shadow-sm{box-shadow:var(--shadow-sm)}.header-container{width:100%}.header-inner{max-width:var(--container-max);margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}@media (min-width: 640px){.header-inner{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.header-inner{padding-left:2rem;padding-right:2rem}}.header-topbar{color:#fff}.header-topbar-row{display:flex;align-items:center;justify-content:flex-end;height:2rem;width:100%;gap:var(--space-4)}.icon-3{width:.75rem;height:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;height:1.5rem;padding:0 var(--space-2);border-radius:6px;border:none;background:transparent;color:inherit;font:inherit;cursor:pointer;transition:background-color .15s ease}.btn-ghost{background:transparent;color:inherit}.btn-ghost:hover{background-color:#ffffff1a}.light-surface .btn-ghost:hover{background-color:#0f172a0f}.header-main{border-bottom:1px solid var(--color-border);background-color:var(--color-header-bg)}.header-main-row{display:flex;align-items:center;justify-content:space-between;height:4rem;width:100%}.logo-link{display:flex;align-items:center;gap:.5rem;flex-shrink:0;text-decoration:none}.logo-image{height:2.5rem;width:auto;min-width:8rem;max-width:30rem;object-fit:contain}.logo-title{display:flex;flex-direction:column}.logo-name{font-size:1.125rem;font-weight:700;color:var(--color-education-blue);line-height:1.2}.logo-sub{font-size:.75rem;line-height:1;color:var(--color-education-gray)}.header-search{position:relative;flex:1 1 auto;max-width:28rem;margin-left:1.5rem;margin-right:1.5rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:var(--color-education-gray);pointer-events:none}.header-search .search-input{width:100%;height:2.5rem;border:1px solid var(--color-border);border-radius:8px;padding:0 .75rem 0 2.5rem;outline:none;color:var(--color-text);background:#fff;transition:border-color .15s ease,box-shadow .15s ease;box-sizing:border-box}.header-search .search-input::placeholder{color:var(--color-education-gray)}.header-search .search-input:focus{border-color:var(--color-education-blue);box-shadow:0 0 0 3px #2563eb26}.header-spacer{flex-shrink:0;width:1.5rem}.header-nav{border-bottom:1px solid var(--color-border);background-color:var(--color-header-nav)}.nav-row{display:flex;align-items:center;height:2.5rem;gap:2rem}.nav-link{display:flex;align-items:center;height:100%;padding:0 .25rem;text-decoration:none;font-size:.875rem;font-weight:500;color:var(--color-education-gray);border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease}.nav-link:hover{color:var(--color-education-blue);border-bottom-color:var(--color-education-blue)}.header-topbar a,.header-topbar button{color:#fff;text-decoration:none}.header-topbar a:hover,.header-topbar button:hover{color:#fff}.header-topbar .btn.btn-ghost:hover{background-color:#ffffff1a}.header-topbar .icon-3{color:#fff}.topbar-greeting{display:flex;align-items:center;gap:.25rem;padding:0 var(--space-1)}.topbar-greeting .name{font-size:.75rem;font-weight:600;color:#fff}.btn .icon-left{margin-right:.25rem}.dark-surface{background:var(--color-header-topbar)}.light-surface{background:var(--color-header-bg)}.header-sticky{position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}@media (max-width: 640px){.header-main-row{gap:.75rem}.header-search{max-width:100%;margin:0 .75rem}.nav-row{gap:.75rem;overflow-x:auto}.logo-image{min-width:6rem}}.lesson-list-title{font-size:1.875rem;font-weight:700;margin-bottom:2rem;color:hsl(var(--foreground))}.lesson-list-loading{display:flex;justify-content:center;align-items:center;min-height:16rem}.lesson-list-loading-text{font-size:1.125rem;color:hsl(var(--foreground))}.lesson-list-error{background:#fff0f0;border:1px solid hsl(0 84.2% 60.2%);color:#ba1c1c;padding:1rem;border-radius:.375rem}.lesson-list-grid{display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.lesson-list-card{background:hsl(var(--card));border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;padding:1.5rem;transition:box-shadow .2s}.lesson-list-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.lesson-list-card-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:hsl(var(--foreground))}.lesson-list-card-description{color:hsl(var(--muted-foreground));margin-bottom:1rem}.lesson-list-card-footer{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.lesson-list-card-price{font-size:1.5rem;font-weight:700;color:hsl(var(--education-blue))}.lesson-list-card-sections{font-size:.875rem;color:hsl(var(--muted-foreground))}.lesson-list-card-button{display:block;width:100%;background:hsl(var(--education-blue));color:hsl(var(--primary-foreground));text-align:center;padding:.5rem 1rem;border-radius:.375rem;text-decoration:none;transition:background-color .2s;font-weight:500}.lesson-list-card-button:hover{background:#08255e}@media (min-width: 1024px){.lesson-list-grid{grid-template-columns:repeat(3,1fr)}.lesson-list-title{font-size:2rem}}@media (max-width: 767px){.lesson-list-grid{grid-template-columns:1fr}.lesson-list-title{font-size:1.5rem;margin-bottom:1.5rem}.lesson-list-card{padding:1.25rem}.lesson-list-card-title{font-size:1.125rem}.lesson-list-card-price{font-size:1.25rem}}.lesson-detail-loading{display:flex;justify-content:center;align-items:center;min-height:16rem}.lesson-detail-loading-text{font-size:1.125rem;color:hsl(var(--foreground))}.lesson-detail-error{background:#fff0f0;border:1px solid hsl(0 84.2% 60.2%);color:#ba1c1c;padding:1rem;border-radius:.375rem}.lesson-detail-header{margin-bottom:1.5rem}.lesson-detail-back-link{color:hsl(var(--education-blue));text-decoration:none;margin-bottom:1rem;display:inline-block;transition:color .2s}.lesson-detail-back-link:hover{color:#08255e}.lesson-detail-title{font-size:1.875rem;font-weight:700;color:hsl(var(--foreground))}.lesson-detail-grade-card{margin-bottom:1.5rem;background:linear-gradient(to right,#f0f5ff,#f0f0ff);border:2px solid hsl(220 100% 90%);border-radius:.5rem;padding:1.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.lesson-detail-grade-content{display:flex;align-items:center;justify-content:space-between}.lesson-detail-grade-info{flex:1}.lesson-detail-grade-heading{font-size:1.25rem;font-weight:700;color:#08225e;margin-bottom:.5rem}.lesson-detail-grade-subheading{font-size:.875rem;color:hsl(var(--muted-foreground))}.lesson-detail-grade-progress-text{font-size:.875rem;color:hsl(var(--muted-foreground));margin-bottom:.5rem}.lesson-detail-grade-progress-bar-container{display:flex;align-items:center;gap:.5rem}.lesson-detail-grade-progress-bar-track{flex:1;background:hsl(var(--secondary));border-radius:9999px;height:.625rem}.lesson-detail-grade-progress-bar-fill{background:hsl(var(--education-blue));height:.625rem;border-radius:9999px;transition:width .3s ease}.lesson-detail-grade-progress-label{font-size:.75rem;font-weight:600;color:hsl(var(--muted-foreground))}.lesson-detail-grade-display{text-align:center;background:hsl(var(--card));border-radius:.5rem;padding:1rem 2rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.lesson-detail-grade-label{font-size:.875rem;color:hsl(var(--muted-foreground));margin-bottom:.25rem}.lesson-detail-grade-value{font-size:3rem;font-weight:700;color:hsl(var(--education-blue))}.lesson-detail-grade-value--empty{color:#c5cad3}.lesson-detail-grade-sublabel{font-size:.75rem;color:hsl(var(--muted-foreground));margin-top:.25rem}.lesson-detail-sections{display:flex;flex-direction:column;gap:1rem}.lesson-detail-section-card{background:hsl(var(--card));border-radius:.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;padding:1.5rem}.lesson-detail-section-inner{display:flex;align-items:flex-start;justify-content:space-between}.lesson-detail-section-content{flex:1}.lesson-detail-section-header{display:flex;align-items:center;margin-bottom:.5rem}.lesson-detail-section-icon{font-size:1.5rem;margin-right:.75rem}.lesson-detail-section-title{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground))}.lesson-detail-section-status{margin-left:.75rem;font-size:1.125rem}.lesson-detail-section-status--passed{color:#16a249}.lesson-detail-section-status--failed{color:hsl(var(--destructive))}.lesson-detail-section-status--in-progress{color:#e7b008}.lesson-detail-section-status--not-started{color:hsl(var(--muted-foreground))}.lesson-detail-section-description{color:hsl(var(--muted-foreground));margin-bottom:.5rem}.lesson-detail-section-meta{display:flex;gap:1rem;font-size:.875rem;color:hsl(var(--muted-foreground));margin-bottom:.5rem}.lesson-detail-section-meta-passing{color:#16a249;font-weight:500}.lesson-detail-section-meta-latest{color:#ff8000;font-weight:500}.lesson-detail-section-meta-category{text-transform:capitalize}.lesson-detail-section-progress{margin-top:.75rem;padding:.75rem;background:hsl(var(--muted));border-radius:.5rem}.lesson-detail-section-progress-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;font-size:.875rem}.lesson-detail-section-progress-item-label{font-weight:500}.lesson-detail-section-progress-item-label--latest{color:hsl(var(--education-blue))}.lesson-detail-section-progress-item-label--best{color:#16a249}.lesson-detail-section-progress-item-label--attempts{color:hsl(var(--muted-foreground))}.lesson-detail-section-progress-item-label--completed{color:#80c}.lesson-detail-section-progress-value{font-size:1.125rem;font-weight:700}.lesson-detail-section-progress-value-grade{font-size:.875rem;color:hsl(var(--muted-foreground));margin-left:.25rem}.lesson-detail-section-progress-value-date{font-size:.875rem}.lesson-detail-section-action{margin-left:1rem}.lesson-detail-section-button{display:block;background:hsl(var(--education-blue));color:hsl(var(--primary-foreground));padding:.75rem 1.5rem;border-radius:.5rem;text-decoration:none;transition:background-color .2s;font-weight:500;text-align:center;min-width:140px}.lesson-detail-section-button:hover{background:#08255e}@media (min-width: 1024px){.lesson-detail-title{font-size:2rem}.lesson-detail-grade-heading{font-size:1.5rem}.lesson-detail-section-progress-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 767px){.lesson-detail-title{font-size:1.5rem}.lesson-detail-grade-card{padding:1rem}.lesson-detail-grade-content{flex-direction:column;gap:1rem}.lesson-detail-grade-heading{font-size:1.125rem}.lesson-detail-grade-display{width:100%}.lesson-detail-grade-value{font-size:2.5rem}.lesson-detail-section-card{padding:1rem}.lesson-detail-section-inner{flex-direction:column;gap:1rem}.lesson-detail-section-header{flex-direction:column;align-items:flex-start}.lesson-detail-section-icon{margin-bottom:.5rem}.lesson-detail-section-title{font-size:1.125rem}.lesson-detail-section-meta{flex-direction:column;gap:.25rem}.lesson-detail-section-progress-grid{grid-template-columns:1fr;gap:.75rem}.lesson-detail-section-action{margin-left:0;width:100%}.lesson-detail-section-button{width:100%}}.video-player-error{background-color:#fff0f0;border:1px solid hsl(0 93% 80%);border-radius:.5rem;padding:1.5rem}.video-player-error-content{display:flex;align-items:center;gap:.75rem}.video-player-error-icon{color:hsl(var(--destructive))}.video-player-error-text{color:hsl(var(--destructive));font-weight:500;margin:0}.video-player-container{position:relative;background-color:#000;border-radius:.5rem;overflow:hidden;box-shadow:0 10px 25px #0000004d;max-width:800px;margin:0 auto}.video-player-container--fullscreen{max-width:100%;margin:0;border-radius:0}.video-player-title-header{background:linear-gradient(135deg,#667eea,#764ba2);color:hsl(var(--primary-foreground));padding:1rem 1.5rem;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.video-player-title{font-weight:600;font-size:1.125rem;margin:0}.video-player-video-wrapper{position:relative;cursor:pointer;max-height:450px}.video-player-video-wrapper--fullscreen{max-height:100%}.video-player-video{width:100%;height:auto}.video-player-video--loading{pointer-events:none}.video-player-loading-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center}.video-player-loading-content{color:hsl(var(--primary-foreground));font-size:1.125rem;display:flex;align-items:center;gap:.5rem}.video-player-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);padding:1rem;transition:opacity .3s}.video-player-controls--visible{opacity:1}.video-player-controls--hidden{opacity:0}.video-player-progress-wrapper{margin-bottom:.5rem}.video-player-progress-bar{width:100%;height:.25rem;background:hsl(var(--muted));border-radius:.5rem;appearance:none;cursor:pointer}.video-player-progress-bar::-webkit-slider-thumb{appearance:none;width:12px;height:12px;border-radius:50%;background:hsl(var(--primary));cursor:pointer}.video-player-progress-bar::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:hsl(var(--primary));cursor:pointer;border:none}.video-player-controls-bar{display:flex;align-items:center;justify-content:space-between;color:hsl(var(--primary-foreground))}.video-player-controls-left,.video-player-controls-right{display:flex;align-items:center;gap:.5rem}.video-player-control-btn{background:none;border:none;color:hsl(var(--primary-foreground));cursor:pointer;padding:.25rem;border-radius:.25rem;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.video-player-control-btn:hover{background:#fff3}.video-player-time-display{font-size:.875rem}.video-player-speed-select{background:transparent;color:hsl(var(--primary-foreground));font-size:.875rem;border:1px solid hsl(var(--muted));border-radius:.25rem;padding:0 .25rem;cursor:pointer}.video-player-speed-option{color:#000}.video-player-volume-wrapper{display:flex;align-items:center;gap:.25rem}.video-player-volume-slider{width:4rem;height:.25rem;background:hsl(var(--muted));border-radius:.5rem;appearance:none;cursor:pointer}.video-player-volume-slider::-webkit-slider-thumb{appearance:none;width:10px;height:10px;border-radius:50%;background:hsl(var(--primary-foreground));cursor:pointer}.video-player-volume-slider::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:hsl(var(--primary-foreground));cursor:pointer;border:none}.video-player-completion-badge{position:absolute;top:1rem;right:1rem;background:#21c45d;color:hsl(var(--primary-foreground));padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;display:flex;align-items:center;gap:.25rem}@media (min-width: 1024px){.video-player-title{font-size:1.25rem}.video-player-container{max-width:900px}}@media (max-width: 767px){.video-player-title-header{padding:.75rem 1rem}.video-player-title{font-size:1rem}.video-player-controls{padding:.5rem}.video-player-controls-left,.video-player-controls-right{gap:.25rem}.video-player-time-display{font-size:.75rem}.video-player-volume-wrapper{display:none}.video-player-completion-badge{font-size:.75rem;padding:.25rem .5rem}}.class-video-page{min-height:100vh;background:hsl(var(--secondary))}.class-video-loading{min-height:100vh;background:hsl(var(--secondary));display:flex;align-items:center;justify-content:center}.class-video-loading-content{text-align:center}.class-video-loading-spinner{animation:spin 1s linear infinite;border-radius:50%;height:3rem;width:3rem;border:2px solid transparent;border-bottom-color:hsl(var(--primary));margin:0 auto 1rem}.class-video-loading-text{color:hsl(var(--muted-foreground))}.class-video-error{min-height:100vh;background:hsl(var(--secondary));display:flex;align-items:center;justify-content:center}.class-video-error-content{text-align:center;max-width:28rem;margin:0 auto;padding:1.5rem}.class-video-error-icon{color:hsl(var(--destructive));font-size:4rem;margin-bottom:1rem}.class-video-error-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.5rem}.class-video-error-message{color:hsl(var(--muted-foreground));margin-bottom:1rem}.class-video-error-link{display:inline-block;background:hsl(var(--primary));color:hsl(var(--primary-foreground));padding:.5rem 1.5rem;border-radius:.5rem;text-decoration:none;transition:background-color .2s}.class-video-error-link:hover{background:hsl(var(--primary-hover))}.class-video-auth-required{min-height:100vh;background:hsl(var(--secondary));display:flex;align-items:center;justify-content:center}.class-video-auth-content{text-align:center;max-width:28rem;margin:0 auto;padding:1.5rem}.class-video-auth-icon{color:#fbbd23;font-size:4rem;margin-bottom:1rem}.class-video-auth-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:.5rem}.class-video-auth-message{color:hsl(var(--muted-foreground));margin-bottom:1rem}.class-video-auth-link{display:inline-block;background:hsl(var(--primary));color:hsl(var(--primary-foreground));padding:.5rem 1.5rem;border-radius:.5rem;text-decoration:none;transition:background-color .2s}.class-video-auth-link:hover{background:hsl(var(--primary-hover))}.class-video-header{background:hsl(var(--background));box-shadow:0 1px 3px #0000001a;border-bottom:1px solid hsl(var(--border))}.class-video-header-container{max-width:56rem;margin:0 auto;padding:1rem}.class-video-header-content{display:flex;align-items:center;gap:1rem}.class-video-back-link{color:hsl(var(--primary));text-decoration:none;display:flex;align-items:center;gap:.25rem;transition:color .2s}.class-video-back-link:hover{color:hsl(var(--primary-hover))}.class-video-header-title-wrapper{flex:1}.class-video-header-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));display:flex;align-items:center;gap:.5rem}.class-video-header-subtitle{color:hsl(var(--muted-foreground))}.class-video-main{max-width:56rem;margin:0 auto;padding:2rem 1rem}.class-video-card{background:hsl(var(--background));border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid hsl(var(--border));overflow:hidden}.class-video-card-content{padding:1.5rem}.class-video-intro{margin-bottom:1rem}.class-video-intro-title{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.5rem}.class-video-intro-text{color:hsl(var(--muted-foreground))}.class-video-player-container{margin-bottom:1.5rem}.class-video-warning{background:#fef8e6;border:1px solid hsl(43 96% 85%);border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.class-video-warning-text{color:#966c03}.class-video-materials{margin-bottom:1.5rem}.class-video-materials-title{font-size:1.125rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.75rem}.class-video-material-item{margin-bottom:1rem;background:hsl(var(--secondary));border-radius:.5rem;padding:1rem}.class-video-material-title{font-weight:500;color:hsl(var(--foreground));margin-bottom:.5rem}.class-video-material-content{font-size:.875rem;max-width:100%;color:hsl(var(--foreground))}.class-video-next-steps{background:hsl(var(--secondary));border-radius:.5rem;padding:1rem}.class-video-next-steps-title{font-weight:600;color:hsl(var(--foreground));margin-bottom:.75rem}.class-video-next-steps-content{display:flex;flex-direction:column;gap:.75rem}.class-video-status{display:flex;align-items:center;gap:.5rem}.class-video-status--completed{color:#21c45d}.class-video-status--pending{color:hsl(var(--muted-foreground))}.class-video-next-steps-text{color:hsl(var(--muted-foreground));font-size:.875rem}.class-video-action-btn{padding:.5rem 1.5rem;border-radius:.5rem;border:none;font-weight:500;cursor:pointer;transition:background-color .2s}.class-video-action-btn--success{background:#21c45d;color:hsl(var(--primary-foreground))}.class-video-action-btn--success:hover{background:#1eae53}.class-video-action-btn--disabled{background:hsl(var(--secondary));color:hsl(var(--muted-foreground));cursor:not-allowed}.class-video-tips-card{margin-top:1.5rem;background:hsl(var(--background));border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid hsl(var(--border));padding:1.5rem}.class-video-tips-title{font-weight:600;color:hsl(var(--foreground));margin-bottom:.75rem}.class-video-tips-list{display:flex;flex-direction:column;gap:.5rem;color:hsl(var(--muted-foreground));font-size:.875rem}.class-video-tips-item{display:flex;align-items:flex-start;gap:.5rem}@media (min-width: 1024px){.class-video-header-title{font-size:1.75rem}.class-video-main{padding:2.5rem 1rem}}@media (max-width: 767px){.class-video-header-content{flex-direction:column;align-items:flex-start}.class-video-header-title{font-size:1.25rem}.class-video-card-content{padding:1rem}.class-video-main{padding:1rem .5rem}.class-video-tips-card{padding:1rem}.class-video-error-icon,.class-video-auth-icon{font-size:3rem}}.section-page-container{max-width:1200px;margin:0 auto}.section-page-loading{display:flex;justify-content:center;align-items:center;min-height:400px}.section-page-loading-text{font-size:1.125rem;color:hsl(var(--education-gray))}.section-page-error{text-align:center;padding:2rem 0}.section-page-error-text{color:hsl(var(--destructive));margin-bottom:1rem}.section-page-error-btn{background:hsl(var(--education-blue));color:hsl(var(--primary-foreground));padding:.5rem 1.5rem;border-radius:.375rem;border:none;cursor:pointer;transition:background-color .2s}.section-page-error-btn:hover{background:#08255e}.section-page-header{margin-bottom:1.5rem}.section-page-nav-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-page-back-btn{display:flex;align-items:center;color:hsl(var(--education-blue));background:none;border:none;cursor:pointer;transition:color .2s;font-size:1rem}.section-page-back-btn:hover{color:#08255e}.section-page-back-icon{width:1.25rem;height:1.25rem;margin-right:.5rem}.section-page-title{font-size:1.5rem;font-weight:700;color:hsl(var(--education-dark, var(--foreground)))}.section-page-spacer{width:1px}.section-page-tabs{display:flex;border-bottom:1px solid hsl(var(--border))}.section-page-tab{padding:.75rem 1.5rem;font-weight:500;font-size:.875rem;border:none;background:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .2s,border-color .2s;color:hsl(var(--muted-foreground))}.section-page-tab:hover{color:hsl(var(--foreground));border-bottom-color:hsl(var(--border))}.section-page-tab--active{border-bottom-color:hsl(var(--education-blue));color:hsl(var(--education-blue))}.section-page-content{background:hsl(var(--background));border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.section-page-bottom-nav{display:flex;justify-content:space-between;margin-top:1.5rem}.section-page-nav-button{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;border:none;cursor:pointer;transition:background-color .2s}.section-page-nav-button--primary{background:hsl(var(--education-blue));color:hsl(var(--primary-foreground))}.section-page-nav-button--primary:hover{background:#08255e}.section-page-nav-button--disabled{background:hsl(var(--secondary));color:hsl(var(--muted-foreground));cursor:not-allowed;opacity:.6}@media (min-width: 1024px){.section-page-title{font-size:1.75rem}}@media (max-width: 767px){.section-page-container{padding:0 1rem}.section-page-nav-bar{flex-direction:column;align-items:flex-start;gap:1rem}.section-page-title{font-size:1.25rem}.section-page-spacer{display:none}.section-page-tab{padding:.75rem 1rem;font-size:.8125rem}.section-page-bottom-nav{flex-direction:column;gap:.75rem}.section-page-nav-button{width:100%}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background-color:#f5f5f5}.auth-box{width:100%;max-width:400px;padding:2rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a}.auth-title{margin-bottom:2rem;font-size:1.5rem;font-weight:700;text-align:center;color:#333}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.input-group{display:flex;flex-direction:column;gap:1rem}.auth-input{width:100%;padding:.75rem;border:1px solid #e0e0e0;border-radius:4px;background-color:#fff;color:#333;font-size:1rem}.auth-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.submit-button{width:100%;padding:.75rem;background-color:#2563eb;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#1d4ed8}.submit-button:disabled{opacity:.7;cursor:not-allowed}.auth-links{display:flex;justify-content:space-between;gap:1rem}.link-button{background:none;border:none;color:#2563eb;font-size:.875rem;cursor:pointer;padding:0;transition:color .2s}.link-button:hover{color:#1d4ed8;text-decoration:underline}.oauth-button{display:inline-flex;align-items:center;gap:8px;width:100%;justify-content:center;padding:10px 14px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#111827;font-weight:600;cursor:pointer}.oauth-separator{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;color:#6b7280;font-size:12px;margin:12px 0}.oauth-separator:before,.oauth-separator:after{content:"";height:1px;background:#e5e7eb;display:block}.grade-display-container{padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;max-width:800px;margin:0 auto}.grade-display-title{font-size:1.75rem;font-weight:700;color:hsl(var(--primary));margin-bottom:1.5rem;text-align:center}.grade-display-loading,.grade-display-error{text-align:center;padding:3rem 2rem;font-size:1.125rem;color:hsl(var(--muted-foreground))}.grade-display-error{color:hsl(var(--destructive))}.grade-display-main{text-align:center;padding:2rem 0;border-bottom:2px solid hsl(var(--border));margin-bottom:2rem}.grade-display-score{font-size:3.5rem;font-weight:800;line-height:1;margin-bottom:.5rem}.grade-display-score.passed{color:#10b981}.grade-display-score.close{color:#f59e0b}.grade-display-score.needs-improvement{color:#ef4444}.grade-display-percentage{font-size:1.5rem;color:hsl(var(--muted-foreground));font-weight:600}.grade-display-target{margin-bottom:2rem;padding:1.5rem;background:hsl(var(--secondary));border-radius:8px}.target-label{font-size:1rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.75rem}.target-progress-bar{width:100%;height:12px;background:hsl(var(--border));border-radius:6px;overflow:hidden;margin-bottom:.75rem}.target-progress-fill{height:100%;border-radius:6px;transition:width .5s ease-in-out}.target-progress-fill.passed{background:linear-gradient(90deg,#10b981,#059669)}.target-progress-fill.close{background:linear-gradient(90deg,#f59e0b,#d97706)}.target-progress-fill.needs-improvement{background:linear-gradient(90deg,#ef4444,#dc2626)}.target-status{font-size:.95rem;font-weight:600;text-align:center}.target-status.passed{color:#10b981}.target-status.close{color:#f59e0b}.target-status.needs-improvement{color:#ef4444}.grade-display-motivation{text-align:center;font-size:1.125rem;font-weight:600;padding:1rem;border-radius:8px;margin-bottom:2rem}.grade-display-motivation.passed{background:#d1fae5;color:#065f46}.grade-display-motivation.close{background:#fef3c7;color:#92400e}.grade-display-motivation.needs-improvement{background:#fee2e2;color:#991b1b}.grade-display-breakdown{margin-top:2rem}.breakdown-title{font-size:1.25rem;font-weight:700;color:hsl(var(--primary));margin-bottom:1rem}.breakdown-stats{display:flex;justify-content:space-around;padding:1rem;background:hsl(var(--secondary));border-radius:8px;margin-bottom:1.5rem;font-size:.95rem;color:hsl(var(--muted-foreground))}.breakdown-table{display:flex;flex-direction:column;gap:.75rem}.breakdown-row{display:grid;grid-template-columns:1fr 2fr auto;align-items:center;gap:1rem;padding:1rem;background:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:8px;transition:all .2s ease}.breakdown-row:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.breakdown-category{font-weight:600;color:hsl(var(--foreground));font-size:1rem}.breakdown-score{display:flex;align-items:baseline;gap:.5rem}.score-value{font-size:1.125rem;font-weight:700}.score-value.passed{color:#10b981}.score-value.close{color:#f59e0b}.score-value.needs-improvement{color:#ef4444}.score-count{font-size:.875rem;color:hsl(var(--muted-foreground))}.breakdown-icon{font-size:1.5rem}@media (min-width: 1024px){.grade-display-container{padding:3rem;max-width:1000px}.grade-display-title{font-size:2.25rem}.grade-display-score{font-size:4.5rem}.grade-display-percentage{font-size:1.75rem}.breakdown-row{padding:1.25rem}.breakdown-category{font-size:1.125rem}}@media (max-width: 767px){.grade-display-container{padding:1rem}.grade-display-title{font-size:1.5rem;margin-bottom:1rem}.grade-display-main{padding:1.5rem 0;margin-bottom:1.5rem}.grade-display-score{font-size:2.5rem}.grade-display-percentage{font-size:1.25rem}.grade-display-target{padding:1rem;margin-bottom:1.5rem}.target-label{font-size:.9rem}.grade-display-motivation{font-size:1rem;padding:.75rem}.breakdown-title{font-size:1.125rem}.breakdown-stats{flex-direction:column;gap:.5rem;text-align:center;padding:.75rem}.breakdown-row{grid-template-columns:1fr;gap:.5rem;padding:.75rem}.breakdown-score{justify-content:space-between}.breakdown-icon{text-align:center}}.improvement-suggestions-container{padding:2rem;max-width:1200px;margin:0 auto}.improvement-title{font-size:1.75rem;font-weight:700;color:hsl(var(--primary));margin-bottom:2rem;text-align:center}.improvement-loading,.improvement-error{text-align:center;padding:3rem 2rem;font-size:1.125rem}.improvement-loading{color:hsl(var(--muted-foreground))}.improvement-error{color:hsl(var(--destructive))}.error-icon{font-size:2.5rem;display:block;margin-bottom:1rem}.improvement-empty{text-align:center;padding:3rem 2rem;background:hsl(var(--secondary));border-radius:12px}.empty-icon{font-size:4rem;display:block;margin-bottom:1rem}.improvement-empty p{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.5rem}.empty-subtitle{font-size:1rem!important;color:hsl(var(--muted-foreground))!important;font-weight:400!important}.weak-topics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.topic-card{background:#fff;border:1px solid hsl(var(--border));border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:all .3s ease;display:flex;flex-direction:column;gap:1rem}.topic-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.topic-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.5rem}.topic-name{font-size:1.25rem;font-weight:700;color:hsl(var(--foreground));flex:1;line-height:1.3}.category-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;white-space:nowrap}.badge-grammar{background:#dbeafe;color:#1e40af}.badge-reading{background:#fce7f3;color:#9f1239}.badge-writing{background:#fef3c7;color:#92400e}.badge-listening{background:#d1fae5;color:#065f46}.badge-default{background:hsl(var(--secondary));color:hsl(var(--foreground))}.topic-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.stat-item{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.875rem;color:hsl(var(--muted-foreground))}.stat-value{font-size:1.125rem;font-weight:700;color:hsl(var(--foreground))}.stat-value.accuracy-low{color:#ef4444}.stat-value.accuracy-medium{color:#f59e0b}.stat-value.accuracy-high{color:#10b981}.accuracy-bar-container{display:flex;align-items:center;gap:.75rem}.accuracy-bar{flex:1;height:10px;background:hsl(var(--border));border-radius:5px;overflow:hidden}.accuracy-bar-fill{height:100%;border-radius:5px;transition:width .5s ease-in-out}.accuracy-bar-fill.accuracy-low{background:linear-gradient(90deg,#ef4444,#dc2626)}.accuracy-bar-fill.accuracy-medium{background:linear-gradient(90deg,#f59e0b,#d97706)}.accuracy-bar-fill.accuracy-high{background:linear-gradient(90deg,#10b981,#059669)}.accuracy-bar-label{font-size:.875rem;font-weight:600;color:hsl(var(--muted-foreground));min-width:45px;text-align:right}.suggested-exercises{padding-top:.5rem;border-top:1px solid hsl(var(--border))}.suggested-title{font-size:.875rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.5rem}.exercise-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.exercise-item{font-size:.875rem}.exercise-link{color:hsl(var(--primary));text-decoration:none;transition:color .2s ease;display:flex;align-items:center;gap:.5rem}.exercise-link:before{content:"→";font-weight:700}.exercise-link:hover{color:hsl(var(--primary-hover));text-decoration:underline}.practice-button{width:100%;padding:.75rem 1.5rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.practice-button:hover{background:hsl(var(--primary-hover));transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.practice-button:active{transform:translateY(0)}.needs-more-data-section{background:#fef3c7;border:2px solid #fbbf24;border-radius:12px;padding:1.5rem;margin-top:2rem}.needs-more-data-title{font-size:1.25rem;font-weight:700;color:#92400e;margin-bottom:.75rem}.needs-more-data-subtitle{font-size:.95rem;color:#78350f;margin-bottom:1rem;line-height:1.5}.needs-more-data-tags{display:flex;flex-wrap:wrap;gap:.5rem}.data-tag{padding:.5rem 1rem;background:#fff;border:1px solid #fbbf24;border-radius:6px;font-size:.875rem;font-weight:600;color:#92400e}@media (min-width: 1024px){.improvement-suggestions-container{padding:3rem}.improvement-title{font-size:2.25rem}.weak-topics-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:2rem}.topic-card{padding:2rem}.topic-name{font-size:1.5rem}}@media (max-width: 767px){.improvement-suggestions-container{padding:1rem}.improvement-title{font-size:1.5rem;margin-bottom:1.5rem}.weak-topics-grid{grid-template-columns:1fr;gap:1rem}.topic-card{padding:1.25rem}.topic-card-header{flex-direction:column;align-items:flex-start}.topic-name{font-size:1.125rem}.category-badge{align-self:flex-start}.topic-stats{grid-template-columns:1fr;gap:.75rem}.needs-more-data-section{padding:1rem}.needs-more-data-title{font-size:1.125rem}.needs-more-data-subtitle{font-size:.875rem}.data-tag{font-size:.8rem;padding:.4rem .75rem}}.exercise-result-container{max-width:900px;margin:0 auto;padding:2rem}.exercise-result-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:60px;height:60px;border:4px solid hsl(var(--border));border-top-color:hsl(var(--primary));border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1.5rem}@keyframes spin{to{transform:rotate(360deg)}}.exercise-result-loading p{font-size:1.125rem;color:hsl(var(--muted-foreground))}.exercise-result-error{text-align:center;padding:3rem 2rem}.error-icon{font-size:3rem;display:block;margin-bottom:1rem}.exercise-result-error p{font-size:1.125rem;color:hsl(var(--destructive));margin-bottom:2rem}.back-button{padding:.75rem 2rem;background:hsl(var(--primary));color:hsl(var(--primary-foreground));border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.back-button:hover{background:hsl(var(--primary-hover))}.confetti-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);font-size:8rem;pointer-events:none;animation:confetti-pop 3s ease-out;z-index:1000}@keyframes confetti-pop{0%{transform:translate(-50%,-50%) scale(0);opacity:0}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}to{transform:translate(-50%,-50%) scale(1) translateY(-100px);opacity:0}}.result-banner{text-align:center;padding:2.5rem 2rem;border-radius:16px;margin-bottom:2rem;animation:slide-down .5s ease-out}@keyframes slide-down{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.result-banner.passed{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981}.result-banner.failed{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.banner-icon{font-size:4rem;margin-bottom:1rem;animation:bounce 1s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.banner-title{font-size:2rem;font-weight:800;margin-bottom:.5rem}.result-banner.passed .banner-title{color:#065f46}.result-banner.failed .banner-title{color:#92400e}.banner-subtitle{font-size:1.125rem;font-weight:500}.result-banner.passed .banner-subtitle{color:#047857}.result-banner.failed .banner-subtitle{color:#b45309}.result-info{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.section-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));flex:1}.category-badge,.info-badge{padding:.4rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:600}.category-badge{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.info-badge{background:#fef3c7;color:#92400e;border:1px solid #fbbf24}.overall-score-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem;background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;margin-bottom:2rem}.score-circle{position:relative;width:180px;height:180px}.score-circle-svg{transform:rotate(-90deg)}.score-circle-bg{stroke:hsl(var(--border))}.score-circle-fill{transition:stroke-dasharray 1s ease-out}.score-circle-fill.passed{stroke:#10b981}.score-circle-fill.failed{stroke:#f59e0b}.score-circle-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.score-value{font-size:3rem;font-weight:800;color:hsl(var(--foreground));line-height:1}.score-percent{font-size:1.5rem;color:hsl(var(--muted-foreground))}.passing-status{text-align:center}.status-text{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.status-text.passed{color:#10b981}.status-text.failed{color:#f59e0b}.target-text{font-size:1rem;color:hsl(var(--muted-foreground))}.breakdown-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem}.breakdown-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:1.5rem}.breakdown-item{margin-bottom:1.5rem}.breakdown-item:last-child{margin-bottom:0}.breakdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.breakdown-label{font-size:1.125rem;font-weight:600;color:hsl(var(--foreground))}.breakdown-score{font-size:1rem;font-weight:600;color:hsl(var(--muted-foreground))}.progress-bar{width:100%;height:32px;background:hsl(var(--border));border-radius:16px;overflow:hidden;position:relative}.progress-fill{height:100%;display:flex;align-items:center;justify-content:center;border-radius:16px;transition:width 1s ease-out;position:relative}.progress-fill.mc{background:linear-gradient(90deg,#3b82f6,#2563eb)}.progress-fill.fitb{background:linear-gradient(90deg,#8b5cf6,#7c3aed)}.progress-fill.open-end{background:linear-gradient(90deg,#ec4899,#db2777)}.progress-text{color:#fff;font-weight:700;font-size:.875rem;text-shadow:0 1px 2px rgba(0,0,0,.3)}.next-steps-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem}.next-steps-title{font-size:1.5rem;font-weight:700;color:hsl(var(--foreground));margin-bottom:1.5rem}.next-steps-buttons{display:flex;flex-direction:column;gap:1rem}.next-step-button{padding:1rem 1.5rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:left}.next-step-button.primary{background:hsl(var(--primary));color:hsl(var(--primary-foreground))}.next-step-button.primary:hover{background:hsl(var(--primary-hover));transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.next-step-button.secondary{background:hsl(var(--secondary));color:hsl(var(--foreground));border:1px solid hsl(var(--border))}.next-step-button.secondary:hover{background:hsl(var(--border));transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.submission-info{text-align:center;padding:1rem;color:hsl(var(--muted-foreground));font-size:.875rem}@media (min-width: 1024px){.exercise-result-container{padding:3rem;max-width:1000px}.result-banner{padding:3rem 2rem}.banner-icon{font-size:5rem}.banner-title{font-size:2.5rem}.score-circle{width:220px;height:220px}.score-value{font-size:3.5rem}.next-steps-buttons{flex-direction:row}.next-step-button{flex:1;text-align:center}}@media (max-width: 767px){.exercise-result-container{padding:1rem}.result-banner{padding:1.5rem 1rem}.banner-icon{font-size:3rem}.banner-title{font-size:1.5rem}.banner-subtitle{font-size:1rem}.section-title{font-size:1.25rem;width:100%}.result-info{gap:.75rem}.overall-score-section{padding:1.5rem 1rem}.score-circle{width:150px;height:150px}.score-value{font-size:2.5rem}.score-percent,.status-text{font-size:1.25rem}.breakdown-section,.next-steps-section{padding:1.5rem 1rem}.breakdown-title,.next-steps-title{font-size:1.25rem}.breakdown-header{flex-direction:column;align-items:flex-start;gap:.5rem}.progress-bar{height:28px}.progress-text{font-size:.75rem}}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 220 85% 25%;--primary-foreground: 0 0% 98%;--primary-hover: 220 85% 20%;--secondary: 220 14% 96%;--secondary-foreground: 220 85% 25%;--muted: 220 14% 96%;--muted-foreground: 220 8.9% 46.1%;--accent: 197 71% 73%;--accent-foreground: 220 85% 25%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 220 13% 91%;--input: 220 13% 91%;--ring: 220 85% 25%;--header-bg: 0 0% 100%;--header-topbar: 220 85% 25%;--header-nav: 220 14% 96%;--header-search: 0 0% 97%;--education-blue: 220 85% 25%;--education-blue-light: 220 85% 35%;--education-teal: 197 71% 73%;--education-gray: 220 8.9% 46.1%;--radius: .5rem;--sidebar-background: 0 0% 98%;--sidebar-foreground: 240 5.3% 26.1%;--sidebar-primary: 240 5.9% 10%;--sidebar-primary-foreground: 0 0% 98%;--sidebar-accent: 240 4.8% 95.9%;--sidebar-accent-foreground: 240 5.9% 10%;--sidebar-border: 220 13% 91%;--sidebar-ring: 217.2 91.2% 59.8%}.dark{--background: 220 26% 14%;--foreground: 0 0% 98%;--card: 220 26% 14%;--card-foreground: 0 0% 98%;--popover: 220 26% 14%;--popover-foreground: 0 0% 98%;--primary: 220 91% 35%;--primary-foreground: 0 0% 98%;--primary-hover: 220 91% 40%;--secondary: 220 20% 20%;--secondary-foreground: 0 0% 98%;--muted: 220 20% 20%;--muted-foreground: 220 13% 65%;--accent: 197 71% 60%;--accent-foreground: 0 0% 98%;--destructive: 0 62.8% 30.6%;--destructive-foreground: 0 0% 98%;--border: 220 20% 20%;--input: 220 20% 20%;--ring: 220 91% 35%;--header-bg: 220 26% 14%;--header-topbar: 220 91% 15%;--header-nav: 220 20% 20%;--header-search: 220 20% 18%;--sidebar-background: 240 5.9% 10%;--sidebar-foreground: 240 4.8% 95.9%;--sidebar-primary: 224.3 76.3% 48%;--sidebar-primary-foreground: 0 0% 100%;--sidebar-accent: 240 3.7% 15.9%;--sidebar-accent-foreground: 240 4.8% 95.9%;--sidebar-border: 240 3.7% 15.9%;--sidebar-ring: 217.2 91.2% 59.8%}body{background-color:hsl(var(--background));color:hsl(var(--foreground));font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;line-height:1.5}.h-full{height:100%}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.space-x-2>*+*{margin-left:.5rem}.space-x-4>*+*{margin-left:1rem}.space-x-8>*+*{margin-left:2rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-16{padding-top:4rem;padding-bottom:4rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-3{margin-left:.75rem}.mr-4{margin-right:1rem}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-semibold{font-weight:600}.bg-background{background-color:hsl(var(--background))}.bg-header-search{background-color:hsl(var(--header-search))}.h-5{height:1.25rem}.h-9{height:2.25rem}.w-5{width:1.25rem}.pl-10{padding-left:2.5rem}.pr-4{padding-right:1rem}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.gap-4{gap:1rem}.gap-8{gap:2rem}@media (min-width: 640px){.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.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:all .15s;border:1px solid transparent;cursor:pointer;outline:none}.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));box-shadow:0 1px 2px #0000000d}.btn-default:hover{background-color:hsl(var(--primary-hover))}.btn-destructive{background-color:hsl(var(--destructive));color:hsl(var(--destructive-foreground));box-shadow:0 1px 2px #0000000d}.btn-destructive:hover{background-color:hsl(var(--destructive) / .9)}.btn-outline{border:1px solid hsl(var(--border));background-color:hsl(var(--background));box-shadow:0 1px 2px #0000000d}.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));box-shadow:0 1px 2px #0000000d}.btn-secondary:hover{background-color:hsl(var(--secondary) / .8)}.btn-ghost{background-color:transparent}.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;background-color:transparent}.btn-link:hover{text-decoration:none}.btn-default{height:2.25rem;padding:.5rem 1rem}.btn-sm{height:2rem;padding:.375rem .75rem;gap:.375rem}.btn-lg{height:2.5rem;padding:.5rem 1.5rem}.btn-icon{width:2.25rem;height:2.25rem;padding:0}.input{display:flex;height:2.25rem;width:100%;min-width:0;border-radius:.375rem;border:1px solid hsl(var(--border));background-color:transparent;padding:.25rem .75rem;font-size:.875rem;box-shadow:0 1px 2px #0000000d;transition:color,box-shadow .15s;outline:none}.input:focus-visible{border-color:hsl(var(--ring));box-shadow:0 0 0 3px hsl(var(--ring) / .5)}.input:disabled{pointer-events:none;cursor:not-allowed;opacity:.5}.input::placeholder{color:hsl(var(--muted-foreground))}.input::selection{background-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}@media (min-width: 768px){.input{font-size:.875rem}}.card{background-color:hsl(var(--card));color:hsl(var(--card-foreground));border-radius:.5rem;border:1px solid hsl(var(--border));box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.bg-blue-600{background-color:#2563eb}.bg-blue-700{background-color:#1d4ed8}.bg-green-600{background-color:#16a34a}.bg-green-700{background-color:#15803d}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-blue-600{color:#2563eb}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000001a}.hover\:bg-blue-700:hover{background-color:#1d4ed8}.hover\:bg-green-700:hover{background-color:#15803d}.hover\:bg-education-blue-light:hover{background-color:hsl(var(--education-blue-light))}.mb-2{margin-bottom:.5rem}.mt-5,.md\:mt-5{margin-top:1.25rem}.md\:mt-8{margin-top:2rem}.max-w-3xl{max-width:48rem}@media (min-width: 640px){.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:flex{display:flex}.sm\:justify-center{justify-content:center}}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:py-4{padding-top:1rem;padding-bottom:1rem}.md\:px-10{padding-left:2.5rem;padding-right:2.5rem}.md\:max-w-3xl{max-width:48rem}}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:0}.top-0{top:0}.left-0{left:0}.right-0{right:0}.bottom-0{bottom:0}.top-4{top:1rem}.right-4{right:1rem}.left-4{left:1rem}.bottom-4{bottom:1rem}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.hidden{display:none}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.object-cover{object-fit:cover}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.translate-x-0{transform:translate(0)}.translate-x-full{transform:translate(100%)}.-translate-x-full{transform:translate(-100%)}.translate-y-0{transform:translateY(0)}.translate-y-full{transform:translateY(100%)}.-translate-y-full{transform:translateY(-100%)}.scale-75{transform:scale(.75)}.scale-100{transform:scale(1)}.scale-105{transform:scale(1.05)}.scale-110{transform:scale(1.1)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-sm{filter:blur(4px)}.brightness-50{filter:brightness(.5)}.brightness-75{filter:brightness(.75)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-75{transition-duration:75ms}.duration-100{transition-duration:.1s}.duration-150{transition-duration:.15s}.duration-300{transition-duration:.3s}.duration-700{transition-duration:.7s}.duration-1000{transition-duration:1s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.h-\[400px\]{height:400px}.h-\[600px\]{height:600px}.h-\[800px\]{height:800px}.m-auto{margin:auto}.group{position:relative}.group:hover .group-hover\:block{display:block}.group-hover\:block{display:none}.top-\[50\%\]{top:50%}.left-5{left:1.25rem}.right-5{right:1.25rem}.bottom-5{bottom:1.25rem}.-translate-y-1\/2{transform:translateY(-50%)}.text-2xl{font-size:1.5rem;line-height:2rem}.rounded-full{border-radius:9999px}.bg-black\/20{background-color:#0003}.bg-black\/40{background-color:#0006}.text-white\/50{color:#ffffff80}.text-white\/75{color:#ffffffbf}.hover\:bg-black\/40:hover{background-color:#0006}.hover\:text-white\/75:hover{color:#ffffffbf}.bg-center{background-position:center}.bg-cover{background-size:cover}.mx-1{margin-left:.25rem;margin-right:.25rem}@media (min-width: 768px){.md\:h-\[600px\]{height:600px}}@media (min-width: 1024px){.lg\:h-\[800px\]{height:800px}}.stroke-\[1\.5\]{stroke-width:1.5}svg{display:block}[role=img]{display:block}.group:hover .hidden{display:none}.group:hover .group-hover\:block{display:block!important}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-500{transition-duration:.5s}.relative{position:relative;z-index:1}.absolute{position:absolute}.min-h-screen{min-height:100vh}.h-8{height:2rem}.w-8{width:2rem}.rounded-full{border-radius:50%}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.border-education-blue{border-color:hsl(var(--education-blue))}.flex-center{display:flex;align-items:center;justify-content:center}.col-6{flex:0 0 50%;max-width:50%}.row{display:flex;flex-wrap:wrap;margin-right:-15px;margin-left:-15px}.form-widget{max-width:400px;margin:0 auto;padding:2rem;background:hsl(var(--card));border-radius:var(--radius);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.form-widget h1.header{font-size:2rem;font-weight:700;margin-bottom:1rem;color:hsl(var(--foreground));text-align:center}.form-widget p.description{color:hsl(var(--muted-foreground));margin-bottom:1.5rem;text-align:center}.form-widget>div{margin-bottom:1rem}.form-widget label{display:block;font-weight:500;margin-bottom:.5rem;color:hsl(var(--foreground))}.inputField{width:100%;padding:.75rem;border:1px solid hsl(var(--border));border-radius:var(--radius);background-color:hsl(var(--background));color:hsl(var(--foreground));font-size:.875rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.inputField:focus{outline:none;border-color:hsl(var(--ring));box-shadow:0 0 0 2px hsl(var(--ring) / .2)}.inputField::placeholder{color:hsl(var(--muted-foreground))}.button{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .15s ease-in-out;background-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.button:hover{background-color:hsl(var(--primary-hover))}.button:disabled{opacity:.5;cursor:not-allowed}.button.block{width:100%}.button.primary{background-color:hsl(var(--primary));color:hsl(var(--primary-foreground))}.button.primary:hover{background-color:hsl(var(--primary-hover))}.loading-spinner{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner .spinner{width:2rem;height:2rem;border:2px solid transparent;border-bottom:2px solid hsl(var(--education-blue));border-radius:50%;animation:spin 1s linear infinite}.w-full{width:100%}.shadow-sm{box-shadow:0 1px 2px #0000000d}.bg-header-bg{background-color:hsl(var(--header-bg))}.bg-header-topbar{background-color:hsl(var(--header-topbar))}.bg-header-nav{background-color:hsl(var(--header-nav))}.text-white{color:#fff}.max-w-7xl{max-width:80rem}.mx-auto{margin-left:auto;margin-right:auto}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.h-6{height:1.5rem}.h-16{height:4rem}.h-3{height:.75rem}.w-3{width:.75rem}.w-6{width:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.space-x-1>*+*{margin-left:.25rem}.mr-1{margin-right:.25rem}.border-b{border-bottom-width:1px}.border-border{border-color:hsl(var(--border))}.flex-shrink-0{flex-shrink:0}.text-lg{font-size:1.125rem;line-height:1.75rem}.font-bold{font-weight:700}.text-education-blue{color:hsl(var(--education-blue))}.text-education-gray{color:hsl(var(--education-gray))}.leading-none{line-height:1}.max-w-md{max-width:28rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x, 0),var(--tw-translate-y)) rotate(var(--tw-rotate, 0)) skew(var(--tw-skew-x, 0)) skewY(var(--tw-skew-y, 0)) scaleX(var(--tw-scale-x, 1)) scaleY(var(--tw-scale-y, 1))}.left-3{left:.75rem}.top-1\/2{top:50%}.h-4{height:1rem}.w-4{width:1rem}.h-10{height:2.5rem}.w-auto{width:auto}.min-w-\[32px\]{min-width:32px}.max-w-\[120px\]{max-width:120px}.object-contain{object-fit:contain}.flex-1{flex:1 1 0%}.font-medium{font-weight:500}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.border-b-2{border-bottom-width:2px}.hover\:border-education-blue:hover{border-color:hsl(var(--education-blue))}.hover\:text-education-blue:hover{color:hsl(var(--education-blue))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}@media (min-width: 640px){.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:flex{display:flex}.sm\:justify-center{justify-content:center}}@media (min-width: 768px){.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:mt-5{margin-top:1.25rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:max-w-3xl{max-width:48rem}.md\:mt-8{margin-top:2rem}.md\:py-4{padding-top:1rem;padding-bottom:1rem}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:px-10{padding-left:2.5rem;padding-right:2.5rem}}@media (min-width: 1024px){.lg\:px-8{padding-left:2rem;padding-right:2rem}}.h-auto{height:auto}.py-12{padding-top:3rem;padding-bottom:3rem}.text-center{text-align:center}.text-4xl{font-size:2.25rem;line-height:2.5rem}.mt-3{margin-top:.75rem}.mt-5{margin-top:1.25rem}.rounded-md{border-radius:.375rem}.shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.px-8{padding-left:2rem;padding-right:2rem}.border{border-width:1px}.border-transparent{border-color:transparent}.bg-education-blue{background-color:hsl(var(--education-blue))}.bg-education-blue-light,.hover\:bg-education-blue-light:hover{background-color:hsl(var(--education-blue-light))}.hero-section{width:100%}.hero-content{max-width:80rem;margin:0 auto;padding:0 1rem 3rem}.hero-title{font-size:2.25rem;font-weight:700;color:hsl(var(--education-blue));line-height:2.5rem}.hero-description{margin-top:.75rem;max-width:28rem;margin-left:auto;margin-right:auto;font-size:1rem;line-height:1.5rem;color:hsl(var(--education-gray))}.hero-cta{margin-top:1.25rem;max-width:28rem;margin-left:auto;margin-right:auto}.cta-button{width:100%;display:flex;align-items:center;justify-content:center;padding:.75rem 2rem;border:1px solid transparent;font-size:1rem;font-weight:500;border-radius:.375rem;color:#fff;background-color:hsl(var(--education-blue));text-decoration:none;transition:background-color .15s ease-in-out}.cta-button:hover{background-color:hsl(var(--education-blue-light))}@media (min-width: 640px){.hero-content{padding-left:1.5rem;padding-right:1.5rem}.hero-title{font-size:3rem;line-height:1}.hero-description{font-size:1.125rem;line-height:1.75rem}.hero-cta{display:flex;justify-content:center}}@media (min-width: 768px){.hero-title{font-size:3.75rem;line-height:1}.hero-description{margin-top:1.25rem;font-size:1.25rem;line-height:1.75rem;max-width:48rem}.hero-cta{margin-top:2rem}.cta-button{padding:1rem 2.5rem;font-size:1.125rem;line-height:1.75rem}}@media (min-width: 1024px){.hero-content{padding-left:2rem;padding-right:2rem}}.h-64{height:16rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.mb-8{margin-bottom:2rem}.grid{display:grid}.gap-6{gap:1.5rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.bg-white{background-color:#fff}.rounded-lg{border-radius:.5rem}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.shadow-lg,.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.bg-red-100{background-color:#fee2e2}.border-red-400{border-color:#f87171}.text-red-700{color:#b91c1c}.rounded{border-radius:.25rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.min-w-32{min-width:32px}.max-w-120{max-width:120px}
