@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.flex-center{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{text-align:center;border-radius:20px;flex-direction:column;gap:1.5rem;width:90%;max-width:450px;padding:3rem;display:flex}.brand-header{flex-direction:column;align-items:center;gap:1rem;display:flex}.brand-header h1{background:linear-gradient(135deg, var(--primary-color), #ff9100);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:2.5rem}.subtitle{color:var(--text-secondary);font-size:1.1rem}.login-btn{justify-content:center;align-items:center;gap:.75rem;margin-top:1rem;padding:12px 24px;font-size:1.1rem;display:flex}.login-btn:disabled{opacity:.7;cursor:not-allowed}.study-flashcard{perspective:1000px;cursor:pointer;width:100%;max-width:400px;height:250px;margin:1rem auto}.flashcard-inner{text-align:center;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,.2,.2,1);position:relative}.study-flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{backface-visibility:hidden;background:var(--surface-color,#fff);border:1px solid var(--border-color,#eaeaea);border-radius:12px;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:2rem;display:flex;position:absolute;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.flashcard-back{background:var(--primary-color,#3b82f6);color:#fff;transform:rotateY(180deg)}.flashcard-front h4,.flashcard-back h4{opacity:.8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 1rem;font-size:.875rem}.flashcard-front p,.flashcard-back p{margin:0;font-size:1.25rem;font-weight:500}.flashcard-front small{opacity:.5;margin-top:auto;font-size:.75rem}.study-quiz,.study-dictation,.study-fill-blank{background:var(--surface-color,#fff);border:1px solid var(--border-color,#eaeaea);border-radius:12px;margin:1rem 0;padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a}.quiz-options{flex-direction:column;gap:.5rem;margin-top:1rem;display:flex}.quiz-option{border:1px solid var(--border-color,#eaeaea);text-align:left;cursor:pointer;color:var(--text-color,#1f2937);background:0 0;border-radius:8px;padding:.75rem 1rem;transition:all .2s}.quiz-option:hover:not(:disabled){background:var(--hover-color,#f3f4f6)}.quiz-option.correct{color:#166534;background:#dcfce7;border-color:#22c55e}.quiz-option.incorrect{color:#991b1b;background:#fee2e2;border-color:#ef4444}.quiz-feedback,.dictation-feedback,.fib-feedback{border-radius:8px;margin-top:1rem;padding:1rem;font-weight:500}.quiz-feedback.success,.dictation-feedback.success{color:#166534;background:#dcfce7}.quiz-feedback.error,.dictation-feedback.error{color:#991b1b;background:#fee2e2}.quiz-explanation{opacity:.9;margin-top:.5rem;font-size:.875rem;font-weight:400}.study-dictation textarea{border:1px solid var(--border-color,#eaeaea);resize:vertical;background:var(--bg-color,#f9fafb);width:100%;min-height:100px;color:var(--text-color,#1f2937);border-radius:8px;margin:1rem 0;padding:.75rem}.play-btn,.check-btn{background:var(--primary-color,#3b82f6);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-weight:500;transition:background .2s}.play-btn:hover,.check-btn:hover{filter:brightness(1.1)}.fib-sentence{margin:1rem 0;line-height:2}.fib-sentence input{border:1px solid var(--border-color,#eaeaea);background:var(--bg-color,#f9fafb);width:120px;color:var(--text-color,#1f2937);border-radius:4px;margin:0 .25rem;padding:.25rem .5rem}.fib-sentence input.correct{background:#dcfce7;border-color:#22c55e}.fib-sentence input.incorrect{background:#fee2e2;border-color:#ef4444}.chat-layout{background-color:var(--bg-primary);width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);flex-direction:column;padding:1.5rem;transition:all .3s;display:flex}.nav-sidebar{white-space:nowrap;width:280px;min-width:280px;overflow:hidden}.sidebar-closed .nav-sidebar{border-right:none;width:0;min-width:0;padding-left:0;padding-right:0}.context-sidebar{border-right:none;border-left:1px solid var(--border-color);white-space:nowrap;width:320px;min-width:320px;transition:all .3s;overflow:hidden}.sidebar-right-closed .context-sidebar{opacity:0;border-left:none;width:0;min-width:0;padding-left:0;padding-right:0}.brand-small{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:2rem;font-size:1.5rem;font-weight:700}.nav-list{flex-direction:column;gap:.5rem;margin-bottom:2rem;display:flex}.nav-item{border-radius:var(--radius-md);color:var(--text-muted);align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{background-color:var(--bg-tertiary);color:var(--text-main)}.nav-item.active{background:var(--accent-gradient);color:#fff;box-shadow:var(--shadow-sm)}.chat-history-section{flex-direction:column;flex:1;gap:.5rem;display:flex;overflow-y:auto}.history-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;font-weight:600}.thread-item{border-radius:var(--radius-md);cursor:pointer;color:var(--text-muted);justify-content:space-between;align-items:center;padding:.75rem;transition:background-color .2s;display:flex}.thread-item:hover,.thread-item.active{background-color:var(--bg-tertiary);color:var(--text-main)}.text-content{white-space:normal;line-height:1.6}.text-content p{margin:0 0 .75rem}.text-content p:last-child{margin-bottom:0}.text-content pre{background:#0000000d;border-radius:8px;margin:.75rem 0;padding:1rem;font-family:monospace;overflow-x:auto}.text-content code{background:#0000000d;border-radius:4px;padding:.2rem .4rem;font-family:monospace;font-size:.9em}.text-content ul,.text-content ol{margin:.75rem 0;padding-left:1.5rem}.thread-title{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.9rem;font-weight:500;overflow:hidden}.del-thread-btn{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;padding:.25rem;transition:opacity .2s,color .2s}.thread-item:hover .del-thread-btn{opacity:1}.del-thread-btn:hover{color:#ef4444}.chat-main{background-color:var(--bg-primary);flex-direction:column;flex:1;display:flex;position:relative}.chat-header{background-color:rgba(var(--bg-secondary), .8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:10;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.chat-header h2{font-size:1.25rem;font-weight:600}.header-actions{align-items:center;gap:1rem;display:flex}.btn-primary{background:var(--accent-gradient);color:#fff;border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-md);border:none;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:flex}.btn-primary:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.icon-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;transition:background-color .2s,color .2s;display:flex}.icon-btn:hover{background-color:var(--bg-tertiary);color:var(--text-main)}.chat-messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:1.5rem;padding:2rem;display:flex;overflow-y:auto}.empty-state{text-align:center;color:var(--text-muted);margin:auto}.empty-state h3{color:var(--text-main);margin-bottom:.5rem;font-size:1.5rem}.message-wrapper{width:100%;display:flex}.message-wrapper.user{justify-content:flex-end}.message-content{border-radius:var(--radius-xl);max-width:70%;box-shadow:var(--shadow-sm);word-wrap:break-word;padding:1rem 1.5rem;font-size:1rem;position:relative}.message-wrapper.user .message-content{background:var(--primary-color);color:#fff;border-bottom-right-radius:4px}.message-wrapper.assistant .message-content{background-color:var(--bg-secondary);color:var(--text-main);border:1px solid var(--border-color);border-bottom-left-radius:4px}.message-actions{justify-content:flex-end;margin-top:.75rem;display:flex}.action-btn{color:inherit;opacity:.6;cursor:pointer;background:0 0;border:none;align-items:center;gap:.25rem;font-size:.8rem;transition:opacity .2s;display:flex}.action-btn:hover{opacity:1}.chat-input-area{background:var(--bg-primary);border-top:1px solid var(--border-color);flex-direction:column;gap:.5rem;padding:1.5rem 2rem;display:flex}.study-mode-selector{align-items:center;gap:.5rem;display:flex}.study-mode-selector select{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-main);outline:none;padding:.25rem .5rem;font-size:.875rem}.input-box{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);align-items:center;gap:1rem;padding:.5rem 1rem;transition:border-color .2s,box-shadow .2s;display:flex}.input-box:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f633}.input-box input[type=text]{color:var(--text-main);background:0 0;border:none;outline:none;flex:1;padding:.5rem 0;font-size:1rem}.send-btn{background:var(--accent-gradient);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:transform .2s,filter .2s;display:flex}.send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.send-btn:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.05)}.context-sidebar h3{margin-bottom:.5rem;font-size:1.1rem}.context-help{color:var(--text-muted);margin-bottom:1.5rem;font-size:.85rem}.notes-list{flex-direction:column;gap:1rem;display:flex;overflow-y:auto}.context-note{background-color:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:1rem;font-size:.9rem;position:relative}.del-btn{color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;transition:opacity .2s,color .2s;position:absolute;top:.5rem;right:.5rem}.context-note:hover .del-btn{opacity:1}.del-btn:hover{color:#ef4444}.loader-dots{align-items:center;gap:4px;display:flex}.text-content pre{background:var(--bg-tertiary);border-radius:var(--radius-md);margin-top:.5rem;padding:1rem;overflow-x:auto}.text-content code{background:var(--bg-tertiary);border-radius:3px;padding:.1rem .3rem;font-family:monospace}@media (width<=768px){.sidebar{z-index:100;position:fixed;top:0;bottom:0;box-shadow:0 0 15px #00000040}.nav-sidebar{width:260px;min-width:260px;left:0}.sidebar-closed .nav-sidebar{border-right:1px solid var(--border-color);width:260px;min-width:260px;padding:1.5rem;transform:translate(-100%)}.context-sidebar{z-index:100;width:280px;min-width:280px;right:0;box-shadow:-5px 0 15px #00000040}.sidebar-right-closed .context-sidebar{border-left:1px solid var(--border-color);opacity:1;width:280px;min-width:280px;padding:1.5rem;transform:translate(100%)}.chat-messages{gap:1rem;padding:1rem}.message-content{max-width:85%;padding:.75rem 1rem}.chat-header{padding:.75rem 1rem}.chat-header h2{white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:1rem;overflow:hidden}.header-actions{gap:.5rem}.header-actions .btn-primary{padding:.5rem .8rem;font-size:.85rem}.chat-input-area{padding:1rem}.input-box{gap:.5rem;padding:.4rem .8rem}.input-box input[type=text]{font-size:.9rem}.study-mode-selector{flex-wrap:wrap;font-size:.8rem}.study-mode-selector select{padding:.2rem .4rem;font-size:.8rem}}.camera-modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:1000;background-color:#07040ebf;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.camera-modal-container{-webkit-backdrop-filter:blur(20px);background:#120c26d9;border:1px solid #ffffff1a;border-radius:24px;flex-direction:column;gap:1.25rem;width:90%;max-width:600px;padding:1.5rem;animation:.3s cubic-bezier(.16,1,.3,1) scaleUp;display:flex;box-shadow:0 25px 50px -12px #00000080,0 0 40px #6366f126}.camera-modal-header{justify-content:space-between;align-items:center;display:flex}.camera-modal-header h3{color:var(--text-main);font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:600}.camera-modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.75rem;line-height:1;transition:color .2s}.camera-modal-close:hover{color:#ef4444}.camera-modal-body{aspect-ratio:4/3;background:#0d091e;border:1px solid #ffffff0d;border-radius:16px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.camera-video-stream,.camera-captured-img{object-fit:cover;width:100%;height:100%}.camera-video-stream{transform:scaleX(-1)}.camera-captured-img{animation:.3s ease-out flashEffect}.camera-modal-footer{justify-content:flex-end;gap:.75rem;display:flex}.camera-modal-footer button{cursor:pointer;border-radius:12px;padding:.75rem 1.5rem;font-family:Outfit,sans-serif;font-weight:600;transition:all .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleUp{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes flashEffect{0%{filter:brightness(3)}to{filter:brightness()}}.dashboard-main{flex-direction:column;flex:1;display:flex}.dashboard-content{padding:2rem;overflow-y:auto}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.stat-card h3{color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem}.stat-value{color:var(--primary-color);font-size:2rem;font-weight:700}.recent-activity{border:1px solid var(--border-color);background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.activity-item{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:1rem 0}.activity-item:last-child{border-bottom:none}:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-main:#0f172a;--text-muted:#64748b;--border-color:#e2e8f0;--primary-color:#3b82f6;--primary-hover:#2563eb;--accent-gradient:linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-main);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;transition:background-color .3s,color .3s}button{font-family:inherit}a{color:inherit;text-decoration:none}
