.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.login-container{max-width:420px;width:100%;text-align:center;position:relative;z-index:1}.login-logo{margin-bottom:1.5rem}.logo-icon{font-size:4rem;display:block;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-container h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:var(--text-secondary);font-size:1.125rem;margin-bottom:2.5rem}.login-card{background:var(--bg-card);border:1px solid var(--bg-hover);border-radius:var(--radius-lg);padding:2rem;margin-bottom:2rem}.login-card h2{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.login-card p{color:var(--text-secondary);font-size:.9375rem;margin-bottom:1.5rem;line-height:1.6}.google-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.5rem;background:#fff;color:#333;font-weight:500;font-size:1rem;border-radius:var(--radius);text-decoration:none;transition:transform .2s,box-shadow .2s}.google-btn:hover{transform:translateY(-2px);box-shadow:0 4px 20px #ffffff26}.login-features{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.feature{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.875rem}.feature-icon{font-size:1.25rem}.login-decoration{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.deco-circle{position:absolute;border-radius:50%;background:var(--accent-gradient);opacity:.1;filter:blur(60px)}.deco-1{width:400px;height:400px;top:-100px;right:-100px}.deco-2{width:300px;height:300px;bottom:-50px;left:-50px}.deco-3{width:200px;height:200px;top:50%;left:50%;transform:translate(-50%,-50%)}.study-list-header{margin-bottom:2rem}.study-list-header h2{font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.study-list-header p{color:var(--text-secondary)}.loading-container{display:flex;justify-content:center;padding:4rem}.empty-state{text-align:center;padding:4rem 2rem;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--bg-hover)}.empty-icon{font-size:3rem;display:block;margin-bottom:1rem}.empty-state h3{font-size:1.25rem;margin-bottom:.5rem}.empty-state p{color:var(--text-secondary)}.study-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.study-card{background:var(--bg-card);border:1px solid var(--bg-hover);border-radius:var(--radius-lg);padding:1.5rem;cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s}.study-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:0 8px 30px #6366f126}.study-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.study-card-header h3{font-size:1.25rem;font-weight:600}.badge{padding:.25rem .75rem;border-radius:100px;font-size:.75rem;font-weight:500}.badge-success{background:#10b98126;color:var(--success)}.study-description{color:var(--text-secondary);font-size:.9375rem;margin-bottom:1.25rem;line-height:1.5}.study-stats{display:flex;gap:1.5rem;margin-bottom:1rem}.stat{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.8125rem;color:var(--text-muted)}.progress-bar-container{height:4px;background:var(--bg-secondary);border-radius:2px;overflow:hidden;margin-bottom:1.25rem}.progress-bar{height:100%;background:var(--accent-gradient);border-radius:2px;transition:width .3s ease}.study-action{width:100%}.essay-modal{max-width:800px;max-height:85vh}.essay-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #2d2d3d;background:linear-gradient(135deg,#1e1e2e,#252538)}.essay-modal .modal-header h2{margin:0;color:#e2e8f0;font-size:1.1rem;font-weight:500}.essay-modal .modal-body{flex:1;overflow-y:auto;padding:0}.essay-content{padding:2rem;background:#fefefe;color:#1a1a2e;font-family:Georgia,Times New Roman,serif;font-size:1rem;line-height:1.8;min-height:100%}.essay-content p{margin-bottom:1.25em;text-indent:2em}.essay-content p:first-child{text-indent:0}.essay-modal .modal-body::-webkit-scrollbar{width:8px}.essay-modal .modal-body::-webkit-scrollbar-track{background:#f1f1f1}.essay-modal .modal-body::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.essay-modal .modal-body::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.task-context-page{min-height:100vh;background:linear-gradient(135deg,#0a0a1a,#1a1a2e)}.task-context-content{max-width:800px;margin:0 auto;padding:2rem}.intro-section{text-align:center;margin-bottom:2rem;padding:1.5rem;background:#6366f11a;border-radius:12px;border:1px solid rgba(99,102,241,.2)}.intro-section h2{color:#e2e8f0;margin-bottom:.75rem;font-size:1.5rem}.intro-section p{color:#94a3b8;line-height:1.6}.context-section{background:#1e1e2e;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid #2d2d3d}.context-section .section-header{margin-bottom:1rem}.context-section .section-header h3{color:#e2e8f0;font-size:1.25rem;margin-bottom:.25rem}.context-section .section-subtitle{color:#64748b;font-size:.875rem}.context-content{background:#0f0f1a;padding:1.25rem;border-radius:8px;color:#cbd5e1;line-height:1.7;font-size:.95rem;white-space:pre-wrap;margin-bottom:1rem;border-left:3px solid #6366f1}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.75rem;background:#6366f10d;border-radius:8px;transition:background .2s}.checkbox-label:hover{background:#6366f11a}.checkbox-label input[type=checkbox]{width:20px;height:20px;accent-color:#6366f1;cursor:pointer}.checkbox-label span{color:#94a3b8;font-size:.95rem}.checkbox-label input:checked+span{color:#a5b4fc}.action-section{text-align:center;margin-top:2rem;padding-top:2rem;border-top:1px solid #2d2d3d}.action-hint{color:#64748b;margin-bottom:1rem}.btn-large{padding:1rem 3rem;font-size:1.1rem}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:1rem;border-radius:8px;margin-bottom:1rem}.instructions-section{border:2px solid #6366f1;background:linear-gradient(135deg,#1e1e2e,#252538)}.instructions-content{background:#0f0f1a;padding:1.5rem;border-radius:8px;color:#e2e8f0;line-height:1.8;font-size:.95rem;margin-bottom:1rem;border-left:3px solid #6366f1;max-height:400px;overflow-y:auto}.instructions-content h2{color:#a5b4fc;font-size:1.25rem;margin:1.5rem 0 .75rem;font-weight:600}.instructions-content h2:first-child{margin-top:0}.instructions-content h3{color:#a5b4fc;font-size:1.1rem;margin:1.25rem 0 .5rem;font-weight:600}.instructions-content h4{color:#94a3b8;font-size:1rem;margin:1rem 0 .5rem;font-weight:600}.instructions-content p{margin:.5rem 0}.instructions-content li{margin-left:1.5rem;margin-bottom:.25rem;list-style-type:disc}.instructions-content strong{color:#f8fafc;font-weight:600}.instructions-content u{text-decoration:underline;text-decoration-color:#a5b4fc}.essay-section .essay-preview{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#0f0f1a;border-radius:8px;border-left:3px solid #10b981;margin-bottom:1rem}.essay-preview .essay-filename{color:#94a3b8;font-family:monospace;font-size:.9rem}.essay-preview .btn{flex-shrink:0}.dialogue-viewer{display:flex;flex-direction:column;gap:.75rem}.dialogue-turn{max-width:550px;border-radius:12px;overflow:hidden}.dialogue-turn.tutor{align-self:flex-start;background:#1a1a2e;border:1px solid #2d2d44;opacity:.85}.dialogue-turn.student{align-self:flex-end;background:#1e3a5f;border:2px solid #3b82f6}.turn-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.05);font-size:.75rem}.turn-speaker{font-weight:600}.dialogue-turn.tutor .turn-speaker{color:#6b7280}.dialogue-turn.student .turn-speaker{color:#60a5fa;font-weight:700}.turn-number{color:#6b7280;font-family:monospace}.turn-content{padding:.75rem}.turn-content p{font-size:.875rem;line-height:1.6;color:#f1f5f9;margin:0;white-space:pre-wrap;word-break:break-word}.dialogue-turn.student .turn-content p{color:#f1f5f9;font-size:.9rem}.dialogue-turn.summarized{background:#18162f;border-color:#3730a3}.dialogue-turn.summarized .turn-content p.summarized-text{font-style:italic;color:#94a3b8;font-size:.8rem}.toggle-original{background:none;border:none;color:#6366f1;font-size:.75rem;cursor:pointer;padding:.25rem 0;margin-top:.5rem;display:block}.toggle-original:hover{color:#818cf8}.original-text{margin-top:.5rem;padding:.75rem;background:#0000004d;border-radius:6px;border-left:2px solid #4338ca}.original-text p{font-style:normal;color:#cbd5e1;font-size:.8rem}.likert-scale{display:flex;flex-direction:column;gap:.75rem}.likert-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted)}.likert-options{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.likert-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .25rem;background:var(--bg-primary);border:2px solid var(--bg-hover);border-radius:var(--radius);cursor:pointer;transition:all .2s ease}.likert-option:hover{border-color:var(--text-muted)}.likert-option.selected{transform:translateY(-2px)}.likert-option.score--2.selected{border-color:var(--likert-neg2);background:#ef44441a}.likert-option.score--1.selected{border-color:var(--likert-neg1);background:#f973161a}.likert-option.score-0.selected{border-color:var(--likert-0);background:#64748b1a}.likert-option.score-1.selected{border-color:var(--likert-pos1);background:#22c55e1a}.likert-option.score-2.selected{border-color:var(--likert-pos2);background:#10b9811a}.likert-value{font-size:1.125rem;font-weight:700;font-family:JetBrains Mono,monospace}.likert-option.score--2 .likert-value{color:var(--likert-neg2)}.likert-option.score--1 .likert-value{color:var(--likert-neg1)}.likert-option.score-0 .likert-value{color:var(--likert-0)}.likert-option.score-1 .likert-value{color:var(--likert-pos1)}.likert-option.score-2 .likert-value{color:var(--likert-pos2)}.likert-description{font-size:.625rem;color:var(--text-muted);text-align:center;line-height:1.2}.likert-option.selected .likert-description{color:var(--text-secondary)}.likert-feedback{text-align:center;font-size:.875rem;color:var(--text-secondary);padding:.5rem;background:var(--bg-primary);border-radius:var(--radius-sm)}.likert-feedback strong{color:var(--text-primary)}.progress-section{padding:.75rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--bg-hover)}.progress-info{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.8125rem}.progress-current{color:var(--text-primary);font-weight:500}.progress-completed{color:var(--text-muted)}.progress-track{height:4px;background:var(--bg-hover);border-radius:2px;position:relative;overflow:visible}.progress-fill{position:absolute;left:0;top:0;height:100%;background:var(--success);border-radius:2px;transition:width .3s ease}.progress-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;background:var(--accent-gradient);border-radius:50%;border:2px solid var(--bg-secondary);transition:left .3s ease;z-index:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#1e1e2e;border-radius:12px;max-width:700px;width:100%;max-height:80vh;display:flex;flex-direction:column;border:1px solid #2d2d3d;box-shadow:0 25px 50px -12px #00000080}.context-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #2d2d3d}.context-modal .modal-header h2{margin:0;color:#e2e8f0;font-size:1.25rem}.modal-close{background:none;border:none;color:#64748b;font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.modal-close:hover{color:#e2e8f0}.modal-body{flex:1;overflow-y:auto;padding:1.5rem}.context-modal .context-section{margin-bottom:1.5rem}.context-modal .context-section:last-child{margin-bottom:0}.context-modal .context-section h3{color:#a5b4fc;font-size:1rem;margin-bottom:.75rem}.context-modal .context-text{background:#0f0f1a;padding:1rem;border-radius:8px;color:#cbd5e1;line-height:1.7;font-size:.9rem;white-space:pre-wrap;border-left:3px solid #6366f1}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #2d2d3d;display:flex;justify-content:flex-end}.instructions-modal{max-width:750px;max-height:80vh}.instructions-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #2d2d3d;background:linear-gradient(135deg,#1e1e2e,#252538)}.instructions-modal .modal-header h2{margin:0;color:#e2e8f0;font-size:1.25rem}.instructions-modal .modal-body{flex:1;overflow-y:auto;padding:1.5rem}.instructions-text{color:#e2e8f0;line-height:1.8;font-size:.95rem}.instructions-text h2{color:#a5b4fc;font-size:1.25rem;margin:1.5rem 0 .75rem;font-weight:600}.instructions-text h2:first-child{margin-top:0}.instructions-text h3{color:#a5b4fc;font-size:1.1rem;margin:1.25rem 0 .5rem;font-weight:600}.instructions-text h4{color:#94a3b8;font-size:1rem;margin:1rem 0 .5rem;font-weight:600}.instructions-text p{margin:.5rem 0}.instructions-text li{margin-left:1.5rem;margin-bottom:.25rem;list-style-type:disc}.instructions-text strong{color:#f8fafc;font-weight:600}.instructions-text u{text-decoration:underline;text-decoration-color:#a5b4fc}.annotate-page{min-height:100vh}.header-actions{display:flex;align-items:center;gap:.75rem}.context-btn{font-size:.875rem;padding:.5rem .75rem;border:1px solid var(--bg-hover);border-radius:var(--radius);transition:all .2s}.context-btn:hover{background:var(--bg-hover);border-color:var(--primary)}.annotate-content{display:flex;max-width:1200px;margin:0 auto;padding:1rem;gap:1.5rem}.dialogue-section{flex:1;max-width:700px}.section-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;margin-bottom:1rem;border-bottom:1px solid var(--bg-hover)}.section-header h2{font-size:1rem;font-weight:500;color:var(--text-secondary)}.section-meta{display:flex;align-items:center;gap:1rem}.turn-count{font-size:.875rem;color:var(--text-muted)}.time-tracker{font-size:.75rem;color:var(--text-muted);opacity:.5;font-family:monospace}.annotation-section{width:350px;flex-shrink:0}.annotation-card{background:var(--bg-card);border:1px solid var(--bg-hover);border-radius:var(--radius-lg);padding:1.5rem;position:sticky;top:1rem}.annotation-question h3{font-size:1rem;font-weight:600;color:var(--text-primary);text-align:center;margin-bottom:1rem}.reasoning-input{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.reasoning-input label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.error-message{padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius);color:var(--error);font-size:.875rem;margin-top:1rem}.annotation-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem}.annotation-actions .btn-primary{flex:1}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem}.error-icon{font-size:3rem;margin-bottom:1rem}.error-screen h2{margin-bottom:.5rem}.error-screen p{color:var(--text-secondary);margin-bottom:1.5rem}@media (max-width: 900px){.annotate-content{flex-direction:column}.dialogue-section{max-width:100%}.annotation-section{width:100%}.annotation-card{position:static}}.complete-page{display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;overflow:hidden}.complete-container{text-align:center;padding:2rem;position:relative;z-index:1}.complete-icon{font-size:5rem;margin-bottom:1.5rem;animation:bounce 1s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.complete-page h1{font-size:3rem;font-weight:700;margin-bottom:1rem;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.complete-message{font-size:1.25rem;color:var(--text-primary);margin-bottom:.5rem}.complete-submessage{color:var(--text-secondary);margin-bottom:2rem}.complete-actions{display:flex;gap:1rem;justify-content:center}.confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;top:-20px;border-radius:2px;animation:fall 3s ease-in-out infinite}@keyframes fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--bg-card);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page{min-height:100vh;display:flex;flex-direction:column}.page-header{padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--bg-hover);display:flex;justify-content:space-between;align-items:center}.page-header h1{font-size:1.25rem;font-weight:600;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.user-info{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary);font-size:.875rem}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:#fff}.page-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.btn{padding:.75rem 1.5rem;border-radius:var(--radius);font-weight:500;font-size:.9375rem;cursor:pointer;transition:all .2s ease;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none}.btn-primary{background:var(--accent-gradient);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px #6366f166}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--bg-hover)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--bg-hover);overflow:hidden}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--bg-hover)}.card-body{padding:1.5rem}textarea{width:100%;padding:1rem;background:var(--bg-secondary);border:1px solid var(--bg-hover);border-radius:var(--radius);color:var(--text-primary);font-family:inherit;font-size:.9375rem;resize:vertical;min-height:120px;transition:border-color .2s}textarea:focus{outline:none;border-color:var(--accent-primary)}textarea::placeholder{color:var(--text-muted)}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a25;--bg-hover: #22222f;--accent-primary: #6366f1;--accent-secondary: #f472b6;--accent-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #f472b6 100%);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--tutor-bg: #1e1b4b;--tutor-border: #4338ca;--student-bg: #1f2937;--student-border: #6b7280;--likert-neg2: #ef4444;--likert-neg1: #f97316;--likert-0: #64748b;--likert-pos1: #22c55e;--likert-pos2: #10b981;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Outfit,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(99,102,241,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.03) 1px,transparent 1px);background-size:50px 50px;pointer-events:none;z-index:-1}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:#6366f14d}
