:root{color-scheme:light;font-family:IBM Plex Sans,DIN Alternate,Microsoft YaHei,PingFang SC,Segoe UI,sans-serif;line-height:1.5;color:#112033;background:#e9eef6;font-synthesis:none;text-rendering:optimizeLegibility;--bg-app: #e9eef6;--bg-panel: rgba(255, 255, 255, .82);--bg-panel-strong: #ffffff;--border-soft: rgba(123, 154, 190, .28);--text-1: #0f1f33;--text-2: #45627f;--accent-cyan: #06b6d4;--accent-blue: #2563eb;--accent-green: #0f9f8f;--accent-gold: #f59e0b;--shadow-soft: 0 10px 28px rgba(18, 40, 66, .1);--shadow-strong: 0 20px 52px rgba(17, 37, 62, .15)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden;color:var(--text-1);background:radial-gradient(circle at 8% 10%,rgba(15,159,143,.12),transparent 22%),radial-gradient(circle at 88% 14%,rgba(37,99,235,.12),transparent 26%),radial-gradient(circle at 55% 88%,rgba(245,158,11,.09),transparent 22%),var(--bg-app)}button,textarea{font:inherit}button{border:0}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr) 376px;height:100vh;background:linear-gradient(180deg,#ffffff8f,#e9eef6d6),var(--bg-app);transition:grid-template-columns .28s ease}.app-shell.chat-collapsed{grid-template-columns:248px minmax(0,1fr) 0}.app-shell.ai-mode,.app-shell.ai-mode.chat-collapsed{grid-template-columns:248px minmax(0,1fr)}.sidebar{display:flex;flex-direction:column;gap:28px;padding:24px 18px;color:#f5fbff;background:linear-gradient(168deg,#091d36fa,#0f2c48f5),#0a1f3d;border-right:1px solid rgba(95,195,255,.18);box-shadow:14px 0 34px #06142a52}.brand{display:flex;align-items:center;gap:12px}.brand>div{min-width:0}.brand-mark{display:grid;width:46px;height:46px;place-items:center;color:#e8fdff;background:linear-gradient(145deg,#16a3d4,#1d63df);border-radius:8px;box-shadow:0 12px 28px #16a3d447}.brand h1,.brand p,.page-header h2,.chat-header h2,.question-card h3{margin:0}.brand h1{font-size:16px;line-height:1.15;letter-spacing:.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand p{color:#9fc5e8;font-size:12px}.nav-list{display:grid;gap:10px}.nav-item{display:grid;grid-template-columns:22px 1fr 18px;align-items:center;gap:10px;width:100%;min-height:48px;padding:0 12px;color:#c4d8ee;cursor:pointer;background:#ffffff05;border-radius:8px;border:1px solid rgba(141,198,242,.08);transition:color .2s ease,background .2s ease,transform .2s ease,border-color .2s ease,box-shadow .2s ease;text-align:left}.nav-item:hover,.nav-item.active{color:#eff9ff;background:#0dc5de1f;border-color:#52d0ff4d;box-shadow:inset 0 0 0 1px #abe8ff1f}.nav-item.active{box-shadow:inset 3px 0 #52d0ff,inset 0 0 0 1px #abe8ff33}.nav-item:hover{transform:translate(2px)}.sidebar-footer{display:flex;gap:10px;align-items:center;margin-top:auto;padding:14px;color:#d7f2ff;background:#0dc5de1f;border:1px solid rgba(96,214,255,.24);border-radius:8px;font-size:13px}.workspace{min-width:0;overflow:hidden;background:linear-gradient(180deg,#ffffff5c,#ffffff1a)}.ai-companion-layout{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(340px,1fr);gap:12px;height:100%;padding:12px}.ai-companion-chat,.ai-companion-graph{min-width:0;min-height:0}.page{display:flex;flex-direction:column;gap:18px;height:100%;padding:24px;overflow:hidden}.page-header,.chat-header{display:flex;justify-content:space-between;gap:16px;align-items:center}.eyebrow{margin:0 0 4px;color:#4f6b88;font-size:12px;font-weight:800;letter-spacing:0}.page-header h2,.chat-header h2{color:#0e2239;font-size:26px;line-height:1.1;text-shadow:0 1px 0 rgba(255,255,255,.5)}.header-stat,.chat-status{display:flex;align-items:center;gap:8px;min-height:36px;padding:0 12px;color:#1e3a56;background:var(--bg-panel-strong);border:1px solid var(--border-soft);border-radius:8px;font-size:13px;font-weight:700;white-space:nowrap;box-shadow:var(--shadow-soft)}.graph-layout{display:grid;grid-template-rows:auto minmax(0,1fr);gap:12px;min-height:0;flex:1}.graph-page.embedded{padding:0}.graph-page.embedded .graph-layout{height:100%;gap:8px}.graph-page.embedded .graph-toolbar{padding:8px 10px}.graph-page.embedded .graph-hint{font-size:11px}.graph-page.embedded .graph-legend{top:10px;right:10px;gap:10px;padding:8px 10px}.graph-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:10px 12px;background:linear-gradient(180deg,#ffffffb8,#f6fbffc7);border:1px solid rgba(125,165,205,.22);border-radius:10px;box-shadow:0 8px 18px #0f284114}.group-filters{display:flex;flex-wrap:wrap;gap:8px}.group-filter{min-height:34px;padding:0 12px;color:#32506d;background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:8px;font-size:13px;font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease}.group-filter.active{color:#fff;background:linear-gradient(135deg,#078cb0,#1860d9);border-color:#0a78c6cc;box-shadow:0 8px 20px #078cb03d}.group-filter:hover{transform:translateY(-1px);border-color:#26aad661}.graph-hint{margin:0;color:#4b6884;font-size:12px;font-weight:700;letter-spacing:.1px}.graph-canvas{position:relative;width:100%;height:100%;min-height:0;background:radial-gradient(circle at 52% 46%,rgba(6,182,212,.14),transparent 33%),radial-gradient(circle at 74% 76%,rgba(14,165,233,.1),transparent 30%),repeating-linear-gradient(0deg,rgba(24,61,97,.025) 0,rgba(24,61,97,.025) 1px,transparent 1px,transparent 24px),repeating-linear-gradient(90deg,rgba(24,61,97,.025) 0,rgba(24,61,97,.025) 1px,transparent 1px,transparent 24px),#fdfefe;border:1px solid var(--border-soft);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-strong)}.graph-canvas:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 16% 12%,rgba(57,211,244,.12),transparent 30%),radial-gradient(circle at 80% 84%,rgba(28,130,246,.1),transparent 32%)}.graph-canvas:after{content:none}.graph-loading-shell{position:absolute;top:16px;left:16px;z-index:4;display:grid;grid-template-columns:auto 1fr;gap:10px 12px;align-items:center;min-width:min(380px,calc(100% - 32px));max-width:calc(100% - 32px);padding:12px 14px;background:linear-gradient(165deg,#ffffffeb,#f1f9ffe6);border:1px solid rgba(126,166,208,.38);border-radius:12px;box-shadow:0 10px 24px #0e26441f,inset 0 1px #ffffffb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.graph-loading-icon-wrap{display:grid;width:34px;height:34px;place-items:center;color:#0e8fb6;background:linear-gradient(145deg,#0e9f8929,#2563eb24);border:1px solid rgba(54,142,208,.34);border-radius:50%;animation:graphLoadingPulse 1.6s ease-in-out infinite}.graph-loading-copy{display:grid;gap:2px;min-width:0}.graph-loading-copy strong{color:#153654;font-size:14px;font-weight:800;line-height:1.2}.graph-loading-copy span{color:#4e6782;font-size:12px;line-height:1.25}.graph-loading-progress{grid-column:1 / -1;position:relative;height:3px;overflow:hidden;border-radius:999px;background:#577ca82e}.graph-loading-progress i{position:absolute;inset:0 auto 0 0;width:36%;border-radius:inherit;background:linear-gradient(90deg,#0ea5b6,#2a69e4);animation:graphLoadingSlide 1.25s ease-in-out infinite}.g6-graph{width:100%;height:100%;min-height:600px;touch-action:none;overscroll-behavior:contain}.graph-legend{position:absolute;top:14px;right:16px;z-index:3;display:flex;align-items:center;gap:14px;padding:10px 14px;background:#ffffffd1;border:1px solid rgba(123,154,190,.26);border-radius:10px;box-shadow:0 12px 22px #0f233a1c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.graph-legend span{display:inline-flex;align-items:center;gap:6px;color:#4b5563;font-size:14px;font-weight:700}.graph-legend i{width:12px;height:12px;border-radius:50%;box-shadow:0 0 0 3px #ffffff9e}.practice-actions{display:flex;gap:10px}.icon-button,.primary-button,.ask-ai-button,.send-button{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border-radius:8px}.icon-button{width:40px;height:40px;color:#1e3f5e;background:var(--bg-panel);border:1px solid var(--border-soft);box-shadow:var(--shadow-soft)}.primary-button{gap:8px;min-height:40px;padding:0 15px;color:#fff;background:linear-gradient(135deg,#0e9f89,#0d84c8);font-weight:800;box-shadow:0 10px 24px #0b87a747}.primary-button:disabled,.send-button:disabled{cursor:not-allowed;opacity:.48}.practice-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.practice-summary div{display:grid;gap:4px;min-height:74px;padding:14px;background:var(--bg-panel-strong);border:1px solid var(--border-soft);border-radius:8px;box-shadow:var(--shadow-soft)}.practice-summary span{color:#64748b;font-size:13px}.practice-summary strong{color:#111827;font-size:24px}.single-question-layout{display:grid;grid-template-rows:auto auto;gap:14px;min-height:0;overflow:auto;align-content:start;padding-right:4px}.question-card{padding:18px;background:var(--bg-panel-strong);border:1px solid var(--border-soft);border-radius:8px;box-shadow:var(--shadow-soft);animation:panelIn .35s ease}.question-topline{display:flex;justify-content:space-between;color:#64748b;font-size:13px;font-weight:800}.question-card h3{margin-top:10px;font-size:18px}.option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}.option-button{display:grid;grid-template-columns:28px 1fr 18px;gap:10px;align-items:center;min-height:48px;padding:8px 12px;color:#1f3550;background:linear-gradient(180deg,#fdfefe,#f3f8fc);border:1px solid #d1deeb;border-radius:8px;cursor:pointer;text-align:left;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease}.option-button:hover{transform:translateY(-1px);box-shadow:0 8px 16px #1e3a5a1a}.option-button:disabled{cursor:default}.option-button span{display:grid;width:28px;height:28px;place-items:center;color:#475569;background:#e2e8f0;border-radius:50%;font-size:13px;font-weight:800}.option-button.chosen{border-color:#1f93c8;background:linear-gradient(180deg,#eef8ff,#e6f5ff)}.option-button.correct{border-color:#16a34a;background:#f0fdf4}.option-button.wrong{border-color:#dc2626;background:#fef2f2}.question-submit-row{display:flex;justify-content:flex-end;margin-top:12px}.fill-answer-wrap{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:14px;align-items:center}.fill-answer-input{width:100%;min-height:42px;padding:8px 10px;color:#1f3550;border:1px solid #c8d8e8;border-radius:8px;background:linear-gradient(180deg,#fdfefe,#f3f8fc);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.fill-answer-input:focus{border-color:#1f93c8;box-shadow:0 0 0 3px #1f93c81f}.fill-answer-input:disabled{opacity:.9}.fill-submit{min-width:108px}.answer-panel{min-height:0;padding:12px;background:var(--bg-panel-strong);border:1px dashed #c7d7e8;border-radius:8px}.answer-panel.visible{border-style:solid}.answer-placeholder{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:8px 10px;color:#42617d;background:linear-gradient(180deg,#f9fcff,#f0f7ff);border:1px solid #d7e5f4;border-radius:8px;font-size:13px;line-height:1.4}.answer-placeholder svg{flex:0 0 auto;color:#64748b}.result-banner{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 12px;border-radius:8px;font-size:14px}.answer-text-line{display:flex;gap:6px;align-items:baseline;margin-top:10px;color:#1f3550;font-size:14px}.answer-text-line strong{color:#0f3658;flex:0 0 auto}.answer-text-line span{min-width:0;overflow-wrap:anywhere}.wrong-recommendation span{color:#64748b;font-size:13px;font-weight:700}.wrong-recommendation strong{color:#111827}.explain{display:flex;gap:8px;margin-top:13px;padding:10px 12px;border-radius:8px;font-size:14px}.correct-text{color:#166534;background:#f0fdf4}.wrong-text{color:#991b1b;background:#fef2f2}.wrong-recommendation{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:13px;padding:14px;color:#243d56;background:linear-gradient(180deg,#fff9ef,#fff4df);border:1px solid #f6d1a4;border-radius:8px;box-shadow:var(--shadow-soft)}.wrong-recommendation div{display:grid;gap:5px}.wrong-recommendation p{margin:0;color:#7c2d12;font-size:14px}.ask-ai-button{flex:0 0 auto;gap:8px;min-height:40px;padding:0 14px;color:#fff;background:linear-gradient(135deg,#f97316,#ee9a0a);font-weight:800;box-shadow:0 10px 22px #f57f1740}.chat-panel{display:flex;flex-direction:column;min-width:0;height:100vh;padding:22px 18px;background:linear-gradient(180deg,#ffffffe0,#f6fafff5);border-left:1px solid var(--border-soft);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.chat-panel.embedded{height:100%;padding:16px;border:1px solid var(--border-soft);border-radius:12px;box-shadow:var(--shadow-strong)}.chat-header-actions{display:flex;align-items:center;gap:8px}.chat-collapse-toggle{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:34px;padding:0 10px;color:#2c4967;background:linear-gradient(180deg,#fff,#eef5fd);border:1px solid rgba(133,167,207,.4);border-radius:999px;font-size:12px;font-weight:700;box-shadow:0 6px 14px #102a481f;transition:all .2s ease}.chat-collapse-toggle:hover{transform:translateY(-1px);border-color:#308ed07a;box-shadow:0 10px 20px #102a4829}.chat-collapse-toggle-inline{min-width:72px}.chat-collapse-toggle-float{min-width:62px;padding:0 8px;color:#f0fbff;background:linear-gradient(135deg,#078cb0f0,#1860d9eb);border-color:#7de0ff6b;box-shadow:0 12px 22px #0b4a8a47}.chat-collapse-toggle-float span{color:#e8f9ff}.chat-panel.collapsed{position:fixed;inset:auto 10px 16px auto;z-index:80;width:fit-content;height:fit-content;min-width:0;min-height:0;padding:0;border:0;box-shadow:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;overflow:visible;pointer-events:none}.chat-panel.collapsed:before{content:none}.chat-collapsed-body{display:flex;align-items:center;justify-content:center;pointer-events:auto}.chat-panel.collapsed .chat-collapse-toggle{pointer-events:auto}.chat-header h2{font-size:22px}.chat-status{background:linear-gradient(180deg,#fbfdff,#f3f9ff)}.status-dot{position:relative;width:10px;height:10px;flex:0 0 10px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#7cf7d1,#17c98f 45%,#099a72);box-shadow:0 0 0 3px #10b98129,0 0 12px #10b9816b,inset 0 1px 1px #ffffff73}.status-dot:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:1px solid rgba(16,185,129,.55);opacity:.42;animation:statusPulseRing 1.8s ease-out infinite}.quick-prompts{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:18px 0 12px}.ai-graph-action-bar{display:grid;grid-template-columns:auto auto 1fr;gap:8px;align-items:center;margin:0 0 8px;padding:8px 10px;border:1px solid rgba(129,168,207,.28);border-radius:8px;background:linear-gradient(180deg,#f5faffeb,#edf6ffe6)}.ai-graph-action-bar span{min-width:0;color:#335d83;font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.graph-insight-panel{display:grid;grid-template-rows:auto auto minmax(0,1fr);gap:8px;min-height:0;flex:1;overflow:hidden;margin-top:10px;padding:10px;border:1px solid rgba(128,170,212,.3);border-radius:10px;background:linear-gradient(180deg,#fafefff2,#f0f8ffe6)}.graph-insight-title{display:flex;align-items:center;justify-content:space-between;gap:8px}.graph-insight-title strong{color:#183f63;font-size:14px}.graph-insight-ask{min-height:32px;padding:0 10px;font-size:12px;box-shadow:none}.graph-insight-content,.graph-insight-ai{padding:8px 10px;border-radius:8px;font-size:13px;line-height:1.34;min-width:0;overflow-wrap:anywhere;word-break:break-word}.graph-insight-content{color:#1d3f5f;background:#ffffffd9;border:1px solid rgba(143,177,214,.34)}.graph-insight-ai{color:#184160;background:#e9f6ffd1;border:1px solid rgba(133,174,214,.3);min-height:0;overflow:auto}.graph-insight-ai pre,.graph-insight-content pre{max-width:100%;overflow:auto}.chat-panel.graph-scope .quick-prompts,.chat-panel.graph-scope .message-list{display:none}.chat-panel.graph-scope .chat-input{margin-top:6px}.chat-panel.graph-scope{gap:8px;padding:10px;overflow:hidden}.chat-panel.graph-scope:before{content:none}.chat-panel.graph-scope .chat-header{align-items:center;padding:0}.chat-panel.graph-scope .chat-header h2{font-size:20px}.chat-panel.graph-scope .chat-status{min-height:30px;padding:0 10px;border-radius:999px;box-shadow:none}.graph-insight-panel{margin-top:2px;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none;display:flex;flex-direction:column;gap:6px;min-height:0;overflow:hidden}.graph-insight-title{padding:0 0 6px;border-bottom:1px solid rgba(126,166,207,.2)}.graph-insight-title strong{font-size:16px;font-weight:800}.graph-insight-content,.graph-insight-ai{padding:0;border:1px solid rgba(130,170,210,.24);border-radius:10px;background:#ffffffad}.graph-insight-content{color:#1b3d5b}.graph-insight-ai{color:#153955;background:#eef8ffb3}.graph-insight-section-label{margin:0;padding:7px 10px 6px;color:#335d83;font-size:12px;font-weight:800;border-bottom:1px solid rgba(130,170,210,.22)}.graph-insight-body{max-height:30vh;min-height:72px;overflow:auto;padding:8px 10px;line-height:1.44;white-space:normal;overflow-wrap:anywhere;word-break:break-word;position:relative;isolation:isolate;contain:layout paint}.graph-insight-body>:first-child{margin-top:0}.graph-insight-body>:last-child{margin-bottom:0}.graph-insight-body p,.graph-insight-body ul,.graph-insight-body ol,.graph-insight-body pre,.graph-insight-body h3,.graph-insight-body h4{margin-top:0;margin-bottom:6px;line-height:1.45}.graph-insight-body :where(h1,h2,h3,h4,h5,h6,p,ul,ol,pre,blockquote){position:static;float:none;clear:both}.graph-insight-body pre{white-space:pre-wrap;word-break:break-word}.graph-insight-content h3,.graph-insight-content h4,.graph-insight-content p,.graph-insight-content ul{margin-top:0;margin-bottom:6px}.graph-insight-content ul,.graph-insight-ai ul,.graph-insight-ai ol{padding-left:16px}.graph-insight-content li,.graph-insight-ai li{margin:0 0 4px;line-height:1.38}.chat-panel.graph-scope .chat-input{padding:6px;border-radius:10px}.chat-panel.graph-scope .chat-input textarea{min-height:40px;max-height:94px;padding:6px 8px}.chat-panel.graph-scope .send-button{width:36px;height:36px}.quick-prompts button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;color:#26445f;background:linear-gradient(180deg,#f7fbff,#ecf4fd);border-radius:8px;border:1px solid #d4e2f0;cursor:pointer;font-size:13px;font-weight:800;transition:all .2s ease}.quick-prompts button:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}.message-list{display:flex;flex:1;flex-direction:column;gap:10px;min-height:0;overflow:auto;padding:10px 2px 14px}.message{width:fit-content;max-width:92%;padding:8px 10px;border-radius:8px;word-break:break-word;font-size:14px;line-height:1.34;letter-spacing:0}.message.assistant p,.message.assistant ul,.message.assistant ol,.message.assistant pre,.message.assistant h1,.message.assistant h2,.message.assistant h3{margin:0 0 4px}.message.assistant{white-space:normal}.message.user{white-space:pre-wrap}.message.assistant>:where(h1,h2,h3,h4,h5,h6,p,ul,ol,pre,blockquote){margin:0 0 3px}.message.assistant>:first-child{margin-top:0}.message.assistant>:last-child{margin-bottom:0}.message.assistant p:last-child,.message.assistant ul:last-child,.message.assistant ol:last-child,.message.assistant pre:last-child{margin-bottom:0}.message.assistant ul,.message.assistant ol{padding-left:15px;margin:2px 0}.message.assistant li{margin:0 0 1px;line-height:1.28}.message.assistant li:last-child{margin-bottom:0}.message.assistant li>p{margin:0}.message.assistant h1,.message.assistant h2,.message.assistant h3{line-height:1.25}.message.assistant h1{font-size:17px;color:#0f4fa8}.message.assistant h2{font-size:16px;color:#0b6a9f}.message.assistant h3{font-size:15px;color:#0d7a6f}.message.assistant strong{color:#0f3d88;font-weight:800}.message.assistant em{color:#0f766e}.message.assistant a{color:#1d4ed8;text-decoration:underline}.message.assistant blockquote{margin:4px 0;padding:4px 8px;color:#265c84;background:#2563eb14;border-left:3px solid rgba(37,99,235,.5);border-radius:6px}.message.assistant hr{border:0;border-top:1px solid rgba(73,123,170,.35);margin:6px 0}.message.assistant ul li::marker,.message.assistant ol li::marker{color:#1e6fb2}.message.assistant code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;color:#0f3f73;background:#0e74901f;padding:1px 4px;border-radius:4px}.message.assistant pre{padding:5px 7px;border-radius:8px;border:1px solid rgba(120,165,210,.35);background:#f0f8ffa6;overflow:auto;margin:2px 0}.message.assistant pre code{color:#114674;background:transparent;padding:0}.message.assistant{align-self:flex-start;color:#24405a;background:linear-gradient(180deg,#f3f9ff,#eaf3fd);border:1px solid #d5e3f2}.message.user{align-self:flex-end;color:#fff;background:linear-gradient(135deg,#0d8fbc,#0f9f8f);box-shadow:0 10px 18px #0c8cb442}.message.typing{color:#64748b}.chat-input{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:end;padding:6px;border:1px solid rgba(132,168,208,.34);border-radius:10px;background:linear-gradient(180deg,#ffffffeb,#f1f8ffeb);box-shadow:inset 0 1px #fffc,0 10px 18px #15355714;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.chat-input:focus-within{border-color:#2b86d38f;box-shadow:inset 0 1px #ffffffe0,0 0 0 3px #2563eb1a,0 12px 22px #143c6624}.chat-input textarea{width:100%;min-height:42px;max-height:108px;resize:none;padding:7px 9px;color:#152b44;line-height:1.38;background:linear-gradient(180deg,#fff,#f7fbff);border:1px solid rgba(133,173,215,.38);border-radius:10px;outline:none;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.chat-input textarea::placeholder{color:#6a86a3}.chat-input textarea:focus{border-color:#2b86d399;background:#fff;box-shadow:0 0 0 3px #2563eb1a}.send-button{width:38px;height:38px;color:#fff;border-radius:9px;background:linear-gradient(135deg,#0e9f89,#0b87c8);border:1px solid rgba(255,255,255,.24);box-shadow:0 10px 20px #0a8ca442,inset 0 1px #ffffff42}.chat-input .send-button:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.03);box-shadow:0 12px 24px #0a829c52,inset 0 1px #ffffff4d}.chat-input .send-button:active:not(:disabled){transform:translateY(0);box-shadow:0 6px 14px #0a829c42,inset 0 1px #ffffff38}@keyframes panelIn{0%{transform:translateY(8px);opacity:.88}to{transform:translateY(0);opacity:1}}@keyframes graphSweep{0%{transform:translate(-10%) rotate(12deg)}to{transform:translate(290%) rotate(12deg)}}@keyframes graphLoadingPulse{0%,to{transform:scale(1);box-shadow:0 0 #0e9f892e}50%{transform:scale(1.04);box-shadow:0 0 0 7px #0e9f890d}}@keyframes graphLoadingSlide{0%{transform:translate(-110%)}to{transform:translate(310%)}}@keyframes statusPulseRing{0%{transform:scale(.72);opacity:.55}80%{transform:scale(1.45);opacity:0}to{transform:scale(1.45);opacity:0}}@media(max-width:1180px){body{overflow:auto}.app-shell{grid-template-columns:210px minmax(0,1fr);height:auto;min-height:100vh}.app-shell.chat-collapsed{grid-template-columns:210px minmax(0,1fr)}.chat-panel{grid-column:1 / -1;height:460px;border-left:0;border-top:1px solid #d8e2ed}.ai-companion-layout{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr) minmax(320px,40vh)}.chat-panel.embedded{grid-column:auto;height:100%;border-top:0;border-left:1px solid var(--border-soft)}}@media(max-width:820px){body{overflow:hidden}.app-shell{display:block;height:100dvh}.app-shell.chat-collapsed{display:block}.sidebar{position:sticky;top:0;z-index:35;gap:10px;padding:8px 10px;box-shadow:0 8px 18px #06142a47}.brand{gap:8px}.brand-mark{width:34px;height:34px}.brand h1{font-size:14px}.brand p{display:none}.nav-list{display:flex;gap:6px}.nav-item{grid-template-columns:16px 1fr;min-height:36px;gap:6px;padding:0 9px;font-size:13px}.nav-item svg:last-child{display:none}.page{gap:10px;padding:10px}.page-header{gap:6px;min-height:0;align-items:center}.page-header h2{font-size:17px;line-height:1.05;white-space:nowrap}.page-header .eyebrow,.chat-header .eyebrow,.header-stat,.sidebar-footer{display:none}.workspace{height:calc(100dvh - 96px);overflow:hidden}.ai-companion-layout{gap:8px;padding:8px;grid-template-columns:1fr;grid-template-rows:minmax(0,1fr)}.ai-companion-graph{display:none}.option-grid,.practice-summary{grid-template-columns:1fr}.wrong-recommendation{align-items:stretch;flex-direction:column}.single-question-layout{gap:10px;padding-right:0}.question-card{padding:12px}.question-card h3{margin-top:8px;font-size:16px}.option-grid{gap:8px;margin-top:10px}.option-button{min-height:42px;padding:7px 10px}.fill-answer-wrap{grid-template-columns:1fr;gap:8px}.fill-submit{width:100%;min-width:0}.answer-panel{padding:10px}.graph-layout{gap:8px}.graph-toolbar{align-items:stretch}.graph-canvas{height:100%;min-height:0}.graph-loading-shell{top:10px;left:10px;max-width:calc(100% - 20px);min-width:0;padding:10px 11px}.graph-loading-copy strong{font-size:13px}.graph-loading-copy span{font-size:11px}.graph-legend{left:12px;right:12px;justify-content:space-between;gap:8px;padding:8px 10px;overflow-x:auto}.g6-graph{min-height:0;height:100%}.chat-panel.mobile{position:fixed;inset:auto 0 0;z-index:60;height:min(64dvh,560px);padding:10px 10px calc(10px + env(safe-area-inset-bottom));border-left:0;border-top:1px solid rgba(123,154,190,.35);border-radius:14px 14px 0 0;box-shadow:0 -16px 34px #0e1e3633;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.chat-panel.mobile:before{border-radius:14px 14px 0 0}.chat-panel.mobile.collapsed{inset:auto 10px calc(10px + env(safe-area-inset-bottom)) auto;width:auto;height:auto;min-width:0;padding:0;border:0;border-radius:0;box-shadow:none;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}.chat-panel.mobile .chat-header{gap:8px}.chat-panel.mobile .chat-header h2{font-size:17px}.chat-panel.mobile .chat-status{min-height:26px;padding:0 7px;font-size:11px}.chat-panel.mobile .quick-prompts{display:none}.chat-panel.mobile .message-list{gap:8px;padding:6px}.chat-panel.mobile .message{max-width:100%;font-size:13px}.chat-panel.mobile .ai-graph-action-bar{grid-template-columns:1fr auto;gap:6px;padding:6px 8px}.chat-panel.mobile .ai-graph-action-bar span{grid-column:1 / -1}.chat-panel.mobile .chat-input{grid-template-columns:1fr auto;margin-top:2px;padding:5px;gap:4px;border-radius:8px}.chat-panel.mobile .chat-input textarea{min-height:36px;max-height:80px;padding:5px 7px;font-size:13px;line-height:1.24;border-radius:8px}.chat-panel.mobile .send-button{width:34px;height:34px;border-radius:7px}.chat-panel.mobile.graph-scope .graph-insight-panel{gap:5px}.chat-panel.mobile.graph-scope .graph-insight-title strong{font-size:15px}.chat-panel.mobile.graph-scope .graph-insight-body{min-height:60px;max-height:24dvh;padding:7px 8px}.chat-panel.mobile .chat-collapse-toggle-inline span{display:none}.chat-panel.mobile .chat-collapse-toggle-inline{min-width:34px;padding:0 8px}.chat-panel.mobile .chat-collapse-toggle-float{min-height:40px;padding:0 10px}.graph-hint{width:100%;font-size:11px;line-height:1.2}.chat-panel.embedded .chat-header{gap:6px;align-items:center}.chat-panel.embedded .chat-header h2{font-size:17px;line-height:1.05}.chat-panel.embedded .chat-status{min-height:26px;padding:0 7px;font-size:11px}.graph-page .page-header{padding-bottom:0}.graph-page .page-header h2{font-size:17px}}.app-shell{position:relative}.app-shell:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 12%,rgba(56,189,248,.12),transparent 36%),radial-gradient(circle at 78% 86%,rgba(16,185,129,.1),transparent 32%);mix-blend-mode:soft-light}.page,.chat-panel{position:relative}.page:before,.chat-panel:before{content:"";position:absolute;inset:0;pointer-events:none;border:1px solid rgba(120,165,210,.14);border-radius:10px}.header-stat,.chat-status,.practice-summary div,.question-card,.graph-canvas,.answer-panel{border-radius:10px}.practice-summary div{position:relative;overflow:hidden}.practice-summary div:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#0ea5e9f2,#10b981bf)}.question-card{background:linear-gradient(180deg,#fffffffa,#f7fbfff5)}.option-button{border-radius:10px}.option-button span{box-shadow:inset 0 0 0 1px #6e8eb438}.option-button.chosen,.option-button.correct,.option-button.wrong{box-shadow:0 8px 20px #1c3a5c1f}.primary-button,.send-button,.ask-ai-button{border:1px solid rgba(255,255,255,.24);letter-spacing:.2px}.primary-button:hover,.send-button:hover,.ask-ai-button:hover{transform:translateY(-1px);filter:brightness(1.03)}.graph-legend,.message.assistant,.quick-prompts button,.chat-input textarea{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.message-list{background:linear-gradient(180deg,#ffffff75,#ffffff29);border:1px solid rgba(139,170,206,.18);border-radius:10px;padding:10px 8px 14px}.chat-input{margin-top:8px}.chat-input textarea{border-radius:10px}.graph-legend span,.nav-item span,.question-card h3{letter-spacing:.1px}*{scrollbar-width:thin;scrollbar-color:rgba(60,101,144,.45) rgba(211,226,241,.42)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#3b82f699,#14b8a68c);border-radius:8px;border:2px solid rgba(255,255,255,.65)}*::-webkit-scrollbar-track{background:#dbe9f66b;border-radius:8px}
