:root{color:#0a2540;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{background-color:var(--color-background-secondary,#fafbfc);min-width:320px;min-height:100vh;margin:0}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary,#0a2540);letter-spacing:-.01em;margin:0;font-weight:600;line-height:1.2}h1{font-size:var(--font-size-xxxl,2rem);font-weight:700}h2{font-size:var(--font-size-xxl,1.5rem);font-weight:700}h3{font-size:var(--font-size-xl,1.25rem);font-weight:600}h4{font-size:var(--font-size-lg,1.125rem);font-weight:600}h5{font-size:var(--font-size-base,1rem);font-weight:600}h6{font-size:var(--font-size-sm,.875rem);font-weight:600}p{color:var(--color-text-secondary,#3d5161);margin:0;line-height:1.6}a{color:var(--color-primary,#1a6ed9);font-weight:500;text-decoration:none;transition:color .15s}a:hover{color:var(--color-primary-hover,#1557b0);text-decoration:none}a:focus{outline:2px solid var(--color-primary,#1a6ed9);outline-offset:2px}ul,ol{margin:0;padding:0}input,textarea,select,button{font-family:inherit;font-size:inherit}:focus{outline:2px solid var(--color-primary-lighter,#e6f2ff);outline-offset:1px}:focus-visible{outline:2px solid var(--color-primary,#1a6ed9);outline-offset:1px}button{font:inherit;cursor:pointer;background:0 0;border:none;margin:0;padding:0;transition:all .2s}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}html{scroll-behavior:smooth}::selection{background-color:var(--color-primary-lighter,#e6f2ff);color:var(--color-text-primary,#0a2540)}.background-animation{pointer-events:none;z-index:1;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.floating-button{border-radius:50%;animation:ease-in-out infinite float;position:absolute;box-shadow:0 4px 12px #0a254014}.button-shape{background:var(--color);border-radius:1rem;width:100%;height:100%;box-shadow:0 4px 12px #0a254014}@keyframes float{0%,to{transform:translate(0,0)rotate(var(--rotation))}25%{transform:translate(calc(15vw*var(--direction-x,1)),calc(10vh*var(--direction-y,1)))rotate(calc(var(--rotation) + 5deg))}50%{transform:translate(calc(8vw*var(--direction-x,1)),calc(20vh*var(--direction-y,1)))rotate(calc(var(--rotation) - 3deg))}75%{transform:translate(calc(-10vw*var(--direction-x,1)),calc(15vh*var(--direction-y,1)))rotate(calc(var(--rotation) + 2deg))}}@media (max-width:768px){.floating-button{opacity:.25}@keyframes float{0%,to{transform:translate(0,0)rotate(var(--rotation))}25%{transform:translate(calc(8vw*var(--direction-x,1)),calc(6vh*var(--direction-y,1)))rotate(calc(var(--rotation) + 3deg))}50%{transform:translate(calc(4vw*var(--direction-x,1)),calc(12vh*var(--direction-y,1)))rotate(calc(var(--rotation) - 2deg))}75%{transform:translate(calc(-5vw*var(--direction-x,1)),calc(9vh*var(--direction-y,1)))rotate(calc(var(--rotation) + 1deg))}}}@media (prefers-reduced-motion:reduce){.floating-button{opacity:.2;animation:none}}.app-header{background-color:var(--color-background-primary,#fff);border-bottom:1px solid var(--color-border-light,#e8eaed);z-index:1000;box-shadow:var(--shadow-sm,0 1px 2px 0 #0a25400a);position:sticky;top:0}.app-header__container{justify-content:space-between;align-items:center;gap:2rem;max-width:1440px;height:3.5rem;margin:0 auto;padding:0 1.5rem;display:flex}.app-header__brand{border-radius:var(--radius-md,.375rem);cursor:pointer;color:inherit;background:0 0;border:none;align-items:center;margin:-.25rem;padding:.25rem;text-decoration:none;transition:background .2s;display:flex}.app-header__brand:hover{background:var(--color-background-secondary,#fafbfc)}.app-header__brand:focus{outline:2px solid var(--color-primary,#1a6ed9);outline-offset:2px}.app-header__logo{object-fit:contain;width:auto;height:1.75rem}.app-header__nav{flex:1;align-items:center;gap:.25rem;display:flex}.app-header__nav-item{color:var(--color-text-secondary,#3d5161);cursor:pointer;border-radius:var(--radius-md,.375rem);white-space:nowrap;background:0 0;border:none;padding:.5rem .875rem;font-size:.875rem;font-weight:500;transition:all .2s}.app-header__nav-item:hover{background:var(--color-background-secondary,#fafbfc);color:var(--color-text-primary,#0a2540)}.app-header__nav-item--active{background:var(--color-background-tertiary,#f5f6f7);color:var(--color-text-primary,#0a2540);font-weight:600}.app-header__actions{align-items:center;gap:.75rem;display:flex}.app-header__user{align-items:center;gap:.5rem;display:flex}.app-header__user-profile{background:var(--color-background-secondary,#fafbfc);border-radius:var(--radius-md,.375rem);cursor:pointer;border:none;padding:.375rem .75rem;transition:all .2s}.app-header__user-profile:hover{background:var(--color-background-tertiary,#f5f6f7)}.app-header__user-profile--active{background:var(--color-background-tertiary,#f5f6f7);box-shadow:inset 0 0 0 1px var(--color-border-light,#e8eaed)}.app-header__user-email{color:var(--color-text-secondary,#3d5161);text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:.8125rem;overflow:hidden}.app-header__logout{color:var(--color-text-secondary,#3d5161);cursor:pointer;border-radius:var(--radius-sm,.25rem);background:0 0;border:none;padding:.25rem .5rem;font-size:.8125rem;font-weight:500;transition:all .2s}.app-header__logout:hover{background:var(--color-background-primary,#fff);color:var(--color-text-primary,#0a2540)}.app-header__profile-picture{justify-content:center;align-items:center;display:flex;position:relative}.app-header__avatar{border:2px solid var(--color-background-primary,#fff);cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;justify-content:center;align-items:center;width:2.25rem;height:2.25rem;padding:0;transition:all .2s;display:flex;overflow:hidden;box-shadow:0 2px 4px #0a25401a}.app-header__avatar:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0a254026}.app-header__avatar:active{transform:translateY(0);box-shadow:0 2px 4px #0a25401a}.app-header__avatar img{object-fit:cover;width:100%;height:100%}.app-header__avatar-placeholder{color:#fff;text-transform:uppercase;justify-content:center;align-items:center;width:100%;height:100%;font-size:1rem;font-weight:600;display:flex}.app-header__dropdown{background:var(--color-background-primary,#fff);border-radius:var(--radius-md,.375rem);border:1px solid var(--color-border-light,#e8eaed);z-index:1000;min-width:240px;animation:.2s dropdownFadeIn;position:absolute;top:calc(100% + .5rem);right:0;box-shadow:0 4px 12px #0a254026}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.app-header__dropdown-header{padding:.875rem 1rem}.app-header__user-name{color:var(--color-text-primary,#0a2540);word-break:break-word;margin-bottom:.25rem;font-size:.9375rem;font-weight:600}.app-header__dropdown-divider{background:var(--color-border-light,#e8eaed);height:1px;margin:.5rem 0}.app-header__dropdown-item{text-align:left;width:100%;color:var(--color-text-secondary,#3d5161);cursor:pointer;border-radius:0 0 var(--radius-md,.375rem)var(--radius-md,.375rem);background:0 0;border:none;padding:.625rem 1rem;font-size:.875rem;transition:background .15s}.app-header__dropdown-item:hover{background:var(--color-background-secondary,#fafbfc);color:var(--color-text-primary,#0a2540)}@media (max-width:768px){.app-header__container{gap:1rem;padding:0 1rem}.app-header__nav{gap:.125rem}.app-header__nav-item{padding:.5rem .625rem;font-size:.8125rem}.app-header__user-email{display:none}.app-header__user-profile{padding:.375rem}.app-header__avatar{width:2rem;height:2rem}}.login-page{background:var(--color-background-primary,#fff);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative}.login-container{z-index:100;width:100%;max-width:420px;padding:1.5rem;position:relative}.login-card{background:var(--color-background-primary,#fff);border-radius:var(--radius-lg,.75rem);padding:3rem 2.5rem;animation:.4s ease-out fadeSlideUp;box-shadow:0 4px 6px #0a254008,0 10px 20px #0a25400f,0 0 0 1px #0a25400a}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-logo{object-fit:contain;width:auto;height:2.5rem;margin-bottom:1.5rem}.login-title{color:var(--color-text-primary,#0a2540);margin:0 0 .5rem;font-size:1.75rem;font-weight:600;line-height:1.3}.login-subtitle{color:var(--color-text-secondary,#3d5161);margin:0;font-size:1rem}.login-content{flex-direction:column;align-items:stretch;gap:1rem;margin-bottom:2rem;display:flex}.login-divider{text-align:center;align-items:center;margin:.5rem 0;display:flex}.login-divider:before,.login-divider:after{content:"";border-bottom:1px solid #e8eaed;flex:1}.login-divider span{color:#697684;padding:0 1rem;font-size:.875rem;font-weight:500}.login-button{color:#3d5161;cursor:pointer;background:#fff;border:1px solid #e8eaed;border-radius:.375rem;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:500;transition:all .2s;display:flex}.login-button:hover{background:#fafbfc;border-color:#d0d8e0}.login-button:active{background:#f1f4f6}.login-button--google svg,.login-button--microsoft svg{flex-shrink:0}.login-footer{text-align:center;border-top:1px solid var(--color-border-light,#e8eaed);padding-top:1.5rem}.login-footer-text{color:var(--color-text-tertiary,#697684);margin:0;font-size:.8125rem;line-height:1.5}@media (max-width:480px){.login-container{padding:1rem}.login-card{padding:2rem 1.5rem}.login-title{font-size:1.5rem}.login-subtitle{font-size:.9375rem}}@media (prefers-color-scheme:dark){.login-page{background:var(--color-background-dark,#0a2540)}.login-card{background:var(--color-background-dark-secondary,#152d4a)}.login-title{color:var(--color-text-dark-primary,#fff)}.login-subtitle{color:var(--color-text-dark-secondary,#a8b5c4)}.login-footer-text{color:var(--color-text-dark-tertiary,#8595a6)}.login-footer{border-top-color:var(--color-border-dark,#2a4061)}}.video-list{width:100%}.video-list__grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.video-card{color:inherit;background:#fff;border-radius:.75rem;flex-direction:column;text-decoration:none;transition:all .25s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0a254014}.video-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0a25401f}.video-card:focus{outline-offset:2px;outline:2px solid #1a6ed9}.video-card__thumbnail{width:100%;padding-top:56.25%;position:relative;overflow:hidden}.video-card__thumbnail img{object-fit:contain;background-color:#fff;width:100%;height:100%;position:absolute;top:0;left:0}.video-card__thumbnail-placeholder{color:#fff;opacity:.8;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.video-card__duration{color:#fff;background:#000c;border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;position:absolute;bottom:.5rem;right:.5rem}.video-card__content{flex-direction:column;flex:1;gap:.5rem;padding:1rem;display:flex}.video-card__title{color:#0a2540;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1.125rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.video-card__description{color:#3d5161;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.875rem;line-height:1.5;display:-webkit-box;overflow:hidden}.video-card__meta{flex-direction:column;gap:.5rem;margin-top:auto;padding-top:.5rem;display:flex}.video-card__date{color:#7891a8;font-size:.75rem}.video-card__tags{flex-wrap:wrap;gap:.375rem;display:flex}.video-card__tag{color:#1a6ed9;background:#e6f2ff;border-radius:.25rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:500}.video-list-empty{text-align:center;padding:4rem 2rem}.video-list-empty p{color:#3d5161;margin:0 0 .5rem;font-size:1.125rem}.video-list-empty__subtitle{color:#7891a8;font-size:.875rem}@media (max-width:768px){.video-list__grid{grid-template-columns:1fr;gap:1rem}.video-card__content{padding:.875rem}.video-card__title{font-size:1rem}}.assessment-list{width:100%}.assessment-list__grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.assessment-card{color:inherit;cursor:pointer;background:#fff;border-radius:.75rem;flex-direction:column;text-decoration:none;transition:all .25s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0a254014}.assessment-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0a25401f}.assessment-card:focus{outline-offset:2px;outline:2px solid #1a6ed9}.assessment-card__thumbnail{width:100%;padding-top:56.25%;position:relative;overflow:hidden}.assessment-card__thumbnail img{object-fit:contain;background-color:#fff;width:100%;height:100%;position:absolute;top:0;left:0}.assessment-card__thumbnail-placeholder{color:#fff;opacity:.8;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.assessment-card__content{flex-direction:column;flex:1;gap:.5rem;padding:1rem;display:flex}.assessment-card__title{color:#0a2540;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1.125rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.assessment-card__description{color:#3d5161;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.875rem;line-height:1.5;display:-webkit-box;overflow:hidden}.assessment-card__meta{flex-direction:column;gap:.5rem;margin-top:auto;padding-top:.5rem;display:flex}.assessment-card__date{color:#7891a8;font-size:.75rem}.assessment-card__tags{flex-wrap:wrap;gap:.375rem;display:flex}.assessment-card__tag{color:#c41e3a;background:#ffe6f0;border-radius:.25rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:500}.assessment-card__actions{gap:.5rem;margin-top:.75rem;display:flex}.assessment-card__button{cursor:pointer;border:none;border-radius:.375rem;flex:1;justify-content:center;align-items:center;gap:.375rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.assessment-card__button:disabled{opacity:.6;cursor:not-allowed}.assessment-card__button--download{color:#1a6ed9;background:#e6f2ff}.assessment-card__button--download:hover:not(:disabled){background:#cce5ff}.assessment-card__button--download:active:not(:disabled){background:#b3d9ff}.assessment-card__button--view{color:#fff;background:#1a6ed9}.assessment-card__button--view:hover:not(:disabled){background:#155ab8}.assessment-card__button--view:active:not(:disabled){background:#104797}.assessment-card__button svg{flex-shrink:0}.assessment-list-empty{text-align:center;padding:4rem 2rem}.assessment-list-empty p{color:#3d5161;margin:0 0 .5rem;font-size:1.125rem}.assessment-list-empty__subtitle{color:#7891a8;font-size:.875rem}@media (max-width:768px){.assessment-list__grid{grid-template-columns:1fr;gap:1rem}.assessment-card__content{padding:.875rem}.assessment-card__title{font-size:1rem}}.course-list{width:100%}.course-list__grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;display:grid}.course-card{color:inherit;cursor:pointer;background:#fff;border-radius:.75rem;flex-direction:column;text-decoration:none;transition:all .25s;display:flex;overflow:hidden;box-shadow:0 2px 8px #0a254014}.course-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0a25401f}.course-card:focus{outline-offset:2px;outline:2px solid #1a6ed9}.course-card__thumbnail{width:100%;padding-top:56.25%;position:relative;overflow:hidden}.course-card__thumbnail img{object-fit:contain;background-color:#fff;width:100%;height:100%;position:absolute;top:0;left:0}.course-card__thumbnail-placeholder{color:#fff;opacity:.8;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.course-card__content{flex-direction:column;flex:1;gap:.5rem;padding:1rem;display:flex}.course-card__title{color:#0a2540;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:1.125rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.course-card__description{color:#3d5161;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.875rem;line-height:1.5;display:-webkit-box;overflow:hidden}.course-card__meta{flex-direction:column;gap:.5rem;margin-top:auto;padding-top:.5rem;display:flex}.course-card__date{color:#7891a8;font-size:.75rem}.course-card__tags{flex-wrap:wrap;gap:.375rem;display:flex}.course-card__tag{color:#06c;background:#e6f7ff;border-radius:.25rem;padding:.25rem .5rem;font-size:.6875rem;font-weight:500}.course-card__actions{gap:.5rem;margin-top:.75rem;display:flex}.course-card__button{cursor:pointer;border:none;border-radius:.375rem;flex:1;justify-content:center;align-items:center;gap:.375rem;padding:.625rem 1rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.course-card__button:disabled{opacity:.6;cursor:not-allowed}.course-card__button--download{color:#1a6ed9;background:#e6f2ff}.course-card__button--download:hover:not(:disabled){background:#cce5ff}.course-card__button--download:active:not(:disabled){background:#b3d9ff}.course-card__button--view{color:#fff;background:#1a6ed9}.course-card__button--view:hover:not(:disabled){background:#155ab8}.course-card__button--view:active:not(:disabled){background:#104797}.course-card__button svg{flex-shrink:0}.course-list-empty{text-align:center;padding:4rem 2rem}.course-list-empty p{color:#3d5161;margin:0 0 .5rem;font-size:1.125rem}.course-list-empty__subtitle{color:#7891a8;font-size:.875rem}@media (max-width:768px){.course-list__grid{grid-template-columns:1fr;gap:1rem}.course-card__content{padding:.875rem}.course-card__title{font-size:1rem}}.home-main{z-index:10;max-width:1200px;margin:0 auto;padding:2rem;position:relative}.home-header{margin-bottom:2rem}.home-title{color:#0a2540;margin:0 0 .5rem;font-size:2rem;font-weight:700;line-height:1.2}.home-subtitle{color:#3d5161;margin:0;font-size:1.125rem;line-height:1.5}.home-loading,.home-error{text-align:center;padding:2rem}.home-error__message{color:#bb4430;margin:0 0 1rem}.home-error__fallback-text{color:#3d5161;margin-top:1rem;font-size:.9rem}.home-section{margin-bottom:3rem}.home-section__title{color:#0a2540;margin:0 0 1.5rem;font-size:1.5rem;font-weight:600;line-height:1.2}.home-empty{text-align:center;padding:4rem 2rem}.home-empty p{color:#3d5161;margin:0 0 .5rem;font-size:1.125rem}.home-empty__subtitle{color:#7891a8;font-size:.875rem}@media (max-width:768px){.home-main{padding:1rem}.home-header{margin-bottom:1.5rem}.home-title{font-size:1.5rem}.home-subtitle{font-size:1rem}.home-section{margin-bottom:2rem}.home-section__title{margin-bottom:1rem;font-size:1.25rem}}.video-player{background:var(--color-background-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:100%;overflow:hidden}.video-player__header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light);background:var(--color-background-primary)}.video-player__title{font-size:var(--font-size-xxl);color:var(--color-text-primary);margin:0 0 var(--spacing-sm)0;font-weight:600}.video-player__description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.video-player__container{aspect-ratio:16/9;background:#000;width:100%;position:relative}.video-player__wrapper{background:#000;width:100%;height:100%;position:relative}.video-player__wrapper>div{width:100%;height:100%}.video-player__controls{padding:var(--spacing-lg)var(--spacing-md)var(--spacing-md);color:#fff;background:linear-gradient(#0000 0%,#000000b3 50%,#000000e6 100%)}.video-player__progress-container{margin-bottom:var(--spacing-sm)}.video-player__progress{appearance:none;border-radius:var(--radius-full);cursor:pointer;width:100%;height:6px;transition:height var(--transition-fast);background:#ffffff4d;outline:none}.video-player__progress:hover{height:8px}.video-player__progress::-webkit-slider-thumb{appearance:none;background:var(--color-primary);cursor:pointer;width:16px;height:16px;transition:transform var(--transition-fast);border-radius:50%;box-shadow:0 2px 8px #1a6ed980}.video-player__progress::-webkit-slider-thumb:hover{transform:scale(1.2)}.video-player__progress::-moz-range-thumb{background:var(--color-primary);cursor:pointer;width:16px;height:16px;transition:transform var(--transition-fast);border:none;border-radius:50%;box-shadow:0 2px 8px #1a6ed980}.video-player__progress::-moz-range-thumb:hover{transform:scale(1.2)}.video-player__time{font-size:var(--font-size-sm);color:#ffffffe6;margin-top:var(--spacing-xs);justify-content:space-between;font-family:monospace;display:flex}.video-player__bottom-controls{justify-content:space-between;align-items:center;gap:var(--spacing-md);display:flex}.video-player__left-controls,.video-player__right-controls{align-items:center;gap:var(--spacing-sm);display:flex}.video-player__button{color:#fff;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.video-player__button:hover{background:#ffffff1a;transform:scale(1.05)}.video-player__button:active{transform:scale(.95)}.video-player__play-button{background:var(--color-primary);border-radius:var(--radius-full);width:48px;height:48px;padding:0}.video-player__play-button:hover{background:var(--color-primary-hover);box-shadow:0 4px 12px #1a6ed966}.video-player__volume-control{align-items:center;gap:var(--spacing-sm);display:flex}.video-player__volume-slider{appearance:none;border-radius:var(--radius-full);cursor:pointer;background:#ffffff4d;outline:none;width:80px;height:4px}.video-player__volume-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;width:12px;height:12px;transition:transform var(--transition-fast);background:#fff;border-radius:50%}.video-player__volume-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.video-player__volume-slider::-moz-range-thumb{cursor:pointer;width:12px;height:12px;transition:transform var(--transition-fast);background:#fff;border:none;border-radius:50%}.video-player__volume-slider::-moz-range-thumb:hover{transform:scale(1.3)}.video-player__error{text-align:center;color:#fff;padding:var(--spacing-lg);border-radius:var(--radius-lg);background:#000c;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.video-player__error-url{font-size:var(--font-size-sm);color:#fff9;margin-top:var(--spacing-sm);word-break:break-all}.video-player__loading{font-size:var(--font-size-sm);color:#fffc}.video-player__button:disabled{opacity:.5;cursor:not-allowed}@media (max-width:640px){.video-player__volume-control{display:none}.video-player__play-button{width:40px;height:40px}.video-player__controls{padding:var(--spacing-md)var(--spacing-sm)}}.video-detail{z-index:100;max-width:1200px;margin:0 auto;padding:2rem;position:relative}.video-detail__header{margin-bottom:1.5rem}.video-detail__back-link{color:#1a6ed9;border-radius:.375rem;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.video-detail__back-link:hover{color:#1557b0;background:#e6f2ff}.video-detail__back-link svg{flex-shrink:0}.video-detail__content{flex-direction:column;gap:1.5rem;display:flex}.video-detail__tags{flex-wrap:wrap;gap:.5rem;display:flex}.video-detail__tag{color:#1a6ed9;background:#e6f2ff;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.video-detail__loading,.video-detail__error{text-align:center;padding:4rem 2rem}.video-detail__loading p{color:#3d5161;font-size:1.125rem}.video-detail__error-message{color:#bb4430;margin:0 0 1.5rem;font-size:1.125rem}@media (max-width:768px){.video-detail{padding:1rem}.video-detail__header{margin-bottom:1rem}.video-detail__content{gap:1rem}}.chat-toggle-button{background:var(--color-primary);color:#fff;cursor:pointer;z-index:1000;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 12px #00000026}.chat-toggle-button:hover{background:var(--color-primary-hover);transform:scale(1.05)}.chat-toggle-button:focus{outline:2px solid var(--color-primary-light);outline-offset:2px}.chat-toggle-button--hidden{opacity:0;pointer-events:none;transform:scale(.8)}.chat-panel{background-color:var(--color-background-primary,#fff);border-left:1px solid var(--color-border,#dfe1e6);z-index:1001;flex-direction:column;width:400px;max-width:100vw;height:100vh;animation:.25s ease-out slideIn;display:flex;position:fixed;top:0;right:0;box-shadow:-4px 0 24px #0a254014}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-panel__header{border-bottom:1px solid var(--color-border-light,#e8eaed);background-color:var(--color-background-secondary,#fafbfc);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.chat-panel__title{color:var(--color-text-primary,#0a2540);text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 40px);margin:0;font-size:1rem;font-weight:600;overflow:hidden}.chat-panel__close{cursor:pointer;color:var(--color-text-secondary,#3d5161);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.chat-panel__close:hover{color:var(--color-text-primary,#0a2540);background-color:var(--color-background-hover,#f5f6f7)}.chat-panel__messages{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.chat-panel__initializing,.chat-panel__empty{height:100%;color:var(--color-text-secondary,#3d5161);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex}.chat-panel__empty p{margin:0;font-size:.9rem;line-height:1.5}.chat-panel__error{background:var(--color-error-light,#f5d6cf);color:var(--color-error,#bb4430);text-align:center;border-radius:8px;padding:12px;font-size:.875rem}.chat-message{max-width:90%;display:flex}.chat-message--user{align-self:flex-end}.chat-message--assistant{align-self:flex-start}.chat-message__content{word-wrap:break-word;border-radius:12px;padding:12px 16px;font-size:.9rem;line-height:1.6}.chat-message--user .chat-message__content{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.chat-message--assistant .chat-message__content{background-color:var(--color-background-tertiary,#f5f6f7);color:var(--color-text-primary,#0a2540);border-bottom-left-radius:4px}.chat-message--assistant .chat-message__content p{margin:0 0 .5em}.chat-message--assistant .chat-message__content p:last-child{margin-bottom:0}.chat-message--assistant .chat-message__content code{background-color:#0000000f;border-radius:4px;padding:2px 6px;font-size:.85em}.chat-message--assistant .chat-message__content pre{background-color:#0000000f;border-radius:6px;margin:.5em 0;padding:12px;overflow-x:auto}.chat-message--assistant .chat-message__content pre code{background:0 0;padding:0}.chat-message--assistant .chat-message__content ul,.chat-message--assistant .chat-message__content ol{margin:.5em 0;padding-left:1.5em}.chat-message--assistant .chat-message__content li{margin-bottom:.25em}.chat-panel__input-form{border-top:1px solid var(--color-border-light,#e8eaed);background-color:var(--color-background-primary,#fff);flex-shrink:0;align-items:flex-end;gap:10px;padding:16px 20px;display:flex}.chat-panel__input{background-color:var(--color-background-secondary,#fafbfc);border:1px solid var(--color-border,#dfe1e6);color:var(--color-text-primary,#0a2540);resize:none;border-radius:8px;flex:1;min-height:44px;max-height:120px;padding:12px 14px;font-family:inherit;font-size:.9rem;line-height:1.4}.chat-panel__input::placeholder{color:var(--color-text-muted,#7891a8)}.chat-panel__input:focus{border-color:var(--color-primary,#1a6ed9);outline:none;box-shadow:0 0 0 3px #1a6ed91a}.chat-panel__input:disabled{opacity:.5;cursor:not-allowed}.chat-panel__send{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex}.chat-panel__send:hover:not(:disabled){background:var(--color-primary-hover)}.chat-panel__send:disabled{opacity:.5;cursor:not-allowed}.chat-panel__spinner{border:2px solid var(--color-border,#dfe1e6);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite chat-spin}.chat-panel__spinner--small{border-width:2px;border-color:#fff #ffffff4d #ffffff4d;width:18px;height:18px}@keyframes chat-spin{to{transform:rotate(360deg)}}@media (max-width:480px){.chat-toggle-button{width:48px;height:48px;bottom:16px;right:16px}.chat-panel{width:100vw}.chat-panel__header{padding:14px 16px}.chat-panel__messages{padding:16px}.chat-panel__input-form{padding:12px 16px}}.assessment-view{z-index:1000;background:#fff;flex-direction:column;width:100%;height:100vh;display:flex;position:fixed;top:0;left:0}.assessment-view__iframe{border:none;width:100%;height:100%}.assessment-view__loading,.assessment-view__error{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.assessment-view__error p{color:#3d5161;margin-bottom:1rem;font-size:1.125rem}.assessment-view__back-link{color:#fff;background:#1a6ed9;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex}.assessment-view__back-link:hover{background:#155ab8}.assessment-view__loading p{color:#3d5161;font-size:1.125rem}.course-overview{z-index:2;min-height:100vh;padding:2rem 1rem;position:relative}.course-overview__container{z-index:2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;border-radius:16px;max-width:1200px;margin:0 auto;padding:2rem;position:relative;box-shadow:0 4px 24px #0000001a}.course-overview__loading,.course-overview__error{min-height:60vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;display:flex}.course-overview__back-link{color:var(--primary-color);margin-top:1rem;font-weight:500;text-decoration:none}.course-overview__back-link:hover{text-decoration:underline}.course-overview__header{margin-bottom:2rem}.course-overview__back{color:var(--text-secondary);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.95rem;text-decoration:none;transition:color .2s;display:inline-flex}.course-overview__back:hover{color:var(--primary-color)}.course-overview__header-content{align-items:flex-start;gap:2rem;display:flex}.course-overview__thumbnail{border-radius:12px;flex-shrink:0;width:200px;height:150px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.course-overview__thumbnail img{object-fit:cover;width:100%;height:100%}.course-overview__header-text{flex:1}.course-overview__title{color:var(--text-primary);margin:0 0 1rem;font-size:2rem;font-weight:700}.course-overview__description{color:var(--text-secondary);margin:0 0 1rem;font-size:1.1rem;line-height:1.6}.course-overview__tags{flex-wrap:wrap;gap:.5rem;display:flex}.course-overview__tag{color:#4caf50;background:#4caf501a;border-radius:6px;padding:.4rem .8rem;font-size:.85rem;font-weight:500;display:inline-block}.course-overview__progress-section{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.course-overview__progress-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.course-overview__progress-header h2{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:600}.course-overview__progress-text{color:var(--text-secondary);font-size:.95rem;font-weight:500}.course-overview__progress-bar{background:#ffffff1a;border-radius:6px;width:100%;height:12px;margin-bottom:.5rem;overflow:hidden}.course-overview__progress-fill{background:linear-gradient(90deg,#4caf50,#66bb6a);border-radius:6px;height:100%;transition:width .3s}.course-overview__progress-percentage{text-align:right;color:var(--text-secondary);margin:0;font-size:.9rem}.course-overview__sections{margin-top:2rem}.course-overview__sections-title{color:var(--text-primary);margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.course-overview__no-sections{text-align:center;color:var(--text-secondary);padding:3rem 1rem}.section-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;margin-bottom:1rem;transition:border-color .2s;overflow:hidden}.section-card:hover{border-color:#fff3}.section-card__header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.section-card__header:hover{background:#ffffff05}.section-card__header-left{flex:1;align-items:center;gap:1rem;display:flex}.section-card__expand-icon{color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.section-card__expand-icon--expanded{transform:rotate(90deg)}.section-card__title{color:var(--text-primary);margin:0;font-size:1.1rem;font-weight:600}.section-card__stats{align-items:center;gap:1rem;display:flex}.section-card__progress-text{color:var(--text-secondary);font-size:.9rem;font-weight:500}.section-card__progress-circle{flex-shrink:0}.section-card__artifacts{border-top:1px solid #ffffff1a;padding:.5rem 1.5rem 1rem}.artifact-item{color:inherit;cursor:pointer;background:#ffffff80;border:2px solid #1a6ed91a;border-radius:8px;justify-content:space-between;align-items:center;margin:.5rem 0;padding:1rem;text-decoration:none;transition:all .2s;display:flex;position:relative}.artifact-item:hover{background:#fffc;border-color:#1a6ed94d;transform:translate(4px);box-shadow:0 2px 8px #1a6ed926}.artifact-item:hover .artifact-item__arrow{opacity:1;transform:translate(4px)}.artifact-item--completed{opacity:.7}.artifact-item__content{flex:1;align-items:center;gap:1rem;display:flex}.artifact-item__checkbox{cursor:pointer;background:0 0;border:2px solid #ffffff4d;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:all .2s;display:flex}.artifact-item__checkbox:hover{background:#4caf501a;border-color:#4caf50}.artifact-item--completed .artifact-item__checkbox{color:#fff;background:#4caf50;border-color:#4caf50}.artifact-item__type-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;margin-right:1rem;transition:all .2s;display:flex}.artifact-item__type-icon--video{color:#ef4444;background:#ef44441a}.artifact-item__type-icon--article{color:#3b82f6;background:#3b82f61a}.artifact-item:hover .artifact-item__type-icon--video{background:#ef444426}.artifact-item:hover .artifact-item__type-icon--article{background:#3b82f626}.artifact-item__info{flex:1;min-width:0}.artifact-item__title-row{align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.artifact-item__title{color:var(--text-primary);flex:1;min-width:0;margin:0;font-size:1rem;font-weight:600}.artifact-item__type-label{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;flex-shrink:0;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.artifact-item__type-icon--video~.artifact-item__info .artifact-item__type-label{color:#dc2626;background:#ef44441a}.artifact-item__type-icon--article~.artifact-item__info .artifact-item__type-label{color:#2563eb;background:#3b82f61a}.artifact-item__description{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.4}.artifact-item__arrow{color:#1a6ed980;opacity:.5;flex-shrink:0;margin-left:1rem;transition:all .2s}.artifact-item__thumbnail{border-radius:6px;flex-shrink:0;width:80px;height:60px;margin-left:1rem;overflow:hidden}.artifact-item__thumbnail img{object-fit:cover;width:100%;height:100%}@media (max-width:768px){.course-overview__container{border-radius:12px;padding:1.5rem}.course-overview__header-content{flex-direction:column}.course-overview__thumbnail{width:100%;height:200px}.course-overview__title{font-size:1.5rem}.section-card__header{padding:1rem}.section-card__artifacts{padding:.5rem 1rem 1rem}.artifact-item{flex-direction:column;align-items:flex-start;padding-right:3rem}.artifact-item__content{width:100%}.artifact-item__type-icon{width:36px;height:36px}.artifact-item__arrow{position:absolute;top:1rem;right:1rem}.artifact-item__thumbnail{width:100%;height:120px;margin-top:.75rem;margin-left:0}.artifact-item__title-row{flex-wrap:wrap}}@media (max-width:480px){.course-overview__container{border-radius:8px;padding:1rem}}.article-viewer{flex-direction:column;width:100%;height:100%;display:flex}.article-viewer__header{background:#ffffff0d;border-bottom:1px solid #ffffff1a;padding:1.5rem}.article-viewer__title{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.article-viewer__description{color:var(--text-secondary);margin:0;font-size:1rem;line-height:1.5}.article-viewer__container{flex:1;min-height:0;position:relative}.article-viewer__iframe{background:#fff;border:none;width:100%;height:100%;position:absolute;top:0;left:0}.artifact-view{z-index:2;flex-direction:column;height:100vh;display:flex;position:relative;overflow:hidden}.artifact-view__loading,.artifact-view__error{min-height:60vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.artifact-view__back-link{color:var(--primary-color);margin-top:1rem;font-weight:500;text-decoration:none}.artifact-view__back-link:hover{text-decoration:underline}.artifact-view__header{background:#ffffff0d;border-bottom:1px solid #ffffff1a;padding:1.5rem 2rem}.artifact-view__breadcrumb{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem;display:flex}.artifact-view__back-button-header{color:var(--text-primary);background:#ffffff1a;border:1px solid #fff3;border-radius:6px;align-items:center;gap:.5rem;margin-right:.5rem;padding:.5rem 1rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-flex}.artifact-view__back-button-header:hover{background:#ffffff26;border-color:#ffffff4d}.artifact-view__breadcrumb-link{color:var(--text-secondary);text-decoration:none;transition:color .2s}.artifact-view__breadcrumb-link:hover{color:var(--primary-color)}.artifact-view__breadcrumb-separator{color:var(--text-secondary);opacity:.5}.artifact-view__breadcrumb-current{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-weight:500;overflow:hidden}.artifact-view__course-info{align-items:center;gap:1.5rem;display:flex}.artifact-view__course-thumbnail{border-radius:8px;flex-shrink:0;width:100px;height:75px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.artifact-view__course-thumbnail img{object-fit:cover;width:100%;height:100%}.artifact-view__course-details{flex:1;min-width:0}.artifact-view__course-title{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;margin:0 0 .5rem;font-size:1.25rem;font-weight:600;overflow:hidden}.artifact-view__course-description{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.9rem;line-height:1.4;display:-webkit-box;overflow:hidden}.artifact-view__content{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:0;margin-top:0;display:flex;overflow:auto}.artifact-view__content--video{background:#000;padding:2rem}.artifact-view__content--article{background:#fff;justify-content:stretch;align-items:stretch;padding:0}.artifact-view__content .video-player{width:100%;max-width:1400px;height:auto;box-shadow:none;border-radius:0}.artifact-view__content .video-player__header{display:none}.artifact-view__content .video-player__container{aspect-ratio:16/9;max-height:calc(100vh - 300px)}.artifact-view__content .article-viewer{flex-direction:column;width:100%;height:100%;display:flex}.artifact-view__content .article-viewer__header{display:none}.artifact-view__content .article-viewer__container{flex:1;height:100%;min-height:0}@media (max-width:768px){.artifact-view__header{padding:1rem}.artifact-view__breadcrumb{font-size:.8rem}.artifact-view__breadcrumb-current{max-width:150px}.artifact-view__course-info{flex-direction:column;align-items:flex-start}.artifact-view__course-thumbnail{width:100%;height:120px}.artifact-view__course-title{white-space:normal;font-size:1.1rem}.artifact-view__content--video{padding:1rem}.artifact-view__content--article{justify-content:stretch;align-items:stretch;padding:0}.artifact-view__content .video-player__container{max-height:calc(100vh - 250px)}}:root{--color-primary:#1a6ed9;--color-primary-hover:#1557b0;--color-primary-light:#4d8fe3;--color-primary-lighter:#e6f2ff;--color-secondary:#ffc40c;--color-secondary-hover:#e6b000;--color-secondary-light:#ffd84d;--color-secondary-lighter:#fff8e1;--color-accent-navy:#0a2540;--color-accent-gray:#9fb5c7;--color-accent-red:#bb4430;--color-accent-red-light:#f5d6cf;--color-text-primary:#0a2540;--color-text-secondary:#3d5161;--color-text-tertiary:#5a6f84;--color-text-muted:#7891a8;--color-text-inverse:#fff;--color-background-primary:#fff;--color-background-secondary:#fafbfc;--color-background-tertiary:#f5f6f7;--color-background-alt:#fafbfc;--color-background-card:#fff;--color-background-hover:#f5f6f7;--color-background-disabled:#e8eaed;--color-border:#dfe1e6;--color-border-light:#e8eaed;--color-border-medium:#dfe1e6;--color-border-dark:#b3b9c4;--color-success:#10b981;--color-success-light:#d1fae5;--color-success-dark:#059669;--color-warning:#ffc40c;--color-warning-light:#fff8e1;--color-warning-dark:#e6b000;--color-error:#bb4430;--color-error-light:#f5d6cf;--color-error-dark:#9a3627;--color-danger:#bb4430;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-xxl:1.5rem;--font-size-xxxl:2rem;--font-size-huge:2.5rem;--line-height-tight:1.2;--line-height-normal:1.5;--line-height-relaxed:1.75;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-xxl:2.5rem;--spacing-xxxl:3rem;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-xxl:1rem;--radius-full:9999px;--border-radius-sm:.25rem;--border-radius-md:.375rem;--border-radius-lg:.5rem;--border-radius-xl:.75rem;--shadow-sm:0 1px 2px 0 #0a25400a;--shadow-md:0 2px 4px 0 #0a25400f;--shadow-lg:0 4px 8px 0 #0a254014;--shadow-xl:0 8px 16px 0 #0a25401a;--shadow-colored:0 2px 4px 0 #1a6ed914;--shadow-yellow:0 2px 4px 0 #ffc40c1f;--transition-fast:.15s ease;--transition-normal:.2s ease;--transition-slow:.3s ease}.App{z-index:10;background-color:#0000;min-height:100vh;position:relative}
