chat.css 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543
  1. /* 基础样式 */
  2. :root {
  3. --primary-color: #1a73e8;
  4. --secondary-color: #f8f9fa;
  5. --user-bubble: #7e9bed;
  6. --assistant-bubble: #fff;
  7. --system-bubble: #fff;
  8. }
  9. body {
  10. background-color: #f5f7fb;
  11. color: #202124;
  12. font-family: 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  13. }
  14. /* 聊天消息样式 */
  15. #chat-messages {
  16. padding: 20px;
  17. display: flex;
  18. flex-direction: column;
  19. gap: 16px;
  20. }
  21. .message {
  22. display: flex;
  23. max-width: 90%;
  24. align-self: flex-start;
  25. padding: 0.5rem 0;
  26. }
  27. .message.user-message {
  28. align-self: flex-end;
  29. flex-direction: row-reverse;
  30. }
  31. .message .avatar {
  32. width: 40px;
  33. height: 40px;
  34. border-radius: 50%;
  35. background-color: #e8eaed;
  36. display: flex;
  37. align-items: center;
  38. justify-content: center;
  39. flex-shrink: 0;
  40. overflow: hidden;
  41. > img {
  42. width: 100%;
  43. height: 100%;
  44. object-fit: cover;
  45. }
  46. }
  47. .message.user-message .avatar {
  48. background-color: var(--primary-color);
  49. color: white;
  50. margin-left: 12px;
  51. }
  52. .message .content {
  53. padding: 12px 16px;
  54. border-radius: 12px;
  55. box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
  56. max-width: calc(100% - 64px);
  57. overflow-wrap: break-word;
  58. }
  59. .user-message .content {
  60. color: #fff;
  61. background-color: var(--user-bubble);
  62. border-top-right-radius: 0;
  63. }
  64. .user-message .content p {
  65. margin-top: 0;
  66. margin-bottom: 0;
  67. }
  68. .assistant-message .avatar {
  69. margin-right: 12px;
  70. }
  71. .assistant-message .content {
  72. background-color: var(--assistant-bubble);
  73. border-top-left-radius: 0;
  74. }
  75. .assistant-message .content p {
  76. margin-top: 0;
  77. margin-bottom: 0;
  78. }
  79. .system-message .avatar {
  80. margin-right: 12px;
  81. }
  82. .system-message .content {
  83. background-color: var(--system-bubble);
  84. border-radius: 8px;
  85. max-width: 100%;
  86. }
  87. .system-message .content p {
  88. margin-top: 0;
  89. margin-bottom: 0;
  90. }
  91. /* Markdown 内容样式 */
  92. .markdown-body {
  93. font-size: 16px;
  94. line-height: 1.6;
  95. }
  96. .markdown-body h1, .markdown-body h2, .markdown-body h3 {
  97. margin-top: 1.5em;
  98. margin-bottom: 0.5em;
  99. font-weight: 600;
  100. }
  101. .markdown-body p {
  102. margin-bottom: 1em;
  103. }
  104. .markdown-body ul, .markdown-body ol {
  105. margin-bottom: 1em;
  106. padding-left: 2em;
  107. }
  108. .markdown-body code {
  109. background-color: rgba(175, 184, 193, 0.2);
  110. border-radius: 6px;
  111. padding: 0.2em 0.4em;
  112. font-size: 85%;
  113. }
  114. .markdown-body pre {
  115. background-color: #f6f8fa;
  116. border-radius: 6px;
  117. padding: 16px;
  118. overflow: auto;
  119. margin: 1em 0;
  120. }
  121. /* 思考指示器 */
  122. .thinking-container {
  123. display: flex;
  124. align-items: center;
  125. padding: 8px;
  126. }
  127. .thinking-indicator {
  128. display: flex;
  129. margin-right: 10px;
  130. }
  131. .thinking-indicator span {
  132. width: 8px;
  133. height: 8px;
  134. background-color: #5f6368;
  135. border-radius: 50%;
  136. display: inline-block;
  137. margin: 0 3px;
  138. animation: bounce 1.4s infinite ease-in-out both;
  139. }
  140. .thinking-indicator span:nth-child(1) {
  141. animation-delay: -0.32s;
  142. }
  143. .thinking-indicator span:nth-child(2) {
  144. animation-delay: -0.16s;
  145. }
  146. @keyframes bounce {
  147. 0%, 80%, 100% {
  148. transform: scale(0);
  149. }
  150. 40% {
  151. transform: scale(1.0);
  152. }
  153. }
  154. .thinking-text {
  155. color: #5f6368;
  156. font-size: 14px;
  157. }
  158. /* 结果卡片 */
  159. .result-card {
  160. border-top: 1px solid #e0e0e0;
  161. background: white;
  162. border-radius: 8px;
  163. overflow: hidden;
  164. box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  165. margin-top: 1rem;
  166. }
  167. .result-card .card-header {
  168. background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  169. border-bottom: 1px solid #dee2e6;
  170. padding: 8px 16px;
  171. }
  172. .result-card .card-header h6 {
  173. color: #495057;
  174. font-weight: 600;
  175. font-size: 0.9rem;
  176. }
  177. .result-card .nav-tabs {
  178. border-bottom: 1px solid #dee2e6;
  179. background-color: #f8f9fa;
  180. }
  181. .result-card .nav-tabs .nav-link {
  182. border: none;
  183. color: #6c757d;
  184. font-weight: 500;
  185. padding: 8px 16px;
  186. border-radius: 0;
  187. transition: all 0.3s ease;
  188. font-size: 0.85rem;
  189. }
  190. .result-card .nav-tabs .nav-link:hover {
  191. color: var(--primary-color);
  192. background-color: #e9ecef;
  193. }
  194. .result-card .nav-tabs .nav-link.active {
  195. color: var(--primary-color);
  196. background-color: white;
  197. border-bottom: 2px solid var(--primary-color);
  198. }
  199. .result-card .tab-content {
  200. background-color: white;
  201. }
  202. .result-card .tab-pane {
  203. padding: 12px;
  204. }
  205. /* 科室和医生卡片样式 */
  206. .department-results .card,
  207. .doctor-results .card {
  208. border: 1px solid #e9ecef;
  209. border-radius: 8px;
  210. transition: all 0.3s ease;
  211. margin-bottom: 12px;
  212. }
  213. .department-results .card:hover,
  214. .doctor-results .card:hover {
  215. box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  216. transform: translateY(-2px);
  217. }
  218. .department-results .card-title,
  219. .doctor-results .card-title {
  220. color: #212529;
  221. font-weight: 600;
  222. margin-bottom: 8px;
  223. font-size: 1rem;
  224. }
  225. .department-results .card-text,
  226. .doctor-results .card-text {
  227. color: #6c757d;
  228. line-height: 1.4;
  229. margin-bottom: 12px;
  230. font-size: 0.875rem;
  231. }
  232. /* 科室卡片特殊样式 */
  233. .dept-card .card-body {
  234. padding: 0.75rem !important;
  235. }
  236. .dept-card .avatar-sm {
  237. width: 32px !important;
  238. height: 32px !important;
  239. background: linear-gradient(135deg, #007bff 0%, #0056b3 100%) !important;
  240. }
  241. .dept-card .avatar-sm i {
  242. font-size: 16px;
  243. color: white !important;
  244. }
  245. /* 医生卡片特殊样式 */
  246. .doctor-card .card-body {
  247. padding: 0.75rem !important;
  248. }
  249. .doctor-card .avatar-md {
  250. width: 45px !important;
  251. height: 45px !important;
  252. background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%) !important;
  253. border: 2px solid #e3f2fd;
  254. }
  255. .doctor-card .avatar-md i {
  256. color: var(--primary-color) !important;
  257. font-size: 18px;
  258. }
  259. /* 徽章样式优化 */
  260. .badge {
  261. font-weight: 500;
  262. padding: 4px 8px;
  263. border-radius: 16px;
  264. font-size: 0.75rem;
  265. }
  266. .badge.bg-primary {
  267. background-color: var(--primary-color) !important;
  268. }
  269. .badge.bg-light {
  270. background-color: #f8f9fa !important;
  271. color: #495057 !important;
  272. border: 1px solid #dee2e6;
  273. }
  274. /* 按钮样式优化 */
  275. .btn-sm {
  276. padding: 3px 5px;
  277. font-size: 0.875rem;
  278. border-radius: 10px;
  279. }
  280. .btn-outline-primary {
  281. border-color: var(--primary-color);
  282. color: var(--primary-color);
  283. transition: all 0.3s ease;
  284. font-size: 0.8rem;
  285. padding: 4px 12px;
  286. }
  287. .btn-outline-primary:hover {
  288. background-color: var(--primary-color);
  289. border-color: var(--primary-color);
  290. transform: translateY(-1px);
  291. }
  292. .btn-outline-secondary {
  293. border-color: #6c757d;
  294. color: #6c757d;
  295. transition: all 0.3s ease;
  296. }
  297. .btn-outline-secondary:hover {
  298. background-color: #6c757d;
  299. border-color: #6c757d;
  300. color: white;
  301. }
  302. /* 结果卡片容器 */
  303. #result-cards-container {
  304. background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  305. border-radius: 12px;
  306. padding: 20px;
  307. margin: 20px;
  308. border: 1px solid #dee2e6;
  309. }
  310. /* 加载状态样式 */
  311. .spinner-border.text-primary {
  312. color: var(--primary-color) !important;
  313. }
  314. /* 响应式调整 */
  315. @media (max-width: 768px) {
  316. .message {
  317. max-width: 95%;
  318. }
  319. .message .avatar {
  320. }
  321. .message .content {
  322. padding: 8px 12px;
  323. max-width: calc(100% - 4px);
  324. }
  325. .result-card {
  326. margin-top: 1rem;
  327. border-radius: 6px;
  328. }
  329. .result-card .card-header {
  330. padding: 6px 12px;
  331. }
  332. .result-card .card-header h6 {
  333. font-size: 0.85rem;
  334. }
  335. .result-card .nav-tabs .nav-link {
  336. padding: 6px 12px;
  337. font-size: 0.8rem;
  338. }
  339. .result-card .tab-pane {
  340. padding: 8px;
  341. }
  342. #result-cards-container {
  343. margin: 15px;
  344. padding: 15px;
  345. }
  346. .dept-card .card-body,
  347. .doctor-card .card-body {
  348. padding: 0.5rem !important;
  349. }
  350. .dept-card .avatar-sm,
  351. .doctor-card .avatar-md {
  352. width: 35px !important;
  353. height: 35px !important;
  354. }
  355. .dept-card .avatar-sm i {
  356. font-size: 14px;
  357. }
  358. .doctor-card .avatar-md i {
  359. font-size: 16px;
  360. }
  361. .badge {
  362. font-size: 0.7rem;
  363. padding: 3px 6px;
  364. }
  365. .btn-sm {
  366. padding: 0.25rem 0.5rem;
  367. font-size: 0.8rem;
  368. }
  369. .card-title {
  370. font-size: 0.9rem !important;
  371. }
  372. .card-text {
  373. font-size: 0.8rem !important;
  374. line-height: 1.4;
  375. }
  376. }
  377. /* 医生卡片交互样式 */
  378. .doctor-card {
  379. cursor: pointer;
  380. transition: all 0.3s ease;
  381. border: 2px solid transparent;
  382. border-radius: 8px;
  383. }
  384. .doctor-card:hover {
  385. border-color: var(--primary-color);
  386. box-shadow: 0 6px 16px rgba(26, 115, 232, 0.15);
  387. transform: translateY(-3px);
  388. }
  389. .doctor-card:active {
  390. transform: translateY(-1px);
  391. }
  392. /* 模态框样式 */
  393. .modal-content {
  394. border-radius: 12px;
  395. border: none;
  396. box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  397. }
  398. .modal-header {
  399. background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  400. border-bottom: 1px solid #dee2e6;
  401. border-radius: 12px 12px 0 0;
  402. }
  403. .modal-title {
  404. color: var(--primary-color);
  405. font-weight: 600;
  406. }
  407. .avatar-lg {
  408. background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%) !important;
  409. border: 3px solid #e3f2fd;
  410. }
  411. .avatar-lg i {
  412. color: var(--primary-color) !important;
  413. }
  414. /* 标签页切换动画 */
  415. .tab-pane.fade {
  416. transition: opacity 0.3s ease;
  417. }
  418. .tab-pane.fade.show {
  419. opacity: 1;
  420. }
  421. /* 加载状态优化 */
  422. .spinner-border {
  423. width: 2rem;
  424. height: 2rem;
  425. }
  426. /* 医生卡片内容布局优化 */
  427. .doctor-card .card-body {
  428. padding: 1rem;
  429. }
  430. .doctor-card .card-title {
  431. font-size: 1.1rem;
  432. font-weight: 600;
  433. color: #212529;
  434. margin-bottom: 0.5rem;
  435. }
  436. .doctor-card .card-text {
  437. font-size: 0.9rem;
  438. line-height: 1.4;
  439. }
  440. .doctor-card .badge {
  441. font-size: 0.75rem;
  442. padding: 0.4rem 0.6rem;
  443. }
  444. /* 预约按钮样式 */
  445. .btn-outline-primary:focus {
  446. box-shadow: 0 0 0 0.2rem rgba(26, 115, 232, 0.25);
  447. }
  448. /* 结果卡片容器阴影效果 */
  449. #result-cards-container {
  450. box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  451. }