@import"https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700&family=Inter:wght@300;400;500&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary: #0d0f12;--bg-secondary: #151820;--bg-sidebar: #101318;--bg-hover: #1c2030;--bg-active: #1e2540;--bg-input: #181c28;--bg-bubble-user: #1a3a5c;--bg-bubble-ai: #161b27;--bg-card: #13171f;--border: #232840;--border-light: #2a3050;--accent: #4f8ef7;--accent-hover: #6ba3ff;--accent-dim: rgba(79, 142, 247, .15);--student-color: #22c55e;--staff-color: #f59e0b;--danger: #ef4444;--text-primary: #e8eaf2;--text-secondary: #9aa0bb;--text-muted: #5a6080;--font-display: "Instrument Sans", sans-serif;--font-body: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--sidebar-width: 280px;--chat-edge-padding: clamp(18px, 3.4vw, 72px);--chat-bubble-max: min(980px, calc(100vw - var(--sidebar-width) - 160px));--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 4px rgba(0,0,0,.4);--shadow-md: 0 4px 16px rgba(0,0,0,.5);--shadow-lg: 0 8px 32px rgba(0,0,0,.6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%;width:100%}body{font-family:var(--font-body);font-size:14px;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}::selection{background:var(--accent-dim);color:var(--accent-hover)}@keyframes pulse{0%,to{opacity:.45;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.chat-layout{display:flex;min-height:100vh;height:100dvh;width:100%;overflow:hidden;position:relative}.chat-main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden;transition:margin-left .2s ease}.mobile-sidebar-toggle,.mobile-sidebar-backdrop{display:none}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);height:100%;background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:all .2s ease}.sidebar-collapsed-panel{width:56px;min-width:56px;align-items:center;padding:12px 8px;gap:8px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 14px 12px;border-bottom:1px solid var(--border)}.sidebar-brand{display:flex;align-items:center;gap:8px}.sidebar-logo{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.user-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:99px;letter-spacing:.5px;text-transform:uppercase}.user-badge.student{background:#22c55e26;color:var(--student-color)}.user-badge.staff{background:#f59e0b26;color:var(--staff-color)}.new-chat-btn{display:flex;align-items:center;gap:8px;margin:12px 10px 8px;padding:9px 14px;background:var(--accent-dim);color:var(--accent);border:1px solid rgba(79,142,247,.3);border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.new-chat-btn:hover{background:#4f8ef740;border-color:var(--accent)}.conversations-list{flex:1;overflow-y:auto;padding:4px 6px}.empty-conversations{padding:24px 12px;text-align:center;color:var(--text-muted);font-size:13px;line-height:1.7}.conversation-item{display:flex;align-items:center;gap:6px;padding:9px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s;min-height:44px}.conversation-item:hover{background:var(--bg-hover)}.conversation-item.active{background:var(--bg-active)}.conversation-item:hover .conv-actions{opacity:1}.conv-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.conv-title{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-date{font-size:11px;color:var(--text-muted)}.conv-actions{display:flex;gap:2px;opacity:0;transition:opacity .12s}.conv-edit{display:flex;align-items:center;gap:4px;flex:1}.conv-edit-input{flex:1;background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);font-size:12px;padding:4px 8px;outline:none}.sidebar-footer{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--border)}.user-info{flex:1;display:flex;align-items:center;gap:10px;min-width:0}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(79,142,247,.3);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.user-details{min-width:0;display:flex;flex-direction:column;gap:1px}.user-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-window{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.messages-container{flex:1;min-height:0;overflow-y:auto;padding:24px 0;display:flex;flex-direction:column;gap:2px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.empty-chat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px var(--chat-edge-padding);text-align:center;gap:16px;animation:fadeIn .4s ease}.empty-chat-icon{width:72px;height:72px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--accent)}.empty-chat-title{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--text-primary);letter-spacing:-.5px}.empty-chat-subtitle{font-size:14px;color:var(--text-secondary);max-width:min(680px,calc(100vw - var(--sidebar-width) - 160px));line-height:1.7}.empty-chat-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px;max-width:min(920px,calc(100vw - var(--sidebar-width) - 160px))}.suggestion-chip{padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .15s;text-align:left}.suggestion-chip:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.suggestion-chip:disabled{opacity:.4;cursor:default}.message-row{display:flex;gap:12px;padding:10px var(--chat-edge-padding);animation:messageIn .2s ease}.message-row.user{flex-direction:row-reverse}.message-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:12px;margin-top:2px}.message-avatar.user{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(79,142,247,.3)}.message-avatar.assistant{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.message-bubble{max-width:var(--chat-bubble-max);border-radius:var(--radius-lg);padding:12px 16px;position:relative}.message-bubble.user{background:var(--bg-bubble-user);border-bottom-right-radius:4px}.message-bubble.assistant{background:var(--bg-bubble-ai);border:1px solid var(--border);border-bottom-left-radius:4px}.message-text-user{font-size:14px;line-height:1.65;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.message-markdown{font-size:14px;line-height:1.75;color:var(--text-primary)}.message-markdown p{margin-bottom:.6em}.message-markdown p:last-child{margin-bottom:0}.message-markdown h1,.message-markdown h2,.message-markdown h3{font-family:var(--font-display);font-weight:600;margin:1em 0 .4em;color:var(--text-primary)}.message-markdown ul,.message-markdown ol{padding-left:1.4em;margin-bottom:.6em}.message-markdown li{margin-bottom:.2em}.message-markdown blockquote{border-left:3px solid var(--accent);padding-left:12px;color:var(--text-secondary);margin:.6em 0}.message-markdown table{border-collapse:collapse;width:100%;margin:.8em 0;font-size:13px}.message-markdown th,.message-markdown td{border:1px solid var(--border);padding:6px 10px;text-align:left}.message-markdown th{background:var(--bg-hover);font-weight:600}.table-wrapper{overflow-x:auto}.inline-code{font-family:var(--font-mono);font-size:12px;background:var(--bg-hover);border:1px solid var(--border);border-radius:4px;padding:1px 5px;color:#e2a96a}.message-actions{display:flex;align-items:center;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.action-btn{display:flex;align-items:center;gap:4px;padding:3px 8px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .12s}.action-btn:hover{border-color:var(--accent);color:var(--accent)}.message-time{font-size:11px;color:var(--text-muted);margin-left:auto}.message-feedback{display:flex;align-items:center;gap:6px;margin-top:10px}.feedback-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .14s ease}.feedback-btn:hover:not(:disabled),.feedback-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.feedback-btn:disabled{opacity:.55;cursor:progress}.feedback-comment-box{display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:8px;margin-top:8px}.feedback-comment-box textarea{width:100%;min-height:46px;resize:vertical;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 10px;font:inherit;font-size:13px}.feedback-comment-box textarea:focus{outline:none;border-color:var(--accent)}.feedback-comment-box button{width:34px;min-height:46px;display:inline-flex;align-items:center;justify-content:center;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-md);color:#fff;cursor:pointer}.feedback-error{margin-top:6px;color:var(--danger);font-size:12px}.feedback-saving-dot{width:7px;height:7px;border-radius:999px;background:currentColor;animation:pulse .9s ease-in-out infinite}.generated-files-panel{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.generated-file-card{display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-card)}.generated-file-item.diagram{display:flex;flex-direction:column;gap:8px}.generated-diagram-inline{overflow:auto;max-height:520px;padding:10px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:#fff}.generated-diagram-inline img{display:block;width:100%;max-width:100%;height:auto;min-height:160px;object-fit:contain}.generated-diagram-loading{padding:14px;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-muted);background:var(--bg-card);font-size:13px}.generated-file-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent-dim);color:var(--accent-hover)}.generated-file-meta{min-width:0}.generated-file-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary);font-size:13px;font-weight:600}.generated-file-subtitle{color:var(--text-muted);font-size:11px}.generated-file-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}.generated-file-btn{height:28px;display:inline-flex;align-items:center;gap:5px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);padding:0 8px;font-size:12px;cursor:pointer;transition:all .12s}.generated-file-btn:hover{border-color:var(--accent);color:var(--accent)}.generated-file-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.generated-file-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}.generated-file-error{margin-top:8px;color:var(--danger);font-size:12px}.generated-preview-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;padding:24px;background:#0000009e}.generated-preview-modal{width:min(760px,100%);max-height:min(760px,calc(100vh - 48px));display:flex;flex-direction:column;border:1px solid var(--border-light);border-radius:var(--radius-lg);background:var(--bg-primary);box-shadow:var(--shadow-lg);overflow:hidden}.generated-preview-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 14px;border-bottom:1px solid var(--border)}.generated-preview-header div{min-width:0;display:flex;flex-direction:column;gap:2px}.generated-preview-header strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary);font-size:14px}.generated-preview-header span{color:var(--text-muted);font-size:11px}.generated-preview-body{max-height:calc(100vh - 150px);overflow:auto;padding:16px;color:var(--text-primary);line-height:1.7}.generated-preview-body pre{white-space:pre-wrap;word-break:break-word;font-family:var(--font-mono);font-size:12px}.generated-preview-body table{width:100%;border-collapse:collapse;margin:10px 0;font-size:13px}.generated-preview-body td,.generated-preview-body th{border:1px solid var(--border);padding:6px 8px;text-align:left}.typing-indicator{display:flex;gap:5px;padding:16px max(24px,calc(50% - 380px))}.typing-indicator.compact{padding:0}.typing-indicator span{width:7px;height:7px;background:var(--text-muted);border-radius:50%;animation:bounce 1.2s infinite}.typing-indicator span:nth-child(2){animation-delay:.15s}.typing-indicator span:nth-child(3){animation-delay:.3s}.loading-conversation{display:flex;justify-content:center;padding:16px;color:var(--text-muted);font-size:14px}@keyframes bounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-6px);opacity:1}}.cursor-blink{display:inline-block;width:2px;height:16px;background:var(--accent);margin-left:2px;vertical-align:text-bottom;animation:cursorBlink .8s infinite}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}.input-bar-wrapper{padding:12px var(--chat-edge-padding) 16px;border-top:1px solid var(--border);background:var(--bg-primary);padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}.tool-controls{display:flex;align-items:center;gap:8px;min-height:30px;position:relative;min-width:0;flex:1}.tool-menu{position:relative;flex-shrink:0}.tool-menu-btn{height:30px;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-secondary);padding:0 9px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.tool-menu-btn.icon-only{width:30px;justify-content:center;padding:0}.tool-menu-btn:hover:not(:disabled),.tool-menu-btn.active{border-color:var(--accent);color:var(--text-primary)}.tool-status-dot{min-width:16px;height:16px;padding:0 5px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:10px;line-height:1;font-weight:700;background:var(--bg-card);color:var(--text-muted);border:1px solid var(--border-light)}.tool-status-dot.on{background:var(--accent-dim);color:var(--accent);border-color:#4f8ef752}.tool-status-dot.off{opacity:.55}.tool-menu-btn:disabled{opacity:.5;cursor:default}.tool-popover{position:absolute;left:0;bottom:calc(100% + 8px);z-index:20;width:min(360px,calc(100vw - 24px));display:flex;flex-direction:column;gap:8px;padding:10px;border:1px solid var(--border-light);border-radius:var(--radius-lg);background:var(--bg-primary);box-shadow:var(--shadow-lg)}.tool-row{display:flex;align-items:center;justify-content:space-between;gap:clamp(12px,1vw,16px)}.tool-row-label{min-width:112px;display:inline-flex;align-items:center;gap:7px;color:var(--text-secondary);font-size:12px;font-weight:500}.tool-segmented{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));width:186px;padding:2px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-input)}.tool-segmented button{min-width:0;height:24px;border:0;border-radius:calc(var(--radius-md) - 2px);background:transparent;color:var(--text-muted);font-size:11px;cursor:pointer}.tool-segmented button.active{background:var(--accent);color:#fff}.tool-summary{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted);font-size:11px}.input-bar{display:flex;flex-direction:column;gap:10px;background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:12px 14px 10px;transition:border-color .15s;position:relative}.input-bar:focus-within{border-color:var(--accent)}.input-textarea{width:100%;min-height:26px;background:none;border:none;outline:none;color:var(--text-primary);font-family:var(--font-body);font-size:14px;line-height:1.6;resize:none;max-height:200px;overflow-y:auto}.input-textarea::placeholder{color:var(--text-muted)}.input-textarea:disabled{opacity:.5}.char-count{font-size:11px;color:var(--text-muted);flex-shrink:0}.char-count.danger{color:var(--danger)}.send-btn{width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .15s}.send-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.05)}.send-btn:disabled{background:var(--border);cursor:default}.send-btn.stop{background:var(--danger)}.send-btn.stop:hover{background:#f87171}.input-disclaimer{text-align:center;font-size:11px;color:var(--text-muted);margin-top:8px}.prompt-footer{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px}.prompt-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.knowledge-role-toggle{display:inline-grid;grid-template-columns:repeat(2,minmax(0,1fr));width:142px;padding:2px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-primary);flex-shrink:0}.knowledge-role-toggle button{min-width:0;height:26px;border:0;border-radius:calc(var(--radius-md) - 2px);background:transparent;color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer}.knowledge-role-toggle button.active.students{background:#22c55e29;color:var(--student-color)}.knowledge-role-toggle button.active.staff{background:#f59e0b29;color:var(--staff-color)}.knowledge-role-toggle button:disabled{cursor:default;opacity:.6}.attached-files{width:100%;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.attached-file{min-width:0;max-width:220px;display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);background:var(--bg-primary);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attached-clear{width:24px;height:24px;border:1px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.login-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);background-image:radial-gradient(ellipse at 20% 50%,rgba(79,142,247,.06) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(79,142,247,.04) 0%,transparent 50%);padding:clamp(24px,5vw,72px);overflow-y:auto;-webkit-overflow-scrolling:touch}.login-card{width:100%;max-width:clamp(420px,38vw,560px);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:clamp(42px,5vw,64px) clamp(34px,4vw,56px);text-align:center;display:flex;flex-direction:column;align-items:center;gap:clamp(16px,1.4vw,22px);box-shadow:var(--shadow-lg);margin:auto}.login-logo{width:clamp(64px,5.2vw,82px);height:clamp(64px,5.2vw,82px);border-radius:50%;background:var(--accent-dim);border:1px solid rgba(79,142,247,.3);display:flex;align-items:center;justify-content:center;color:var(--accent)}.login-logo svg{width:clamp(40px,3.2vw,52px);height:clamp(40px,3.2vw,52px)}.login-title{font-family:var(--font-display);font-size:clamp(28px,2.5vw,38px);font-weight:700;letter-spacing:0;line-height:1.12}.login-subtitle{font-size:clamp(14px,1.1vw,17px);color:var(--text-secondary);line-height:1.7;max-width:420px}.login-domains{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.domain-badge{font-size:clamp(12px,.9vw,14px);font-family:var(--font-mono);padding:6px 14px;border-radius:99px}.domain-badge.student{background:#22c55e1a;color:var(--student-color);border:1px solid rgba(34,197,94,.3)}.domain-badge.staff{background:#f59e0b1a;color:var(--staff-color);border:1px solid rgba(245,158,11,.3)}.microsoft-btn{display:flex;align-items:center;gap:10px;min-height:clamp(46px,3.6vw,54px);padding:12px 24px;background:var(--bg-hover);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);font-size:clamp(14px,1vw,16px);font-weight:500;cursor:pointer;transition:all .15s;width:100%;justify-content:center}.microsoft-btn:hover{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.login-divider{position:relative;width:100%;text-align:center;margin:clamp(18px,2vw,28px) 0;color:var(--text-muted);font-size:clamp(12px,.9vw,14px)}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}.login-divider span{background:var(--bg-card);padding:0 12px;position:relative;z-index:1}.email-form{width:100%;display:flex;flex-direction:column;gap:clamp(12px,1vw,16px)}.form-toggle{display:flex;background:var(--bg-hover);border-radius:var(--radius-md);padding:2px;margin-bottom:8px}.form-toggle button{flex:1;min-height:clamp(38px,3vw,46px);padding:8px 16px;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:clamp(14px,1vw,16px);cursor:pointer;transition:all .15s}.form-toggle button.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.form-input{width:100%;min-height:clamp(46px,3.6vw,54px);padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:clamp(14px,1vw,16px);transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}.email-btn{min-height:clamp(46px,3.6vw,54px);padding:12px 24px;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-md);color:#fff;font-size:clamp(14px,1vw,16px);font-weight:500;cursor:pointer;transition:all .15s;width:100%}.email-btn:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.email-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{color:var(--danger);font-size:clamp(12px,.9vw,14px);text-align:center;margin:0}.login-footer{font-size:clamp(12px,.9vw,14px);color:var(--text-muted)}.icon-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .12s;flex-shrink:0}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn.danger:hover{color:var(--danger)}.icon-btn-sm{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .12s;flex-shrink:0}.icon-btn-sm:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn-sm.danger:hover{color:var(--danger)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes messageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@media (min-width: 1280px){:root{--chat-edge-padding: clamp(28px, 3.6vw, 80px);--chat-bubble-max: min(1040px, calc(100vw - var(--sidebar-width) - 180px))}.empty-chat-title{font-size:28px}.empty-chat-subtitle{font-size:15px}.suggestion-chip{font-size:14px;padding:9px 15px}.message-markdown,.message-text-user,.input-textarea{font-size:15px}}@media (min-width: 1680px){:root{--sidebar-width: 320px;--chat-edge-padding: clamp(36px, 3.2vw, 92px);--chat-bubble-max: min(1180px, calc(100vw - var(--sidebar-width) - 200px))}.sidebar-header{padding:18px 16px 14px}.sidebar-logo{font-size:16px}.new-chat-btn,.conv-title,.user-name{font-size:14px}.conv-date,.user-email{font-size:12px}.conversation-item{min-height:48px;padding:10px 12px}.empty-chat-icon{width:84px;height:84px}.empty-chat-title{font-size:32px}.empty-chat-subtitle,.message-markdown,.message-text-user,.input-textarea{font-size:16px}.message-markdown table{font-size:14px}}@media (min-width: 2200px){:root{--sidebar-width: 360px;--chat-edge-padding: clamp(48px, 3vw, 120px);--chat-bubble-max: min(1380px, calc(100vw - var(--sidebar-width) - 260px))}.message-markdown,.message-text-user,.input-textarea{font-size:17px}}@media (max-width: 768px){.chat-layout{min-height:100dvh;height:100dvh}.sidebar{position:fixed;inset:0 auto 0 0;z-index:110;width:min(86vw,320px);min-width:min(86vw,320px);max-width:min(86vw,320px);height:100dvh;transform:translate(0);box-shadow:var(--shadow-lg)}.sidebar-collapsed-panel{display:none}.chat-main{margin-left:0;width:100%}.mobile-sidebar-toggle{position:fixed;top:calc(12px + env(safe-area-inset-top,0px));left:12px;z-index:105;width:40px;height:40px;border:1px solid var(--border);border-radius:999px;background:#101318eb;color:var(--text-primary);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:109;background:#03060c8f;border:none}.messages-container{padding-top:64px}.message-row{gap:8px;padding:10px 12px}.message-avatar{width:26px;height:26px;font-size:11px}.message-bubble{max-width:min(100%,calc(100vw - 64px));padding:12px 14px}.generated-file-card{grid-template-columns:34px minmax(0,1fr)}.generated-file-actions{grid-column:1 / -1;justify-content:flex-start}.generated-preview-backdrop{padding:12px}.typing-indicator,.pipeline-step-indicator{padding-left:12px;padding-right:12px}.input-bar-wrapper{padding:10px 12px calc(14px + env(safe-area-inset-bottom,0px))}.tool-controls{flex-wrap:wrap}.prompt-footer{align-items:flex-end}.knowledge-role-toggle{width:136px}.tool-popover{width:calc(100vw - 24px)}.tool-row{align-items:stretch;flex-direction:column;gap:8px}.tool-segmented{width:100%}.input-bar{padding:10px 12px}.input-textarea{min-height:24px}.empty-chat{padding:40px 16px}.empty-chat-title{font-size:20px}.empty-chat-subtitle,.empty-chat-suggestions{width:100%;max-width:min(100%,420px)}.empty-chat-suggestions{flex-direction:column;align-items:stretch;gap:8px}.suggestion-chip{width:100%;max-width:100%;min-width:0;display:block;white-space:normal;overflow-wrap:anywhere;word-break:normal;line-height:1.45}.login-page{align-items:flex-start;padding:calc(16px + env(safe-area-inset-top,0px)) 16px calc(24px + env(safe-area-inset-bottom,0px))}.login-card{max-width:100%;padding:28px 20px;gap:14px}.login-title,.forbidden-code{font-size:22px}.forbidden-code{font-size:52px;letter-spacing:-2px}.upload-page,.forbidden-page,.maintenance-page{min-height:100dvh;padding:calc(16px + env(safe-area-inset-top,0px)) 16px calc(24px + env(safe-area-inset-bottom,0px));overflow-y:auto}.upload-page{padding-left:16px;padding-right:16px}.role-tabs,.reindex-actions,.docs-header,.doc-item{flex-wrap:wrap}.role-tab,.reindex-btn{justify-content:center}.role-tab{flex:1 1 140px}.drop-zone{padding:28px 16px}.docs-header,.reindex-block,.forbidden-card,.maintenance-card{padding-left:18px;padding-right:18px}.doc-ext{order:3}.doc-item .icon-btn-sm{opacity:1}}@media (min-width: 641px) and (max-width: 1024px){.login-page{align-items:center;padding:clamp(32px,6vw,64px)}.login-card{max-width:min(560px,calc(100vw - 56px));padding:clamp(42px,6vw,58px) clamp(36px,5vw,52px);gap:clamp(16px,2vw,20px)}.login-title{font-size:clamp(30px,4vw,36px)}.login-subtitle{font-size:clamp(15px,1.8vw,17px)}.form-input,.email-btn,.microsoft-btn{min-height:52px;font-size:16px}}@media (max-width: 480px){.message-row{padding:8px 10px}.message-bubble{max-width:calc(100vw - 52px)}.login-subtitle,.maintenance-message,.forbidden-message{max-width:none}.form-toggle button{padding:8px 10px;font-size:13px}.docs-meta,.forbidden-user-info{width:100%;justify-content:space-between}.doc-item{align-items:flex-start}}.upload-page{min-height:100vh;min-height:100dvh;background:var(--bg-primary);padding:32px max(24px,calc(50% - 480px));overflow-y:auto;-webkit-overflow-scrolling:touch}.upload-header{margin-bottom:28px}.back-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;cursor:pointer;transition:all .12s;margin-bottom:16px}.back-btn:hover{border-color:var(--accent);color:var(--accent)}.upload-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px;margin-bottom:6px}.upload-subtitle{font-size:13px;color:var(--text-secondary);line-height:1.6}.role-tabs{display:flex;gap:8px;margin-bottom:24px}.role-tab{padding:8px 20px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.role-tab:hover{border-color:var(--accent);color:var(--accent)}.role-tab.active.students{background:#22c55e1a;border-color:var(--student-color);color:var(--student-color)}.role-tab.active.staff{background:#f59e0b1a;border-color:var(--staff-color);color:var(--staff-color)}.upload-content{display:flex;flex-direction:column;gap:20px}.drop-zone{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:40px 24px;text-align:center;cursor:pointer;transition:all .15s;background:var(--bg-card)}.drop-zone:hover,.drop-zone.dragging{border-color:var(--accent);background:var(--accent-dim)}.drop-zone.uploading{cursor:default;border-color:var(--border)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-secondary)}.drop-zone-content svg{color:var(--accent)}.drop-zone-content p{font-size:14px}.drop-zone-content strong{color:var(--accent)}.drop-hint{font-size:12px;color:var(--text-muted)}.upload-result{display:flex;flex-direction:column;gap:6px}.result-item{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px}.result-item.success{background:#22c55e1a;color:var(--student-color)}.result-item.error{background:#ef44441a;color:var(--danger)}.result-item.info{background:var(--accent-dim);color:var(--accent)}.result-item svg{flex-shrink:0;margin-top:1px}.docs-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.docs-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.docs-title{font-size:14px;font-weight:600;color:var(--text-primary)}.docs-meta{display:flex;align-items:center;gap:8px}.chunks-badge{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);background:var(--bg-hover);padding:3px 8px;border-radius:99px}.docs-empty{padding:40px 24px;text-align:center;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:10px;font-size:13px;line-height:1.7}.docs-list{padding:8px}.doc-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-sm);transition:background .12s}.doc-item:hover{background:var(--bg-hover)}.doc-item:hover .icon-btn-sm{opacity:1}.doc-icon{width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-hover);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.doc-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.doc-name{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-meta{font-size:11px;color:var(--text-muted)}.doc-ext{font-size:10px;font-family:var(--font-mono);font-weight:600;padding:2px 6px;border-radius:4px;background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border);text-transform:uppercase;flex-shrink:0}.doc-item .icon-btn-sm{opacity:0}.role-label.students{color:var(--student-color)}.role-label.staff{color:var(--staff-color)}.forbidden-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow-x:hidden;overflow-y:auto;padding:24px}.forbidden-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;opacity:.35;-webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black,transparent);mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black,transparent)}.forbidden-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}.orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(239,68,68,.12) 0%,transparent 70%);top:-100px;left:-100px;animation:orbFloat 8s ease-in-out infinite}.orb-2{width:300px;height:300px;background:radial-gradient(circle,rgba(79,142,247,.08) 0%,transparent 70%);bottom:-80px;right:-80px;animation:orbFloat 10s ease-in-out infinite reverse}@keyframes orbFloat{0%,to{transform:translate(0)}50%{transform:translate(20px,-20px)}}.forbidden-card{position:relative;z-index:1;width:100%;max-width:440px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px 40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:var(--shadow-lg),0 0 0 1px #ef444414,inset 0 1px #ffffff0a;animation:cardIn .4s cubic-bezier(.16,1,.3,1)}@keyframes cardIn{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.forbidden-icon-wrap{position:relative;width:72px;height:72px;display:flex;align-items:center;justify-content:center}.forbidden-icon-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:1px solid rgba(239,68,68,.3);background:#ef444414;animation:ringPulse 2.5s ease-in-out infinite}@keyframes ringPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.08);opacity:.7}}.forbidden-icon{color:var(--danger);position:relative;z-index:1}.forbidden-code{font-family:var(--font-mono);font-size:64px;font-weight:700;line-height:1;letter-spacing:-4px;background:linear-gradient(135deg,#ef4444,#f87171,#fca5a5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 20px rgba(239,68,68,.4))}.forbidden-title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px;margin-top:-4px}.forbidden-message{font-size:14px;color:var(--text-secondary);line-height:1.7;max-width:320px}.forbidden-user-info{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);flex-wrap:wrap;justify-content:center}.forbidden-user-email{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary)}.forbidden-user-role{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px}.forbidden-user-role.student{background:#22c55e1f;color:var(--student-color)}.forbidden-user-role.staff{background:#f59e0b1f;color:var(--staff-color)}.forbidden-actions{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:4px}.forbidden-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;width:100%}.forbidden-btn.primary{background:var(--accent-dim);border:1px solid rgba(79,142,247,.4);color:var(--accent)}.forbidden-btn.primary:hover{background:#4f8ef733;border-color:var(--accent)}.forbidden-btn.secondary{background:none;border:1px solid var(--border);color:var(--text-secondary)}.forbidden-btn.secondary:hover{border-color:var(--danger);color:var(--danger)}.forbidden-footer{font-size:12px;color:var(--text-muted);line-height:1.6;max-width:300px;margin-top:4px}.maintenance-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow-x:hidden;overflow-y:auto;padding:24px}.maintenance-bg{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.maintenance-ring{position:absolute;border-radius:50%;border:1px solid rgba(79,142,247,.08);animation:ringExpand 4s ease-out infinite}.ring-1{width:120px;height:120px;animation-delay:0s}.ring-2{width:240px;height:240px;animation-delay:.5s}.ring-3{width:380px;height:380px;animation-delay:1s}.ring-4{width:520px;height:520px;animation-delay:1.5s}.ring-5{width:660px;height:660px;animation-delay:2s}.ring-6{width:800px;height:800px;animation-delay:2.5s}@keyframes ringExpand{0%{transform:scale(.8);opacity:.6}to{transform:scale(1.1);opacity:0}}.maintenance-card{position:relative;z-index:1;width:100%;max-width:min(680px,calc(100vw - var(--sidebar-width) - 160px));background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px 40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:var(--shadow-lg),0 0 60px #4f8ef70f;animation:cardIn .5s cubic-bezier(.16,1,.3,1)}.maintenance-icon-wrap{width:72px;height:72px;border-radius:50%;background:var(--accent-dim);border:1px solid rgba(79,142,247,.3);display:flex;align-items:center;justify-content:center;color:var(--accent);transition:all .4s}.maintenance-icon-wrap.done{background:#22c55e1a;border-color:#22c55e66;color:var(--student-color)}.spin-slow{animation:spin 2s linear infinite}.maintenance-title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.maintenance-message{font-size:clamp(14px,1.1vw,17px);color:var(--text-secondary);line-height:1.7;max-width:420px}.maintenance-progress-bar{width:100%;height:3px;background:var(--border);border-radius:99px;overflow:hidden}.maintenance-progress-fill{height:100%;background:var(--accent);border-radius:99px;animation:progressSlide 2s ease-in-out infinite}@keyframes progressSlide{0%{transform:translate(-100%);width:60%}50%{transform:translate(80%);width:60%}to{transform:translate(200%);width:60%}}.maintenance-stats{display:flex;flex-direction:column;gap:6px;width:100%}.maintenance-stat{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:var(--text-muted)}.maintenance-footer{font-size:12px;color:var(--text-muted);line-height:1.6;max-width:280px}.reindex-block{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px}.reindex-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.reindex-info{display:flex;align-items:flex-start;gap:10px;color:var(--accent);flex:1}.reindex-info svg{margin-top:2px;flex-shrink:0}.reindex-title{font-size:13px;font-weight:600;color:var(--text-primary)}.reindex-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px;line-height:1.5}.sessions-warning{color:var(--staff-color);font-weight:500}.reindex-actions{display:flex;gap:6px;align-items:center}.reindex-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap}.reindex-btn.primary{background:var(--accent-dim);border:1px solid rgba(79,142,247,.4);color:var(--accent)}.reindex-btn.primary:hover:not(:disabled){background:#4f8ef733;border-color:var(--accent)}.reindex-btn.primary:disabled{opacity:.4;cursor:not-allowed}.reindex-btn.warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--staff-color)}.reindex-btn.warning:hover{background:#f59e0b33;border-color:var(--staff-color)}.reindex-running{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);padding:7px 14px}.maintenance-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md);color:var(--staff-color);font-size:13px;margin-bottom:16px}.drop-zone.disabled{opacity:.5;cursor:not-allowed}.role-tab{display:flex;align-items:center;gap:6px}.result-item.warning{background:#f59e0b1a;color:var(--staff-color)}.maintenance-card.done{border-color:#22c55e4d;box-shadow:var(--shadow-lg),0 0 60px #22c55e14}.maintenance-progress-bar.done{background:#22c55e26}.maintenance-progress-countdown{height:100%;background:var(--student-color);border-radius:99px;width:100%;transform-origin:left center;animation:countdownShrink linear forwards}@keyframes countdownShrink{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.maintenance-back-btn{padding:10px 24px;background:#22c55e1a;border:1px solid rgba(34,197,94,.4);border-radius:var(--radius-md);color:var(--student-color);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;margin-top:4px}.maintenance-back-btn:hover{background:#22c55e33;border-color:var(--student-color)}.pipeline-step-indicator{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:12px max(24px,calc(50% - 380px))}.pipeline-step-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);animation:fadeIn .2s ease}.pipeline-step-icon{font-size:14px}.agent-run-id{color:var(--text-muted);font-size:12px}.agent-step-list{display:grid;grid-template-columns:1fr;gap:4px;width:100%}.agent-step-item{display:flex;align-items:baseline;gap:8px;color:var(--text-secondary);font-size:12px}.agent-step-item.pending{opacity:.72}.agent-step-item.running{color:var(--text-primary)}.agent-step-item.success{color:var(--student-color)}.agent-step-item.failed,.agent-step-item.timeout{color:var(--danger)}.agent-step-item small{min-width:0;color:var(--text-muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.citations-panel{margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.citations-toggle{display:inline-flex;align-items:center;gap:6px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:12px;font-family:var(--font-body);padding:4px 10px;cursor:pointer;transition:all .12s}.citations-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.citations-list{margin-top:8px;display:flex;flex-direction:column;gap:3px}.citation-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid transparent;color:var(--text-secondary);font-size:12px;font-family:var(--font-body);cursor:pointer;text-align:left;transition:all .12s}.citation-item:hover{background:var(--bg-hover);border-color:var(--border-light)}.citation-item.active{background:var(--accent-dim);border-color:var(--accent);color:var(--text-primary)}.citation-num{color:var(--accent);font-weight:600;font-size:11px;min-width:26px;flex-shrink:0}.citation-filename{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.citation-score{color:var(--text-muted);font-size:11px;flex-shrink:0;font-variant-numeric:tabular-nums}.citation-snippet{margin-top:6px;padding:10px 14px;background:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--accent);animation:fadeIn .15s ease}.citation-snippet-meta{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);margin-bottom:8px}.citation-snippet-meta strong{color:var(--text-secondary);font-weight:500}.citation-snippet-pos{color:var(--text-muted);font-variant-numeric:tabular-nums}.citation-snippet-text{margin:0;padding:0;color:var(--text-secondary);font-size:13px;line-height:1.65;white-space:pre-wrap;word-break:break-word;font-style:normal;border:none}.generated-preview-image{display:block;max-width:100%;height:auto;margin:0 auto}.admin-feedback-page{min-height:100dvh;background:var(--bg-primary);color:var(--text-primary);padding:clamp(20px,4vw,48px)}.admin-feedback-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.admin-feedback-kicker{color:var(--accent);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em}.admin-feedback-header h1{font-family:var(--font-display);font-size:clamp(26px,3vw,38px);letter-spacing:0;line-height:1.15}.admin-feedback-refresh,.admin-feedback-search,.admin-feedback-tabs button{border:1px solid var(--border);background:var(--bg-card);color:var(--text-primary);border-radius:var(--radius-md)}.admin-feedback-refresh{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 14px;cursor:pointer}.admin-feedback-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}.admin-feedback-stat{min-width:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.admin-feedback-stat-icon{color:var(--accent);min-height:20px}.admin-feedback-stat span,.admin-feedback-block span,.admin-feedback-count,.admin-feedback-meta{color:var(--text-muted);font-size:12px}.admin-feedback-stat strong{display:block;margin-top:6px;color:var(--text-primary);font-size:clamp(20px,2vw,28px);line-height:1.2;overflow-wrap:anywhere}.admin-feedback-stat small{display:block;margin-top:4px;color:var(--text-secondary)}.admin-feedback-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.admin-feedback-tabs{display:flex;gap:8px;flex-wrap:wrap}.admin-feedback-tabs button{min-height:36px;padding:0 12px;cursor:pointer}.admin-feedback-tabs button.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.admin-feedback-search{min-width:min(420px,100%);display:flex;align-items:center;gap:8px;padding:0 12px}.admin-feedback-search input{min-height:38px;flex:1;min-width:0;background:transparent;border:0;color:var(--text-primary);outline:none}.admin-feedback-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}.admin-feedback-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.admin-feedback-item-head,.admin-feedback-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.admin-feedback-item-head{margin-bottom:12px;color:var(--text-secondary);font-size:12px}.feedback-rating-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:4px 9px}.feedback-rating-pill.positive{color:var(--student-color);border-color:#22c55e59}.feedback-rating-pill.negative{color:var(--danger);border-color:#ef444459}.admin-feedback-content{display:grid;gap:10px}.admin-feedback-block{border-left:2px solid var(--border-light);padding-left:10px}.admin-feedback-block.important{border-color:var(--accent)}.admin-feedback-block p{margin-top:3px;color:var(--text-primary);line-height:1.6;overflow-wrap:anywhere}.admin-feedback-meta{margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.admin-feedback-error,.admin-feedback-empty{border:1px solid var(--border);background:var(--bg-card);border-radius:var(--radius-md);padding:12px;color:var(--text-secondary)}.admin-feedback-error{color:var(--danger)}@media (max-width: 900px){.admin-feedback-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-feedback-toolbar{align-items:stretch;flex-direction:column}.admin-feedback-search{min-width:0;width:100%}}@media (max-width: 560px){.admin-feedback-page{padding:16px}.admin-feedback-header{align-items:stretch;flex-direction:column}.admin-feedback-stats{grid-template-columns:1fr}}
