:root{--bg:#f5f6f8;--surface:#fff;--surface-hover:#f8f9fb;--border:#e2e5ea;--border-light:#eef0f4;--text-primary:#1a1d23;--text-secondary:#5f6775;--text-muted:#9ca3af;--primary:#6366f1;--primary-hover:#5558e6;--primary-light:#eef2ff;--primary-lighter:#f5f7ff;--accent:#8b5cf6;--highlight:#fbbf24;--highlight-bg:#fbbf2433;--highlight-border:#fbbf2480;--success:#22c55e;--error:#ef4444;--warning:#f59e0b;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--radius:8px;--radius-lg:12px;--radius-sm:6px;--header-height:60px;--transition:.15s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px}.app-container{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:0 16px;display:flex}.header-left{flex-shrink:0}.logo{color:var(--primary);white-space:nowrap;align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.logo svg{flex-shrink:0}.header-center{flex:1;max-width:600px}.url-input-group{gap:8px;display:flex}.url-input-group input{border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition);outline:none;flex:1;padding:8px 12px;font-size:13px}.url-input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.fallback-badge{color:var(--primary);background:var(--primary-light);white-space:nowrap;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;line-height:1.4;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text-primary)}.btn-icon{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;padding:8px}.btn-icon:hover{background:var(--surface-hover);color:var(--text-primary)}.btn-sm{padding:4px 10px;font-size:12px}.btn-lg{padding:12px 24px;font-size:15px}.btn-send{flex-shrink:0;padding:8px 12px}.app-main{flex:1;display:flex;overflow:hidden}.panel-tabs{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;gap:0;padding:0 16px;display:flex}.panel-tab{color:var(--text-secondary);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 14px;font-size:13px;font-weight:500;display:inline-flex}.panel-tab:hover{color:var(--text-primary)}.panel-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.panel-tab svg{flex-shrink:0}.paper-panel{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;width:50%;min-width:300px;display:flex}.tab-content{flex:1;display:none;overflow:hidden}.tab-content.active{flex-direction:column;display:flex}.paper-placeholder{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px 24px;display:flex}.paper-placeholder h3{color:var(--text-primary);font-size:16px}.paper-placeholder p{color:var(--text-secondary);max-width:360px;font-size:13px}.paper-placeholder textarea{border:1px solid var(--border);border-radius:var(--radius);resize:vertical;width:100%;max-width:460px;height:180px;transition:border-color var(--transition);outline:none;padding:12px;font-family:inherit;font-size:13px}.paper-placeholder textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.paper-content{flex:1;padding:24px;overflow-y:auto}.paper-header-info{border-bottom:1px solid var(--border-light);margin-bottom:24px;padding-bottom:20px}.paper-header-info h1{margin-bottom:8px;font-size:20px;line-height:1.4}.paper-header-info .authors{color:var(--text-secondary);margin-bottom:4px;font-size:13px}.paper-header-info .paper-meta{color:var(--text-muted);font-size:12px}.paper-body{color:var(--text-primary);font-size:14px;line-height:1.75}.paper-body p{margin-bottom:12px}.paper-body h2{color:var(--text-primary);margin-top:28px;margin-bottom:12px;font-size:17px}.paper-body h3{margin-top:20px;margin-bottom:8px;font-size:15px}.paper-body mark,.paper-highlight{background:var(--highlight-bg);border-bottom:2px solid var(--highlight-border);cursor:pointer;transition:background var(--transition);border-radius:2px;padding:1px 2px}.paper-body mark:hover,.paper-body mark.active,.paper-highlight:hover,.paper-highlight.active{background:#fbbf2466}.pdf-placeholder{color:var(--text-muted);flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.pdf-iframe{border:none;flex:1;width:100%}.resize-handle{cursor:col-resize;width:4px;transition:background var(--transition);background:0 0;flex-shrink:0;position:relative}.resize-handle:hover,.resize-handle.active{background:var(--primary)}.mode-panel{background:var(--bg);flex-direction:column;flex:1;min-width:360px;display:flex}.mode-tabs{background:var(--surface)}.mode-content{flex-direction:column;flex:1;display:none;overflow:hidden}.mode-content.active{display:flex}.mode-empty-state{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px 24px;display:flex}.mode-empty-state h3{font-size:18px;font-weight:600}.mode-empty-state p{color:var(--text-secondary);max-width:320px;font-size:14px;line-height:1.6}.tutor-header{background:var(--surface);border-bottom:1px solid var(--border-light);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.tutor-progress{flex:1;align-items:center;gap:10px;display:flex}.progress-bar{background:var(--border-light);border-radius:3px;flex:1;max-width:200px;height:6px;overflow:hidden}.progress-fill{background:var(--primary);border-radius:3px;width:0%;height:100%;transition:width .4s}.progress-text{color:var(--text-muted);white-space:nowrap;font-size:12px}.tutor-mode-indicator{color:var(--primary);background:var(--primary-light);border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:flex}.tutor-mode-indicator.clarification{color:var(--warning);background:#f59e0b1a}.indicator-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.clarification-banner{color:var(--warning);background:#f59e0b14;border-top:1px solid #f59e0b33;flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 16px;font-size:12px;font-weight:500;display:flex}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-message{gap:10px;max-width:90%;animation:.25s messageIn;display:flex}@keyframes messageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-message.ai{align-self:flex-start}.chat-message.user{flex-direction:row-reverse;align-self:flex-end}.message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:600;display:flex}.chat-message.ai .message-avatar{background:var(--primary-light);color:var(--primary)}.chat-message.user .message-avatar{color:var(--text-secondary);background:#e2e8f0}.message-bubble{border-radius:var(--radius-lg);padding:10px 14px;font-size:13.5px;line-height:1.6}.chat-message.ai .message-bubble{background:var(--surface);border:1px solid var(--border-light);border-top-left-radius:4px}.chat-message.user .message-bubble{background:var(--primary);color:#fff;border-top-right-radius:4px}.message-bubble p{margin-bottom:8px}.message-bubble p:last-child{margin-bottom:0}.message-bubble code{background:#0000000f;border-radius:3px;padding:1px 5px;font-size:12.5px}.chat-message.user .message-bubble code{background:#fff3}.message-bubble pre{color:#e2e8f0;border-radius:var(--radius-sm);background:#1e293b;margin:8px 0;padding:12px;overflow-x:auto}.message-bubble pre code{color:inherit;background:0 0;padding:0}.message-bubble ul,.message-bubble ol{margin:8px 0;padding-left:20px}.message-bubble li{margin-bottom:4px}.message-bubble .ref-highlight{background:var(--highlight-bg);border-bottom:2px solid var(--highlight-border);cursor:pointer;transition:background var(--transition);border-radius:2px;padding:1px 3px;font-style:italic}.message-bubble .ref-highlight:hover{background:#fbbf2466}.typing-indicator{align-items:center;gap:4px;padding:12px 14px;display:flex}.typing-indicator span{background:var(--text-muted);border-radius:50%;width:7px;height:7px;animation:1.4s infinite typing}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.chat-input-area{background:var(--surface);border-top:1px solid var(--border-light);flex-shrink:0;padding:12px 16px}.input-row{align-items:flex-end;gap:8px;display:flex}.input-row textarea{border:1px solid var(--border);border-radius:var(--radius);resize:none;max-height:120px;transition:border-color var(--transition);outline:none;flex:1;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.5}.input-row textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.input-row textarea:disabled{background:var(--bg);cursor:not-allowed}.readings-container{flex:1;overflow-y:auto}.readings-section{margin-bottom:28px}.readings-section h3{align-items:center;gap:8px;margin-bottom:4px;font-size:15px;font-weight:600;display:flex}.section-desc{color:var(--text-muted);margin-bottom:14px;font-size:12px}.readings-list{flex-direction:column;gap:10px;display:flex}.reading-card{background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius);transition:border-color var(--transition),box-shadow var(--transition);padding:14px}.reading-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.reading-card h4{margin-bottom:4px;font-size:14px;font-weight:600;line-height:1.4}.reading-card h4 a{color:var(--primary);text-decoration:none}.reading-card h4 a:hover{text-decoration:underline}.reading-card .reading-meta{color:var(--text-muted);margin-bottom:6px;font-size:12px}.reading-card .reading-desc{color:var(--text-secondary);font-size:13px;line-height:1.5}.readings-loading{color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:40px;font-size:13px;display:flex}.spinner{border:3px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.open{display:flex}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:440px;max-height:90vh;animation:.2s modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-header h2{font-size:17px;font-weight:600}.modal-body{padding:20px 24px}.modal-footer{justify-content:flex-end;gap:8px;padding:0 24px 20px;display:flex}.form-group{margin-bottom:18px}.form-group label{color:var(--text-primary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group select,.form-group input[type=text],.form-group input[type=password]{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;transition:border-color var(--transition);background:var(--surface);outline:none;padding:9px 12px;font-family:inherit;font-size:13px}.form-group select:focus,.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.api-key-row{gap:6px;display:flex}.api-key-row input{flex:1}.form-hint{color:var(--text-muted);margin-top:5px;font-size:11.5px;display:block}.toast-container{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--text-primary);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);align-items:center;gap:8px;max-width:360px;padding:10px 16px;font-size:13px;animation:.3s toastIn,.3s 3s forwards toastOut;display:flex}.toast.error{background:var(--error)}.toast.success{background:var(--success)}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translateY(-8px)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.retry-banner{border-radius:var(--radius);color:var(--error);background:#ef444414;border:1px solid #ef444433;justify-content:space-between;align-items:center;gap:8px;margin:4px 0;padding:10px 16px;font-size:13px;animation:.25s messageIn;display:flex}.assistant-header{background:var(--surface);border-bottom:1px solid var(--border-light);flex-shrink:0;justify-content:flex-end;padding:8px 16px;display:flex}.past-sessions-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:600}.past-sessions-inline{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.past-session{border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}.past-session-toggle{background:var(--surface);width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background var(--transition);border:none;align-items:center;gap:8px;padding:8px 12px;font-size:12px;font-weight:500;display:flex}.past-session-toggle:hover{background:var(--surface-hover)}.past-session-count{color:var(--text-muted);margin-left:auto;font-size:11px}.past-session-messages{background:var(--bg);border-top:1px solid var(--border-light);flex-direction:column;gap:10px;max-height:400px;padding:12px;display:flex;overflow-y:auto}@media (max-width:768px){.app-main{flex-direction:column}.paper-panel{border-right:none;border-bottom:1px solid var(--border);min-width:0;height:40vh;width:100%!important}.resize-handle{display:none}.mode-panel{min-width:0}.logo span{display:none}.url-input-group{max-width:none}}
