:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.role-selector-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.role-selector-card{background:#fff;border-radius:16px;padding:40px;max-width:600px;width:100%;box-shadow:0 20px 60px #0003}.role-selector-header{text-align:center;margin-bottom:40px}.role-selector-header h1{font-size:28px;color:#1a1a2e;margin:0 0 8px}.role-selector-header p{font-size:16px;color:#666;margin:0}.role-options{display:flex;flex-direction:column;gap:16px}.role-option{display:flex;align-items:center;gap:20px;padding:24px;border:2px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s ease;text-align:left}.role-option:hover:not(:disabled){border-color:#667eea;background:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.role-option:disabled{opacity:.6;cursor:not-allowed}.role-option.student:hover:not(:disabled){border-color:#4caf50;background:#f1f8f2}.role-option.instructor:hover:not(:disabled){border-color:#2196f3;background:#f0f7ff}.role-icon{font-size:40px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border-radius:12px}.role-content h2{font-size:18px;color:#1a1a2e;margin:0 0 4px}.role-content p{font-size:14px;color:#666;margin:0}.role-selector-footer{margin-top:32px;padding-top:24px;border-top:1px solid #eee;text-align:center}.email-display{font-size:14px;color:#888;margin:0 0 8px}.logout-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;padding:0;text-decoration:underline}.logout-link:hover{color:#764ba2}@media (max-width: 480px){.role-selector-card{padding:24px}.role-option{flex-direction:column;text-align:center;padding:20px}.role-icon{margin:0 auto}}.course-card{background:#fff;border:1px solid #e0e0e0;border-left:4px solid transparent;border-radius:12px;padding:24px;cursor:pointer;transition:all .2s ease}.course-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.course-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.course-name{font-size:18px;font-weight:600;color:#1a1a2e;margin:0;flex:1}.instructor-badge{background:#e3f2fd;color:#1976d2;font-size:12px;font-weight:500;padding:4px 8px;border-radius:4px;white-space:nowrap}.course-description{font-size:14px;color:#666;margin:0 0 12px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-instructor{font-size:13px;color:#888;margin:0 0 12px}.course-card-footer{padding-top:12px;border-top:1px solid #f0f0f0}.view-course-link{font-size:14px;color:#667eea;font-weight:500}.course-card:hover .view-course-link{color:#764ba2}.profile-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.profile-modal{background:var(--bg-primary, #ffffff);border-radius:12px;width:100%;max-width:400px;box-shadow:0 4px 20px #00000026}.profile-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color, #e5e5e5)}.profile-modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-primary, #1a1a1a)}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary, #666);padding:0;line-height:1}.close-btn:hover{color:var(--text-primary, #1a1a1a)}.profile-modal-body{padding:20px}.form-group{margin-bottom:16px}.form-group:last-of-type{margin-bottom:0}.form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary, #1a1a1a);margin-bottom:6px}.form-group input{width:100%;padding:10px 12px;border:1px solid var(--border-color, #d1d5db);border-radius:8px;font-size:14px;color:var(--text-primary, #1a1a1a);background:var(--bg-primary, #ffffff);transition:border-color .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--accent-color, #6366f1);box-shadow:0 0 0 3px #6366f11a}.form-group input.disabled{background:var(--bg-secondary, #f5f5f5);color:var(--text-secondary, #666);cursor:not-allowed}.helper-text{font-size:12px;color:var(--text-secondary, #666);margin-top:4px;display:block}.error-message{background:#fef2f2;color:#dc2626;padding:10px 12px;border-radius:8px;font-size:14px;margin-top:16px}.profile-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color, #e5e5e5)}.cancel-btn,.save-btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn{background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, #d1d5db);color:var(--text-primary, #1a1a1a)}.cancel-btn:hover:not(:disabled){background:var(--bg-hover, #e5e5e5)}.save-btn{background:var(--accent-color, #6366f1);border:none;color:#fff}.save-btn:hover:not(:disabled){background:var(--accent-hover, #4f46e5)}.cancel-btn:disabled,.save-btn:disabled{opacity:.6;cursor:not-allowed}.edit-profile-btn{background:none;border:1px solid #ddd;padding:10px 16px;border-radius:8px;font-size:14px;color:#333;cursor:pointer;transition:all .2s ease}.edit-profile-btn:hover{background:#f5f5f5;border-color:#ccc}@font-face{font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2) format("woff2"),url(/assets/KaTeX_AMS-Regular-DMm9YOAa.woff) format("woff"),url(/assets/KaTeX_AMS-Regular-DRggAlZN.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff) format("woff"),url(/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff) format("woff"),url(/assets/KaTeX_Fraktur-Regular-CB_wures.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Main-Bold-Cx986IdX.woff2) format("woff2"),url(/assets/KaTeX_Main-Bold-Jm3AIy58.woff) format("woff"),url(/assets/KaTeX_Main-Bold-waoOVXN0.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2) format("woff2"),url(/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff) format("woff"),url(/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2) format("woff2"),url(/assets/KaTeX_Main-Italic-BMLOBm91.woff) format("woff"),url(/assets/KaTeX_Main-Italic-3WenGoN9.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Main-Regular-B22Nviop.woff2) format("woff2"),url(/assets/KaTeX_Main-Regular-Dr94JaBh.woff) format("woff"),url(/assets/KaTeX_Main-Regular-ypZvNtVU.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2) format("woff2"),url(/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff) format("woff"),url(/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Math-Italic-t53AETM-.woff2) format("woff2"),url(/assets/KaTeX_Math-Italic-DA0__PXp.woff) format("woff"),url(/assets/KaTeX_Math-Italic-flOr_0UB.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:700;src:url(/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff) format("woff"),url(/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:italic;font-weight:400;src:url(/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff) format("woff"),url(/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:400;src:url(/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff) format("woff"),url(/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf) format("truetype")}@font-face{font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Script-Regular-D3wIWfF6.woff2) format("woff2"),url(/assets/KaTeX_Script-Regular-D5yQViql.woff) format("woff"),url(/assets/KaTeX_Script-Regular-C5JkGWo-.ttf) format("truetype")}@font-face{font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2) format("woff2"),url(/assets/KaTeX_Size1-Regular-C195tn64.woff) format("woff"),url(/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf) format("truetype")}@font-face{font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2) format("woff2"),url(/assets/KaTeX_Size2-Regular-oD1tc_U0.woff) format("woff"),url(/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf) format("truetype")}@font-face{font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(data:font/woff2;base64,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) format("woff2"),url(/assets/KaTeX_Size3-Regular-CTq5MqoE.woff) format("woff"),url(/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf) format("truetype")}@font-face{font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2) format("woff2"),url(/assets/KaTeX_Size4-Regular-BF-4gkZK.woff) format("woff"),url(/assets/KaTeX_Size4-Regular-DWFBv043.ttf) format("truetype")}@font-face{font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2) format("woff2"),url(/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff) format("woff"),url(/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf) format("truetype")}.katex{font: 1.21em KaTeX_Main,Times New Roman,serif;line-height:1.2;text-indent:0;text-rendering:auto}.katex *{-ms-high-contrast-adjust:none!important;border-color:currentColor}.katex .katex-version:after{content:"0.16.22"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.katex .katex-html>.newline{display:block}.katex .base{position:relative;white-space:nowrap;width:-webkit-min-content;width:-moz-min-content;width:min-content}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;display:inline-table;table-layout:fixed}.katex .vlist-r{display:table-row}.katex .vlist{display:table-cell;position:relative;vertical-align:bottom}.katex .vlist>span{display:block;height:0;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{overflow:hidden;width:0}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{display:table-cell;font-size:1px;min-width:2px;vertical-align:bottom;width:2px}.katex .vbox{align-items:baseline;display:inline-flex;flex-direction:column}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{display:inline-flex;flex-direction:row}.katex .thinbox{max-width:0;width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .clap,.katex .llap,.katex .rlap{position:relative;width:0}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline{border-bottom-style:dashed;display:inline-block;width:100%}.katex .sqrt>.root{margin-left:.2777777778em;margin-right:-.5555555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.1666666667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.6666666667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.4566666667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.1466666667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.7142857143em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.8571428571em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.1428571429em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.2857142857em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.4285714286em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.7142857143em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.0571428571em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.4685714286em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.9628571429em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.5542857143em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.7777777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.8888888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.1111111111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.3044444444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.7644444444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.5833333333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.7283333333em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.0733333333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.4861111111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.4402777778em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.7277777778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.2893518519em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.4050925926em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462962963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.5208333333em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.5787037037em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.2002314815em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.4398148148em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.2410800386em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.2892960463em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512054em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.3857280617em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.4339440694em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.4821600771em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.5785920926em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.6943105111em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.8331726133em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.1996142719em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.2009646302em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.2411575563em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.2813504823em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.3215434084em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.3617363344em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.4019292605em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.4823151125em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778135em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.6945337621em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.8336012862em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{display:inline-block;width:.12em}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{display:inline-block;min-width:1px}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;fill-rule:nonzero;fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;display:block;height:inherit;position:absolute;width:100%}.katex svg path{stroke:none}.katex img{border-style:none;max-height:none;max-width:none;min-height:0;min-width:0}.katex .stretchy{display:block;overflow:hidden;position:relative;width:100%}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{overflow:hidden;position:relative;width:100%}.katex .halfarrow-left{left:0;overflow:hidden;position:absolute;width:50.2%}.katex .halfarrow-right{overflow:hidden;position:absolute;right:0;width:50.2%}.katex .brace-left{left:0;overflow:hidden;position:absolute;width:25.1%}.katex .brace-center{left:25%;overflow:hidden;position:absolute;width:50%}.katex .brace-right{overflow:hidden;position:absolute;right:0;width:25.1%}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{border:.04em solid;box-sizing:border-box}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{border-right:.049em solid;border-top:.049em solid;box-sizing:border-box;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{display:inline-block;position:absolute;right:calc(50% + .3em);text-align:left}.katex .cd-label-right{display:inline-block;left:calc(50% + .3em);position:absolute;text-align:right}.katex-display{display:block;margin:1em 0;text-align:center}.katex-display>.katex{display:block;text-align:center;white-space:nowrap}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{padding-left:2em;text-align:left}body{counter-reset:katexEqnNo mmlEqnNo}.confirmation-bar-container{border-top:1px solid #ddd;padding:1rem}.confirmation-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #00000014;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.confirmation-question{flex:1;font-size:14px;color:#495057;font-weight:500}.confirmation-btn{padding:8px 24px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.confirmation-bar .confirmation-btn-yes{background:#06c;color:#fff}.confirmation-bar .confirmation-btn-yes:hover:not(:disabled){background:#0052a3;transform:translateY(-1px);box-shadow:0 2px 8px #0066cc4d}.confirmation-bar .confirmation-btn-yes.selected{background:#0052a3;box-shadow:0 2px 8px #06c6}.confirmation-bar .confirmation-btn-no{background:#dc3545;color:#fff}.confirmation-bar .confirmation-btn-no:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 2px 8px #dc35454d}.confirmation-bar .confirmation-btn-no.selected{background:#c82333;box-shadow:0 2px 8px #dc354566}.confirmation-btn:active:not(:disabled){transform:translateY(0)}.confirmation-btn:disabled{cursor:not-allowed;opacity:.6}.dashboard-container{min-height:100vh;background:#f5f7fa}.dashboard-container.instructor{background:#f8f9ff}.dashboard-header{background:#fff;padding:20px 32px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000a}.header-left h1{font-size:24px;color:#1a1a2e;margin:0 0 4px}.header-left p{font-size:14px;color:#666;margin:0}.header-right{display:flex;gap:12px;align-items:center}.switch-role-btn{background:#f0f0f0;border:none;padding:10px 16px;border-radius:8px;font-size:14px;color:#333;cursor:pointer;transition:all .2s ease}.switch-role-btn:hover{background:#e0e0e0}.create-course-btn{background:#667eea;border:none;padding:10px 20px;border-radius:8px;font-size:14px;color:#fff;cursor:pointer;font-weight:500;transition:all .2s ease}.create-course-btn:hover{background:#5a6fd6}.dashboard-container .logout-btn{background:none;border:1px solid #ef4444;padding:10px 16px;border-radius:8px;font-size:14px;color:#ef4444;cursor:pointer;transition:all .2s ease;width:auto}.dashboard-container .logout-btn:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626}.dashboard-content{padding:32px;max-width:1200px;margin:0 auto}.course-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.loading-state,.error-state,.empty-state{text-align:center;padding:60px 20px}.loading-state .spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.loading-state p,.error-state p{color:#666;font-size:16px}.error-state button{margin-top:16px;background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer}.empty-state{background:#fff;border-radius:12px;padding:60px 40px;max-width:400px;margin:0 auto}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h2{font-size:20px;color:#1a1a2e;margin:0 0 8px}.empty-state p{font-size:14px;color:#666;margin:0 0 4px}@media (max-width: 768px){.dashboard-header{flex-direction:column;gap:16px;text-align:center}.header-right{flex-wrap:wrap;justify-content:center}.dashboard-content{padding:20px}.course-grid{grid-template-columns:1fr}}.strategies-panel{background:#fff;border-radius:12px;padding:32px}.strategies-panel h2{font-size:22px;font-weight:600;color:#1a1a2e;margin:0 0 6px}.panel-description{font-size:14px;color:#6b7280;margin:0 0 28px;line-height:1.5}.current-strategies{margin-bottom:32px}.current-strategies h3{font-size:15px;font-weight:600;color:#374151;margin:0}.strategies-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.strategies-header h3{margin:0}.strategies-panel .edit-btn{background:#6b7280;border:none;padding:9px 20px;border-radius:8px;font-size:13px;font-weight:500;color:#fff;cursor:pointer;transition:all .15s ease}.strategies-panel .edit-btn:hover{background:#4b5563}.edit-actions{display:flex;align-items:center;gap:10px}.strategies-panel .discard-btn{background:#fff;border:1px solid #d1d5db;padding:8px 19px;border-radius:8px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s ease}.strategies-panel .discard-btn:hover:not(:disabled){background:#f9fafb;color:#374151}.strategies-panel .save-btn{background:#10b981;border:none;padding:9px 20px;border-radius:8px;font-size:13px;font-weight:500;color:#fff;cursor:pointer;transition:all .15s ease}.strategies-panel .save-btn:hover:not(:disabled){background:#059669}.strategies-panel .save-btn:disabled,.strategies-panel .discard-btn:disabled{opacity:.5;cursor:not-allowed}.strategy-section{border-radius:12px;margin-bottom:16px;overflow:hidden}.strategy-section:last-of-type{margin-bottom:0}.strategy-section[data-section=LOs]{background:#f8fafc}.strategy-section[data-section=LOs] .section-header{background:#e0f2fe}.strategy-section[data-section=LOs] .section-header:hover{background:#bae6fd}.strategy-section[data-section=LOs] .section-title{color:#0369a1}.strategy-section[data-section=LOs] .section-count{background:#0ea5e9;color:#fff}.strategy-section[data-section=LOs] .expand-icon{color:#0ea5e9}.strategy-section[data-section=LO_selection_rules]{background:#f8fdfb}.strategy-section[data-section=LO_selection_rules] .section-header{background:#d1fae5}.strategy-section[data-section=LO_selection_rules] .section-header:hover{background:#a7f3d0}.strategy-section[data-section=LO_selection_rules] .section-title{color:#047857}.strategy-section[data-section=LO_selection_rules] .section-count{background:#10b981;color:#fff}.strategy-section[data-section=LO_selection_rules] .expand-icon{color:#10b981}.strategy-section[data-section=activity_design_rules]{background:#faf8ff}.strategy-section[data-section=activity_design_rules] .section-header{background:#ede9fe}.strategy-section[data-section=activity_design_rules] .section-header:hover{background:#ddd6fe}.strategy-section[data-section=activity_design_rules] .section-title{color:#6d28d9}.strategy-section[data-section=activity_design_rules] .section-count{background:#8b5cf6;color:#fff}.strategy-section[data-section=activity_design_rules] .expand-icon{color:#8b5cf6}.strategy-section[data-section=common_misconceptions]{background:#fffcf5}.strategy-section[data-section=common_misconceptions] .section-header{background:#fef3c7}.strategy-section[data-section=common_misconceptions] .section-header:hover{background:#fde68a}.strategy-section[data-section=common_misconceptions] .section-title{color:#b45309}.strategy-section[data-section=common_misconceptions] .section-count{background:#f59e0b;color:#fff}.strategy-section[data-section=common_misconceptions] .expand-icon{color:#f59e0b}.section-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;transition:background .15s ease;-webkit-user-select:none;user-select:none}.section-header-left{display:flex;align-items:center;gap:12px;flex:1;cursor:pointer}.section-header-right{display:flex;align-items:center;gap:8px}.expand-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:500;flex-shrink:0}.section-title{font-size:14px;font-weight:600}.section-count{font-size:12px;padding:3px 10px;border-radius:10px;font-weight:600}.section-edit-btn{background:#6b7280;border:none;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;color:#fff;cursor:pointer;transition:all .15s ease}.section-edit-btn:hover{background:#4b5563}.strategy-section[data-section=LOs] .section-edit-btn{background:#0ea5e9}.strategy-section[data-section=LOs] .section-edit-btn:hover{background:#0284c7}.strategy-section[data-section=LO_selection_rules] .section-edit-btn{background:#10b981}.strategy-section[data-section=LO_selection_rules] .section-edit-btn:hover{background:#059669}.strategy-section[data-section=activity_design_rules] .section-edit-btn{background:#8b5cf6}.strategy-section[data-section=activity_design_rules] .section-edit-btn:hover{background:#7c3aed}.strategy-section[data-section=common_misconceptions] .section-edit-btn{background:#f59e0b}.strategy-section[data-section=common_misconceptions] .section-edit-btn:hover{background:#d97706}.section-edit-actions{display:flex;align-items:center;gap:8px}.section-unsaved-indicator{display:flex;align-items:center;gap:4px;font-size:11px;color:#d97706;font-weight:500}.section-unsaved-indicator .unsaved-dot{width:6px;height:6px;background:#f59e0b;border-radius:50%}.section-discard-btn{background:#fff;border:1px solid #d1d5db;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s ease}.section-discard-btn:hover:not(:disabled){background:#f9fafb;color:#374151;border-color:#9ca3af}.section-save-btn{background:#10b981;border:none;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;color:#fff;cursor:pointer;transition:all .15s ease}.section-save-btn:hover:not(:disabled){background:#059669}.section-save-btn:disabled,.section-discard-btn:disabled{opacity:.5;cursor:not-allowed}.section-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(0,0,0,.08)}.section-footer .add-item-btn{margin-top:0}.section-footer-right{display:flex;align-items:center;gap:10px}.strategy-section.editing{box-shadow:0 0 0 2px #3b82f64d}.strategy-section[data-section=LOs].editing{box-shadow:0 0 0 2px #0ea5e94d}.strategy-section[data-section=LO_selection_rules].editing{box-shadow:0 0 0 2px #10b9814d}.strategy-section[data-section=activity_design_rules].editing{box-shadow:0 0 0 2px #8b5cf64d}.strategy-section[data-section=common_misconceptions].editing{box-shadow:0 0 0 2px #f59e0b4d}.section-preview{padding:12px 18px;border-top:1px solid rgba(0,0,0,.05)}.preview-item{font-size:13px;color:#6b7280;line-height:1.5;padding:4px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-more{font-size:12px;color:#9ca3af;font-style:italic;padding-top:4px}.section-content{padding:20px}.tree-node{position:relative;margin-bottom:6px}.tree-node:last-child{margin-bottom:0}.tree-node-header{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border-radius:8px;transition:box-shadow .15s ease}.tree-node-header:hover{box-shadow:0 2px 8px #3b82f626}.tree-node-header .expand-icon{cursor:pointer;width:24px;height:24px;font-size:14px;color:#3b82f6;background:#eff6ff;border-radius:6px;transition:all .15s ease}.tree-node-header .expand-icon:hover{background:#dbeafe}.tree-node-title{font-size:14px;color:#1f2937;flex:1;font-weight:500}.sub-count{font-size:12px;color:#9ca3af;font-weight:400}.sub-items{margin-left:12px;margin-top:4px;padding-left:24px;position:relative}.sub-items:before{content:"";position:absolute;left:11px;top:0;bottom:0;width:2px;background:#bfdbfe}.sub-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border-radius:6px;margin-bottom:4px;position:relative}.sub-item:before{content:"";position:absolute;left:-13px;top:50%;width:12px;height:2px;background:#bfdbfe}.sub-item:last-child:after{content:"";position:absolute;left:-13px;top:calc(50% + 1px);bottom:-4px;width:2px;background:#f8fafc}.sub-item:last-child{margin-bottom:0}.sub-item-text{font-size:13px;color:#4b5563;line-height:1.5;flex:1}.strategy-item{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fff;border-radius:8px;margin-bottom:8px}.strategy-item:last-child{margin-bottom:0}.strategy-text{font-size:13px;color:#374151;line-height:1.6;flex:1}.strategy-input{flex:1;padding:0;border:none;border-bottom:1px dashed transparent;border-radius:0;font-size:14px;font-family:inherit;color:#1f2937;background:transparent;transition:border-color .15s ease}.strategy-input:hover{border-bottom-color:#d1d5db}.strategy-input:focus{outline:none;border-bottom-color:#3b82f6}.strategy-textarea.lo-title{font-size:14px;font-weight:500;color:#1f2937}.strategy-textarea.lo-sub{font-size:13px;color:#4b5563}.strategy-textarea{flex:1;padding:0;border:none;border-bottom:1px dashed transparent;border-radius:0;font-size:13px;font-family:inherit;color:#374151;background:transparent;resize:none;min-height:1.6em;max-height:6.4em;transition:border-color .15s ease;line-height:1.6;overflow-y:auto;field-sizing:content}.strategy-textarea:hover{border-bottom-color:#d1d5db}.strategy-textarea:focus{outline:none;border-bottom-color:#3b82f6}.strategy-section[data-section=LOs] .strategy-textarea:focus{border-bottom-color:#0ea5e9}.strategy-section[data-section=LO_selection_rules] .strategy-textarea:focus{border-bottom-color:#10b981}.strategy-section[data-section=activity_design_rules] .strategy-textarea:focus{border-bottom-color:#8b5cf6}.strategy-section[data-section=common_misconceptions] .strategy-textarea:focus{border-bottom-color:#f59e0b}.delete-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:#d1d5db;font-size:16px;cursor:pointer;transition:all .15s ease;flex-shrink:0}.delete-btn:hover{background:#fef2f2;color:#ef4444}.add-item-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:#ffffffb3;border:none;border-radius:8px;color:#6b7280;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease;margin-top:12px}.add-item-btn:hover{background:#fff;color:#374151}.strategy-section[data-section=LOs] .add-item-btn:hover{color:#0ea5e9}.strategy-section[data-section=LO_selection_rules] .add-item-btn:hover{color:#10b981}.strategy-section[data-section=activity_design_rules] .add-item-btn:hover{color:#8b5cf6}.strategy-section[data-section=common_misconceptions] .add-item-btn:hover{color:#f59e0b}.add-item-btn.main{margin-top:14px}.add-item-btn.add-sub{margin-left:36px;margin-top:6px}.upload-section{border-top:1px solid #e5e7eb;padding-top:28px;margin-top:8px}.upload-section h3{font-size:15px;font-weight:600;color:#374151;margin:0}.upload-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.file-input-area{border:2px dashed #d1d5db;border-radius:12px;padding:48px 32px;text-align:center;transition:all .2s ease;cursor:pointer;background:#f9fafb}.file-input-area:hover{border-color:#3b82f6;background:#eff6ff}.file-input-area.dragging{border-color:#3b82f6;background:#dbeafe;border-style:solid}.hidden-input{display:none}.file-input-label{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:14px}.upload-icon{font-size:36px;opacity:.8}.upload-text{font-size:14px;color:#3b82f6;font-weight:500}.file-input-label span:last-child{font-size:14px;color:#3b82f6;font-weight:500}.pending-upload{background:#f9fafb;border-radius:12px;padding:24px;border:1px solid #e5e7eb}.file-info{display:flex;align-items:center;gap:14px;margin-bottom:18px}.file-icon{font-size:28px}.file-name{font-size:14px;font-weight:600;color:#374151}.preview-stats{display:flex;gap:10px;margin-bottom:22px;flex-wrap:wrap}.preview-stats span{font-size:12px;color:#fff;padding:6px 12px;border-radius:6px;font-weight:500}.preview-stats span:nth-child(1){background:#3b82f6}.preview-stats span:nth-child(2){background:#10b981}.preview-stats span:nth-child(3){background:#8b5cf6}.preview-stats span:nth-child(4){background:#f59e0b}.upload-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-btn{background:#fff;border:1px solid #d1d5db;padding:10px 22px;border-radius:8px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .15s ease}.cancel-btn:hover:not(:disabled){background:#f9fafb}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.upload-btn{background:#3b82f6;border:none;padding:10px 22px;border-radius:8px;font-size:14px;color:#fff;font-weight:500;cursor:pointer;transition:all .15s ease}.upload-btn:hover:not(:disabled){background:#2563eb}.upload-btn:disabled{opacity:.6;cursor:not-allowed}.strategies-message{margin-top:20px;padding:14px 18px;border-radius:10px;font-size:14px;font-weight:500}.strategies-message.error{background:#fef2f2;color:#dc2626}.strategies-message.success{background:#ecfdf5;color:#059669}.loading-state{text-align:center;padding:48px}.loading-state .spinner{width:36px;height:36px;border:3px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.loading-state p{color:#6b7280;font-size:14px;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}.stat{background:#fff;border-radius:10px;padding:18px;text-align:center;box-shadow:0 1px 3px #0000000f}.stat-value{display:block;font-size:28px;font-weight:600;color:#3b82f6;margin-bottom:6px}.stat-label{font-size:12px;color:#6b7280;font-weight:500}.rule-card{background:#fff;border-radius:8px;padding:14px 16px;margin-bottom:8px;transition:box-shadow .15s ease}.rule-card:last-child{margin-bottom:0}.strategy-section[data-section=LO_selection_rules] .rule-card:hover{box-shadow:0 2px 8px #10b98126}.strategy-section[data-section=activity_design_rules] .rule-card:hover{box-shadow:0 2px 8px #8b5cf626}.rule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.rule-id{font-size:11px;color:#9ca3af;font-family:monospace}.rule-body{display:flex;flex-direction:column;gap:8px}.rule-condition,.rule-strategy{display:flex;align-items:flex-start;gap:8px}.rule-condition label,.rule-strategy label{font-size:12px;font-weight:600;color:#9ca3af;min-width:45px;flex-shrink:0}.rule-arrow{display:none}.rule-text{font-size:13px;color:#374151;line-height:1.6;flex:1}.rule-textarea{flex:1;padding:0;border:none;border-bottom:1px dashed transparent;border-radius:0;font-size:13px;font-family:inherit;color:#374151;background:transparent;resize:none;min-height:1.6em;max-height:6.4em;transition:border-color .15s ease;line-height:1.6;overflow-y:auto;field-sizing:content}.rule-textarea:hover{border-bottom-color:#d1d5db}.rule-textarea:focus{outline:none;border-bottom-color:#3b82f6}.rule-textarea.condition,.rule-textarea.strategy{background:transparent;border-bottom:1px dashed transparent}.strategy-section[data-section=LO_selection_rules] .rule-textarea:focus{border-bottom-color:#10b981}.strategy-section[data-section=activity_design_rules] .rule-textarea:focus{border-bottom-color:#8b5cf6}.info-btn{width:20px;height:20px;border-radius:50%;border:1px solid #d1d5db;background:#fff;color:#6b7280;font-size:12px;font-weight:600;cursor:pointer;margin-left:auto;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.info-btn:hover{background:#f3f4f6;color:#374151;border-color:#9ca3af}.schema-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.schema-modal{background:#fff;border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.schema-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.schema-modal-header h3{font-size:18px;font-weight:600;color:#111827;margin:0}.close-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:#6b7280;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.close-btn:hover{background:#f3f4f6;color:#374151}.schema-modal-content{padding:24px}.schema-description{font-size:14px;color:#6b7280;line-height:1.6;margin:0 0 20px}.schema-code{background:#1f2937;color:#10b981;padding:16px;border-radius:8px;font-size:13px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;overflow-x:auto;margin:0 0 20px;line-height:1.6}.schema-fields{background:#f9fafb;border-radius:8px;padding:16px}.schema-fields h4{font-size:14px;font-weight:600;color:#374151;margin:0 0 12px}.schema-fields ul{margin:0;padding-left:20px}.schema-fields li{font-size:13px;color:#4b5563;line-height:1.8}.schema-fields li strong{color:#111827}.enrollment-panel{background:#fff;border-radius:12px;padding:24px}.enrollment-panel h2{font-size:20px;color:#1a1a2e;margin:0 0 8px}.enroll-section{margin-bottom:24px}.enroll-section h3,.enrolled-section h3{font-size:16px;color:#1a1a2e;margin:0 0 12px}.email-input-area textarea{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:100px;transition:border-color .2s ease;box-sizing:border-box}.enroll-btn{align-self:flex-start;background:#667eea;border:none;padding:10px 20px;border-radius:8px;font-size:14px;color:#fff;font-weight:500;cursor:pointer;transition:all .2s ease}.enroll-btn:hover:not(:disabled){background:#5a6fd6}.enroll-btn:disabled{opacity:.6;cursor:not-allowed}.enrollment-message{margin-bottom:16px;padding:12px 16px;border-radius:8px;font-size:14px}.enrollment-message.error{background:#fff0f0;color:#d32f2f;border:1px solid #ffcdd2}.enrollment-message.success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.enrolled-section{border-top:1px solid #eee;padding-top:24px}.empty-enrollments{text-align:center;padding:40px 20px;background:#f8f9ff;border-radius:8px}.empty-enrollments p{color:#666;font-size:14px;margin:0}.enrollment-list{display:flex;flex-direction:column;gap:8px}.enrollment-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9ff;border-radius:8px;border:1px solid #e8e8f0}.student-info{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.student-email{font-size:14px;color:#1a1a2e;font-weight:500}.student-name{font-size:13px;color:#666}.student-status{font-size:12px;padding:4px 8px;border-radius:4px}.student-status.active{background:#e8f5e9;color:#2e7d32}.student-status.pending{background:#fff8e1;color:#f57c00}@media (max-width: 600px){.enrollment-item{flex-direction:column;align-items:flex-start;gap:12px}.remove-btn{align-self:flex-end}}.admin-panel{background:#fff;border-radius:12px;padding:24px}.admin-panel h2{font-size:20px;color:#1a1a2e;margin:0 0 8px}.panel-description{font-size:14px;color:#666;margin:0 0 24px}.add-admin-section{margin-bottom:24px}.add-admin-section h3,.admins-section h3{font-size:16px;color:#1a1a2e;margin:0 0 12px}.email-input-area{display:flex;flex-direction:column;gap:12px}.email-input-area textarea{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s ease;box-sizing:border-box}.email-input-area textarea:focus{outline:none;border-color:#667eea}.email-input-area textarea:disabled{background:#f5f5f5;cursor:not-allowed}.input-hint{font-size:13px;color:#667eea}.add-admin-btn{align-self:flex-start;background:#667eea;border:none;padding:10px 20px;border-radius:8px;font-size:14px;color:#fff;font-weight:500;cursor:pointer;transition:all .2s ease}.add-admin-btn:hover:not(:disabled){background:#5a6fd6}.add-admin-btn:disabled{opacity:.6;cursor:not-allowed}.admin-message{margin-bottom:16px;padding:12px 16px;border-radius:8px;font-size:14px}.admin-message.error{background:#fff0f0;color:#d32f2f;border:1px solid #ffcdd2}.admin-message.success{background:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.admins-section{border-top:1px solid #eee;padding-top:24px}.empty-admins{text-align:center;padding:40px 20px;background:#f8f9ff;border-radius:8px}.empty-admins p{color:#666;font-size:14px;margin:0}.admin-list{display:flex;flex-direction:column;gap:8px}.admin-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9ff;border-radius:8px;border:1px solid #e8e8f0}.admin-info{display:flex;flex-wrap:wrap;align-items:center;gap:12px}.admin-email{font-size:14px;color:#1a1a2e;font-weight:500}.creator-badge{font-size:12px;padding:4px 8px;border-radius:4px;background:#e3f2fd;color:#1976d2;font-weight:500}.remove-btn{background:none;border:1px solid #ffcdd2;padding:6px 12px;border-radius:6px;font-size:13px;color:#d32f2f;cursor:pointer;transition:all .2s ease}.remove-btn:hover:not(:disabled){background:#fff0f0}.remove-btn:disabled{opacity:.5;cursor:not-allowed}.loading-state{text-align:center;padding:40px}.loading-state .spinner{width:32px;height:32px;border:3px solid #f0f0f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:#666;font-size:14px;margin:0}@media (max-width: 600px){.admin-item{flex-direction:column;align-items:flex-start;gap:12px}.remove-btn{align-self:flex-end}}.instructor-course-view{min-height:100vh;background:#f8fafc;display:flex}.instructor-sidebar{width:260px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;flex-shrink:0}.instructor-sidebar-header{padding:16px 20px;border-bottom:1px solid #e0e0e0}.instructor-back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:#667eea;font-size:13px;cursor:pointer;padding:8px 12px;margin:-8px -12px;border-radius:6px;transition:all .2s ease}.instructor-back-btn:hover{color:#5a6fd6;background:#f5f7fa}.instructor-course-info{padding:20px;border-bottom:1px solid #e0e0e0}.instructor-course-title{font-size:16px;font-weight:600;color:#1a1a2e;margin:0;line-height:1.4}.instructor-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.instructor-nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:none;border:none;border-radius:8px;font-size:14px;color:#666;cursor:pointer;text-align:left;transition:all .2s ease}.instructor-nav-item:hover{background:#f5f7fa;color:#333}.instructor-nav-item.active{background:#f0f3ff;color:#667eea}.instructor-nav-item.active svg{color:#667eea}.instructor-nav-item svg{flex-shrink:0}.instructor-nav-item span{font-weight:500}.instructor-sidebar-footer{padding:16px 20px;border-top:1px solid #e0e0e0}.instructor-logout-btn{width:100%;background:none;border:1px solid #ef4444;padding:10px 16px;border-radius:8px;font-size:14px;color:#ef4444;cursor:pointer;transition:all .2s ease}.instructor-logout-btn:hover{background:#fef2f2;border-color:#dc2626;color:#dc2626}.instructor-main-content{flex:1;padding:32px 40px;overflow-y:auto;max-width:900px}.instructor-content-panel{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000000d;max-width:600px}.instructor-content-panel h2{font-size:20px;color:#1e293b;margin:0 0 24px;font-weight:600}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;transition:all .2s ease;box-sizing:border-box;background:#fafafa}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f11a}.save-message{padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px}.save-message.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.save-message.error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.save-btn{background:#6366f1;border:none;padding:12px 24px;border-radius:8px;font-size:14px;color:#fff;font-weight:500;cursor:pointer;transition:all .2s ease}.save-btn:hover:not(:disabled){background:#4f46e5}.save-btn:disabled{opacity:.6;cursor:not-allowed}.instructor-course-view .loading-state,.instructor-course-view .error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100%;text-align:center}.instructor-course-view .loading-state .spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#6366f1;border-radius:50%;animation:instructor-spin 1s linear infinite;margin-bottom:16px}@keyframes instructor-spin{to{transform:rotate(360deg)}}.instructor-course-view .error-state p{color:#64748b;margin-bottom:16px}.instructor-course-view .error-state button{background:#6366f1;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:500}.instructor-course-view .error-state button:hover{background:#4f46e5}@media (max-width: 768px){.instructor-course-view{flex-direction:column}.instructor-sidebar{width:100%}.instructor-nav{flex-direction:row;overflow-x:auto;padding:8px 12px;gap:8px}.instructor-nav-item{white-space:nowrap;padding:10px 14px}.instructor-sidebar-footer{display:none}.instructor-main-content{padding:20px}.instructor-content-panel{max-width:none}}.create-course-container{min-height:100vh;background:#f5f7fa;display:flex;align-items:center;justify-content:center;padding:40px 20px}.create-course-card{background:#fff;border-radius:12px;padding:40px;max-width:500px;width:100%;box-shadow:0 4px 12px #00000014}.create-course-card h1{font-size:24px;color:#1a1a2e;margin:0 0 8px}.create-course-card>p{font-size:14px;color:#666;margin:0 0 32px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group input:disabled,.form-group textarea:disabled{background:#f5f5f5;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:100px}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:8px;font-size:14px;margin-bottom:20px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px}.cancel-btn{background:none;border:1px solid #ddd;padding:12px 24px;border-radius:8px;font-size:14px;color:#666;cursor:pointer;transition:all .2s ease}.cancel-btn:hover:not(:disabled){background:#f5f5f5;border-color:#ccc}.submit-btn{background:#667eea;border:none;padding:12px 24px;border-radius:8px;font-size:14px;color:#fff;font-weight:500;cursor:pointer;transition:all .2s ease}.submit-btn:hover:not(:disabled){background:#5a6fd6}.submit-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden;position:fixed;top:0;left:0}.sidebar{width:250px;background-color:#2c3e50;color:#fff;display:flex;flex-direction:column;height:100vh;overflow:hidden}.sidebar-back-link{padding:.75rem 1rem;border-bottom:1px solid #34495e;flex-shrink:0}.sidebar-back-link a,.back-to-dashboard{color:#bdc3c7;text-decoration:none;font-size:.85rem;display:flex;align-items:center;gap:4px;transition:color .2s ease}.sidebar-back-link a:hover,.back-to-dashboard:hover{color:#fff}.sidebar-course-name{padding:.75rem 1rem;font-size:1rem;font-weight:600;color:#ecf0f1;border-bottom:1px solid #34495e;flex-shrink:0}.sidebar-header{padding:1rem;flex-shrink:0;border-bottom:1px solid #34495e;margin-bottom:.5rem}.new-session-btn{width:100%;padding:.5rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.new-session-btn:hover{background-color:#2980b9}.session-list{flex:1;overflow-y:auto;min-height:0;padding:0}.session-list::-webkit-scrollbar{width:8px}.session-list::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}.session-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.session-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.session-list-header{padding:.5rem 0;position:sticky;top:0;background-color:#2c3e50;text-align:center;z-index:1}.session-list-header h3{margin:0;font-size:1.1rem;color:#ecf0f1;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.no-sessions-message{padding:2rem 1rem;text-align:center;color:#95a5a6;font-size:.95rem;font-style:italic}.lo-group{margin-bottom:.1rem}.lo-group-header{padding:.25rem .5rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:500;color:#bdc3c7;background-color:#34495e99;border-radius:6px;border-left:2px solid transparent;transition:all .2s;-webkit-user-select:none;user-select:none;font-size:.85rem}.lo-group-header:hover{background-color:#34495e66;border-left-color:#3498db;color:#ecf0f1}.lo-group-header.active{background-color:#3474db26;border-left-color:#3498db;color:#ecf0f1}.chevron-icon{transition:transform .2s ease;color:#95a5a6;flex-shrink:0}.chevron-icon.collapsed{transform:rotate(-90deg)}.lo-group-header:hover .chevron-icon{color:#ecf0f1}.lo-title{flex:1;font-size:.85rem;font-weight:500}.lo-count{color:#7f8c8d;font-size:.75rem;font-weight:400;background-color:#34495e80;padding:.15rem .5rem;border-radius:10px}.lo-sessions{padding:0;overflow:hidden;transition:max-height .3s ease-in-out,opacity .2s}.lo-sessions:not(.collapsed){max-height:1000px;overflow:visible;opacity:1}.lo-sessions.collapsed{max-height:0;overflow:hidden;opacity:0}.session-item{padding:.5rem .75rem;margin:0 .25rem;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.75rem;font-weight:400;color:#bdc3c7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-item:hover{background-color:#34495e80;color:#ecf0f1;transform:translate(2px)}.session-item.active{background-color:#3474db26;color:#ecf0f1}.completion-indicator{font-size:14px;margin-right:6px;flex-shrink:0}.completion-indicator.complete{color:#22c55e}.completion-indicator.in-progress{font-size:12px;color:#f59e0b}.main-content{flex:1;display:flex;padding:1rem;gap:1rem;height:calc(100vh - 2rem);overflow:hidden;justify-content:space-between}.main-content.landing-mode{padding:0;gap:0;width:100%;flex:1;height:100vh}.main-content.landing-mode .conversation-panel{width:100%;max-width:none;border-radius:0;border:none;height:100%;display:flex;flex-direction:column;align-items:center;background-color:#fff}.main-content.landing-mode .chat-messages-inner{width:100%;max-width:900px;margin:0 auto;padding:1rem 1rem 0;display:flex;flex-direction:column;gap:1rem;box-sizing:border-box;min-height:100%}.main-content.landing-mode .lo-selector-container{margin-top:auto;padding-bottom:1rem}.main-content.landing-mode .chat-messages:not(:has(.message)){justify-content:center}.main-content.landing-mode .chat-input{width:100%;padding:0;background-color:#f8f9fa;border-top:1px solid #ddd;flex-shrink:0;display:flex;justify-content:center;box-sizing:border-box}.main-content.landing-mode .chat-input-inner{width:100%;max-width:900px;padding:1rem;display:flex;gap:.5rem}.main-content.landing-mode .chat-input-inner textarea{flex:1;font-size:1.1rem;padding:.75rem;border:1px solid #ddd;border-radius:4px;resize:none;overflow-y:auto;min-height:44px;max-height:200px}.main-content.landing-mode .chat-input-inner button{padding:.75rem 2rem;font-size:1.1rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer}.main-content.landing-mode .chat-input-inner button:hover{background-color:#0056b3}.main-content.landing-mode .chat-input-inner button:disabled{background-color:#6c757d;cursor:not-allowed}.left-panels{flex:0 1 auto;width:60%;display:flex;flex-direction:column;gap:1rem;max-width:60%;min-width:400px}.activity-panel{height:100%;border:1px solid #ddd;border-radius:8px;background-color:#fff;display:flex;flex-direction:column;min-height:250px}.whiteboard-panel{height:50%;border:1px solid #ddd;border-radius:8px;background-color:#fff;display:flex;flex-direction:column;min-height:250px}.conversation-panel{flex:1;max-width:40%;border:1px solid #ddd;border-radius:8px;background-color:#fff;display:flex;flex-direction:column;transition:all .3s ease-in-out;position:relative}.scroll-to-bottom{position:absolute;bottom:100px;left:50%;transform:translate(-50%);width:40px;height:40px;min-width:40px;min-height:40px;border-radius:50%;background-color:#fff;color:#2c3e50;border:1px solid #ddd;font-size:20px;line-height:1;cursor:pointer;box-shadow:0 2px 12px #00000026;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s;padding:0}.scroll-to-bottom:hover{background-color:#f8f9fa;box-shadow:0 4px 16px #0003;transform:translate(-50%) translateY(-2px)}.panel-header{display:flex;justify-content:space-between;align-items:center;background-color:#e6f3ff;border-bottom:1px solid #ddd;border-radius:8px 8px 0 0}.panel-header h3{margin:0;padding:1rem;background-color:transparent;color:#2c3e50;border-bottom:none;border-radius:0;font-weight:600}.metadata-info-button{width:28px;height:28px;border-radius:50%;border:2px solid #3498db;background-color:transparent;color:#3498db;font-size:1rem;font-weight:700;cursor:pointer;margin-right:1rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.metadata-info-button:hover{background-color:#3498db;color:#fff}.metadata-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.metadata-modal{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-width:600px;max-height:80vh;width:90%;display:flex;flex-direction:column}.metadata-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #e0e0e0;background-color:#f8f9fa;border-radius:12px 12px 0 0}.metadata-modal-header h3{margin:0;font-size:1.1rem;color:#2c3e50}.metadata-modal-close{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:0;line-height:1}.metadata-modal-close:hover{color:#333}.metadata-modal-content{padding:1.25rem;overflow-y:auto;flex:1}.metadata-item{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #eee}.metadata-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.metadata-label{font-weight:600;color:#3498db;font-size:.85rem;text-transform:uppercase;letter-spacing:.03em;margin-bottom:.4rem}.metadata-value{color:#2c3e50;line-height:1.5}.metadata-value .metadata-empty{color:#999;font-style:italic}.metadata-list{margin:0;padding-left:1.25rem}.metadata-list li{margin-bottom:.25rem}.rule-cards{display:flex;flex-direction:column;gap:.5rem}.rule-card{border:1px solid #e0e0e0;border-radius:6px;background-color:#f8f9fa;overflow:hidden}.rule-card[open]{background-color:#fff}.rule-card-header{padding:.6rem .8rem;cursor:pointer;display:flex;align-items:center;font-weight:500;color:#2c3e50;list-style:none}.rule-card-header::-webkit-details-marker{display:none}.rule-card-header:before{content:"▶";font-size:.7rem;margin-right:.5rem;color:#666;transition:transform .2s}.rule-card[open] .rule-card-header:before{transform:rotate(90deg)}.rule-id{font-family:monospace;font-size:.9rem;color:#3498db}.rule-card-content{padding:.8rem;border-top:1px solid #e0e0e0;background-color:#fff}.rule-field{margin-bottom:.6rem}.rule-field:last-child{margin-bottom:0}.rule-field-label{display:block;font-size:.75rem;font-weight:600;color:#666;text-transform:uppercase;margin-bottom:.2rem}.rule-field-value{color:#2c3e50;line-height:1.4;font-size:.9rem}.panel-content{flex:1;padding:1rem;overflow-y:auto}.panel-content h3{background-color:#f5f5f5;color:#666;padding:.5rem .75rem;border-radius:4px;margin:1rem 0 .5rem}.activity-progress-bar{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:.75rem 1rem;margin-bottom:1.5rem}.progress-text{font-size:.9rem;font-weight:600;color:#2c3e50;margin-bottom:.5rem}.progress-bar-container{width:100%;height:8px;background-color:#e0e0e0;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s ease-in-out;border-radius:4px}.activity-static{margin-bottom:1.5rem}.activity-question{border:2px solid #e0e0e0;border-radius:8px;padding:1.25rem;margin-bottom:1.5rem;background-color:#fff;transition:all .3s ease}.activity-question.completed{border-color:#2ecc71;background-color:#f0fdf4}.activity-question.incomplete{border-color:#ff6b6b;background-color:#fff5f5}.activity-question.pending{border-color:#3498db}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem;margin:-.5rem -.5rem 1rem;border-radius:4px;transition:background-color .2s}.question-header:hover{background-color:#00000008}.question-header-left,.question-header-right{display:flex;align-items:center;gap:.5rem}.collapse-icon{font-size:.75rem;color:#7f8c8d;transition:transform .2s;display:inline-block}.question-number{font-size:.875rem;font-weight:700;color:#3498db;text-transform:uppercase;letter-spacing:.5px}.part-status{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600}.completed-badge{background-color:#2ecc71;color:#fff}.incomplete-badge{background-color:#ff6b6b;color:#fff}.question-content{margin-bottom:1rem;color:#2c3e50;line-height:1.6}.answer-section{margin-top:1rem}.answer-input{width:100%;min-height:100px;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:.95rem;resize:vertical;transition:border-color .2s;box-sizing:border-box}.answer-input:focus{outline:none;border-color:#3498db}.answer-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.submit-button{margin-top:.75rem;padding:.6rem 1.5rem;background-color:#3498db;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.submit-button:hover:not(:disabled){background-color:#2980b9;transform:translateY(-1px);box-shadow:0 2px 8px #3498db4d}.submit-button:disabled{background-color:#bdc3c7;cursor:not-allowed;transform:none}.validation-feedback{margin-top:1rem;padding:1rem;border-radius:6px;border-left:4px solid #3498db;background-color:#e3f2fd}.validation-feedback.correct{border-left-color:#2ecc71;background-color:#f0fdf4}.validation-feedback.incorrect{border-left-color:#e74c3c;background-color:#fef2f2}.feedback-header{font-weight:700;color:#2c3e50;margin-bottom:.5rem;font-size:.9rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem;margin:-.5rem -.5rem .5rem;border-radius:4px;transition:background-color .2s;display:flex;align-items:center;gap:.5rem}.feedback-header:hover{background-color:#00000008}.feedback-content{padding-top:.5rem}.previous-attempts{margin-top:1rem;border-top:1px solid #e0e0e0;padding-top:.75rem}.previous-attempts summary{cursor:pointer;font-size:.875rem;color:#7f8c8d;font-weight:600;padding:.25rem 0;-webkit-user-select:none;user-select:none}.previous-attempts summary:hover{color:#2c3e50}.attempts-list{margin-top:.75rem}.attempt-item{padding:.75rem;background-color:#f8f9fa;border-radius:6px;margin-bottom:.5rem;border-left:3px solid #95a5a6}.attempt-header{font-size:.75rem;color:#7f8c8d;margin-bottom:.5rem;font-weight:600}.attempt-answer{font-size:.875rem;color:#2c3e50;margin-bottom:.5rem}.attempt-feedback{font-size:.875rem;color:#555;font-style:italic;padding-top:.5rem;border-top:1px solid #e0e0e0}.no-activity{text-align:center;color:#7f8c8d;padding:2rem;font-style:italic}.chat-messages{flex:1;width:100%;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;box-sizing:border-box}.message{display:flex;max-width:80%}.message-user{align-self:flex-end}.message-agent{align-self:flex-start}.message-content{padding:.75rem 1rem;border-radius:18px;word-wrap:break-word}.message-content>*{margin:0}.message-user .message-content{background-color:#007bff;color:#fff}.message-agent .message-content{background-color:#f1f3f4;color:#333}.message-edit-textarea{width:100%;border:none;outline:none;resize:none;background:transparent;font-family:inherit;font-size:inherit;line-height:inherit;padding:0;margin:0;overflow:hidden;color:inherit}.agent-status{display:flex;align-items:center;gap:.25rem;color:#666;font-style:italic}.status-text{background:linear-gradient(90deg,#999,#999,#333,#999,#999);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:textSweep 2s ease-in-out infinite}.status-dots{display:inline-flex;gap:.1rem}.status-dots span{animation:dotPulse 2s ease-in-out infinite}.status-dots span:nth-child(1){animation-delay:.5s}.status-dots span:nth-child(2){animation-delay:.6s}.status-dots span:nth-child(3){animation-delay:.7s}@keyframes textSweep{0%,to{background-position:0% 0%}50%{background-position:100% 0%}}@keyframes dotPulse{0%,40%{opacity:.4}50%,60%{opacity:1}to{opacity:.4}}.chat-input{padding:1rem;border-top:1px solid #ddd;display:flex;gap:.5rem;flex-shrink:0;width:100%;box-sizing:border-box}.chat-input textarea{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;resize:none;overflow-y:auto;min-height:44px;max-height:200px;line-height:1.5;display:block;box-sizing:border-box;min-width:0}.chat-input textarea:focus{outline:none;border-color:#007bff}.chat-input button{padding:.75rem 1.5rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;flex-shrink:0}.chat-input button:hover{background-color:#0056b3}.chat-input button:disabled{background-color:#6c757d;cursor:not-allowed}.panel-content h1{color:#333;margin-top:0;font-size:2rem}.panel-content h2{color:#555;border-bottom:1px solid #eee;padding-bottom:.5rem}.panel-content h3{color:#666}.panel-content ul{padding-left:1.5rem}.panel-content li{margin:.5rem 0}.welcome-message{text-align:center;padding:4rem 2rem;color:#666}.welcome-message h2{color:#333;font-size:2rem;margin-bottom:1.5rem;font-weight:600}.welcome-message p{font-size:1.1rem;line-height:1.6;margin-bottom:1rem;max-width:600px;margin-left:auto;margin-right:auto}.main-content.landing-mode .welcome-message{padding:6rem 2rem;width:100%;max-width:min(900px,calc(100% - 2rem));box-sizing:border-box}.main-content.landing-mode .welcome-message h2{font-size:2.5rem}.main-content.landing-mode .welcome-message p{font-size:1.2rem}.lo-selector-container{width:100%;max-width:900px;margin:2rem auto;padding:0 2rem;box-sizing:border-box}.landing-lo-selector{max-height:50vh;overflow-y:auto;padding:1rem 0}.landing-lo-selector .lo-selector-container{margin:0 auto;padding:0 1rem}.lo-selector-title{font-size:1.5rem;font-weight:600;color:#2c3e50;margin-bottom:1.5rem;text-align:center}.lo-grid{display:flex;flex-direction:column;gap:1rem;width:100%}.lo-button{padding:1.25rem 1.5rem;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;color:#2c3e50;text-align:left;transition:all .2s ease;line-height:1.5;box-shadow:0 1px 3px #0000000d}.lo-button:hover{border-color:#3498db;background-color:#f8f9fa;transform:translateY(-2px);box-shadow:0 4px 12px #3498db26}.lo-button.selected{border-color:#3498db;background-color:#e3f2fd;color:#1976d2;font-weight:600;box-shadow:0 2px 8px #3498db33}.lo-button.selected:hover{background-color:#e3f2fd;transform:translateY(-2px);box-shadow:0 4px 12px #3498db40}.loading-message{display:flex;align-self:flex-start;max-width:80%;margin:1rem 0}.loading-content{background-color:#f1f3f4;padding:1rem;border-radius:18px;display:flex;align-items:center;gap:.75rem}.loading-dots{display:flex;gap:.25rem}.loading-dots span{width:8px;height:8px;border-radius:50%;background-color:#666;animation:loading-bounce 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}.loading-text{font-style:italic;color:#666;font-size:.9rem}@keyframes loading-bounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.login-page{min-height:100vh;width:100vw;background:linear-gradient(to bottom right,#1e3a8a,#3b82f6,#60a5fa);display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-10%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(139,92,246,.3) 0%,transparent 70%);border-radius:50%;filter:blur(60px);animation:float-blob 20s ease-in-out infinite}.login-page:after{content:"";position:absolute;bottom:-10%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(59,130,246,.4) 0%,transparent 70%);border-radius:50%;filter:blur(60px);animation:float-blob 15s ease-in-out infinite reverse}@keyframes float-blob{0%,to{transform:translate(0) scale(1)}50%{transform:translate(30px,-30px) scale(1.1)}}.login-hero{width:100%;max-width:1200px;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative;z-index:1}.login-hero-content{color:#fff}.login-hero-badge{display:inline-block;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.3)}.login-hero-title{font-size:3.5rem;font-weight:800;color:#fff;margin-bottom:1.5rem;letter-spacing:-.02em;line-height:1.1}.login-hero-subtitle{font-size:1.25rem;color:#ffffffe6;margin-bottom:2.5rem;line-height:1.6;max-width:500px}.signin-button{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:1rem 2rem;background:#fff;color:#0c4a6e;border:none;border-radius:12px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #0003}.signin-button:hover{background:#f0f9ff;box-shadow:0 15px 40px #00000040;transform:translateY(-3px)}.signin-button:active{transform:translateY(-1px);box-shadow:0 8px 25px #0003}.google-icon{flex-shrink:0}.signin-note{font-size:.9rem;color:#fffc;margin-top:1.5rem;margin-bottom:0}.login-hero-visual{display:flex;align-items:center;justify-content:center;position:relative}.hero-graphic{width:400px;height:400px;position:relative}.graphic-circle{position:absolute;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.graphic-circle-1{width:300px;height:300px;top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse-ring 4s ease-in-out infinite}.graphic-circle-2{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%);animation:pulse-ring 4s ease-in-out infinite .5s}.graphic-circle-3{width:100px;height:100px;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff3;animation:pulse-ring 4s ease-in-out infinite 1s}@keyframes pulse-ring{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1.05);opacity:.8}}@media (max-width: 968px){.login-hero{grid-template-columns:1fr;gap:3rem}.login-hero-title{font-size:2.5rem}.login-hero-subtitle{font-size:1.1rem}.hero-graphic{width:300px;height:300px}.graphic-circle-1{width:240px;height:240px}.graphic-circle-2{width:160px;height:160px}.graphic-circle-3{width:80px;height:80px}}@media (max-width: 640px){.login-hero-title{font-size:2rem}.login-hero-subtitle{font-size:1rem}.hero-graphic{width:250px;height:250px}.graphic-circle-1{width:200px;height:200px}.graphic-circle-2{width:130px;height:130px}.graphic-circle-3{width:60px;height:60px}.login-page:before,.login-page:after{width:500px;height:500px}}.sidebar-footer{border-top:1px solid #34495e;padding:1rem;flex-shrink:0}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.5rem;background-color:#ffffff0d;border-radius:8px;cursor:pointer;transition:background-color .2s}.user-info:hover{background-color:#ffffff1a}.user-info .edit-icon{color:#bdc3c7;opacity:0;transition:opacity .2s;flex-shrink:0}.user-info:hover .edit-icon{opacity:1}.user-avatar{width:40px;height:40px;border-radius:50%;border:2px solid #3498db;display:flex;align-items:center;justify-content:center;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-initials{background-color:#3498db;color:#fff;font-weight:600;font-size:.8rem;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.user-details{flex:1;min-width:0}.user-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.8rem;color:#bdc3c7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{width:100%;padding:.75rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.logout-btn:hover{background-color:#c0392b}.loading-screen{width:100vw;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background-color:#f8f9fa;font-size:1.2rem;color:#666}.spinner{width:48px;height:48px;border:4px solid rgba(0,0,0,.1);border-left-color:#1a73e8;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.panel-content table{border-collapse:collapse;width:100%;margin:1rem 0;border:1px solid #ddd}.panel-content th,.panel-content td{border:1px solid #ddd;padding:12px;text-align:left}.panel-content th{background-color:#f8f9fa;font-weight:600;color:#333}.panel-content tr:nth-child(2n){background-color:#f8f9fa}.panel-content tr:hover{background-color:#f1f3f4}.error-banner{background-color:#fee;border:1px solid #fcc;border-radius:8px;padding:12px 16px;margin:12px 16px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-text{color:#c33;font-size:14px;line-height:1.5}.confirmation-message-container{margin:1rem 0;padding:1rem;background:#f8f9fa;border-radius:12px;border:2px solid #e0e0e0;animation:fadeInSlide .3s ease-out}@keyframes fadeInSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.confirmation-message-container .confirmation-bar{background:transparent;padding:0;border:none}.other-session-notice{padding:12px 16px;background-color:#f0f4f8;border-top:1px solid #e2e8f0;color:#64748b;font-size:14px;text-align:center;font-style:italic}
