:root{--color-header-bg: #ffffff;--color-header-topbar: hsl(var(--brand-blue, 220 80% 24%));--color-header-nav: hsl(var(--brand-grey, 0 8% 95%));--color-education-blue: hsl(var(--brand-blue, 220 80% 24%));--color-education-gray: #64748b;--color-border: #e5e7eb;--color-text: hsl(var(--brand-blue, 220 80% 24%));--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;padding-top:10px;padding-bottom:10px}.header-topbar-row{display:flex;align-items:center;justify-content:flex-end;height:48px;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:170px;width:100%}.logo-link{display:flex;align-items:center;gap:.5rem;flex-shrink:0;text-decoration:none}.logo-image{height: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{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}.header-spacer{flex-shrink:0;width:1.5rem}.header-nav{border-bottom:1px solid var(--color-border);background-color:var(--color-header-nav)}.main-nav{display:flex;align-items:center;height:100%;gap:2.5rem}.nav-placeholder{height:60px;width:100%}.nav-link{display:flex;align-items:center;height:100%;padding:0 .25rem;text-decoration:none;font-size:1rem;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)}.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}.main-nav{gap:.75rem;overflow-x:auto}.logo-image{min-width:6rem}}.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}.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;border:none;cursor:pointer}.lesson-list-card-button:hover{background:#08255e}.lesson-list-purchase-button{background:#21c45d}.lesson-list-purchase-button:hover{background:#1a9948}@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}}.avatar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;display:flex;align-items:center;justify-content:center;cursor:pointer;animation:avatar-overlay-fade-in .3s ease-in}@keyframes avatar-overlay-fade-in{0%{opacity:0}to{opacity:1}}.avatar-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;pointer-events:none}.avatar-container{position:relative;display:flex;flex-direction:row-reverse;align-items:flex-start;gap:0;max-width:800px;padding:32px;z-index:10000;pointer-events:none}.avatar-dialogue-wrapper{flex:1;display:flex;flex-direction:column;z-index:2}.avatar-dialogue-box{background-image:url(/dialogue-bubble.png);background-size:100% 100%;background-repeat:no-repeat;background-position:center;padding:40px 55px 120px 45px;min-height:280px;max-height:350px;width:400px;position:relative;animation:avatar-dialogue-slide-up .4s ease-out}@keyframes avatar-dialogue-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.avatar-dialogue-content{width:100%;height:100%;overflow:hidden;position:relative}.avatar-welcome-scroll-container{position:relative;height:200px;overflow:hidden;mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%)}.avatar-welcome-scroll-text{animation:avatar-scroll-up 35s linear forwards;padding-top:0;padding-bottom:50px}@keyframes avatar-scroll-up{0%{transform:translateY(0)}to{transform:translateY(calc(-100% + 200px))}}.avatar-welcome-paragraph{font-size:1.5em;font-weight:700;line-height:1.8;color:hsl(var(--brand-teal));margin:0 0 1.5em;text-align:left}.avatar-feedback-text{font-size:1.5em;font-weight:700;line-height:1.7;color:hsl(var(--brand-teal));margin:0;text-align:left}.avatar-video-container{flex-shrink:0;width:400px;height:400px;display:flex;align-items:center;justify-content:center;animation:avatar-bounce .6s cubic-bezier(.68,-.55,.265,1.55);margin-top:100px;margin-right:-40px;z-index:1}@keyframes avatar-bounce{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.avatar-video{width:100%;height:100%;object-fit:cover}.avatar-loading{display:flex;align-items:center;justify-content:center}.avatar-loading-spinner{width:50px;height:50px;border:5px solid hsl(var(--brand-teal) / .3);border-top-color:hsl(var(--brand-teal));border-radius:50%;animation:avatar-spin 1s linear infinite}@keyframes avatar-spin{to{transform:rotate(360deg)}}.avatar-click-hint{position:fixed;bottom:40px;left:50%;transform:translate(-50%);color:#fffc;font-size:.95em;z-index:10001;animation:avatar-hint-pulse 2s ease-in-out infinite;pointer-events:none}@keyframes avatar-hint-pulse{0%,to{opacity:.6}50%{opacity:1}}@media (max-width: 768px){.avatar-container{flex-direction:column;align-items:center;max-width:90%;padding:20px}.avatar-dialogue-box{background-image:none;background:#fff;border-radius:20px;padding:24px 28px;box-shadow:0 8px 24px #0003;min-height:200px;max-height:300px;width:100%}.avatar-welcome-scroll-container{height:160px}.avatar-welcome-paragraph{font-size:.95em}.avatar-feedback-text{font-size:1em}.avatar-video-container{width:160px;height:160px;margin-top:20px;margin-left:0;margin-right:0}.avatar-click-hint{bottom:20px;font-size:.85em}}.breadcrumb-container{width:100%;background-color:transparent;padding:12px 0}.breadcrumb-inner{max-width:80rem;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}@media (min-width: 640px){.breadcrumb-inner{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.breadcrumb-inner{padding-left:2rem;padding-right:2rem}}.breadcrumb-list{display:flex;flex-wrap:wrap;align-items:center;list-style:none;margin:0;padding:0;gap:0}.breadcrumb-item{display:flex;align-items:center;font-size:.875rem;line-height:1.25rem}.breadcrumb-link{color:#0c2f6d;text-decoration:none;transition:color .15s ease}.breadcrumb-link:hover{color:#1e40af;text-decoration:underline}.breadcrumb-separator{margin:0 8px;color:#94a3b8;font-weight:400}.breadcrumb-current{color:#64748b;font-weight:500}.with-left-menu .breadcrumb-inner{padding-left:calc(72px + 2rem)}@media (max-width: 768px){.breadcrumb-container{padding:8px 0}.breadcrumb-item{font-size:.75rem}.breadcrumb-separator{margin:0 4px}.with-left-menu .breadcrumb-inner{padding-left:1rem}}.lesson-detail-container{justify-content:left;display:flex;flex-direction:column}.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;width:80%;align-self:center}.lesson-detail-title{font-size:1.25rem;font-weight:800;color:hsl(var(--brand-blue));text-align:center}.lesson-detail-subheader{font-size:1.5rem;color:hsl(var(--brand-red));font-weight:800;margin-top:.5rem;text-align:center}.lesson-detail-grade-card{width:80%;align-self:center;margin-bottom:1.5rem;background:linear-gradient(to right,#f0f5ff,#f0f0ff);border:2px solid hsl(220 100% 90%);border-radius:.5rem;padding:1.5rem}.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}.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{width:80%;align-self:center;display:flex;flex-direction:column;gap:1rem}.lesson-detail-section-card{background:hsl(var(--card));border-radius:.5rem;padding:1.5rem}.lesson-detail-section-inner{display:flex;align-items:stretch;justify-content:space-between;gap:1.5rem}.lesson-detail-section-content{flex:1;display:flex;flex-direction:column}.lesson-detail-section-header{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:.5rem;margin-left:1rem;flex:1;justify-content:center}.lesson-detail-section-icon{font-size:1.5rem;margin-right:.75rem}.lesson-detail-section-line1{font-size:1.25rem;font-weight:800;color:hsl(var(--brand-blue));margin-bottom:1rem}.lesson-detail-section-title{font-size:2rem;font-weight:800;color:hsl(var(--brand-blue))}.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-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,.lesson-detail-section-progress-item-label--best,.lesson-detail-section-progress-item-label--attempts,.lesson-detail-section-progress-item-label--completed{color:hsl(var(--education-blue))}.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:0;align-self:flex-end;display:flex;flex-direction:row;gap:.5rem}.lesson-detail-section-button{display:block;background:hsl(var(--education-teal, 178 54% 48%));color:hsl(var(--primary-foreground));padding:.75rem 1.5rem;border-radius:.5rem;text-decoration:none;transition:all .2s;font-weight:500;text-align:center;min-width:140px}.lesson-detail-section-button:hover{background:#2d9592}.lesson-banner{width:80%;align-self:center;margin-bottom:2rem;overflow:hidden;max-height:400px}.lesson-banner-image{width:100%;height:100%;object-fit:cover}.lesson-detail-section-image-wrapper{flex-shrink:0;width:200px;border-radius:.5rem;overflow:hidden}.lesson-detail-section-image{width:100%;height:auto;display:block}@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:1rem}.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%}.lesson-detail-header,.lesson-detail-grade-card,.lesson-detail-sections{width:95%}.lesson-detail-section-image-wrapper{width:100%;height:auto;margin-bottom:1rem}}.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}}.exercise-content-page{min-height:100vh;background:hsl(var(--background));border:none}.exercise-content-header-section{max-width:56rem;margin:0 auto;padding:1.5rem 0}.exercise-content-lesson-title{font-size:1.75rem;font-weight:800;color:hsl(var(--brand-blue));margin:0 0 .75rem;line-height:1.3;text-align:center;padding:0 1rem}.exercise-content-section-title-header{font-size:1.75rem;font-weight:800;color:hsl(var(--brand-blue));margin:0;line-height:1.4;text-align:left;padding:0}@media (min-width: 1024px){.exercise-content-section-title-header{padding-left:1.5rem}}@media (max-width: 767px){.exercise-content-header-section{padding:1rem 0}.exercise-content-lesson-title{font-size:1.5rem}.exercise-content-section-title-header{font-size:1.125rem;padding-left:.75rem;padding-right:.75rem}}@media (max-width: 480px){.exercise-content-lesson-title{font-size:1.25rem}.exercise-content-section-title-header{font-size:1rem}}.exercise-content-header{background:hsl(var(--card));box-shadow:none;border-bottom:none;padding:1.5rem 24px;max-width:56rem;margin:0 auto}.exercise-content-header .exercise-content-title{font-size:1.5rem;font-weight:600;color:hsl(var(--foreground));margin-bottom:.5rem}.exercise-content-description{color:hsl(var(--muted-foreground));font-size:.875rem}.unified-exercise-page{display:flex;flex-direction:column;gap:2rem}.video-section{background:hsl(var(--card));border-radius:.5rem;padding:0;box-shadow:none}.start-exercise-button-wrapper{display:flex;justify-content:flex-end;padding:0 .5rem;margin-top:-1rem}.start-exercise-button{background:hsl(var(--brand-teal));color:#fff;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600;border-radius:.5rem;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0000001a}.start-exercise-button:hover:not(:disabled){background:hsl(var(--brand-teal) / .85);box-shadow:0 6px 8px #00000026;transform:translateY(-1px)}.start-exercise-button:active:not(:disabled){transform:translateY(1px);box-shadow:0 2px 4px #0000001a}.start-exercise-button.pressed{background:hsl(var(--brand-teal) / .7);cursor:default;box-shadow:inset 0 2px 4px #0003;transform:translateY(1px)}.start-exercise-button:disabled{cursor:default}.materials-section{background:hsl(var(--card));border-radius:.5rem;padding:1.5rem;box-shadow:none}.materials-section .section-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:hsl(var(--foreground))}.exercise-section{background:hsl(var(--card));border-radius:.5rem;padding:0;box-shadow:none}.exercise-content-loading,.exercise-content-error,.exercise-content-empty{display:flex;align-items:center;justify-content:center;min-height:100vh}.exercise-content-state-inner{text-align:center}.exercise-content-spinner{display:inline-block;width:3rem;height:3rem;border:2px solid hsl(var(--border));border-top-color:hsl(var(--education-blue));border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.exercise-content-error-icon{color:hsl(var(--destructive));font-size:1.25rem;margin-bottom:1rem}.exercise-content-state-text{color:hsl(var(--muted-foreground))}.exercise-content-progress-bar{background:hsl(var(--card));box-shadow:none;border-bottom:1px solid hsl(var(--border))}.exercise-content-progress-inner{max-width:56rem;margin:0 auto;padding:1rem}.exercise-content-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.exercise-content-title{font-size:1.25rem;font-weight:600;color:hsl(var(--foreground))}.exercise-content-step-indicator{font-size:.875rem;color:hsl(var(--muted-foreground))}.exercise-content-progress-track{width:100%;background:hsl(var(--secondary));border-radius:9999px;height:.5rem}.exercise-content-progress-fill{background:hsl(var(--education-blue));height:.5rem;border-radius:9999px;transition:width .3s ease}.exercise-content-step-titles{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:hsl(var(--muted-foreground))}.exercise-content-step-title{color:hsl(var(--muted-foreground))}.exercise-content-step-title--active{color:hsl(var(--education-blue));font-weight:500}.exercise-content-main{max-width:56rem;margin:0 auto;padding:1.5rem 0}.exercise-content-card{background:hsl(var(--card));border-radius:.5rem;box-shadow:none;border:none;padding:1.5rem}.exercise-content-section-title{font-size:1.125rem;font-weight:500;color:hsl(var(--foreground));margin-bottom:1rem}.exercise-content-nav{display:flex;justify-content:space-between;margin-top:1.5rem}.exercise-content-nav-button{padding:.5rem 1rem;border-radius:.5rem;font-weight:500;border:none;cursor:pointer;transition:background-color .2s}.exercise-content-nav-button--secondary{background:hsl(var(--secondary));color:hsl(var(--foreground))}.exercise-content-nav-button--secondary:hover{background:#e2e4e9}.exercise-content-nav-button--primary{background:hsl(var(--education-blue));color:hsl(var(--primary-foreground))}.exercise-content-nav-button--primary:hover{background:#08255e}.exercise-content-nav-button--disabled{background:hsl(var(--secondary));color:hsl(var(--muted-foreground));cursor:not-allowed;opacity:.6}.exercise-content-nav-button--disabled:hover{background:hsl(var(--secondary))}.materials-container{display:flex;flex-direction:column;gap:1.5rem}.material-card{border:1px solid hsl(var(--border));border-radius:.5rem;padding:1.5rem;background:hsl(var(--muted))}.material-card-title{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:hsl(var(--foreground))}.material-card-content{max-width:100%;line-height:1.75;color:hsl(var(--foreground));max-height:450px;overflow-y:auto;padding-right:.5rem}.material-card-content::-webkit-scrollbar{width:10px}.material-card-content::-webkit-scrollbar-track{background:#e6e6e6;border-radius:.5rem}.material-card-content::-webkit-scrollbar-thumb{background:#999;border-radius:5px}.material-card-content::-webkit-scrollbar-thumb:hover{background:gray}.exercise-description{margin-bottom:1.5rem;padding:1rem;background:#f0f5ff;border-radius:.5rem}.exercise-description-text{color:#083691}.exercise-grammar-info{margin-bottom:1rem;padding:1rem;background:#f0f5ff;border:1px solid hsl(220 100% 90%);border-radius:.5rem}.exercise-grammar-info-content{display:flex;align-items:flex-start;gap:.5rem}.exercise-grammar-info-icon{width:1.25rem;height:1.25rem;color:hsl(var(--education-blue));margin-top:.125rem;flex-shrink:0}.exercise-grammar-info-text{flex:1}.exercise-grammar-info-title{font-size:.875rem;color:#083691;font-weight:500}.exercise-grammar-info-description{font-size:.75rem;color:#1241a1;margin-top:.25rem}.exercise-grammar-info-retry{font-size:.75rem;color:hsl(var(--education-blue));margin-top:.25rem;font-style:italic}.exercise-materials{margin-bottom:2rem}.exercise-materials-title,.exercise-questions-title{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:hsl(var(--foreground))}.exercise-questions-list{display:flex;flex-direction:column;gap:1.5rem}.exercise-question-card{border:1px solid hsl(var(--border));border-radius:.5rem;padding:1rem}.exercise-question-content{display:flex;align-items:flex-start;margin-bottom:1rem}.exercise-question-label{font-weight:600;color:hsl(var(--foreground));font-size:1rem;margin-right:.5rem;flex-shrink:0;line-height:1.5}.exercise-question-text{color:hsl(var(--foreground));flex:1;line-height:1.5}.exercise-question-options{display:flex;flex-direction:column;gap:.5rem}.exercise-question-option-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:.25rem;transition:background-color .2s,color .2s}.exercise-question-option-label:hover{background-color:hsl(var(--secondary))}.exercise-question-option-label.selected{color:hsl(var(--brand-blue));background-color:hsl(var(--brand-blue) / .05)}.exercise-question-option-letter{font-weight:600;color:hsl(var(--foreground));min-width:1.5rem}.exercise-question-option-label.selected .exercise-question-option-letter{color:hsl(var(--brand-blue))}.exercise-question-radio{accent-color:hsl(var(--brand-blue));width:1.125rem;height:1.125rem}.exercise-question-input{width:100%;padding:.5rem .75rem;border:1px solid hsl(var(--border));border-radius:.5rem;transition:border-color .2s,box-shadow .2s}.exercise-question-input:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px hsl(var(--education-blue))}.exercise-question-textarea{width:100%;padding:.5rem .75rem;border:1px solid hsl(var(--border));border-radius:.5rem;transition:border-color .2s,box-shadow .2s;resize:vertical}.exercise-question-textarea:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px hsl(var(--education-blue))}.exercise-question-word-counter{font-size:.875rem;color:hsl(var(--muted-foreground));margin-bottom:.5rem}.exercise-questions-empty{color:hsl(var(--muted-foreground));text-align:center;padding:2rem 0}.exercise-questions-parts{display:flex;flex-direction:column;gap:1.5rem}.question-part{display:flex;flex-direction:column}.question-part-header{width:100%;background:hsl(var(--primary));color:hsl(var(--primary-foreground));padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;border:none;cursor:pointer;transition:background-color .2s;border-radius:.5rem .5rem 0 0}.question-part-header:hover{background:hsl(var(--primary-hover))}.question-part-header.locked{background:hsl(var(--primary) / .6);cursor:not-allowed;opacity:.7}.question-part-header.locked:hover{background:hsl(var(--primary) / .6)}.question-part-title{font-size:1.125rem;font-weight:600;color:hsl(var(--primary-foreground))}.question-part-toggle-icon{width:1.5rem;height:1.5rem;transition:transform .2s;flex-shrink:0}.question-part-toggle-icon.expanded{transform:rotate(180deg)}.question-part-content{border:6px solid hsl(var(--primary));border-top:none;border-radius:0 0 .5rem .5rem}.question-part-scrollable{max-height:450px;overflow-y:auto;padding:1rem;background:hsl(var(--card))}.question-part-scrollable::-webkit-scrollbar{width:10px}.question-part-scrollable::-webkit-scrollbar-track{background:#e6e6e6;border-radius:0 0 .5rem}.question-part-scrollable::-webkit-scrollbar-thumb{background:#999;border-radius:5px}.question-part-scrollable::-webkit-scrollbar-thumb:hover{background:gray}.question-part-scrollable .exercise-question-card{margin-bottom:1.5rem}.question-part-scrollable .exercise-question-card:last-child{margin-bottom:0}.exercise-submit-section{background:hsl(var(--card));border-radius:.5rem;padding:0;box-shadow:none;margin-top:0}.save-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem;margin-bottom:1rem;padding:.5rem;border-radius:.375rem}.save-status.saving{color:hsl(var(--education-blue));background:hsl(var(--education-blue) / .1)}.save-status.saved{color:#21c45d;background:#21c45d1a}.save-status.error{color:#ef4343;background:#ef43431a}.spinner{display:inline-block;width:1rem;height:1rem;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.exercise-submit-button{width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:hsl(var(--brand-teal));border:none;border-radius:.5rem;cursor:pointer;transition:all .2s ease-in-out}.exercise-submit-button:hover:not(.disabled){background:hsl(var(--brand-teal) / .9);transform:translateY(-1px);box-shadow:none}.exercise-submit-button:active:not(.disabled){transform:translateY(0)}.exercise-submit-button.disabled{background:hsl(var(--muted));color:hsl(var(--muted-foreground));cursor:not-allowed}@media (min-width: 1024px){.exercise-content-title{font-size:1.5rem}.exercise-content-main{padding:1.5rem}.exercise-content-card{padding:2rem}}@media (max-width: 767px){.exercise-content-progress-inner{padding:.75rem}.exercise-content-title{font-size:1rem}.exercise-content-step-indicator{font-size:.75rem}.exercise-content-step-titles{font-size:.625rem}.exercise-content-main{padding:1rem .75rem}.exercise-content-card{padding:1rem}.exercise-content-nav{flex-direction:column;gap:.75rem}.exercise-content-nav-button{width:100%}.material-card{padding:1rem}.exercise-question-card{padding:.75rem}}.collapsible-content{display:flex;flex-direction:column;border-radius:.5rem;box-shadow:none}.collapsible-content-header{width:100%;background:hsl(var(--brand-teal));color:#fff;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;border:none;cursor:pointer;transition:background-color .2s;border-radius:.5rem .5rem 0 0}.collapsible-content-header:hover{background:hsl(var(--brand-teal) / .9)}.collapsible-content-title{font-size:1.125rem;font-weight:600}.collapsible-content-toggle-icon{width:1.5rem;height:1.5rem;transition:transform .2s;flex-shrink:0}.collapsible-content-toggle-icon.expanded{transform:rotate(180deg)}.collapsible-content-body{border:6px solid hsl(var(--brand-teal));border-top:none;border-radius:0 0 .5rem .5rem;background:hsl(var(--card))}.collapsible-content-scrollable{max-height:450px;overflow-y:auto;padding:1.5rem}.collapsible-content-scrollable::-webkit-scrollbar{width:10px}.collapsible-content-scrollable::-webkit-scrollbar-track{background:#e6e6e6;border-radius:0 0 .5rem}.collapsible-content-scrollable::-webkit-scrollbar-thumb{background:#999;border-radius:5px}.collapsible-content-scrollable::-webkit-scrollbar-thumb:hover{background:gray}.material-reading-content{line-height:1.75;color:hsl(var(--foreground))}.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{width:80%;place-self:center;background:hsl(var(--background));border-radius:.5rem;box-shadow:none}.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:hsl(var(--primary));box-shadow:0 0 0 2px hsl(var(--primary) / .2)}.submit-button{width:100%;padding:.75rem;background-color:hsl(var(--primary));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:hsl(var(--primary-hover))}.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:hsl(var(--brand-blue, 220 80% 24%));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;transition:background-color .2s}.oauth-button:hover{background-color:#f3f4f6}.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}.profile-page{display:flex;justify-content:center;padding:2rem 1rem}.profile-card{width:100%;max-width:720px;background:hsl(var(--card));color:hsl(var(--card-foreground));border:1px solid hsl(var(--border));border-radius:.5rem;padding:1.5rem;box-shadow:0 6px 18px #1018280f}.profile-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.profile-header h2{margin:0;font-size:1.25rem;color:hsl(var(--education-blue))}.profile-sub{color:hsl(var(--muted-foreground));font-size:.95rem}.profile-form{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.profile-form .form-row{display:flex;flex-direction:column;gap:.5rem}.profile-form label{color:hsl(var(--foreground));font-weight:600;font-size:.95rem}.profile-input{padding:.75rem;border:1px solid hsl(var(--border));border-radius:.375rem;background:hsl(var(--background));color:hsl(var(--foreground))}.profile-input:focus{outline:none;box-shadow:0 0 0 3px hsl(var(--ring) / .14);border-color:hsl(var(--ring))}.profile-actions{grid-column:1 / -1;display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-primary{background:hsl(var(--education-blue));color:hsl(var(--primary-foreground));border:none;padding:.75rem 1.25rem;border-radius:.375rem;font-weight:600;cursor:pointer}.btn-primary:hover{background:hsl(var(--education-blue-light))}.btn-secondary{background:transparent;border:1px solid hsl(var(--border));padding:.75rem 1rem;border-radius:.375rem;cursor:pointer}@media (max-width: 720px){.profile-form{grid-template-columns:1fr}.profile-actions{justify-content:stretch;flex-direction:column}}.course-char-root{font-family:"M PLUS Rounded 1c",Noto Sans TC,Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;font-weight:900;color:hsl(var(--brand-blue, 220 80% 24%));line-height:1.5;display:flex;flex-direction:column;min-height:100vh}.cc-hero{background:linear-gradient(90deg,hsl(var(--brand-blue)),hsl(var(--brand-teal)));color:#fff;padding:0}.cc-hero img{width:100%;display:block;max-height:70vh;object-fit:cover}.cc-hero-inner{max-width:1000px;margin:0 auto}.cc-title{font-size:28px;margin:0 0 8px}.cc-sub{margin:0;opacity:.95}.cc-main{max-width:1200px;margin:24px auto;padding:0 16px;display:grid;gap:18px}.content-section{background:#fff;width:70%;justify-self:center}.content-section h2{font-size:28px;font-weight:700;margin:0 0 16px;color:hsl(var(--brand-teal))}.content-section p,.content-section table{font-size:24px;font-weight:700;margin:0 0 12px;color:hsl(var(--brand-blue, 220 80% 24%))}.content-section table td{border:none;padding:8px 12px;vertical-align:top}.three-frames{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.three-frames .title-frame{border-width:10px}.three-frames .title-frame .title-frame-header{font-size:28px;padding:0}.cc-overview h2,.cc-structure h2,.cc-cta h2{margin-top:0}.cc-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.feature h3{margin:0 0 6px}.cc-structure ul{padding-left:20px;margin:8px 0 0}.cc-structure li{margin-bottom:8px}.cc-cta{text-align:center}.cc-footer{text-align:center;margin-top:auto;padding:18px;font-size:13px;color:#475569}@media (max-width: 640px){.cc-title{font-size:20px}.cc-main{padding:0 12px}.three-frames{grid-template-columns:1fr}}.title-frame{border:6px solid hsl(var(--brand-teal));border-radius:0;overflow:visible;background:#c4f5f3;position:relative;margin-top:50px}.title-frame-holder{padding:16px;font-size:16px;display:flex;justify-content:center}.title-frame-holder img{width:50%;height:50%;display:block;margin-top:-60px}.title-frame-header{background:hsl(var(--brand-blue));color:#fff;font-weight:700;text-align:center;padding:18px 16px 10px;font-size:18px}.title-frame-body{padding:14px 16px;color:hsl(var(--brand-blue));font-size:16px}.title-frame.big .title-frame-header{font-size:22px;padding:14px 18px}@media (max-width:640px){.title-frame{margin-top:40px}.title-frame-body{font-size:15px}.title-frame-header{font-size:16px}.title-frame-holder img{max-width:90px;margin-top:-60px}}.dse-page-container{max-width:1200px;margin:0 auto;padding:2rem;font-family:"M PLUS Rounded 1c",Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;color:#333}.dse-section{margin-bottom:3rem;background:#fff;padding:2rem;border-radius:12px}.dse-title{color:hsl(var(--brand-blue));font-size:2rem;margin-bottom:1.5rem;border-bottom:2px solid #E5E7EB;padding-bottom:1rem}.dse-subtitle{color:hsl(var(--brand-blue));font-size:1.5rem;margin-top:2rem;margin-bottom:1rem}.dse-text{line-height:1.6;margin-bottom:1rem;color:#4b5563;font-size:28px}.dse-link{color:#2563eb;text-decoration:none;word-break:break-all}.dse-link:hover{text-decoration:underline}.level-card{border-radius:8px;margin-bottom:1.5rem}.level-card .dse-text{color:hsl(var(--brand-blue))}.level-title{color:hsl(var(--brand-teal));font-weight:700;font-size:38px;margin-bottom:.5rem}.mark-block-container{margin-bottom:2rem;border:3px solid hsl(var(--brand-blue));border-radius:8px;overflow:hidden}.mark-title-text{background:hsl(var(--brand-blue));color:#fff;padding:.75rem 1.5rem;margin:0;font-size:1.1rem}.mark-tabs{display:flex;background:hsl(var(--brand-blue));border-bottom:3px solid hsl(var(--brand-blue))}.mark-tab{flex:1;padding:1rem;text-align:center;cursor:pointer;font-weight:600;color:#fffc;transition:all .2s;border-bottom:2px solid transparent}.mark-tab:hover{background:#ffffff1a;color:#fff}.mark-tab.active{color:hsl(var(--brand-blue));background:#fff;border-bottom:2px solid hsl(var(--brand-blue))}.mark-content{padding:1.5rem;background:#fff;min-height:200px}.mark-list{margin:0;padding-left:1.5rem}.mark-list li{margin-bottom:.5rem;color:#374151}.paper-section{margin-top:2rem}.paper-title{font-size:1.25rem;font-weight:700;color:#fff;background-color:hsl(var(--brand-teal));padding:.5rem 1rem;margin-bottom:1rem;display:inline-block}@media (max-width: 768px){.dse-page-container{padding:1rem}.mark-tabs{flex-direction:column}.mark-tab{border-bottom:1px solid #E5E7EB}.mark-tab.active{border-left:4px solid hsl(var(--brand-blue));border-bottom:1px solid #E5E7EB}}.dse-section-header{color:hsl(var(--brand-teal));font-weight:700;font-size:1.25rem;margin-bottom:1rem}.assessment-table{display:grid;grid-template-columns:80px 1fr 100px 150px;gap:0;margin-top:20px;font-size:1rem;background-color:#fff;border-top:4px solid white;border-left:4px solid white}.header-cell{background-color:hsl(var(--brand-blue));color:#fff;padding:10px;font-weight:700;text-align:center;display:flex;align-items:center;justify-content:center;border-bottom:4px solid white;border-right:4px solid white}.component-header{grid-column:1 / span 2}.public-exam-cell{grid-row:span 4;background-color:hsl(var(--brand-teal));color:hsl(var(--brand-blue));display:flex;flex-direction:column;justify-content:center;align-items:center;font-weight:700;padding:10px;text-align:center;line-height:1.2;border-right:4px solid white;border-bottom:4px solid white}.paper-cell{background-color:hsl(var(--brand-teal));color:hsl(var(--brand-blue));padding:10px 20px;display:flex;align-items:center;font-weight:700;border-right:4px solid white;border-bottom:4px solid white}.data-cell{background-color:hsl(var(--brand-teal));color:hsl(var(--brand-blue));padding:10px;display:flex;align-items:center;justify-content:center;font-weight:700;border-right:4px solid white;border-bottom:4px solid white}.bottom-border{border-bottom:4px solid white}.no-right-border{border-right:none}.sba-cell{grid-column:1 / span 2;background-color:hsl(var(--brand-teal));color:hsl(var(--brand-blue));padding:10px 20px;display:flex;align-items:center;font-weight:700;border-right:4px solid white;border-bottom:4px solid white}.sba-data-merged{grid-column:3 / span 2;background-color:hsl(var(--brand-teal));color:hsl(var(--brand-blue));padding:10px;display:flex;align-items:center;justify-content:center;font-weight:700;border-bottom:4px solid white}.mark-header{color:hsl(var(--brand-teal));font-size:28px;font-weight:700;margin-bottom:.5rem}.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-header{margin-bottom:1.5rem}.exercise-result-lesson-title{font-size:1.75rem;font-weight:800;color:hsl(var(--brand-blue));margin:0 0 .75rem;line-height:1.3;text-align:center}.exercise-result-section-title{font-size:1.75rem;font-weight:800;color:hsl(var(--brand-blue));margin:0;line-height:1.4;text-align:left}@media (max-width: 767px){.exercise-result-header{margin-bottom:1rem}.exercise-result-lesson-title{font-size:1.5rem}.exercise-result-section-title{font-size:1.125rem}}@media (max-width: 480px){.exercise-result-lesson-title{font-size:1.25rem}.exercise-result-section-title{font-size:1rem}}.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}.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}.questions-list-container{max-height:500px}}@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}.question-type-header{flex-direction:column;gap:1rem;padding:1rem}.question-type-title{font-size:1.1rem;text-align:center}.question-type-toggle{width:100%;padding:.65rem 1.5rem;font-size:1rem}.questions-list-container{max-height:300px;padding:.75rem}.download-link{padding:.75rem 1rem;font-size:.9rem;text-align:center}.mc-option{padding:.75rem .875rem;gap:.75rem}.mc-option-indicator{min-width:28px;height:28px}.mc-check,.mc-cross{font-size:1.5rem}.mc-circle{font-size:1.3rem}.mc-option-content{gap:.5rem}.mc-option-label{min-width:20px;font-size:.95rem}.mc-option-text{font-size:.95rem}}.result-breadcrumb{font-size:.9rem;color:#666;margin-bottom:1rem;padding:.5rem 0}.result-breadcrumb span:first-child{color:hsl(var(--brand-blue));cursor:pointer}.result-section-header{margin-bottom:1.5rem}.result-section-header .section-title{font-size:1.8rem;font-weight:700;color:hsl(var(--brand-blue));margin:0}.result-score-display{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem 2rem;margin-bottom:2rem;background:hsl(var(--brand-teal));color:#fff;border-radius:8px;font-size:1.1rem;border:none;box-shadow:0 2px 4px #0000001a}.result-score-display .score-label{font-weight:600;color:#fff}.result-score-display .score-value{font-size:1.5rem;font-weight:800;color:#fff}.result-score-display .score-status{font-size:1rem;font-weight:600;color:#fff;opacity:.95}.result-message{margin-bottom:2rem;padding:0;background:transparent;border:none}.message-title{font-size:1.3rem;font-weight:800;color:hsl(var(--brand-blue));margin:0 0 1rem}.message-content{font-size:1.05rem;line-height:1.6;color:#374151}.message-content a{color:hsl(var(--brand-blue));text-decoration:none;font-weight:600}.message-content a:hover{text-decoration:underline}.question-review-section{background:#fff;border-radius:12px;padding:0;margin-bottom:2rem}.review-title{font-size:1.3rem;font-weight:800;color:hsl(var(--brand-blue));margin:0 0 1.5rem}.question-type-section{margin-bottom:2rem}.question-type-section:last-of-type{margin-bottom:0}.question-type-header{display:flex;justify-content:space-between;align-items:center;background:hsl(var(--brand-blue));padding:1.25rem 1.5rem;border-radius:8px 8px 0 0;margin-bottom:0}.question-type-title{color:#fff;font-size:1.5rem;font-weight:700;margin:0;letter-spacing:.5px}.question-type-toggle{background:hsl(var(--brand-teal));color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.question-type-toggle:hover{background:hsl(var(--brand-teal));opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px hsl(var(--brand-teal) / .3)}.question-review-section .download-link{padding:1rem 1.5rem;text-align:right;margin-top:2rem;font-size:1rem;color:hsl(var(--brand-blue))}.download-link a{color:hsl(var(--brand-teal));text-decoration:none;font-weight:600;margin:0 .25rem}.download-link a:hover{text-decoration:underline}.questions-list-container{max-height:400px;overflow-y:auto;padding:1rem;background:#f9fafb;border-left:1px solid #e5e7eb;border-right:1px solid #e5e7eb}.questions-list-container::-webkit-scrollbar{width:8px}.questions-list-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.questions-list-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.questions-list-container::-webkit-scrollbar-thumb:hover{background:#555}.questions-list{display:flex;flex-direction:column;gap:1.5rem}.question-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.25rem}.question-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.question-text{flex:1;font-size:1.05rem;font-weight:600;color:#1f2937;line-height:1.5}.question-status{display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:6px;font-size:.95rem;font-weight:600;white-space:nowrap}.question-status.correct{background:#dcfce7;color:#16a34a}.question-status.incorrect{background:#fee2e2;color:#dc2626}.status-icon{font-size:1.2rem;font-weight:800}.mc-options-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.mc-option{display:flex;align-items:flex-start;gap:1rem;padding:.875rem 1rem;border-radius:8px;border:2px solid #e5e7eb;background:#fff;transition:all .2s ease}.mc-option.correct-option{background:#f0fdf4;border-color:#86efac}.mc-option.incorrect-option{background:#fef2f2;border-color:#fca5a5}.mc-option-indicator{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;font-size:1.5rem;font-weight:800}.mc-check{color:#16a34a;font-size:1.8rem}.mc-cross{color:#dc2626;font-size:1.8rem}.mc-circle{color:#9ca3af;font-size:1.5rem}.mc-option-content{flex:1;display:flex;align-items:flex-start;gap:.75rem}.mc-option-label{font-weight:700;color:#1f2937;min-width:24px}.mc-option-text{flex:1;color:#374151;line-height:1.5}.mc-option.correct-option .mc-option-label,.mc-option.correct-option .mc-option-text{color:#166534}.mc-option.incorrect-option .mc-option-label,.mc-option.incorrect-option .mc-option-text{color:#991b1b}.answer-row{display:flex;align-items:flex-start;gap:1rem;margin-bottom:.75rem;font-size:1rem}.answer-label{font-weight:600;color:#6b7280;min-width:100px}.answer-value{flex:1;padding:.5rem .75rem;border-radius:6px;background:#fff;border:1px solid #e5e7eb}.answer-value.correct{background:#f0fdf4;border-color:#86efac;color:#166534;font-weight:600}.answer-value.incorrect{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.answer-row.model-answer{margin-top:1rem}.answer-row.model-answer .answer-value{background:#fffbeb;border-color:#fcd34d}.answer-row.suggested-answer{margin-top:1rem}.answer-feedback{margin-top:1rem;padding:1rem;background:#eff6ff;border-left:3px solid #3b82f6;border-radius:6px}.feedback-label{font-weight:600;color:#1e40af;margin-bottom:.5rem}.feedback-content{color:#1f2937;line-height:1.6}.result-actions{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.action-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.action-button.primary{background:#60c5ba;color:#fff}.action-button.primary:hover{background:#4db5a9;transform:translateY(-2px);box-shadow:0 4px 12px #60c5ba4d}.submission-info{text-align:center;font-size:.9rem;color:#6b7280;padding-top:1rem;border-top:1px solid #e5e7eb}@media (max-width: 767px){.result-score-display{flex-direction:column;gap:.5rem;padding:1rem}.result-score-display .score-value{font-size:1.8rem}.questions-list-container{max-height:400px}.question-header{flex-direction:column;gap:.75rem}.answer-row{flex-direction:column;gap:.5rem}.answer-label{min-width:auto}}@media (min-width: 1024px){.questions-list-container{max-height:600px}}.essay-feedback-container,.essay-mistakes-container{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid hsl(var(--border))}.feedback-section-title{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:hsl(var(--foreground))}.rubric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.rubric-item{background:hsl(var(--background));border:1px solid hsl(var(--border));border-radius:8px;padding:1rem}.rubric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid hsl(var(--border))}.rubric-category{font-weight:600;color:hsl(var(--primary))}.rubric-score{font-weight:700;background:hsl(var(--primary));color:hsl(var(--primary-foreground));padding:.2rem .5rem;border-radius:4px;font-size:.9rem}.rubric-content p{margin:.5rem 0;font-size:.95rem;line-height:1.5}.rubric-content strong{color:hsl(var(--foreground))}.mistakes-list{display:flex;flex-direction:column;gap:1rem}.mistake-item{background:hsl(var(--muted));border-radius:8px;padding:1rem}.mistake-original,.mistake-correction,.mistake-explanation{margin-bottom:.5rem;font-size:.95rem}.mistake-text-original{color:hsl(var(--destructive));text-decoration:line-through}.mistake-text-correction{color:hsl(var(--success));font-weight:600}.pending-grade-container{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:20px}.pending-grade-card{border-radius:12px;padding:40px;max-width:500px;width:100%;text-align:center}.pending-grade-icon-container{margin-bottom:24px}.pending-grade-icon{font-size:48px}.pending-grade-icon--animated{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.pending-grade-loading-dots{display:flex;justify-content:center;gap:8px;margin-top:12px}.pending-grade-loading-dots span{width:8px;height:8px;background:#1e3a8a;border-radius:50%;animation:bounce 1.4s ease-in-out infinite}.pending-grade-loading-dots span:nth-child(2){animation-delay:.2s}.pending-grade-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}}.pending-grade-title{font-size:24px;font-weight:600;color:#1e3a8a;margin:0 0 16px}.pending-grade-message{font-size:16px;color:#666;margin:0 0 24px}.pending-grade-status{margin-bottom:24px}.pending-grade-status-text{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:#888}.pending-grade-spinner{width:16px;height:16px;border:2px solid #ddd;border-top-color:#1e3a8a;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pending-grade-info-box{background:#f8f9fa;border-radius:8px;padding:16px;margin-bottom:24px}.pending-grade-info-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#555;margin-bottom:8px}.pending-grade-info-item:last-child{margin-bottom:0}.pending-grade-info-icon{font-size:16px}.pending-grade-actions{display:flex;justify-content:center;gap:12px;margin-bottom:16px}.pending-grade-btn{padding:12px 24px;font-size:16px;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.pending-grade-btn--primary{background:#1e3a8a;color:#fff}.pending-grade-btn--primary:hover{background:#1e40af}.pending-grade-btn--secondary{background:#1e3a8a;color:#fff}.pending-grade-btn--secondary:hover{background:#1e40af}.pending-grade-hint{font-size:13px;color:#999;margin:0}.pending-grade-debug{margin-top:20px;font-size:12px;color:#aaa;font-family:monospace}.photo-card-container{position:relative;display:inline-block}.photo-card{background:transparent;border:none;text-align:center;padding:0;cursor:pointer;display:block;width:100%}.photo-card-image-wrapper{position:relative;width:100%;aspect-ratio:3/2;overflow:hidden;background:#f3f4f6}.photo-card-image{width:100%;height:100%;object-fit:cover;display:block}.photo-card-hover-line{height:6px;width:100%;background:hsl(var(--brand-teal));transform:scaleX(0);transform-origin:left;transition:transform .18s ease;margin-bottom:10px;border-radius:0}.photo-card:hover .photo-card-hover-line,.photo-card:focus .photo-card-hover-line{transform:scaleX(1)}.photo-card-hover-line.disabled{background:transparent!important}.photo-card:hover .photo-card-hover-line.disabled,.photo-card:focus .photo-card-hover-line.disabled{transform:scaleX(0)!important}.photo-card-body{padding-top:6px}.photo-card-title{font-weight:600;font-size:20px;margin-top:12px;color:#6b7280;line-height:1.1;max-height:24px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;line-clamp:1}.photo-card.is-owned .photo-card-title{color:hsl(var(--brand-blue))}.photo-card-buy-button{background:hsl(var(--brand-blue));color:#fff;border:none;padding:4px 6px;border-radius:6px;font-size:14px;font-weight:400;cursor:pointer;margin-top:12px;transition:all .2s ease;display:inline-block;text-transform:uppercase;letter-spacing:.5px}.photo-card-buy-button:hover{background:hsl(var(--brand-blue));transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.photo-card-buy-button:active{transform:translateY(0);box-shadow:0 2px 6px #0000001a}.photo-card-hover-overlay{position:absolute;top:0;margin-top:60%;left:50%;width:320%;max-width:800px;height:auto;min-height:200px;transform:translate(-50%) scale(.95);opacity:0;pointer-events:none;transition:all .3s ease;z-index:100;padding:0}.photo-card-container:hover .photo-card-hover-overlay{opacity:1;transform:translate(-50%) scale(1);pointer-events:auto}.photo-card-hover-description{background:#f2efefd9;border-radius:12px;box-shadow:0 10px 40px #00000040,0 4px 12px #00000026;padding:32px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:16px;height:auto;min-height:150px;border:1px solid rgba(27,50,103,.1)}.photo-card-hover-title{font-weight:700;margin-bottom:8px;font-size:21px}.photo-card-hover-subheader{font-weight:700;margin-bottom:12px;font-size:24px}.photo-card-hover-body{font-weight:600;line-height:1.6;font-size:21px;max-width:100%}.photo-card-hover-body table,.photo-card-hover-body .syllabus-table{width:100%;border-collapse:separate;border-spacing:8px 4px;margin:8px 0}.photo-card-hover-body table td,.photo-card-hover-body .syllabus-table td{padding:3px 12px;text-align:left;vertical-align:top}.photo-card-hover-body table td:first-child,.photo-card-hover-body .syllabus-table td:first-child{font-weight:700;white-space:nowrap;width:40px}@media (max-width:640px){.photo-card-container{width:220px}.photo-card-hover-overlay{width:90%;max-width:90vw}.photo-card-hover-description{padding:24px}}.banner{width:100%;margin:0}.banner-content{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:200px}.banner-image{width:100%;max-height:40vh;object-fit:cover;display:block;min-height:200px}.banner-button{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#ffffffe6;border:2px solid rgba(255,255,255,.3);padding:1rem 2.5rem;border-radius:50px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-transform:uppercase;letter-spacing:1px;color:hsl(var(--brand-blue, 220 80% 24%));box-shadow:0 4px 20px #0003}.banner-button:hover{background:#fff;transform:translate(-50%,-50%) translateY(-3px);box-shadow:0 8px 30px #0000004d;border-color:#fffc}.banner-button:active{transform:translate(-50%,-50%) translateY(-1px);box-shadow:0 4px 15px #0003}@media (max-width: 768px){.banner-content{flex-direction:column;text-align:center;padding:2rem 1.5rem}.banner-text{margin-right:0;margin-bottom:1.5rem}.banner-title{font-size:1.75rem}.banner-subtitle{font-size:1rem}.banner-button{width:100%;max-width:250px}}@media (max-width: 480px){.banner-content{padding:1.5rem 1rem}.banner-title{font-size:1.5rem}.banner-subtitle{font-size:.9rem}}.subject-header,.section-header{display:flex;gap:12px;align-items:end;justify-self:center;margin:18px 0}.subject-header h1,.section-header h1{font-size:24px;font-weight:900;color:hsl(var(--brand-blue));margin:0}.lessons-grid-regular,.lessons-grid-bonus{display:flex;flex-wrap:wrap;gap:24px;width:80%;max-width:1400px;margin-bottom:2rem;justify-content:center;justify-self:center;align-items:flex-start}.lessons-grid-regular .photo-card-title,.lessons-grid-bonus .photo-card-title{color:#a6a6a6}.muted{color:#6b7280}.error{color:#b00020}@font-face{font-family:Noto Sans TC;src:url(/assets/NotoSansTC-VariableFont_wght-BcAoRI3a.ttf) format("truetype");font-weight:100 900;font-style:normal}@font-face{font-family:"M PLUS Rounded 1c";src:url(/assets/MPLUSRounded1c-Thin-D_n3KY36.ttf) format("truetype");font-weight:100;font-style:normal;unicode-range:U+0000-00FF,U+0100-017F}@font-face{font-family:"M PLUS Rounded 1c";src:url(/assets/MPLUSRounded1c-Light-3RMxnNGg.ttf) format("truetype");font-weight:300;font-style:normal;unicode-range:U+0000-00FF,U+0100-017F}@font-face{font-family:"M PLUS Rounded 1c";src:url(/assets/MPLUSRounded1c-Regular-CCUzdWRQ.ttf) format("truetype");font-weight:400;font-style:normal;unicode-range:U+0000-00FF,U+0100-017F}@font-face{font-family:"M PLUS Rounded 1c";src:url(/assets/MPLUSRounded1c-Medium-C4P_Jtj_.ttf) format("truetype");font-weight:500;font-style:normal;unicode-range:U+0000-00FF,U+0100-017F}@font-face{font-family:"M PLUS Rounded 1c";src:url(/assets/MPLUSRounded1c-Bold-CX_Uxxew.ttf) format("truetype");font-weight:700;font-style:normal;unicode-range:U+0000-00FF,U+0100-017F}@font-face{font-family:"M PLUS Rounded 1c";src:url(/assets/MPLUSRounded1c-ExtraBold-By8rfB5I.ttf) format("truetype");font-weight:800;font-style:normal;unicode-range:U+0000-00FF,U+0100-017F}@font-face{font-family:"M PLUS Rounded 1c";src:url(/assets/MPLUSRounded1c-Black-B2b23NeV.ttf) format("truetype");font-weight:900;font-style:normal;unicode-range:U+0000-00FF,U+0100-017F}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}:root{--brand-blue: 220 80% 24%;--brand-teal: 178 54% 48%;--brand-grey: 0 8% 95%;--brand-red: 351 89% 37%;--brand-yellow: 44 93% 56%;--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: var(--brand-blue);--primary-foreground: 0 0% 98%;--primary-hover: 220 80% 19%;--secondary: var(--brand-grey);--secondary-foreground: var(--brand-blue);--muted: var(--brand-grey);--muted-foreground: 220 8.9% 46.1%;--accent: var(--brand-teal);--accent-foreground: 220 80% 24%;--destructive: var(--brand-red);--destructive-foreground: 210 40% 98%;--warning: var(--brand-yellow);--warning-foreground: 220 80% 24%;--success: 142 71% 45%;--success-foreground: 0 0% 98%;--border: 220 13% 91%;--input: 220 13% 91%;--ring: var(--brand-blue);--header-bg: 0 0% 100%;--header-topbar: var(--brand-blue);--header-nav: var(--brand-grey);--header-search: 0 0% 97%;--education-blue: var(--brand-blue);--education-blue-light: 220 80% 34%;--education-teal: var(--brand-teal);--education-gray: 220 8.9% 46.1%;--sidebar-active: var(--brand-teal);--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:"M PLUS Rounded 1c",Noto Sans TC,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;line-height:1.5}.h-full{height:100%}.container{width:100%;margin:0;padding:0;justify-self:center}.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}.with-left-menu{margin-left:0rem}@media (max-width: 900px){.with-left-menu{margin-left:0!important}}.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}.floating-menu{position:fixed;left:20px;bottom:22px;z-index:1400;display:flex;flex-direction:column;align-items:flex-start;pointer-events:none;overflow:visible}.fm-toggle{pointer-events:auto;z-index:1410;width:56px;height:56px;border-radius:50%;background:hsl(var(--brand-blue));color:#fff;border:none;box-shadow:0 6px 18px #0b53942e;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.fm-items{position:absolute;left:0;bottom:72px;width:160px;display:flex;flex-direction:column;gap:1px;pointer-events:auto;opacity:0;transform:translateY(6px);transition:opacity .18s ease,transform .18s ease;background:transparent;border-radius:0;padding:0;box-shadow:none;z-index:1405;pointer-events:none;overflow:hidden}.floating-menu.open .fm-items{opacity:1;transform:translateY(0);pointer-events:auto}.burger{display:inline-block;width:22px;height:18px;position:relative}.burger .line{position:absolute;left:0;right:0;height:2px;background:#fff;transition:transform .25s ease,opacity .2s ease}.burger .line:nth-child(1){top:0}.burger .line:nth-child(2){top:8px}.burger .line:nth-child(3){top:16px}.floating-menu.open .burger .line:nth-child(1){transform:translateY(8px) rotate(45deg)}.floating-menu.open .burger .line:nth-child(2){opacity:0}.floating-menu.open .burger .line:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.fm-item{border:none;display:block;width:100%;text-align:center;padding:.5rem .6rem;background:hsl(var(--brand-grey));border-radius:0;font-weight:700;color:hsl(var(--brand-blue));font-size:1rem;text-decoration:none}.fm-item:hover{background:#e8e3e3}.fm-item.active{background:hsl(var(--brand-teal));color:hsl(var(--brand-blue));position:relative}.fm-item.active:before{display:none}.fm-item.active:hover{background:hsl(var(--brand-teal))}@media (min-width: 901px){.floating-menu{display:none}}@media (max-width:640px){.floating-menu{left:12px;bottom:12px}.fm-toggle{width:48px;height:48px;font-size:18px}.fm-item{padding:7px 10px}}.left-menu{position:fixed;left:20px;top:70%;transform:translateY(-50%);width:8rem;background:transparent;padding:0;z-index:1200}.left-menu nav{display:flex;flex-direction:column;gap:1px}.left-menu-item{display:block;padding:.2rem .6rem;color:hsl(var(--brand-blue, 220 80% 24%));text-decoration:none;border-radius:0;background:hsl(var(--brand-grey, 0 8% 95%));font-weight:700;text-align:center;font-size:1rem}.left-menu-item:hover{background:#e8e3e3}.left-menu-item.active{background:hsl(var(--brand-teal, 178 54% 48%));color:hsl(var(--brand-blue, 220 80% 24%));position:relative}@media (max-width: 900px){.left-menu{display:none}}.app-footer{text-align:center;padding:18px;background:hsl(var(--brand-blue));color:#fff;border-top:1px solid #eef2ff}.app-footer p{margin:0;font-size:13px}
