:root{--bg:#0b0d14;--panel:#121622;--panel-soft:#0f1320;--border:rgba(255,255,255,0.08);--border-strong:rgba(255,255,255,0.12);--text:#f3f5f7;--muted:#a7afc0;--accent:#6d5efc;--accent-hover:#8578ff;--accent-soft:rgba(109,94,252,0.16);--success:#22c55e;--error:#ef4444;--font-mono:"JetBrains Mono","Fira Code","Consolas",monospace;--bg-dark:var(--bg);--bg-card:var(--panel);--bg-input:rgba(255,255,255,0.04);--text-muted:var(--muted);--heading-1:#e8e6ff;--heading-2:#d9ddff;--heading-3:#c7cdff;--sidebar-width:280px;--content-max-width:920px;--content-padding:2rem;--content-padding-tablet:1.5rem;--content-padding-mobile:1rem}[data-theme=light]{--bg:#f5f6f9;--panel:#ffffff;--panel-soft:#f8f9fc;--border:rgba(0,0,0,0.1);--border-strong:rgba(0,0,0,0.18);--text:#1a1d26;--muted:#5c6370;--accent:#5b4dd4;--accent-hover:#4a3ec4;--accent-soft:rgba(91,77,212,0.12);--success:#16a34a;--error:#dc2626;--bg-dark:var(--bg);--bg-card:var(--panel);--bg-input:rgba(0,0,0,0.04);--text-muted:var(--muted);--heading-1:#2d2f3a;--heading-2:#3d4050;--heading-3:#4d5060}[data-theme=light] body{background:radial-gradient(circle at top,rgba(91,77,212,.06),transparent 30%),var(--bg)}*{box-sizing:border-box}html{scroll-behavior:smooth}body,html{overflow-x:hidden}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:radial-gradient(circle at top,rgba(109,94,252,.08),transparent 30%),var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.app-main,.app-sidebar,html{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.app-main::-webkit-scrollbar,.app-sidebar::-webkit-scrollbar,html::-webkit-scrollbar{width:8px;height:8px}.app-main::-webkit-scrollbar-track,.app-sidebar::-webkit-scrollbar-track,html::-webkit-scrollbar-track{background:transparent}.app-main::-webkit-scrollbar-thumb,.app-sidebar::-webkit-scrollbar-thumb,html::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.app-main::-webkit-scrollbar-thumb:hover,.app-sidebar::-webkit-scrollbar-thumb:hover,html::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.app-layout{display:flex;margin:0;min-height:100vh}.app-main{flex:1 1;min-width:0;overflow-x:auto;overflow-y:auto;padding:var(--content-padding);max-width:100%}@media (max-width:1024px){.app-main{padding:var(--content-padding-tablet)}}@media (max-width:768px){.app-main{padding:var(--content-padding-mobile)}}.app-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--panel);border-right:1px solid var(--border);padding:1.5rem 0;height:100vh;overflow-x:hidden;overflow-y:auto;flex-shrink:0}.app-sidebar-nav>div{margin-bottom:.25rem}.sidebar-item{display:block;position:relative;padding:.5rem 1rem .5rem 1.25rem;border-radius:14px;margin:0 .5rem;color:var(--muted);transition:all .18s ease;min-width:0;overflow-wrap:break-word;word-break:break-word}.sidebar-item:hover{background:rgba(255,255,255,.04);color:var(--text)}.sidebar-item.active{background:var(--accent-soft);color:var(--heading-1)}.sidebar-item.active:before{content:"";position:absolute;left:-4px;top:10px;bottom:10px;width:4px;border-radius:999px;background:var(--accent);box-shadow:0 0 14px rgba(109,94,252,.55)}.sidebar-item-sub{padding-left:2rem;font-size:.875rem}@media (max-width:1024px){.app-sidebar{position:fixed;top:0;left:0;z-index:100;height:100vh;transform:translateX(-100%);transition:transform .25s ease;box-shadow:4px 0 24px rgba(0,0,0,.3)}.app-sidebar.is-open{transform:translateX(0)}.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;opacity:0;transition:opacity .25s ease}.sidebar-backdrop.is-visible{display:block;opacity:1}}.interview-page{max-width:var(--content-max-width);margin:0 auto}.interview-page-header{margin-bottom:1.5rem}.interview-tabs{background:var(--panel);border-radius:14px;border:1px solid var(--border);overflow-x:auto;overflow-y:visible}.interview-tabs-nav{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 .5rem;background:rgba(255,255,255,.02)}.interview-tabs-tab{display:flex;align-items:center;gap:.5rem;padding:.9rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;color:var(--muted);font-size:.9rem;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.interview-tabs-tab:hover{color:var(--text)}.interview-tabs-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.interview-tabs-tab-icon{font-size:1rem}.interview-tabs-content{padding:1.5rem 1.5rem 2rem}.interview-tab-panel{min-height:200px}.interview-tab-chat{padding:0}.interview-tab-chat .interview-ask{border:none;border-radius:0;box-shadow:none;background:transparent}.interview-tab-chat .interview-ask-expanded{min-height:400px}.interview-ask-embedded .interview-ask-expanded{border-radius:0}.interview-section{margin-bottom:2rem}.interview-section-title{font-size:1.125rem;font-weight:700;color:var(--heading-2);margin:0 0 1rem}.interview-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:.75rem;gap:.75rem}@media (max-width:640px){.topic-grid{grid-template-columns:1fr}}.page-header{margin:0 0 .5rem;font-size:2rem;font-weight:800;line-height:1.15;letter-spacing:-.03em;color:var(--heading-1)}.page-subtitle{color:var(--muted);margin-bottom:1rem}.card-list{flex-direction:column;gap:.75rem}.card-link,.card-list{display:flex;min-width:0}.card-link{align-items:center;flex-wrap:wrap;gap:.5rem;padding:1rem 1.25rem;background:var(--panel);border-radius:14px;border:1px solid var(--border);color:var(--text);font-weight:500;transition:all .18s ease;overflow:hidden}.card-link:hover{border-color:rgba(109,94,252,.4);background:rgba(255,255,255,.04)}.card-link-icon{flex-shrink:0}.card-link-title{flex:1 1;min-width:0;overflow-wrap:break-word;word-break:break-word}.card-link-meta{flex-shrink:0;color:var(--muted);font-size:.875rem;margin-left:.5rem}@media (max-width:768px){.card-link{padding:.875rem 1rem}.card-link-meta{width:100%;margin-left:0;margin-top:.25rem;padding-left:1.75rem}}.btn{border-radius:12px;padding:.72rem 1rem;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .18s ease;border:1px solid transparent;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:var(--accent);color:white;box-shadow:0 8px 18px rgba(109,94,252,.28)}.card-header .btn-primary{margin-bottom:0}.btn-create{margin-bottom:1.5rem}.btn-primary:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.06)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary{background:rgba(255,255,255,.03);border-color:var(--border);color:var(--text)}.btn-secondary:hover{background:rgba(255,255,255,.06);border-color:var(--border-strong)}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:.5rem .85rem;font-weight:500}.btn-ghost:hover{color:var(--text);background:rgba(255,255,255,.04)}.btn-success{background:var(--success)}.btn-success:hover:not(:disabled){background:#16a34a}.btn-danger{background:var(--error);color:white}.btn-danger:hover:not(:disabled){background:#dc2626;filter:brightness(1.05)}.topic-layout{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,420px);grid-gap:1.5rem;gap:1.5rem;align-items:start;min-width:0}@media (max-width:1024px){.topic-layout{grid-template-columns:1fr;gap:1.5rem}}.topic-header{grid-column:1/-1;margin-bottom:1.5rem;display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap}.topic-back-link{display:inline-block;font-size:.875rem;color:var(--muted);margin-bottom:.5rem;transition:color .15s}.topic-back-link:hover{color:var(--accent)}.topic-header h1{font-size:2rem;font-weight:800;line-height:1.15;letter-spacing:-.03em;margin:0 0 .25rem;color:var(--heading-1)}.topic-readme{min-width:0}.topic-questions{position:-webkit-sticky;position:sticky;top:1.5rem}@media (max-width:1024px){.topic-questions{position:static}}.page-card{background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01)),var(--panel);box-shadow:0 10px 30px rgba(0,0,0,.28);overflow-x:auto;overflow-y:visible}.page-card,.questions-card{border:1px solid var(--border);border-radius:22px;min-width:0}.questions-card{background:var(--panel-soft);overflow:hidden}.card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}.card-body{padding:2rem;min-width:0;overflow-x:auto}.section-block+.section-block{margin-top:1.5rem}.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent);margin:1.5rem 0}.study-card{background:var(--panel);border-radius:22px;border:1px solid var(--border);overflow:hidden;min-width:0}.study-card-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02);display:flex;justify-content:space-between;align-items:center}.study-card-body{padding:1.5rem;min-width:0;overflow-x:auto}.topic-questions .card-body,.topic-questions .study-card-body{max-height:calc(100vh - 12rem);overflow-y:auto}.topic-questions .card-body::-webkit-scrollbar,.topic-questions .study-card-body::-webkit-scrollbar{width:6px}.topic-questions .card-body::-webkit-scrollbar-track,.topic-questions .study-card-body::-webkit-scrollbar-track{background:transparent}.topic-questions .card-body::-webkit-scrollbar-thumb,.topic-questions .study-card-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.questions-progress{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--muted)}.questions-progress-text{font-weight:600;min-width:2.5rem}.questions-progress-bar{width:64px;height:6px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden}.questions-progress-fill{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .3s ease}.answer-textarea{width:100%;min-height:110px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:14px;padding:.95rem 1rem;color:var(--text);font-family:inherit;font-size:.9rem;resize:vertical;transition:all .18s ease}.answer-textarea::placeholder{color:rgba(255,255,255,.28)}.answer-textarea:hover{border-color:var(--border-strong);background:rgba(255,255,255,.04)}.answer-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);background:rgba(255,255,255,.05)}.topic-label{color:var(--heading-2);font-weight:700;font-size:.95rem}.markdown-content{min-width:0;overflow-wrap:break-word}.markdown-content h1{font-size:2rem;line-height:1.15;font-weight:800;letter-spacing:-.03em;margin:1.5rem 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);color:var(--heading-1)}.markdown-content h2{font-size:1.35rem;font-weight:700;margin:1.25rem 0 1rem;color:var(--heading-2)}.markdown-content h3{font-size:1.02rem;font-weight:700;color:var(--text);margin:0 0 .35rem}.markdown-content h4,.markdown-content h5,.markdown-content h6{color:var(--heading-3);font-weight:600}.markdown-content li,.markdown-content p{font-size:.98rem;line-height:1.75;color:var(--muted);margin:.75rem 0}.markdown-content p:first-child{margin-top:0}.markdown-content ol,.markdown-content ul{margin:.75rem 0;padding-left:1.5rem}.markdown-content blockquote{border-left:4px solid var(--accent);margin:1rem 0;padding:.5rem 1rem;background:var(--accent-soft);border-radius:0 8px 8px 0}.code-block,.markdown-content pre{padding:1rem 1.1rem;overflow-x:auto;max-width:100%;margin:1rem 0;font-size:.92rem;line-height:1.65;color:#d9e1f2}.code-block,.code-editor,.markdown-content pre{background:#0c101a;border:1px solid var(--border);border-radius:16px}.code-editor{overflow:hidden;margin:0}.code-editor-cm .cm-editor{font-family:var(--font-mono)}.code-editor-cm .cm-scroller{border-radius:0}.markdown-content pre::-webkit-scrollbar{height:6px}.markdown-content pre::-webkit-scrollbar-track{background:transparent}.markdown-content pre::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.markdown-content code{font-family:var(--font-mono);font-size:.9em}.markdown-content pre code{background:none;padding:0}.markdown-content .table-wrapper{overflow-x:auto;max-width:100%;margin:1rem 0;border-radius:12px;border:1px solid var(--border)}.markdown-content .table-wrapper::-webkit-scrollbar{height:6px}.markdown-content table{width:100%;border-collapse:collapse;font-size:.9rem}.markdown-content td,.markdown-content th{padding:.625rem .875rem;border:1px solid var(--border);text-align:left;vertical-align:top}.markdown-content th{background:rgba(255,255,255,.04);font-weight:600;color:var(--text)}.markdown-content tr:nth-child(2n) td{background:rgba(255,255,255,.02)}.markdown-content tr:hover td{background:rgba(255,255,255,.03)}.mermaid-diagram-wrapper{max-width:100%;overflow:auto}.mermaid-diagram{display:flex;justify-content:flex-start;background:transparent;min-width:min-content}.mermaid-diagram svg{flex-shrink:0;overflow:visible}.mermaid-diagram foreignObject{overflow:visible!important}.mermaid-diagram .edgePath path{stroke:var(--accent);stroke-width:2px}.sidebar-toggle{display:none;position:fixed;bottom:1.5rem;left:1rem;z-index:98;width:48px;height:48px;border-radius:12px;background:var(--accent);color:white;border:none;cursor:pointer;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:0 8px 18px rgba(109,94,252,.35);transition:all .18s ease}.sidebar-toggle:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(109,94,252,.45)}.sidebar-close-btn{display:none;padding:.4rem .6rem;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;cursor:pointer}.sidebar-close-btn:hover{background:rgba(255,255,255,.1)}[data-theme=light] .sidebar-close-btn{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.1);color:var(--text)}[data-theme=light] .sidebar-close-btn:hover{background:rgba(0,0,0,.1)}.theme-toggle{padding:.4rem .6rem;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:1rem;cursor:pointer}.theme-toggle:hover{background:rgba(255,255,255,.1)}[data-theme=light] .theme-toggle{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.1)}[data-theme=light] .theme-toggle:hover{background:rgba(0,0,0,.08)}@media (max-width:1024px){.sidebar-toggle{display:flex}.sidebar-close-btn{display:block}}@media (min-width:1025px){.sidebar-toggle{display:none!important}}.interview-ask .interview-ask-toggle:hover,.requirements-section .requirements-toggle:hover{background:rgba(255,255,255,.03)}.documents-list{display:flex;flex-direction:column;gap:.75rem}.document-card{margin-bottom:0}.document-drag-handle{cursor:-webkit-grab;cursor:grab;color:var(--muted);font-size:.9rem;padding:.25rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0}.document-drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.document-card-dragging{box-shadow:0 8px 24px rgba(0,0,0,.4)}.notebook-loading{padding:2rem;text-align:center;color:var(--muted)}.notebook-view{display:flex;flex-direction:column;gap:1rem}.notebook-cell{border:1px solid var(--border);border-radius:12px;overflow:hidden}.notebook-cell-markdown{padding:1rem 1.25rem;background:rgba(255,255,255,.02)}.notebook-cell-code .notebook-cell-toolbar{padding:.5rem 1rem;background:rgba(0,0,0,.2);border-top:1px solid var(--border);display:flex;justify-content:flex-end}.notebook-cell-output{padding:1rem 1.25rem;background:rgba(0,0,0,.15);border-top:1px solid var(--border)}.notebook-cell-output .code-block{margin:0}.interview-ask-expanded{display:flex;flex-direction:column;min-height:320px}.interview-ask-toolbar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0}.interview-ask-select{padding:.45rem .85rem;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.85rem}.interview-ask-chat-select{flex:1 1;min-width:120px}.interview-ask-btn-secondary{padding:.45rem .85rem;font-size:.85rem;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer}.interview-ask-btn-secondary:hover{background:rgba(255,255,255,.04)}.interview-ask-btn-ghost{padding:.4rem .65rem;font-size:.8rem;background:transparent;border:none;border-radius:6px;color:var(--muted);cursor:pointer}.interview-ask-btn-ghost:hover{color:var(--text);background:rgba(255,255,255,.04)}.interview-ask-messages{flex:1 1;min-height:180px;max-height:420px;overflow-y:auto;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:1.25rem}.interview-ask-empty{color:var(--muted);font-size:.9rem;padding:1rem 0}.interview-ask-empty-hint{font-size:.8rem;margin-top:.35rem;opacity:.85}.interview-ask-suggestions{display:flex;flex-direction:column;gap:.5rem;margin-top:1.25rem}.interview-ask-suggestion{padding:.65rem 1rem;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:.9rem;text-align:left;cursor:pointer;transition:all .18s ease}.interview-ask-suggestion:hover:not(:disabled){background:var(--accent-soft);border-color:rgba(109,94,252,.35);color:var(--heading-1)}.interview-ask-suggestion:disabled{opacity:.6;cursor:not-allowed}.interview-ask-msg{display:flex;flex-direction:column;gap:.35rem}.interview-ask-msg-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.interview-ask-msg-user .interview-ask-msg-header{flex-direction:row-reverse}.interview-ask-copy{padding:.25rem .5rem;font-size:.7rem;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--muted);cursor:pointer;opacity:.8}.interview-ask-copy:hover{color:var(--text);background:rgba(255,255,255,.04)}.interview-ask-msg-user{align-self:flex-end;max-width:90%}.interview-ask-msg-user .interview-ask-msg-content{background:var(--accent-soft);padding:.6rem 1rem;border-radius:12px 12px 4px 12px;border:1px solid rgba(109,94,252,.25)}.interview-ask-msg-assistant{align-self:flex-start;max-width:95%}.interview-ask-msg-assistant .interview-ask-msg-content{background:rgba(255,255,255,.03);padding:.75rem 1rem;border-radius:12px 12px 12px 4px;border-left:3px solid var(--accent);white-space:pre-wrap;font-size:.9rem;line-height:1.55}.interview-ask-msg-label{color:var(--muted);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.interview-ask-msg-user .interview-ask-msg-label{text-align:right}.interview-ask-form{display:flex;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid var(--border);flex-shrink:0}.interview-ask-input{flex:1 1;padding:.7rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:.9rem}.interview-ask-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.interview-ask-submit{padding:.7rem 1.25rem}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.modal-content{border-radius:16px;padding:1.5rem;width:100%;max-width:400px;margin:auto}.empty-state,.modal-content{background:var(--panel);border:1px solid var(--border)}.empty-state{text-align:center;padding:3rem 2rem;max-width:420px;margin:2rem auto 0;border-radius:20px}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.9}.empty-state-title{font-size:1.35rem;font-weight:700;color:var(--heading-1);margin:0 0 .5rem}.empty-state-text{color:var(--muted);font-size:.95rem;line-height:1.6;margin:0 0 1.5rem}.empty-state-hint{margin-top:1.25rem;font-size:.8rem;color:var(--muted);opacity:.85}.empty-state-hint code{background:var(--bg-input);padding:.15rem .4rem;border-radius:4px;font-size:.75rem}.breadcrumbs{flex-wrap:wrap;font-size:.875rem;margin-bottom:1rem}.breadcrumbs,.breadcrumbs-item{display:flex;align-items:center;gap:.25rem}.breadcrumbs-sep{margin:0 .15rem}.breadcrumbs-link,.breadcrumbs-sep{color:var(--muted)}.breadcrumbs-link:hover{color:var(--accent)}.breadcrumbs-current{color:var(--text);font-weight:500}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;max-width:360px;pointer-events:none}.toast{padding:.85rem 1.25rem;border-radius:12px;font-size:.9rem;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.35);border:1px solid var(--border);animation:toast-in .25s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.4);color:#86efac}.toast-error{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.4);color:#fca5a5}.toast-info{background:var(--panel);color:var(--text)}