*{box-sizing:border-box;font-family:Inter,Arial,sans-serif}body{margin:0;background:#f4f6f8;color:#1d2733}#root{min-height:100vh}.chat-shell{width:100%;max-width:none;margin:0;min-height:100vh;display:grid;grid-template-rows:auto minmax(420px,1fr) auto auto auto;gap:12px;padding:12px}.chat-header{background:#fff;border-radius:12px;padding:14px 16px;border:1px solid #e3e8ef}.chat-header h1{margin:0 0 4px;font-size:20px}.chat-header p{margin:0;color:#5f6f84;font-size:13px}.debug-line{margin-top:6px!important;font-size:12px!important;color:#6b7b90!important}.warning-line{margin-top:6px!important;color:#a35a00!important;font-size:12px!important}.dev-diagnostics{margin-top:8px;font-size:12px;color:#66768b;display:grid;gap:2px}.chat-messages{background:#fff;border-radius:12px;border:1px solid #e3e8ef;padding:14px;overflow:auto;min-height:380px;max-height:calc(100vh - 260px);display:grid;gap:10px}.message-row{display:flex;align-items:flex-start}.message-row-user{justify-content:flex-end}.message-row-ai{justify-content:flex-start}.message-bubble{max-width:88%;border-radius:12px;padding:10px 12px;line-height:1.45;height:auto;white-space:pre-wrap;overflow-wrap:anywhere}.message-user{background:#1665d8;color:#fff}.message-row-user .message-bubble{align-self:flex-end;width:fit-content;max-width:78%}.message-ai{background:#f2f5f8;border:1px solid #dee7f2}.message-meta{font-size:11px;margin-bottom:6px;color:#607089}.typing{color:#4b5c72}.answer-short{font-weight:700}.answer-steps{margin:8px 0 0;padding-left:20px}.answer-steps li{margin-bottom:6px}.step-images{margin-top:8px;display:grid;gap:8px}.step-image{margin:0}.step-image img{display:block;max-width:100%;height:auto;border:1px solid #d7e1ef;border-radius:8px;background:#fff}.step-image figcaption{margin-top:4px;font-size:12px;color:#607089}.answer-panel{border-radius:10px;padding:10px;margin-top:8px}.answer-panel h4{margin:0 0 8px}.answer-panel ul{margin:0;padding-left:18px}.answer-panel.errors{background:#fff0f0;border:1px solid #f1b3b3}.answer-panel.notes{background:#fff9e8;border:1px solid #f0db8d}.answer-panel.related{background:#eef5ff;border:1px solid #cddfff}.related-topic-list{display:flex;flex-wrap:wrap;gap:8px}.related-topic-btn{background:#fff;border:1px solid #b9d2ff;color:#0b4ea8;border-radius:999px;padding:6px 12px;font-size:12px;line-height:1.2;white-space:nowrap}.related-topic-btn:hover{background:#e8f1ff}.mode-label{display:inline-block;margin-bottom:8px;padding:3px 8px;border-radius:999px;font-size:12px;background:#e6f2ff;color:#0b4ea8}.chat-input-wrap{background:#fff;border:1px solid #e3e8ef;border-radius:12px;padding:10px;display:grid;gap:10px;position:sticky;bottom:0;z-index:2}.quick-questions{display:flex;gap:8px;flex-wrap:wrap}.topic-suggestions{background:#fff;border:1px solid #e3e8ef;border-radius:12px;padding:10px 12px;display:grid;gap:8px}.topic-suggestions h3{margin:0;font-size:14px}.suggestion-sections,.suggestion-topics{display:flex;flex-wrap:wrap;gap:8px}.section-btn{background:#f3f6fb;color:#24364c;border:1px solid #d7e1ef;border-radius:999px;padding:6px 12px;font-size:12px}.section-btn.active{background:#e7f0ff;color:#0b4ea8;border-color:#b9d2ff}.topic-btn{background:#fff;color:#0b4ea8;border:1px solid #c8dafb;border-radius:999px;padding:6px 12px;font-size:12px}.topic-btn:hover{background:#eaf2ff}.suggestion-note{margin:0;font-size:12px;color:#5f6f84}.chat-input-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:end}textarea{width:100%;min-height:64px;max-height:140px;border:1px solid #d6deea;border-radius:10px;padding:10px;resize:vertical}button{cursor:pointer;border:none;border-radius:10px;padding:10px 12px}.send-btn{background:#1665d8;color:#fff;min-height:40px;min-width:92px}.send-btn:disabled{opacity:.6;cursor:not-allowed}.ghost-btn{background:#eef3f9;color:#223247}.request-cta{display:flex;justify-content:flex-start}.request-cta-block{background:#fff;border:1px solid #e3e8ef;border-radius:12px;padding:10px 12px;align-items:center;gap:10px}.request-form{background:#fff;border:1px solid #e3e8ef;border-radius:12px;padding:12px;display:grid;gap:8px}.request-form h3{margin:0}.request-form button{width:fit-content;background:#1665d8;color:#fff}.error-banner,.notice-banner,.empty-state{background:#fff;border:1px solid #e3e8ef;border-radius:12px;padding:10px 12px}.error-banner{color:#a32626}.notice-banner{color:#146f32}@media (max-width: 720px){.message-bubble{max-width:96%}.chat-input-row{grid-template-columns:1fr}.chat-shell{padding:8px;gap:8px}}
