:root{--color-bg: #ffffff;--color-bg-secondary: #f8f9fa;--color-bg-tertiary: #f0f1f3;--color-text: #111111;--color-text-secondary: #555555;--color-text-muted: #888888;--color-border: #e2e4e8;--color-border-light: #eef0f2;--color-accent: #111111;--color-accent-hover: #333333;--color-danger: #dc3545;--color-danger-hover: #c82333;--color-success: #28a745;--color-overlay: rgba(0, 0, 0, .4);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .1);--transition: .2s ease;--header-height: 52px;--left-panel-width: 280px;--right-panel-width: 300px;--footer-height: 40px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--color-text);background:var(--color-bg);line-height:1.5}button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none}input{font-family:inherit;border:none;outline:none;background:none}.custom-scrollbar::-webkit-scrollbar{width:5px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.custom-scrollbar::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.landing-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center;background:var(--color-bg)}.landing-logo{width:80px;height:80px;margin-bottom:1.5rem;border-radius:var(--radius-lg)}.landing-title{font-size:2.4rem;font-weight:800;color:var(--color-text);margin-bottom:.6rem;letter-spacing:-.5px}.landing-description{font-size:1.1rem;color:var(--color-text-secondary);max-width:480px;margin-bottom:2.5rem;line-height:1.6}.landing-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2.2rem;font-size:1rem;font-weight:600;color:#fff;background:var(--color-accent);border-radius:var(--radius-md);transition:background var(--transition),transform var(--transition);text-decoration:none}.landing-btn:hover{background:var(--color-accent-hover);transform:translateY(-1px)}.landing-btn svg{width:18px;height:18px}.conversation-page{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--color-bg)}.conv-header{display:flex;align-items:center;gap:.6rem;height:var(--header-height);padding:0 1rem;border-bottom:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0;z-index:10}.conv-header-logo{width:28px;height:28px;border-radius:var(--radius-sm)}.conv-header-title{font-size:.95rem;font-weight:700;color:var(--color-text)}.conv-header-spacer{flex:1}.conv-header-toggle{display:none;width:34px;height:34px;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background var(--transition)}.conv-header-toggle:hover{background:var(--color-bg-tertiary)}.conv-header-toggle svg{width:20px;height:20px;color:var(--color-text-secondary)}.conv-body{display:flex;flex:1;overflow:hidden;position:relative}.left-panel{width:var(--left-panel-width);min-width:var(--left-panel-width);display:flex;flex-direction:column;border-right:1px solid var(--color-border);background:var(--color-bg-secondary);overflow:hidden;flex-shrink:0}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border-light);flex-shrink:0}.panel-header-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted)}.panel-header-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:background var(--transition),color var(--transition)}.panel-header-btn:hover{background:var(--color-border);color:var(--color-text)}.panel-header-btn svg{width:16px;height:16px}.subject-add-form{display:flex;gap:.4rem;padding:.6rem .75rem;border-bottom:1px solid var(--color-border-light)}.subject-add-input{flex:1;padding:.45rem .65rem;font-size:.85rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);transition:border-color var(--transition)}.subject-add-input:focus{border-color:var(--color-accent)}.subject-add-input::placeholder{color:var(--color-text-muted)}.subject-add-submit{padding:.45rem .65rem;font-size:.8rem;font-weight:600;color:#fff;background:var(--color-accent);border-radius:var(--radius-sm);transition:background var(--transition)}.subject-add-submit:hover{background:var(--color-accent-hover)}.subject-list{flex:1;overflow-y:auto;padding:.4rem .5rem}.subject-item{display:flex;align-items:center;gap:.5rem;padding:.6rem .7rem;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);position:relative}.subject-item:hover{background:var(--color-border-light)}.subject-item.active{background:var(--color-bg);box-shadow:var(--shadow-sm)}.subject-item-icon{width:18px;height:18px;color:var(--color-text-muted);flex-shrink:0}.subject-item-title{flex:1;font-size:.88rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.subject-item-delete{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-muted);opacity:0;transition:opacity var(--transition),color var(--transition),background var(--transition)}.subject-item:hover .subject-item-delete{opacity:1}.subject-item-delete:hover{color:var(--color-danger);background:#dc354514}.subject-item-delete svg{width:14px;height:14px}.subject-item-edit{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-muted);opacity:0;transition:opacity var(--transition),color var(--transition),background var(--transition)}.subject-item:hover .subject-item-edit{opacity:1}.subject-item-edit:hover{color:var(--color-accent);background:#1111110f}.subject-item-edit svg{width:13px;height:13px}.subject-edit-input{flex:1;padding:.25rem .45rem;font-size:.88rem;font-weight:500;border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);min-width:0}.panel-empty{padding:2rem 1rem;text-align:center;color:var(--color-text-muted);font-size:.85rem;line-height:1.5}.center-panel{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--color-bg)}.center-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--color-text-muted)}.center-placeholder-icon{width:48px;height:48px;margin-bottom:1rem;color:var(--color-border)}.center-placeholder-text{font-size:.95rem;max-width:300px}.right-panel{width:var(--right-panel-width);min-width:var(--right-panel-width);display:flex;flex-direction:column;border-left:1px solid var(--color-border);background:var(--color-bg-secondary);overflow:hidden;flex-shrink:0;transition:width var(--transition),min-width var(--transition),opacity var(--transition)}.right-panel.hidden{width:0;min-width:0;border-left:none;opacity:0;pointer-events:none}.doc-add-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;width:calc(100% - 1.5rem);margin:.6rem .75rem;padding:.5rem;font-size:.82rem;font-weight:600;color:#fff;background:var(--color-accent);border-radius:var(--radius-sm);transition:background var(--transition)}.doc-add-btn:hover{background:var(--color-accent-hover)}.doc-add-btn svg{width:15px;height:15px}.hidden-file-input{display:none}.upload-progress{margin:0 .75rem .5rem;padding:.5rem .65rem;border-radius:var(--radius-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border)}.upload-progress.failed{border-color:var(--color-danger);background:#dc35450a}.upload-progress.completed{border-color:var(--color-success);background:#28a7450a}.upload-progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.upload-progress-name{font-size:.78rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:55%}.upload-progress-msg{font-size:.72rem;color:var(--color-text-muted)}.upload-progress-bar{height:4px;border-radius:2px;background:var(--color-border);overflow:hidden}.upload-progress-fill{height:100%;border-radius:2px;background:var(--color-accent);transition:width .3s ease}.upload-progress.failed .upload-progress-fill{background:var(--color-danger)}.upload-progress.completed .upload-progress-fill{background:var(--color-success)}.doc-list{flex:1;overflow-y:auto;padding:0 .5rem .5rem}.doc-item{display:flex;align-items:center;gap:.5rem;padding:.55rem .7rem;border-radius:var(--radius-sm);transition:background var(--transition)}.doc-item:hover{background:var(--color-border-light)}.doc-item-icon{width:18px;height:18px;color:var(--color-text-muted);flex-shrink:0}.doc-item-info{flex:1;min-width:0}.doc-item-name{font-size:.85rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-item-meta{font-size:.72rem;color:var(--color-text-muted)}.doc-item-status{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}.doc-item-status.completed{background:var(--color-success)}.doc-item-status.processing{background:#f0ad4e}.doc-item-status.uploading{background:#5bc0de}.doc-item-status.failed{background:var(--color-danger)}.doc-item-delete{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-muted);opacity:0;transition:opacity var(--transition),color var(--transition),background var(--transition)}.doc-item:hover .doc-item-delete{opacity:1}.doc-item-delete:hover{color:var(--color-danger);background:#dc354514}.doc-item-delete svg{width:14px;height:14px}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1rem;border-bottom:1px solid var(--color-border-light);flex-shrink:0}.chat-header-title{font-size:.9rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.chat-clear-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-muted);transition:background var(--transition),color var(--transition)}.chat-clear-btn:hover{background:#dc354514;color:var(--color-danger)}.chat-clear-btn svg{width:16px;height:16px}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem}.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--color-text-muted);padding:2rem}.chat-empty-icon{width:40px;height:40px;color:var(--color-border);margin-bottom:.75rem}.chat-empty p{font-size:.9rem;max-width:280px}.chat-message{display:flex}.chat-message.user{justify-content:flex-end}.chat-message.assistant{justify-content:flex-start}.chat-bubble{max-width:85%;border-radius:var(--radius-md);padding:.7rem 1rem;font-size:.88rem;line-height:1.5}.chat-bubble.user{background:var(--color-accent);color:#fff;border-bottom-right-radius:4px}.chat-bubble.user p{margin:0;white-space:pre-wrap;word-break:break-word}.chat-bubble.assistant{background:var(--color-bg-secondary);border:1px solid var(--color-border-light);color:var(--color-text);border-bottom-left-radius:4px;max-width:90%}.chat-loading{display:flex;align-items:center;gap:4px;padding:4px 0}.chat-loading-dot{width:6px;height:6px;border-radius:50%;background:var(--color-text-muted);animation:chatBounce 1.4s infinite ease-in-out both}.chat-loading-dot:nth-child(1){animation-delay:-.32s}.chat-loading-dot:nth-child(2){animation-delay:-.16s}.chat-loading-dot:nth-child(3){animation-delay:0s}@keyframes chatBounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.chat-loading-text{font-size:.78rem;color:var(--color-text-muted);margin-left:6px}.chat-no-results{margin:0;color:var(--color-text-secondary)}.chat-bubble.assistant.llm-response{max-width:92%;padding:0;overflow:hidden}.llm-response-text{padding:.85rem 1rem .5rem}.llm-response-text.markdown-body p{margin:0 0 .6rem;font-size:.88rem;line-height:1.7;color:var(--color-text);word-break:break-word}.llm-response-text.markdown-body p:last-child{margin-bottom:0}.llm-response-text.markdown-body h1,.llm-response-text.markdown-body h2,.llm-response-text.markdown-body h3,.llm-response-text.markdown-body h4,.llm-response-text.markdown-body h5,.llm-response-text.markdown-body h6{margin:1rem 0 .5rem;font-weight:700;line-height:1.3;color:var(--color-text)}.llm-response-text.markdown-body h1{font-size:1.2rem}.llm-response-text.markdown-body h2{font-size:1.1rem}.llm-response-text.markdown-body h3{font-size:1rem}.llm-response-text.markdown-body h4{font-size:.95rem}.llm-response-text.markdown-body strong{font-weight:700}.llm-response-text.markdown-body em{font-style:italic}.llm-response-text.markdown-body ul,.llm-response-text.markdown-body ol{margin:.4rem 0 .6rem 1.2rem;font-size:.88rem;line-height:1.7}.llm-response-text.markdown-body li{margin-bottom:.25rem}.llm-response-text.markdown-body li>ul,.llm-response-text.markdown-body li>ol{margin-top:.15rem;margin-bottom:0}.llm-response-text.markdown-body blockquote{margin:.5rem 0;padding:.4rem .8rem;border-left:3px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.llm-response-text.markdown-body code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.82rem;background:var(--color-bg-tertiary);padding:.15rem .35rem;border-radius:4px;color:var(--color-text)}.llm-response-text.markdown-body pre{margin:.5rem 0;padding:.75rem 1rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);overflow-x:auto}.llm-response-text.markdown-body pre code{background:none;padding:0;font-size:.82rem;line-height:1.55}.llm-response-text.markdown-body table{width:100%;border-collapse:collapse;margin:.5rem 0;font-size:.84rem}.llm-response-text.markdown-body th,.llm-response-text.markdown-body td{padding:.4rem .6rem;border:1px solid var(--color-border);text-align:left}.llm-response-text.markdown-body th{background:var(--color-bg-tertiary);font-weight:700;font-size:.82rem}.llm-response-text.markdown-body hr{margin:.8rem 0;border:none;border-top:1px solid var(--color-border-light)}.llm-response-text.markdown-body a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}.llm-response-text.markdown-body a:hover{color:var(--color-accent-hover)}.inline-source-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;vertical-align:middle;margin:0 1px;cursor:default;position:relative;color:var(--color-text-muted);transition:color var(--transition)}.inline-source-icon:hover{color:var(--color-accent)}.inline-source-icon--clickable{cursor:pointer}.inline-source-icon .ref-link-icon{width:13px;height:13px}.inline-source-icon[data-tooltip]:before{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--color-text);color:var(--color-bg);font-size:.72rem;font-weight:500;line-height:1.4;padding:.3rem .6rem;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition);z-index:1000;box-shadow:var(--shadow-md);letter-spacing:.01em}.inline-source-icon[data-tooltip]:after{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--color-text);pointer-events:none;opacity:0;transition:opacity var(--transition);z-index:1000}.inline-source-icon[data-tooltip]:hover:before,.inline-source-icon[data-tooltip]:hover:after{opacity:1}.source-references{display:flex;flex-wrap:wrap;gap:.35rem;padding:.5rem 1rem .65rem;border-top:1px solid var(--color-border-light)}.source-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .55rem;font-size:.72rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);border-radius:100px;color:var(--color-text-secondary);cursor:default;transition:background var(--transition),border-color var(--transition);max-width:200px}.source-pill:hover{background:var(--color-bg);border-color:var(--color-border)}.source-pill-clickable{cursor:pointer;font-family:inherit;text-align:left}.source-pill-clickable:hover{background:var(--color-bg);border-color:var(--color-accent);color:var(--color-text)}.ref-link-icon{width:11px;height:11px;color:var(--color-text-muted);flex-shrink:0}.source-pill-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.source-pill-page{color:var(--color-text-muted);white-space:nowrap}.source-pill-toggle{cursor:pointer;background:var(--color-accent);border-color:var(--color-accent);color:#fff;font-weight:700;max-width:none}.source-pill-toggle:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.source-pill-toggle .source-pill-name{color:inherit}.confirm-overlay{position:fixed;inset:0;background:var(--color-overlay);z-index:100;display:flex;align-items:center;justify-content:center;animation:confirmFadeIn .15s ease}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:var(--color-bg);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:1.4rem 1.6rem;max-width:380px;width:90%;animation:confirmSlideIn .15s ease}@keyframes confirmSlideIn{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirm-title{font-size:.95rem;font-weight:700;color:var(--color-text);margin-bottom:.5rem}.confirm-message{font-size:.84rem;color:var(--color-text-secondary);line-height:1.55;margin-bottom:1.2rem}.confirm-actions{display:flex;justify-content:flex-end;gap:.5rem}.confirm-btn{padding:.4rem 1rem;font-size:.82rem;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition),color var(--transition)}.confirm-btn-cancel{background:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.confirm-btn-cancel:hover{background:var(--color-bg-secondary)}.confirm-btn-danger{background:var(--color-danger);color:#fff;border:1px solid var(--color-danger)}.confirm-btn-danger:hover{background:var(--color-danger-hover);border-color:var(--color-danger-hover)}.llm-media-container{border-top:1px solid var(--color-border-light);padding:.65rem 1rem .75rem;display:flex;flex-direction:column;gap:.65rem}.media-section{display:flex;flex-direction:column;gap:.4rem}.media-section-header{display:flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-muted)}.media-section-count{background:var(--color-bg-tertiary);padding:0 5px;border-radius:8px;font-size:.68rem;font-weight:600;color:var(--color-text-muted)}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}.media-card{background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);overflow:hidden}.media-card img{display:block;width:100%;height:140px;object-fit:cover;background:var(--color-bg-tertiary)}.media-card-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:140px;background:var(--color-bg-tertiary);color:var(--color-text-muted);font-size:.75rem}.media-card video{display:block;width:100%;height:140px;object-fit:cover;background:#000}.media-card-audio{padding:.5rem}.media-card-audio audio{width:100%;height:36px}.media-card-label{display:flex;align-items:center;justify-content:space-between;padding:.3rem .5rem;background:var(--color-bg-tertiary);border-top:1px solid var(--color-border-light)}.media-card-source{font-size:.7rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.media-card-meta{font-size:.68rem;color:var(--color-text-muted);white-space:nowrap;margin-left:.35rem}.chat-result-modality-icon{width:13px;height:13px;color:var(--color-text-muted);flex-shrink:0}.chat-input-area{padding:.6rem 1rem;border-top:1px solid var(--color-border-light);flex-shrink:0;background:var(--color-bg)}.chat-input-wrapper{display:flex;align-items:flex-end;gap:.5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.4rem .5rem;transition:border-color var(--transition)}.chat-input-wrapper:focus-within{border-color:var(--color-accent)}.chat-input{flex:1;padding:.35rem .4rem;font-size:.88rem;line-height:1.4;color:var(--color-text);background:transparent;border:none;outline:none;resize:none;max-height:120px;min-height:auto;font-family:inherit}.chat-input::placeholder{color:var(--color-text-muted)}.chat-input:disabled{opacity:.6}.chat-send-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--color-accent);color:#fff;transition:background var(--transition),opacity var(--transition);flex-shrink:0}.chat-send-btn:hover:not(:disabled){background:var(--color-accent-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-send-btn svg{width:16px;height:16px}.conv-footer{height:var(--footer-height);display:flex;align-items:center;justify-content:center;border-top:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0;font-size:.72rem;color:var(--color-text-muted)}.panel-overlay{display:none;position:fixed;inset:0;background:var(--color-overlay);z-index:20}@media(max-width:1024px){:root{--left-panel-width: 240px;--right-panel-width: 260px}}@media(max-width:768px){:root{--left-panel-width: 280px;--right-panel-width: 280px}.conv-header-toggle{display:flex}.left-panel{position:fixed;top:var(--header-height);left:0;bottom:0;z-index:25;transform:translate(-100%);transition:transform .25s ease;border-right:1px solid var(--color-border);box-shadow:var(--shadow-lg)}.left-panel.mobile-open{transform:translate(0)}.right-panel{position:fixed;top:var(--header-height);right:0;bottom:0;z-index:25;transform:translate(100%);transition:transform .25s ease;width:var(--right-panel-width);min-width:var(--right-panel-width);border-left:1px solid var(--color-border);box-shadow:var(--shadow-lg);opacity:1;pointer-events:auto}.right-panel.hidden{width:var(--right-panel-width);min-width:var(--right-panel-width);border-left:1px solid var(--color-border);opacity:1;pointer-events:auto;transform:translate(100%)}.right-panel.mobile-open{transform:translate(0)}.panel-overlay.visible{display:block}.landing-title{font-size:1.8rem}.landing-description{font-size:1rem}}@media(max-width:480px){:root{--left-panel-width: 100%;--right-panel-width: 100%}.landing-title{font-size:1.5rem}.landing-logo{width:60px;height:60px}}.document-view-panel{position:absolute;right:0;top:0;bottom:0;width:var(--right-panel-width);min-width:var(--right-panel-width);display:flex;flex-direction:column;background:var(--color-bg);border-left:1px solid var(--color-border);z-index:30;overflow:hidden;animation:docViewSlideIn .18s ease;transition:width .22s ease}.document-view-panel--pdf{width:clamp(360px,55vw,680px);min-width:clamp(360px,55vw,680px)}.document-view-panel--expanded{position:fixed;top:var(--header-height);right:0;bottom:var(--footer-height);left:0;width:100%;min-width:0;z-index:50;border-left:none;box-shadow:var(--shadow-lg)}@keyframes docViewSlideIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.doc-view-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.65rem .75rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0;min-height:46px}.doc-view-header-info{display:flex;align-items:center;gap:.4rem;min-width:0;flex:1}.doc-view-title{font-size:.8rem;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.doc-view-page{font-size:.7rem;color:var(--color-text-muted);background:var(--color-bg-tertiary);border:1px solid var(--color-border-light);padding:.05rem .4rem;border-radius:100px;white-space:nowrap;flex-shrink:0}.doc-view-badge{display:inline-block;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:.1rem .4rem;border-radius:var(--radius-sm);flex-shrink:0;color:#fff}.doc-view-badge--pdf{background:#e63946}.doc-view-badge--image{background:#6a4c93}.doc-view-badge--audio{background:#1d8348}.doc-view-badge--video{background:#1a5276}.doc-view-badge--text{background:#555}.doc-view-header-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.doc-view-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-muted);flex-shrink:0;transition:background var(--transition),color var(--transition)}.doc-view-action-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.doc-view-action-btn svg{width:15px;height:15px}.doc-view-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-muted);flex-shrink:0;transition:background var(--transition),color var(--transition)}.doc-view-close:hover{background:#dc354514;color:var(--color-danger)}.doc-view-close svg{width:16px;height:16px}.doc-view-content{flex:1;overflow:auto;display:flex;flex-direction:column;background:var(--color-bg)}.doc-view-iframe{flex:1;width:100%;height:100%;border:none;display:block;min-height:0}.doc-view-image-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--color-bg-secondary);overflow:auto}.doc-view-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.doc-view-media-center{flex:1;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--color-bg-secondary)}.doc-view-audio-card{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.5rem 1rem;box-shadow:var(--shadow-sm)}.doc-view-media-icon{width:48px;height:48px;color:var(--color-text-muted)}.doc-view-media-label{font-size:.82rem;font-weight:600;color:var(--color-text-secondary);text-align:center;word-break:break-all}.doc-view-audio-player{width:100%}.doc-view-video{width:100%;display:block;background:#000}.doc-view-text{flex:1;padding:1rem;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.78rem;line-height:1.6;color:var(--color-text);white-space:pre-wrap;word-break:break-word;overflow:auto;background:var(--color-bg);margin:0}.doc-view-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--color-text-muted);font-size:.82rem}.doc-view-spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:docViewSpin .7s linear infinite}@keyframes docViewSpin{to{transform:rotate(360deg)}}.doc-view-unsupported{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--color-text-muted);font-size:.85rem}@media(max-width:768px){.document-view-panel{position:fixed;top:var(--header-height);right:0;bottom:var(--footer-height);width:var(--right-panel-width);min-width:var(--right-panel-width);z-index:35;box-shadow:var(--shadow-lg)}.document-view-panel--pdf{width:var(--right-panel-width);min-width:var(--right-panel-width)}.document-view-panel--expanded{left:0;width:100%;min-width:0}}#root{width:100%;min-height:100vh}
