:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors:active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors:active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-form{background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 6px #0000000d;border:1px solid #e9ecef;max-width:400px;width:100%;text-align:center}.login-form h1{color:#333;margin-bottom:10px;font-size:28px;font-weight:600}.login-form p{color:#666;margin-bottom:30px;font-size:16px}.form-group{margin-bottom:20px;text-align:left}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:#667eea}.login-form button{width:100%;background:#495057;color:#fff;padding:12px;font-size:16px;font-weight:600;margin-top:10px;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.login-form button:hover:not(:disabled){background:#343a40}.login-form button:disabled{opacity:.6;cursor:not-allowed}.dashboard{min-height:100vh;padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;padding:0 20px}.dashboard-header h1{color:#2c3e50;font-size:32px;font-weight:600}.dashboard-content{max-width:1200px;margin:0 auto}.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;margin-bottom:50px}.service-card{background:#fff;padding:30px;border-radius:12px;text-align:center;cursor:pointer;transition:all .2s ease;border:1px solid #e9ecef;box-shadow:0 2px 4px #0000000d}.service-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #0000001a;border-color:#dee2e6}.service-icon{font-size:48px;margin-bottom:20px}.service-card h2{color:#333;font-size:24px;font-weight:600;margin-bottom:15px}.service-card p{color:#666;font-size:16px;margin-bottom:8px}.recent-activity{background:#fff;padding:30px;border-radius:12px;border:1px solid #e9ecef;box-shadow:0 2px 4px #0000000d}.recent-activity h2{color:#333;font-size:24px;font-weight:600;margin-bottom:20px}.recent-item{display:flex;align-items:center;padding:20px;border-radius:12px;cursor:pointer;transition:all .2s ease;margin-bottom:15px;background:#ffffff80}.recent-item:hover{background:#fffc;transform:translate(8px)}.recent-icon{font-size:32px;margin-right:20px}.recent-details h3{color:#333;font-size:18px;font-weight:600;margin-bottom:5px}.recent-details p{color:#666;font-size:14px;margin-bottom:10px}.progress-info{display:flex;align-items:center;gap:10px}.progress-info .progress-bar{width:200px;height:6px;background:#0000001a}.progress-info span{font-size:12px;color:#666;white-space:nowrap}.boards-beyond,.uworld-amboss,.bootcamp{min-height:100vh;padding:20px}.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:15px 20px;background:#fff;border-radius:12px;border:1px solid #e9ecef;box-shadow:0 2px 4px #0000000d}.content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;max-width:1200px;margin:0 auto}.content-item{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:20px;border-radius:12px;cursor:pointer;transition:all .3s ease;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 16px #0000001a;display:flex;align-items:flex-start;gap:15px}.content-item:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.item-icon{font-size:32px;flex-shrink:0}.item-details{flex:1}.item-details h3{color:#333;font-size:16px;font-weight:600;margin-bottom:8px;line-height:1.3}.item-details p{color:#666;font-size:14px;margin-bottom:4px}.video-progress,.block-progress{margin-top:10px}.video-progress .progress-bar{height:3px;margin-bottom:5px}.progress-text{font-size:12px;color:#666}.completed{color:#4caf50;font-weight:600}.video-navigation{display:flex;justify-content:space-between;gap:1rem;margin-top:2rem}.nav-btn{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fff;border:1px solid #dee2e6;border-radius:8px;color:#495057;cursor:pointer;transition:all .2s ease;min-height:60px;flex:1;max-width:300px}.nav-btn:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd;transform:translateY(-2px)}.nav-arrow{font-size:1.5rem;font-weight:700}.nav-info{display:flex;flex-direction:column;align-items:flex-start;text-align:left;flex:1}.next-btn .nav-info{align-items:flex-end;text-align:right}.nav-label{font-size:.9rem;opacity:.8;margin-bottom:.25rem}.nav-title{font-size:.95rem;font-weight:500;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.image-folder-item{border:2px dashed #dee2e6}.image-folder-item:hover{background:#f8f9fa;border-color:#adb5bd}.video-player{min-height:100vh;background:#f8f9fa;display:flex;flex-direction:column}.player-header{background:#fff;padding:10px 20px;display:flex;align-items:center;gap:15px;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000000d}.video-info h1{color:#2c3e50;font-size:16px;font-weight:600;margin-bottom:2px;line-height:1.2}.video-info p{color:#6c757d;font-size:12px;margin-bottom:1px;line-height:1.3}.player-container{flex:1;display:flex;flex-direction:column;position:relative;max-width:1200px;margin:0 auto;padding:20px}.loading-overlay{position:absolute;inset:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:10}.video-element{width:100%;max-height:70vh;object-fit:contain;border-radius:12px 12px 0 0;background:#000;box-shadow:0 4px 20px #0000001a}.progress-info{background:#ffffffe6;border:1px solid rgba(0,0,0,.1);border-radius:0 0 12px 12px;padding:10px 20px}.progress-stats{display:flex;flex-flow:row nowrap;justify-content:space-between;align-items:center;color:#495057;font-size:14px;width:100%}.completed-checkmark{color:#4caf50;font-size:20px;font-weight:700}.image-viewer{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column}.viewer-header{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 2px 8px #0000001a}.viewer-controls{display:flex;gap:10px}.nav-btn{background:#495057;color:#fff;padding:8px 16px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.nav-btn:not(:disabled):hover{background:#343a40}.image-container{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;overflow:auto}.question-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 16px #0000001a}.image-navigation{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:20px;border-top:1px solid rgba(0,0,0,.1)}.thumbnail-strip{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:15px;max-height:200px;overflow-y:auto}.thumbnail{width:40px;height:40px;border-radius:6px;background:#667eea1a;color:#667eea;font-size:12px;font-weight:500;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.thumbnail:hover{background:#f8f9fa;border-color:#adb5bd;transform:translateY(-2px)}.thumbnail.active{background:#495057;color:#fff;box-shadow:0 2px 4px #0000001a}.keyboard-shortcuts{text-align:center;margin-top:15px}.keyboard-shortcuts p{color:#666;font-size:12px}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:20px;text-align:center}.services-grid{grid-template-columns:1fr;gap:20px}.content-grid{grid-template-columns:1fr}.content-header,.viewer-header{flex-direction:column;gap:15px;align-items:flex-start}.viewer-controls{align-self:stretch;justify-content:space-between}.progress-info .progress-bar{width:150px}.thumbnail-strip{max-height:120px}.thumbnail{width:35px;height:35px;font-size:11px}}@media(max-width:480px){.login-form{padding:30px 20px}.dashboard,.content-item{padding:15px}.item-details h3{font-size:14px}.item-details p{font-size:12px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f9fa;min-height:100vh;color:#2c3e50;line-height:1.6}#app{min-height:100vh}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;color:#666}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:15px;border-radius:8px;text-align:center;margin:20px}.error-message button{background:#c33;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-top:10px}.error-message button:hover{background:#a22}button{cursor:pointer;border:none;border-radius:6px;font-size:14px;font-weight:500;transition:all .2s ease}.back-btn{background:#f8f9fa;color:#495057;padding:8px 16px;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500}.back-btn:hover{background:#e9ecef;border-color:#adb5bd;transform:translate(-2px)}.logout-btn{background:#dc3545;color:#fff;padding:8px 16px;border:none;border-radius:6px;cursor:pointer;transition:background .2s ease;font-size:14px;font-weight:500}.logout-btn:hover{background:#c82333}.progress-bar{width:100%;height:4px;background:#0000001a;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#45a049);transition:width .3s ease}.breadcrumb{display:flex;align-items:center;gap:5px}.breadcrumb-link{background:none;color:#495057;padding:4px 8px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s ease}.breadcrumb-link:hover{background:#f8f9fa;color:#2c3e50}.breadcrumb-separator{color:#6c757d}.header-left{display:flex;align-items:center;gap:10px}.up-btn{background:#6c757d;color:#fff;padding:8px 16px;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease;font-size:14px;font-weight:500}.up-btn:hover{background:#5a6268}
