body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.assignment-mark-container{background:#f7f7f7;border-radius:16px;display:flex;height:calc(100vh - 40px);margin:20px;overflow:hidden;width:calc(100% - 40px)}.essays-section{background:#fff;box-shadow:0 2px 8px #00000012;margin:12px;padding:24px}.essay-image-wrapper,.essays-section{border-radius:12px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.essay-image-wrapper{background:#f1f1f1;padding:16px;position:relative}.controls-bar{background:#f1f1f1;display:flex;justify-content:space-between;padding:8px 0;position:sticky;top:0;z-index:10}.controls-bar button{background:#0006;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 12px}.controls-bar button:hover{background:#0009}.canvas-container{align-items:flex-start;display:flex;flex:1 1;justify-content:center;min-height:0;overflow-x:hidden;overflow-y:auto}.essay-image{border-radius:8px;box-shadow:0 2px 8px #00000014;cursor:pointer;display:block;flex:none;height:auto;width:100%}.chatbot-section{border-radius:12px;box-shadow:0 2px 8px #00000026;color:#fff;display:flex;flex:1 1;flex-direction:column;margin:12px 12px 12px 0;padding:24px}.chatbot-section h2{margin-bottom:20px}.toggle-tabs{background:#ffffff14;border-radius:10px;display:inline-flex;gap:4px;margin-bottom:16px;padding:4px}.toggle-tabs button{background:#0000;border:none;border-radius:8px;color:#ddd;cursor:pointer;padding:8px 12px}.toggle-tabs button.active{background:#6c5ce7;color:#fff}.chatbot-messages{background:#ffffff1a;border-radius:8px;flex:1 1;overflow-y:auto;padding:16px}.feedback-container{background:#fff8e1;border:1px solid #ffecb3;border-radius:8px;margin-bottom:16px;padding:12px 16px}.feedback-container h3{color:#bf360c;font-size:1rem;margin:0 0 8px}.feedback-box{background:#fff;border-radius:4px;box-shadow:inset 0 1px 2px #0000001a;color:#333;font-size:.9rem;max-height:200px;overflow-y:auto;padding:8px 12px;text-align:left;white-space:pre-line}.report-container{display:flex;flex-direction:column;gap:12px;height:90%}.export-bar{align-items:center;display:flex;gap:12px;justify-content:space-between}.bar-actions{display:inline-flex;gap:8px}.cancel-btn,.edit-btn,.save-btn{border:none;border-radius:8px;cursor:pointer;padding:8px 14px}.edit-btn,.save-btn{background:#00b894;color:#fff}.cancel-btn{background:#d63031;color:#fff}.export-btn{background:#6c5ce7;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 14px}.export-btn:disabled{background:#ffffff40;cursor:not-allowed}.report-section{background:#ffffff14;border-radius:8px;margin-bottom:20px;overflow-y:scroll;padding:12px;scroll-behavior:smooth}.report-section.full-report-section{padding:16px 18px}.report-editor{background:#ffffff0f;border-radius:8px;padding:10px 12px}.report-editor .editor-label{color:#ddd;display:block;font-size:.9rem;margin-bottom:6px}.report-editor textarea{background:#1e1b38;border:1px solid #fff3;border-radius:8px;color:#fff;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace;min-height:160px;padding:10px 12px;resize:vertical;width:100%}.preview-heading{color:#ddd;font-size:.9rem;margin:10px 0 6px}.report-section.full-report-section.exporting,.report-section.full-report-section.exporting *{background:#fff!important;color:#000!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.score-pill{background:#2a2548;border-radius:999px;color:#fff;display:inline-block;margin-bottom:8px;padding:6px 10px}.report-page+.report-page{margin-top:10px}.report-list{margin:8px 0 0;padding-left:18px}.report-list.compact{grid-gap:8px 12px;display:grid;gap:8px 12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));list-style:none;padding:0}.report-list.compact li{background:#0003;border-radius:6px;padding:8px}.report-list .k{font-weight:600}.report-list .v{opacity:.9}.full-report-section .fr-h2{color:#fff;font-size:1.5rem;margin:8px 0 6px}.full-report-section .fr-h3{color:#e6e6ff;font-size:1.75rem;margin:8px 0 4px}.full-report-section .fr-h4{color:#d9d9ff;font-size:1.25rem;margin:6px 0 2px}.full-report-section .fr-p{color:#f1f1f1;font-size:20px;-webkit-hyphens:auto;hyphens:auto;line-height:1.6;margin:6px 0 10px;text-align:justify;text-justify:inter-word}.full-report-section .fr-ol,.full-report-section .fr-ul{font-size:20px;margin:6px 0 10px 20px}.full-report-section .fr-li{font-size:20px;-webkit-hyphens:auto;hyphens:auto;margin:4px 0;text-align:justify;text-justify:inter-word}.full-report-section .fr-hr{background:linear-gradient(90deg,#ffffff26,#ffffff0d);border:none;height:1px;margin:14px 0}.full-report-section code,.full-report-section pre{background:#00000059;border-radius:4px;padding:2px 6px}.chatbot-section{background:#1d193d}.chatbot-input{align-items:center;background-color:#1e1b38;border-radius:12px;box-shadow:0 0 10px #0003;display:flex;gap:8px;margin-top:12px;padding:12px}.chatbot-input input[type=text]{background-color:#2a2548;border:none;border-radius:9999px;box-shadow:inset 0 0 0 2px #0000;color:#fff;flex:1 1;font-size:14px;outline:none;padding:12px 16px;transition:box-shadow .2s ease}.chatbot-input input[type=text]:focus{box-shadow:inset 0 0 0 2px #6c5ce7}.chatbot-input button{background-color:#6c5ce7;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 18px;transition:background-color .2s ease,transform .1s ease}.chatbot-input button:hover{background-color:#7d6df0;transform:scale(1.05)}.chatbot-input button:active{transform:scale(.95)}@media (max-width:1024px){.assignment-mark-container{flex-direction:column;height:auto;overflow:auto}.essays-section{margin:12px;min-height:50vh;padding:20px;width:calc(100% - 24px)}.essay-image-wrapper{height:auto}.chatbot-section{margin:12px;min-height:40vh;width:calc(100% - 24px)}.chatbot-messages{min-height:180px}}.chat-page{align-items:flex-start;background:#fafbfc;background:var(--main-bg);display:flex;flex-direction:column;min-height:100vh;width:95%}.chat-page h2{font-size:1.5rem;font-weight:700;margin-bottom:20px;padding-left:30px;padding-top:40px}.chat-body{box-sizing:border-box;display:flex;flex-direction:column;gap:22px;max-width:1200px;padding:0 1vw;width:100%}.chat-body ul{list-style:none}.chat-body ul,.chat-card{align-items:flex-start;display:flex;flex-direction:column}.chat-card{background:#fff;background:var(--card-bg);border:1px solid #eaeaea;border:1px solid var(--border);border-radius:18px;border-radius:var(--radius);box-shadow:0 4px 16px 0 #1e225a0d;box-shadow:var(--shadow);box-sizing:border-box;margin-bottom:18px;padding:22px 26px 18px;transition:box-shadow .22s cubic-bezier(.25,.8,.25,1),transform .15s cubic-bezier(.25,.8,.25,1),border-color .18s,background .15s;width:100%}.chat-card:hover{background:#fffbe7;border-color:#ffd600;box-shadow:0 8px 32px 0 #ffd60022,0 1.5px 8px 0 #ffd60044;cursor:pointer;transform:translateY(-6px) scale(1.03)}.chat-title{font-size:1.1rem;font-weight:700;padding-bottom:4px}.chat-datetime{color:#7c8895;color:var(--muted);font-size:.9rem;font-weight:550}:root{--radius:22px}body{color:#222;color:var(--text);font-family:Inter,Arial,sans-serif}.no-sidebar,body{background:#fafbfc;background:var(--main-bg)}.no-sidebar{display:flex;flex-direction:column;margin:0 auto;max-width:1200px;min-height:100vh;padding:38px 24px 0}.dashboard-header h1{font-size:2rem;font-weight:700;margin-bottom:6px}.dashboard-header .wave{font-size:1.3em}.dashboard-header p{color:#7c8895;color:var(--muted);font-size:1rem;margin-bottom:28px}.dashboard-cards{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.card{background:#fff;background:var(--card-bg);border:1px solid #eaeaea;border:1px solid var(--border);border-radius:22px;border-radius:var(--radius);box-shadow:0 4px 16px 0 #1e225a0d;box-shadow:var(--shadow);cursor:pointer;display:flex;flex-direction:column;gap:4px;min-width:0;padding:40px 55px 36px;transition:box-shadow .22s cubic-bezier(.25,.8,.25,1),transform .15s cubic-bezier(.25,.8,.25,1),border-color .18s,background .15s}.card:hover{background:#fffbe7;border-color:#ffd600;box-shadow:0 8px 32px 0 #ffd60022,0 1.5px 8px 0 #ffd60044;transform:translateY(-6px) scale(1.03)}.card h2{color:#7c8895;color:var(--muted);font-size:1rem;font-weight:600;margin-bottom:2px}.card-value{color:#222;font-size:2rem;font-weight:700;margin:8px 0 6px}.card-value.green{color:#00cf30}.card-value.red{color:#da1428}.card-desc{color:#7c8895;color:var(--muted);font-size:.95rem}.card-desc .green{color:#3cb371;font-weight:600}.card-desc .red{color:#e45757;font-weight:600}.dashboard-lower{display:flex;gap:30px}.dashboard-activity{background:#fff;background:var(--card-bg);border:1px solid #eaeaea;border:1px solid var(--border);border-radius:22px;border-radius:var(--radius);box-shadow:0 4px 16px 0 #1e225a0d;box-shadow:var(--shadow);max-height:220px;max-width:420px;min-width:290px;overflow-y:auto;padding:22px 24px 16px;transition:box-shadow .22s cubic-bezier(.25,.8,.25,1),transform .15s cubic-bezier(.25,.8,.25,1),border-color .18s,background .15s;width:100%}.dashboard-activity:hover{background:#fffbe7;border-color:#ffd600;box-shadow:0 8px 32px 0 #ffd60022,0 1.5px 8px 0 #ffd60044;transform:translateY(-6px) scale(1.03)}.dashboard-activity h3{font-size:1.05rem;font-weight:600;margin-bottom:13px}.dashboard-activity ul{list-style:none;margin:0;padding:0}.dashboard-activity li{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;font-size:1.01rem;gap:12px;padding:7px 0}.dashboard-activity li:last-child{border-bottom:none}.dot{border-radius:50%;display:inline-block;height:11px;width:11px}.dot.yellow{background:#ffd600}.dot.green{background:#55c87a}.dot.purple{background:#ac8afe}.activity-time{color:#7c8895;color:var(--muted);font-size:.96rem;font-weight:500;margin-left:auto}@media (max-width:1200px){.dashboard-cards{grid-template-columns:1fr 1fr}.dashboard-lower{flex-direction:column}}@media (max-width:800px){.no-sidebar{padding:14px 6px}.dashboard-cards{grid-template-columns:1fr}.dashboard-lower{align-items:flex-start;display:flex;gap:30px}}.dashboard-footer{margin-top:60px}.waves-footer{align-items:center;display:flex;justify-content:center;padding:40px 0}.waves-bottom{height:450px;opacity:1;width:600px}body{margin:0;padding:0}h2{margin-top:0}.iner{height:60vh;margin:2rem auto;max-width:800px;position:relative;width:80vw}.back-btn{border:1px solid rgba(0,0,0,.501);font-weight:700;margin:10px;padding:10px 30px;transition:1s}.back-btn:hover{background:rgba(255,191,0,.903);border:1px solid #fefe57}.mistakes-analytics-container{align-items:center;display:flex;font-family:Arial,sans-serif;justify-content:flex-start;margin-left:250px;min-height:100vh;padding:0 0 0 15%;position:relative;width:calc(100vw - 250px)}.mistakes-content{align-items:flex-start;display:flex;flex-direction:column;justify-content:center;max-width:800px;padding:3rem;text-align:left;width:auto}.mistakes-title{color:#2c3e50;font-size:clamp(2rem,4vw,3rem);font-weight:700;margin-bottom:2rem;text-align:left}.chart-container{align-self:flex-start;height:450px;margin-bottom:2rem;padding:20px;width:600px}.loading-container{padding:3rem}.loading-spinner{border:4px solid #bdc3c7;border-top-color:#3498db;margin:0 auto 1rem}@media (max-width:768px){.mistakes-analytics-container{margin-left:0;width:100vw}.chart-container{height:400px;max-width:500px;width:100%}.mistakes-content{padding:2rem 1rem}}@media (max-width:480px){.chart-container{height:350px}.mistakes-title{font-size:1.8rem}}.ranking-chart-container{height:60vh;margin:2rem auto;width:80vw}.ranking-title{color:#2c3e50;font-size:2rem;margin-bottom:2rem}.error-container,.ranking-title{font-weight:700;text-align:center}.error-container{background-color:#fadbd8;border:1px solid #f1948a;border-radius:8px;color:#e74c3c;margin:2rem auto;max-width:500px;padding:2rem}.loading-container{color:#7f8c8d;font-size:18px;padding:2rem;text-align:center}.back-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;display:block;font-size:16px;font-weight:600;margin-left:auto;margin-right:auto;margin-top:2rem;padding:12px 30px;transform:translateY(0);transition:all .3s ease}.back-btn:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}:root{--primary:#ffd600}.chat-conversation-container{border-radius:18px;height:100vh;margin:40px auto 30px;max-width:1200px;padding-bottom:36px}.chat-conversation-header{border-top-left-radius:18px;border-top-right-radius:18px;padding:50px 40px 18px}.chat-conversation-header h2{color:#222;color:var(--text);font-size:1.22rem;font-weight:700;letter-spacing:.01em;margin:0 0 8px}.chat-conversation-date{color:#7c8895;color:var(--muted);font-size:.97rem;font-weight:500;margin-bottom:2px}.chat-messages{gap:22px;padding:34px 40px 0}.chat-bubble,.chat-messages{display:flex;flex-direction:column}.chat-bubble{border-radius:18px;box-shadow:0 1.5px 8px #eaeaea;box-shadow:0 1.5px 8px var(--border);font-size:1.05rem;line-height:1.55;max-width:75%;padding:17px 20px;position:relative;word-break:break-word}.user-bubble{align-self:flex-end;background:#ffe8a3;background:var(--accent);border-bottom-right-radius:8px;color:#222;color:var(--text)}.assistant-bubble{align-self:flex-start;background:#fff;background:var(--card-bg);border:1px solid #eaeaea;border:1px solid var(--border);border-bottom-left-radius:8px;color:#222;color:var(--text)}.chat-bubble-content{font-size:1rem;margin-bottom:8px;text-align:left}.chat-bubble-time{align-self:flex-end;color:#7c8895;color:var(--muted);font-size:.86rem;font-weight:500;margin-top:4px}@media (max-width:700px){.chat-conversation-container{border-radius:0;margin:0;max-width:98vw}.chat-conversation-header,.chat-messages{padding-left:5vw;padding-right:5vw}}.chat-input-bar{align-items:center;background:#eaeaea;background:var(--border);border-radius:16px;bottom:0;display:flex;gap:10px;left:0;margin:0 8px 12px;padding:16px 20px;position:sticky;z-index:10}.chat-input{background:#fff;background:var(--card-bg);border:none;border-radius:1.5em;box-shadow:none;color:#222;color:var(--text);flex:1 1;font-size:1.08rem;margin-right:8px;outline:none;padding:13px 18px;transition:background .17s,border .17s}.chat-input:focus{border:1.5px solid #ffd600;border:1.5px solid var(--primary)}.chat-send-btn{align-items:center;background:#ffd600;background:var(--primary);border:none;border-radius:50%;box-shadow:0 1px 6px #eaeaea;box-shadow:0 1px 6px var(--border);cursor:pointer;display:flex;height:42px;justify-content:center;margin-left:4px;padding:0;transition:background .16s;width:42px}.chat-send-btn:disabled{cursor:not-allowed;opacity:.45}.chat-send-btn svg{fill:#fff;height:26px;pointer-events:none;width:26px}.recent-sessions{box-sizing:border-box;margin-left:0;margin-right:0;margin-top:20px;padding:0 12px;width:100%}.recent-sessions-title{color:#222;color:var(--text);font-size:.8rem;font-weight:800;margin-bottom:11px;padding-left:2px;text-align:left}.recent-sessions-list{display:flex;flex-direction:column;gap:9px;list-style:none;margin:0;padding:0}.recent-sessions-list li{margin:0;padding:0}.recent-session-link{align-items:flex-start;background:#0000;border-radius:8px;color:#fff;color:var(--card-bg);display:flex;font-size:.8rem;gap:12px;padding:8px 10px;text-align:left;text-decoration:none;transition:background .18s,color .13s}.recent-session-link:hover{background:#fac548;background:var(--primary)}.recent-session-link:hover .recent-session-date,.recent-session-link:hover .recent-session-icon,.recent-session-link:hover .recent-session-title{color:#fff;color:var(--card-bg)}.recent-session-icon{color:#222;color:var(--text);font-size:1.18rem;margin-top:2px;min-width:1.35em;transition:color .13s}.recent-session-title{font-size:1em;font-weight:700;line-height:1.13;margin-bottom:0}.recent-session-date,.recent-session-title{color:#222;color:var(--text);text-align:left;transition:color .13s}.recent-session-date{font-size:.93em;font-weight:450;margin-top:1.5px}.user-popover{animation:pop-fadein .2s;background:#fff;background:var(--card-bg);border-radius:18px;bottom:30px;box-shadow:0 8px 32px #0000002b;color:#fff;display:flex;flex-direction:column;left:80px;min-width:240px;padding:22px 20px 18px;position:fixed;z-index:1100}@keyframes pop-fadein{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}.user-popover-info{align-items:flex-start;display:flex;flex-direction:column;gap:2px;margin-bottom:18px}.user-popover-avatar{color:#fac548;color:var(--primary);font-size:2.2em;margin-bottom:7px}.user-popover-email{color:#222;color:var(--text);font-size:1.04em;font-weight:700;margin-bottom:1px}.user-popover-sub{color:#7c8895;color:var(--muted);font-size:.97em;font-weight:400;word-break:break-all}.user-popover-action{align-items:center;background:none;border:none;border-radius:10px;color:#357ab8;cursor:pointer;display:flex;font-size:1.05em;font-weight:700;gap:12px;justify-content:flex-start;margin-top:2px;padding:12px 0;text-decoration:none;transition:background .14s,color .14s;width:100%}.user-popover-action:hover{background:#e7f0ff;color:#1d5fa0}.user-popover-logout{align-items:center;background:none;border:none;border-radius:10px;color:#f45b4b;cursor:pointer;display:flex;font-size:1.05em;font-weight:700;gap:12px;justify-content:flex-start;margin-top:4px;padding:12px 0;transition:background .14s;width:100%}.user-popover-logout:hover{background:#ffe1db;color:#e02e00}@-webkit-keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size:12px;--rc-drag-handle-mobile-size:24px;--rc-drag-handle-bg-colour:#0003;--rc-drag-bar-size:6px;--rc-border-color:#ffffffb3;--rc-focus-color:#08f}.ReactCrop{cursor:crosshair;display:inline-block;max-width:100%;position:relative}.ReactCrop *,.ReactCrop :after,.ReactCrop :before{-webkit-box-sizing:border-box;box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{max-height:inherit;overflow:hidden}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-height:inherit;max-width:100%}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{-ms-touch-action:none;touch-action:none}.ReactCrop__crop-mask{bottom:0;height:calc(100% + .5px);left:0;pointer-events:none;position:absolute;right:0;top:0;width:calc(100% + .5px)}.ReactCrop__crop-selection{cursor:move;left:0;position:absolute;top:0;-webkit-transform:translateZ(0);transform:translateZ(0)}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);bottom:-1px;content:"";left:-1px;opacity:.3;pointer-events:none;position:absolute;right:-1px;top:-1px}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed #fff}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){-webkit-animation:marching-ants 1s;animation:marching-ants 1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-play-state:running;animation-play-state:running;-webkit-animation-timing-function:linear;animation-timing-function:linear;background-image:-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444));background-image:linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0);background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;background-size:10px 1px,10px 1px,1px 10px,1px 10px;color:#fff}.ReactCrop__crop-selection:focus{outline:2px solid #08f;outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{background-color:#fff6;content:"";display:block;position:absolute}.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{height:100%;width:1px}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before{height:1px;width:100%}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{background-color:#0003;background-color:var(--rc-drag-handle-bg-colour);border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);height:12px;height:var(--rc-drag-handle-size);position:absolute;width:12px;width:var(--rc-drag-handle-size)}.ReactCrop__drag-handle:focus{background:#08f;background:var(--rc-focus-color)}.ReactCrop .ord-nw{cursor:nw-resize;left:0}.ReactCrop .ord-n,.ReactCrop .ord-nw{top:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop .ord-n{cursor:n-resize;left:50%}.ReactCrop .ord-ne{cursor:ne-resize;top:0}.ReactCrop .ord-e,.ReactCrop .ord-ne{right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%)}.ReactCrop .ord-e{cursor:e-resize;top:50%}.ReactCrop .ord-se{bottom:0;cursor:se-resize;right:0;-webkit-transform:translate(50%,50%);transform:translate(50%,50%)}.ReactCrop .ord-s{cursor:s-resize;left:50%}.ReactCrop .ord-s,.ReactCrop .ord-sw{bottom:0;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%)}.ReactCrop .ord-sw{cursor:sw-resize;left:0}.ReactCrop .ord-w{cursor:w-resize;left:0;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{height:6px;height:var(--rc-drag-bar-size);left:0;top:0;-webkit-transform:translateY(-50%);transform:translateY(-50%);width:100%}.ReactCrop__drag-bar.ord-e{height:100%;right:0;top:0;-webkit-transform:translate(50%);transform:translate(50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop__drag-bar.ord-s{bottom:0;height:6px;height:var(--rc-drag-bar-size);left:0;-webkit-transform:translateY(50%);transform:translateY(50%);width:100%}.ReactCrop__drag-bar.ord-w{height:100%;left:0;top:0;-webkit-transform:translate(-50%);transform:translate(-50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w,.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle{display:none}@media (pointer:coarse){.ReactCrop .ord-e,.ReactCrop .ord-n,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{height:24px;height:var(--rc-drag-handle-mobile-size);width:24px;width:var(--rc-drag-handle-mobile-size)}}.crop-modal{align-items:center;background:#0009;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:1000}.crop-box{background:#fff;border-radius:10px;box-sizing:border-box;display:flex;flex-direction:column;gap:16px;height:95vh;max-width:800px;overflow:hidden;padding:20px;width:90vw}.ReactCrop{background-color:#111;border-radius:8px;flex:1 1;height:85%;max-height:100%}.ReactCrop__child-wrapper{height:100%;object-fit:contain}.crop-actions{display:flex;gap:10px;justify-content:flex-end}.crop-actions button{background-color:#f5f5f5;border:1px solid #888;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.crop-actions button:hover{background-color:#ddd}.upload-container{font-family:Arial,sans-serif;margin-top:8px;max-height:none;overflow-y:visible;padding:16px 20px;width:100%}.App .main,.main{align-items:flex-start!important;justify-content:flex-start!important}.upload-title{margin-top:0}.upload-description,.upload-title{margin-bottom:16px}.essay-type-select{border-radius:10px;margin-bottom:30px;margin-left:10px;margin-top:10px;padding:5px 15px}.upload-area{background-color:#f9fafa;border:2px dashed #fbc02d;border-radius:12px;cursor:pointer;margin:0 auto 16px;max-width:600px;padding:32px;text-align:center;transition:border-color .3s,background-color .3s}.upload-area:hover{background-color:#fbedca;border-color:#fbc02d;transition:1s}.upload-icon,.upload-icon img{color:#fbc02d;margin-bottom:12px}.upload-icon img{width:60px}.click-text{color:#fbc02d;font-weight:700}.file-input-hidden{display:none}.ai-model-section,.student-name-section{margin-bottom:16px}.ai-model-label,.student-name-label{color:#333;display:block;font-weight:600;margin-bottom:8px}.ai-model-select,.student-name-input{background-color:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;max-width:400px;outline:none;padding:12px 16px;transition:border-color .2s ease;width:100%}.ai-model-select:focus,.ai-model-select:hover,.student-name-input:focus,.student-name-input:hover{border-color:#667eea}.uploaded-section{align-items:center;display:flex;flex-direction:column;gap:12px;margin-top:12px;min-height:120px}.uploaded-files-grid{align-items:flex-start;background:#0000;border-radius:0;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:10px}.uploaded-item{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;margin:6px;min-width:150px;padding:0;position:relative;transition:transform .2s,box-shadow .2s;width:150px}.uploaded-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.uploaded-item.dragging{box-shadow:0 8px 20px #0003;transform:rotate(2deg) scale(1.05);z-index:1000}.uploaded-item img{border:none;border-radius:8px;height:120px;object-fit:cover;width:100%}.file-info{display:none}.submit-button{align-self:center;background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:8px;padding:12px 30px;transition:background .2s}.submit-button:hover:not(:disabled){background:#218838}.submit-button.disabled,.submit-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.loading-overlay{align-items:center;background:#000000b3;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.loading-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-width:400px;padding:32px;text-align:center;width:90%}.loading-content,.loading-content-relative{position:relative}.close-button{align-items:center;background:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:30px;justify-content:center;position:absolute;right:12px;top:12px;width:30px}.close-button:hover{background:#c82333}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#fbc02d;height:50px;margin:0 auto 16px;width:50px}.loading-content h2{color:#333;font-size:1.4rem;margin-bottom:10px}.loading-message{color:#666;font-size:1rem;margin-bottom:14px}.progress-container{margin:14px 0}.progress-bar{background:#e9ecef;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#28a745,#20c997);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:#333;font-size:1.05rem;font-weight:700}.loading-tip{color:#666;font-size:.9rem;font-style:italic;margin-top:10px}.image-modal-overlay{align-items:center;background:#000c;cursor:pointer;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10000}.image-modal-content{cursor:default;max-height:90vh;max-width:90vw;position:relative}.modal-image{border-radius:8px;box-shadow:0 10px 30px #00000080;max-height:90vh;max-width:100%;object-fit:contain}.modal-close-btn{align-items:center;background:#ffffffe6;border:none;border-radius:50%;color:#333;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:35px;justify-content:center;position:absolute;right:0;top:-40px;transition:background .2s;width:35px}.modal-close-btn:hover{background:#fff}@media (max-width:768px){.upload-area{padding:24px}.uploaded-item{min-width:200px;width:200px}.uploaded-item img{height:110px}.modal-close-btn{right:10px;top:10px}}@media (max-width:480px){.uploaded-item{min-width:150px;width:150px}.uploaded-item img{height:100px}}.admin-app{margin:0;padding:0;text-align:center}.admin-app,.admin-sidebar{display:flex;height:100vh;overflow:hidden}.admin-sidebar{align-items:flex-start;background:#fff;border-right:1px solid #d3d3d3;color:#000;flex-direction:column;left:0;padding-top:8px;top:0;transition:width 1.2s;width:60px;z-index:1000}.admin-sidebar.expanded{align-self:start;width:200px}.admin-sidebar .logo-container{align-items:center;border-bottom:.2px solid #dfdfdf;display:flex;flex-direction:row;justify-content:center;padding-bottom:10px;padding-top:10px}.admin-sidebar .logo-container img{align-items:center;display:flex;height:40px;justify-content:center;padding-left:10px;width:45px}.admin-sidebar .logo-name{font-size:1.2rem;font-weight:700;padding-left:10px;padding-right:20px;white-space:nowrap}.admin-sidebar .sidebar-links{display:flex;flex:1 1 auto;flex-direction:column;gap:2px;margin-top:10px;width:100%}.admin-sidebar .sidebar-bottom{padding-bottom:20px;width:100%}.admin-sidebar .navlink{align-self:start;border-radius:8px;color:#000;cursor:pointer;display:flex;font-size:.8em;font-weight:700;gap:1.3em;margin:0 14px 4px 2px;min-width:0;padding:12px 0;text-decoration:none;transition:.3s;width:calc(100% - 10px)}.admin-sidebar .navlink.active,.admin-sidebar .navlink:hover{background:#fac548;border-radius:999px;color:#fff}.admin-sidebar .sidebar__icon{font-size:1.2em;min-width:40px;padding-left:20px;text-align:center}.admin-sidebar .sidebar__label{opacity:0;transition:opacity .2s;white-space:nowrap}.admin-sidebar.expanded .sidebar__label{opacity:1}.admin-main{background-color:#fafbfc;flex:1 1;height:100vh;overflow-y:auto;width:100%}.admin-dashboard{background-color:#fafbfc;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.dashboard-header{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:20px;text-align:center}.dashboard-header h1{color:#333;font-size:2.5rem;margin:0 0 10px}.dashboard-header p{color:#666;font-size:1.1rem;margin:0}.token-generator-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.token-generator-section h2{color:#333;font-size:1.8rem;margin-bottom:20px}.token-form{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr 1fr 1fr;margin-bottom:20px}.form-group label{text-align:left}.form-group input,.form-group select{border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;padding:12px;transition:border-color .3s}.form-group input:focus,.form-group select:focus{border-color:#fac548;outline:none}.generate-btn{background:linear-gradient(135deg,#fac548,#f9b234);border:none;border-radius:8px;box-shadow:0 4px 15px #fac5484d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;grid-column:1/-1;padding:15px 30px;transition:all .3s}.generate-btn:hover:not(:disabled){box-shadow:0 6px 20px #fac54866;transform:translateY(-2px)}.generate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.generated-url{background:#f8f9fa;border-left:4px solid #fac548;border-radius:8px;margin-top:20px;padding:20px}.generated-url h3{color:#333;margin-bottom:15px}.url-container{display:flex;gap:10px;margin-bottom:10px}.url-input{background:#fff;border:2px solid #e1e5e9;border-radius:8px;flex:1 1;font-family:monospace;font-size:.9rem;padding:12px}.copy-btn{background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:700;padding:12px 20px;transition:background .3s}.copy-btn:hover{background:#218838}.url-note{color:#666;font-size:.9rem;margin:0;text-align:left}.tokens-list-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.tokens-list-section h2{color:#333;font-size:1.8rem;margin-bottom:20px}.tokens-list{grid-gap:20px;display:grid;gap:20px}.token-card{align-items:flex-start;border:2px solid #e1e5e9;border-radius:12px;display:flex;justify-content:space-between;padding:20px;transition:all .3s}.token-card:hover{box-shadow:0 4px 15px #0000001a;transform:translateY(-2px)}.token-card.active{background:#f8fff9;border-color:#28a745}.token-card.inactive{background:#fff8f8;border-color:#dc3545;opacity:.8}.token-info{flex:1 1;text-align:left}.token-info h4{color:#333;font-size:1.2rem;margin:0 0 10px}.token-info p{color:#666;font-size:.9rem;margin:5px 0}.token-actions{display:flex;flex-direction:column;gap:10px;margin-left:20px}.deactivate-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:background .3s}.deactivate-btn:hover{background:#c82333}.deactivated-section{border-top:3px solid #dc3545}@media (max-width:768px){.admin-dashboard{padding:15px}.token-form{grid-template-columns:1fr}.token-card{flex-direction:column;gap:15px}.token-actions{flex-direction:row;margin-left:0;width:100%}.dashboard-header h1{font-size:2rem}}.section-header{justify-content:space-between;margin-bottom:1rem}.section-header,.tokens-filter{align-items:center;display:flex}.tokens-filter{gap:.5rem}.tokens-filter label{color:#555;font-weight:500}.tokens-limit-select{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem}.tokens-count-info{color:#666;font-style:italic;margin-top:1rem;text-align:center}.user-management-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.user-management-section h2{color:#333;font-size:1.8rem;margin-bottom:16px;text-align:left}.user-create-form{grid-gap:12px;align-items:end;display:grid;gap:12px;grid-template-columns:2fr 2fr 1fr auto;margin-bottom:16px}.user-create-form input,.user-create-form select{border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;padding:12px}.user-create-form button{background:linear-gradient(135deg,#4a90e2,#357ab8);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 18px}.bulk-create{display:flex;gap:12px;justify-content:flex-end;margin-bottom:20px}.bulk-create button{background:#fac548;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:12px 18px}.users-table{border:2px solid #e1e5e9;border-radius:12px;overflow-x:auto}.users-table table{border-collapse:collapse;width:100%}.users-table td,.users-table th{border-bottom:1px solid #eef1f4;padding:12px 10px;text-align:left}.users-table thead th{background:#f6f8fa;color:#444;font-weight:700}.users-table tbody tr:hover{background:#fafbfc}.user-delete-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;padding:6px 10px}@media (max-width:768px){.user-create-form{grid-template-columns:1fr}.bulk-create{justify-content:stretch}}.App{display:flex;height:100dvh;margin:0;overflow:hidden;padding:0;text-align:center}.logo-container{border-bottom:.2px solid #dfdfdf;flex-direction:row;padding-bottom:10px;padding-top:10px}.logo-container,.logo-container img{align-items:center;display:flex;justify-content:center}.logo-container img{height:50px;padding-left:10px;width:55px}.logo-name{font-size:1.5rem;font-weight:700;padding-left:10px;padding-right:50px}.sidebar{align-items:flex-start;background:#fff;border-right:1px solid #d3d3d3;color:#000;height:100vh;left:0;overflow:hidden;padding-top:8px;top:0;transition:width 1.2s;width:60px}.sidebar,.sidebar-links{display:flex;flex-direction:column}.sidebar-links{flex:1 1 auto;gap:2px;margin-top:10px;width:100%}.sidebar__icon-fixed{align-items:center;background:none;display:flex;height:32px;justify-content:center;padding-left:20px;pointer-events:none;width:32px}.sidebar.expanded{align-self:start;width:200px}.sidebar-bottom{padding-bottom:20px;width:100%}.navlink{align-self:start;border-radius:8px;color:#000;display:flex;font-size:.8em;font-weight:700;gap:1.3em;margin:0 14px 4px 2px;min-width:0;padding:12px 0;text-decoration:none;transition:.3s;width:calc(100% - 10px)}.navlink.active,.navlink:hover{background:#fac548;border-radius:999px;color:#fff}.sidebar__icon{font-size:1.2em;min-width:40px;padding-left:20px;text-align:center}.sidebar__label{opacity:0;transition:opacity .2s;white-space:nowrap}.sidebar.expanded .sidebar__label{opacity:1}.main{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;height:100dvh;justify-content:flex-start;margin-left:60px;overflow-y:auto;padding:24px;transition:margin-left .3s ease;width:100%}.sidebar.expanded~.main{margin-left:200px}.welcome{box-sizing:border-box;height:100%;justify-content:space-between;padding:40px 0;width:100%}.intro,.welcome{align-items:center;display:flex;flex-direction:column}.intro{flex:1 1}.bottom,.intro{justify-content:center}.bottom{display:flex;margin-top:auto;padding-bottom:20px;width:100%}.question{background-color:#3c3c3c;border-radius:5px;font-size:1.5rem;height:15vh;margin-top:auto;padding:10px;width:70%}:root{--main-bg:#fafbfc;--card-bg:#fff;--border:#eaeaea;--text:#222;--muted:#7c8895;--primary:#fac548;--accent:#ffe8a3;--shadow:0 4px 16px 0 #1e225a0d;--radius:18px}*{box-sizing:border-box;font-family:Segoe UI,sans-serif;margin:0;padding:0}.login-container,body,html{height:100vh;width:100%}.login-container{background:#fff;display:flex}.login-left{align-items:center;background:#f4f6fc;display:flex;flex:1 1;justify-content:center}.login-left img{height:100%;width:100%}.login-right{display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:60px 80px;position:relative}.top-right{align-items:center;display:flex;font-size:14px;gap:10px;position:absolute;right:40px;top:30px}.top-right button{background:none;border:1px solid #ccc;border-radius:20px;cursor:pointer;font-weight:600;padding:6px 14px}.form-box{max-width:400px;width:100%}.form-box h1{font-size:30px;margin-bottom:10px}.form-box p{color:#888;font-size:14px;margin-bottom:30px}.form-box form{display:flex;flex-direction:column}.form-box input{border:1px solid #ddd;border-radius:10px;font-size:14px;margin-bottom:20px;padding:12px 16px;transition:.2s}.form-box input:focus{border-color:#fac548;border-color:var(--primary);outline:none}.login-btn{background:#ffe8a3;background:var(--accent);border:none;border-radius:30px;color:#fff;cursor:pointer;font-size:15px;font-weight:700;margin-top:10px;padding:12px;transition:background .2s}.login-btn:hover{background:#fac548;background:var(--primary)}.social-login{margin-top:40px;text-align:center}.social-login p{color:#777;font-size:14px;margin-bottom:12px}.social-icons{display:flex;gap:14px;justify-content:center}.icon{background:#eee;border:none;border-radius:50%;cursor:pointer;font-size:16px;font-weight:700;padding:10px 14px;transition:.2s}.icon:hover{background:#ddd}.error-msg{color:#d93025}.error-msg,.success-msg{font-size:14px;margin-bottom:10px;margin-top:-10px}.success-msg{color:#188038}.teacher-register-container{align-items:center;background-color:#fafbfc;display:flex;justify-content:center;min-height:100vh;padding:20px}.teacher-register-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;max-width:450px;padding:40px;text-align:center;width:100%}.teacher-register-card h2{color:#333;font-size:2.5rem;font-weight:600;margin-bottom:8px}.teacher-register-card p{color:#666;font-size:1.1rem;margin-bottom:30px}.teacher-register-card form{text-align:left}.form-group{display:flex;flex-direction:column;margin-bottom:20px}.form-group label{color:#333;display:block;font-size:1rem;font-weight:700;margin-bottom:8px}.form-group input{border:2px solid #e1e5e9;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:#fac548;outline:none}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.7}.btn-primary{background:linear-gradient(135deg,#fac548,#f9b234);border:none;border-radius:8px;box-shadow:0 4px 15px #fac5484d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;margin-top:10px;padding:15px 30px;transition:all .3s ease;width:100%}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #fac54866;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;margin-top:20px;padding:12px 24px;transition:all .3s ease}.btn-secondary:hover{background:#5a6268;transform:translateY(-1px)}.error-message{background:#fff8f8;border:2px solid #dc3545;border-radius:8px;color:#dc3545}.error-message,.success-message{font-size:.9rem;margin:15px 0;padding:12px 16px}.success-message{background:#f8fff9;border:2px solid #28a745;border-radius:8px;color:#28a745}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#fac548;height:40px;margin:20px auto;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-link{border-top:1px solid #e1e5e9;margin-top:30px;padding-top:20px;text-align:center}.login-link p{color:#666;font-size:.9rem;margin:0}.login-link a{color:#fac548;font-weight:500;text-decoration:none}.login-link a:hover{text-decoration:underline}@media (max-width:480px){.teacher-register-container{padding:10px}.teacher-register-card{padding:30px 20px}.teacher-register-card h2{font-size:2rem}}.teacher-dashboard-main{align-items:flex-start;justify-content:flex-start;margin:0 auto;max-width:1200px}.teacher-dashboard-header{margin-bottom:30px;text-align:center}.teacher-dashboard-header h1{color:#333;font-size:2rem;font-weight:700;margin-bottom:6px}.teacher-dashboard-header p{color:var(--muted);font-size:1rem;margin-bottom:28px}.teacher-dashboard-cards{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(2,350px);justify-content:center;margin-bottom:32px}.teacher-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;display:flex;flex-direction:column;gap:4px;min-width:0;padding:40px 55px 36px;transition:box-shadow .22s cubic-bezier(.25,.8,.25,1),transform .15s cubic-bezier(.25,.8,.25,1),border-color .18s,background .15s}.teacher-card:hover{background:#fffbe7;border-color:#ffd600;box-shadow:0 8px 32px 0 #ffd60022,0 1.5px 8px 0 #ffd60044;transform:translateY(-6px) scale(1.03)}.teacher-card h2{color:var(--muted);font-size:1rem;font-weight:600;margin-bottom:2px}.teacher-card-value{color:#222;font-size:2rem;font-weight:700;margin:8px 0 6px}.teacher-card-value.green{color:#00cf30}.teacher-card-value.red{color:#da1428}.teacher-card-desc{color:var(--muted);font-size:.95rem}.teacher-dashboard-footer{margin-top:60px}.teacher-waves-footer{align-items:center;display:flex;justify-content:center;padding:40px 0}.teacher-waves-bottom{height:450px;opacity:1;width:600px}@media (max-width:1200px){.teacher-dashboard-cards{gap:32px;grid-template-columns:1fr 1fr}.teacher-card{min-width:240px;padding:40px 48px 36px}.teacher-card-value{font-size:3rem}}@media (max-width:800px){.teacher-no-sidebar{padding:14px 6px}.teacher-dashboard-cards{gap:24px;grid-template-columns:1fr}.teacher-card{min-width:200px;padding:32px 40px 28px}.teacher-card-value{font-size:2.5rem}}.main:has(.teacher-dashboard-main){align-items:flex-start!important;justify-content:flex-start!important;padding:0!important}.teacher-dashboard-main{background:var(--main-bg);box-sizing:border-box;display:flex;flex-direction:column;margin:0;max-width:none;min-height:100%;overflow-y:auto;padding:20px 24px;width:100%}.teacher-dashboard-content{display:flex;flex-direction:column;margin:0 auto;max-width:1200px;width:100%}.change-password-wrapper{margin:40px auto;max-width:520px}.change-password-card{background:#fff;border:2px solid #e1e5e9;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:24px}.change-password-title{color:#333;font-size:1.8rem;margin:0 0 16px;text-align:left}.change-password-form{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr}.change-password-form label{color:#333;font-weight:600}.change-password-input{border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;padding:12px}.change-password-input:focus{border-color:#fac548;outline:none}.change-password-button{background:linear-gradient(135deg,#fac548,#f9b234);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:700;padding:12px 18px}.change-password-help{color:#666;font-size:.9rem}.change-password-error{color:#dc3545}.change-password-success{color:#28a745}.access-denied-container{align-items:center;display:flex;flex-direction:column;height:60vh;justify-content:center;padding:20px;text-align:center}.access-denied-title{color:#e74c3c;font-size:24px;font-weight:700;margin-bottom:20px}.access-denied-message{color:#555;font-size:18px;line-height:1.5;margin-bottom:30px}.back-to-home-button{background-color:#3498db;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;min-width:120px;padding:12px 24px;transition:background-color .3s ease}.back-to-home-button:hover{background-color:#2980b9}.back-to-home-button:focus{outline:2px solid #3498db;outline-offset:2px}.back-to-home-button:active{transform:translateY(1px)}
/*# sourceMappingURL=main.f90d071c.css.map*/