style.css 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683
  1. /* Apple Health–inspired: light grouped background, SF-like stack, soft cards */
  2. :root {
  3. --bg-grouped: #f2f2f7;
  4. --bg-elevated: #ffffff;
  5. --separator: rgba(60, 60, 67, 0.12);
  6. --label-primary: #000000;
  7. --label-secondary: rgba(60, 60, 67, 0.6);
  8. --label-tertiary: rgba(60, 60, 67, 0.3);
  9. --accent-blue: #007aff;
  10. --accent-green: #34c759;
  11. --accent-orange: #ff9500;
  12. --accent-red: #ff3b30;
  13. --radius-lg: 20px;
  14. --radius-md: 12px;
  15. --radius-sm: 10px;
  16. --shadow-card: 0 1px 3px rgba(0, 0, 0, 0.06);
  17. --font-stack: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display",
  18. "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  19. --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  20. }
  21. *,
  22. *::before,
  23. *::after {
  24. box-sizing: border-box;
  25. }
  26. html {
  27. -webkit-font-smoothing: antialiased;
  28. }
  29. body {
  30. margin: 0;
  31. min-height: 100vh;
  32. font-family: var(--font-stack);
  33. font-size: 17px;
  34. line-height: 1.47;
  35. color: var(--label-primary);
  36. background: var(--bg-grouped);
  37. padding: 0 0 48px;
  38. }
  39. .app {
  40. max-width: 820px;
  41. margin: 0 auto;
  42. padding: 16px 20px 32px;
  43. }
  44. /* —— Header(大标题区,类似「健康」顶部)—— */
  45. .app-header {
  46. text-align: center;
  47. padding: 24px 8px 8px;
  48. }
  49. .app-title {
  50. margin: 0;
  51. font-size: 34px;
  52. font-weight: 700;
  53. letter-spacing: 0.37px;
  54. line-height: 1.12;
  55. }
  56. .app-subtitle {
  57. margin: 4px 0 0;
  58. font-size: 13px;
  59. font-weight: 400;
  60. line-height: 1.35;
  61. letter-spacing: 0.02em;
  62. color: var(--label-tertiary);
  63. }
  64. /* —— 用户条 —— */
  65. .user-strip {
  66. margin-bottom: 16px;
  67. }
  68. .user-strip .field-label {
  69. display: block;
  70. font-size: 13px;
  71. font-weight: 600;
  72. color: var(--label-secondary);
  73. text-transform: uppercase;
  74. letter-spacing: -0.08px;
  75. margin-bottom: 6px;
  76. }
  77. .user-strip .field-hint {
  78. display: block;
  79. margin-top: 8px;
  80. font-size: 13px;
  81. color: var(--label-secondary);
  82. }
  83. .tech-toggle {
  84. display: flex;
  85. align-items: center;
  86. gap: 10px;
  87. margin-top: 14px;
  88. padding-top: 14px;
  89. border-top: 1px solid var(--separator);
  90. font-size: 15px;
  91. font-weight: 500;
  92. color: var(--label-secondary);
  93. cursor: pointer;
  94. }
  95. .tech-toggle input {
  96. width: auto;
  97. accent-color: var(--accent-blue);
  98. }
  99. .reflect-run-row {
  100. display: flex;
  101. flex-wrap: wrap;
  102. align-items: stretch;
  103. gap: 10px;
  104. }
  105. .reflect-run-row select {
  106. flex: 1 1 200px;
  107. min-width: 0;
  108. }
  109. .reflect-follow-fieldset {
  110. border: none;
  111. margin: 0;
  112. padding: 0;
  113. }
  114. .reflect-follow-fieldset legend {
  115. padding: 0;
  116. }
  117. .radio-row {
  118. display: flex;
  119. align-items: center;
  120. gap: 10px;
  121. margin-top: 10px;
  122. font-size: 15px;
  123. font-weight: 500;
  124. cursor: pointer;
  125. }
  126. .radio-row input {
  127. width: auto;
  128. accent-color: var(--accent-blue);
  129. }
  130. .reflect-reason-block {
  131. margin-top: 14px;
  132. padding: 14px 16px;
  133. background: rgba(118, 118, 128, 0.06);
  134. border-radius: var(--radius-md);
  135. border: 1px solid var(--separator);
  136. }
  137. .btn-compact {
  138. padding: 10px 14px;
  139. font-size: 15px;
  140. font-weight: 600;
  141. font-family: inherit;
  142. border: none;
  143. border-radius: var(--radius-md);
  144. cursor: pointer;
  145. background: rgba(118, 118, 128, 0.12);
  146. color: var(--accent-blue);
  147. white-space: nowrap;
  148. }
  149. .btn-compact:hover {
  150. background: rgba(118, 118, 128, 0.18);
  151. }
  152. .app-dialog {
  153. max-width: 360px;
  154. width: calc(100vw - 40px);
  155. padding: 22px 20px;
  156. border: none;
  157. border-radius: var(--radius-lg);
  158. box-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
  159. }
  160. .app-dialog::backdrop {
  161. background: rgba(0, 0, 0, 0.35);
  162. }
  163. .dialog-title {
  164. margin: 0 0 10px;
  165. font-size: 20px;
  166. font-weight: 700;
  167. }
  168. .dialog-body {
  169. margin: 0 0 18px;
  170. font-size: 15px;
  171. color: var(--label-secondary);
  172. line-height: 1.45;
  173. }
  174. .dialog-actions {
  175. margin-top: 0;
  176. justify-content: flex-end;
  177. }
  178. .history-summary {
  179. margin-top: 12px;
  180. padding: 14px 16px;
  181. font-size: 15px;
  182. line-height: 1.45;
  183. color: var(--label-primary);
  184. background: rgba(118, 118, 128, 0.06);
  185. border-radius: var(--radius-md);
  186. }
  187. .history-raw {
  188. margin-top: 12px;
  189. }
  190. .history-raw summary {
  191. cursor: pointer;
  192. font-size: 15px;
  193. font-weight: 600;
  194. color: var(--accent-blue);
  195. padding: 8px 0;
  196. }
  197. .history-raw pre {
  198. margin: 8px 0 0;
  199. }
  200. /* —— 分段控件(Tab)—— */
  201. .tab-segment {
  202. display: flex;
  203. padding: 4px;
  204. margin: 0 0 20px;
  205. background: rgba(118, 118, 128, 0.12);
  206. border-radius: 10px;
  207. gap: 2px;
  208. }
  209. .tab-segment button {
  210. flex: 1;
  211. border: none;
  212. padding: 8px 10px;
  213. font-size: 13px;
  214. font-weight: 600;
  215. font-family: inherit;
  216. color: var(--label-primary);
  217. background: transparent;
  218. border-radius: 8px;
  219. cursor: pointer;
  220. transition: background 0.2s ease, color 0.2s ease;
  221. }
  222. .tab-segment button[aria-selected="true"] {
  223. background: var(--bg-elevated);
  224. box-shadow: 0 3px 8px rgba(0, 0, 0, 0.08), 0 1px 1px rgba(0, 0, 0, 0.04);
  225. }
  226. .tab-segment button[aria-selected="false"] {
  227. color: var(--label-secondary);
  228. }
  229. .tab-segment button:focus-visible {
  230. outline: 2px solid var(--accent-blue);
  231. outline-offset: 2px;
  232. }
  233. .tab-panel {
  234. animation: fadeIn 0.22s ease;
  235. }
  236. @keyframes fadeIn {
  237. from {
  238. opacity: 0;
  239. }
  240. to {
  241. opacity: 1;
  242. }
  243. }
  244. /* —— 卡片 —— */
  245. .card {
  246. background: var(--bg-elevated);
  247. border-radius: var(--radius-lg);
  248. padding: 20px 18px;
  249. margin-bottom: 16px;
  250. box-shadow: var(--shadow-card);
  251. }
  252. .card h2 {
  253. margin: 0 0 4px;
  254. font-size: 22px;
  255. font-weight: 700;
  256. letter-spacing: 0.35px;
  257. }
  258. .card h3 {
  259. margin: 20px 0 8px;
  260. font-size: 20px;
  261. font-weight: 600;
  262. }
  263. .card > p.muted,
  264. .section-lead {
  265. margin: 0 0 16px;
  266. font-size: 15px;
  267. color: var(--label-secondary);
  268. }
  269. .card-hr {
  270. margin: 24px 0;
  271. border: none;
  272. height: 1px;
  273. background: var(--separator);
  274. }
  275. /* —— 表单控件 —— */
  276. .field-label-inline {
  277. display: block;
  278. font-size: 13px;
  279. font-weight: 600;
  280. color: var(--label-secondary);
  281. margin-bottom: 6px;
  282. }
  283. input[type="text"],
  284. input[type="number"],
  285. input[type="file"],
  286. select,
  287. textarea {
  288. width: 100%;
  289. max-width: 100%;
  290. font-family: inherit;
  291. font-size: 17px;
  292. padding: 12px 14px;
  293. border-radius: var(--radius-sm);
  294. border: 1px solid var(--separator);
  295. background: rgba(118, 118, 128, 0.05);
  296. color: var(--label-primary);
  297. }
  298. input::placeholder,
  299. textarea::placeholder {
  300. color: var(--label-tertiary);
  301. }
  302. input:focus,
  303. select:focus,
  304. textarea:focus {
  305. outline: none;
  306. border-color: var(--accent-blue);
  307. box-shadow: 0 0 0 3px rgba(0, 122, 255, 0.25);
  308. background: var(--bg-elevated);
  309. }
  310. textarea {
  311. min-height: 120px;
  312. resize: vertical;
  313. }
  314. /* 主按钮:填充蓝 */
  315. .btn {
  316. display: inline-flex;
  317. align-items: center;
  318. justify-content: center;
  319. padding: 12px 20px;
  320. font-size: 17px;
  321. font-weight: 600;
  322. font-family: inherit;
  323. border: none;
  324. border-radius: var(--radius-md);
  325. cursor: pointer;
  326. transition: transform 0.15s ease, opacity 0.15s ease;
  327. }
  328. .btn:active {
  329. transform: scale(0.98);
  330. }
  331. .btn-primary {
  332. background: var(--accent-blue);
  333. color: #fff;
  334. }
  335. .btn-primary:hover {
  336. opacity: 0.92;
  337. }
  338. .btn-secondary {
  339. background: rgba(118, 118, 128, 0.12);
  340. color: var(--accent-blue);
  341. }
  342. .btn-secondary:hover {
  343. background: rgba(118, 118, 128, 0.18);
  344. }
  345. .btn-row {
  346. display: flex;
  347. flex-wrap: wrap;
  348. gap: 10px;
  349. margin-top: 14px;
  350. }
  351. .flex-row {
  352. display: flex;
  353. gap: 16px;
  354. flex-wrap: wrap;
  355. }
  356. .flex-column {
  357. display: flex;
  358. flex-direction: column;
  359. gap: 10px;
  360. flex: 1;
  361. min-width: 260px;
  362. }
  363. .diet-grid {
  364. display: grid;
  365. grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  366. gap: 14px;
  367. align-items: end;
  368. }
  369. .diet-grid label {
  370. display: flex;
  371. flex-direction: column;
  372. gap: 6px;
  373. font-size: 13px;
  374. font-weight: 600;
  375. color: var(--label-secondary);
  376. }
  377. .diet-grid label.checkbox-row {
  378. flex-direction: row;
  379. align-items: center;
  380. gap: 10px;
  381. }
  382. .diet-grid input[type="number"],
  383. .diet-grid select {
  384. font-weight: 400;
  385. color: var(--label-primary);
  386. }
  387. .checkbox-row {
  388. display: flex;
  389. flex-direction: row;
  390. align-items: center;
  391. gap: 10px;
  392. font-size: 15px;
  393. font-weight: 500;
  394. }
  395. .checkbox-row input[type="checkbox"] {
  396. width: auto;
  397. accent-color: var(--accent-blue);
  398. }
  399. /* —— 状态与分析 —— */
  400. #analysis {
  401. margin-top: 16px;
  402. font-size: 15px;
  403. font-weight: 600;
  404. color: var(--label-secondary);
  405. }
  406. #progressList {
  407. margin-top: 12px;
  408. padding: 12px 16px;
  409. list-style: none;
  410. background: rgba(118, 118, 128, 0.06);
  411. border-radius: var(--radius-md);
  412. }
  413. #progressList li {
  414. display: flex;
  415. flex-wrap: wrap;
  416. align-items: baseline;
  417. gap: 0 6px;
  418. margin-bottom: 8px;
  419. font-size: 15px;
  420. padding-bottom: 8px;
  421. border-bottom: 1px solid var(--separator);
  422. min-height: 1.5em;
  423. }
  424. #progressList .agent-progress-label {
  425. flex: 0 1 auto;
  426. font-weight: 600;
  427. color: var(--label-secondary);
  428. }
  429. #progressList .agent-progress-status {
  430. flex: 1 1 120px;
  431. color: var(--label-primary);
  432. word-break: break-word;
  433. }
  434. #progressList li:last-child {
  435. margin-bottom: 0;
  436. padding-bottom: 0;
  437. border-bottom: none;
  438. }
  439. #report {
  440. margin-top: 8px;
  441. font-size: 15px;
  442. line-height: 1.5;
  443. }
  444. #report :where(p, ul, ol) {
  445. margin: 0 0 12px;
  446. }
  447. /* —— 饮食结果区 —— */
  448. #dietStatus {
  449. margin-top: 12px;
  450. font-size: 15px;
  451. font-weight: 600;
  452. color: var(--label-secondary);
  453. }
  454. #dietResult {
  455. margin-top: 16px;
  456. padding: 16px;
  457. background: rgba(118, 118, 128, 0.06);
  458. border-radius: var(--radius-md);
  459. border: 1px solid var(--separator);
  460. font-size: 15px;
  461. }
  462. #dietResult h4 {
  463. margin: 0 0 10px;
  464. font-size: 17px;
  465. font-weight: 600;
  466. }
  467. #dietResult code {
  468. font-family: var(--font-mono);
  469. font-size: 13px;
  470. background: rgba(118, 118, 128, 0.1);
  471. padding: 2px 6px;
  472. border-radius: 6px;
  473. }
  474. #dietHistoryPre {
  475. margin-top: 12px;
  476. max-height: 360px;
  477. overflow: auto;
  478. font-family: var(--font-mono);
  479. font-size: 12px;
  480. line-height: 1.45;
  481. background: rgba(118, 118, 128, 0.06);
  482. padding: 14px;
  483. border-radius: var(--radius-md);
  484. border: 1px solid var(--separator);
  485. white-space: pre-wrap;
  486. word-break: break-word;
  487. }
  488. /* —— 横幅与详情 —— */
  489. .banner {
  490. padding: 12px 14px;
  491. border-radius: var(--radius-md);
  492. font-size: 15px;
  493. margin: 12px 0;
  494. }
  495. .banner-warning {
  496. background: rgba(255, 149, 0, 0.12);
  497. color: #c65a00;
  498. border: 1px solid rgba(255, 149, 0, 0.35);
  499. }
  500. .banner-error {
  501. color: var(--accent-red);
  502. }
  503. .meal-plan-list {
  504. margin: 8px 0;
  505. padding-left: 20px;
  506. }
  507. .meal-plan-list li {
  508. margin-bottom: 10px;
  509. }
  510. .muted-why {
  511. color: var(--label-secondary);
  512. font-size: 0.94em;
  513. }
  514. .meal-tips {
  515. font-size: 0.95em;
  516. color: var(--label-secondary);
  517. }
  518. details.diet-trace {
  519. margin-top: 12px;
  520. font-size: 13px;
  521. color: var(--label-secondary);
  522. }
  523. details.diet-trace summary {
  524. cursor: pointer;
  525. font-weight: 600;
  526. color: var(--accent-blue);
  527. padding: 8px 0;
  528. }
  529. details.diet-trace pre {
  530. margin: 8px 0 0;
  531. padding: 12px;
  532. background: rgba(0, 0, 0, 0.04);
  533. border-radius: var(--radius-sm);
  534. overflow: auto;
  535. max-height: 280px;
  536. font-family: var(--font-mono);
  537. font-size: 11px;
  538. }
  539. /* —— 历史页空状态 —— */
  540. .history-placeholder {
  541. padding: 24px 16px;
  542. text-align: center;
  543. color: var(--label-secondary);
  544. font-size: 15px;
  545. }
  546. .hidden {
  547. display: none !important;
  548. }
  549. /* 兼容旧版 score 条(若仍使用) */
  550. .score-container {
  551. margin-top: 20px;
  552. padding: 14px;
  553. background: rgba(118, 118, 128, 0.06);
  554. border-radius: var(--radius-md);
  555. }
  556. .score-label {
  557. font-weight: 600;
  558. margin-bottom: 8px;
  559. font-size: 15px;
  560. }
  561. .score-bar-bg {
  562. width: 100%;
  563. height: 8px;
  564. background: rgba(118, 118, 128, 0.2);
  565. border-radius: 4px;
  566. overflow: hidden;
  567. }
  568. .score-bar {
  569. height: 100%;
  570. width: 0%;
  571. background: var(--accent-green);
  572. transition: width 0.8s ease;
  573. border-radius: 4px;
  574. }
  575. .score-text {
  576. margin-top: 8px;
  577. font-size: 15px;
  578. font-weight: 600;
  579. }
  580. @media (max-width: 600px) {
  581. .app-title {
  582. font-size: 28px;
  583. }
  584. .tab-segment button {
  585. font-size: 12px;
  586. padding: 8px 6px;
  587. }
  588. }