:root{--font-display: "Noto Serif TC", "Iowan Old Style", serif;--font-body: "Noto Sans TC", "Segoe UI", sans-serif;--bg-base: #f6f3ea;--bg-tint: #fffaf2;--surface: rgba(255, 252, 245, .84);--surface-strong: #fffdf8;--surface-soft: #f4ede1;--text-primary: #18323d;--text-secondary: #5a7480;--text-muted: #78909a;--line: rgba(24, 50, 61, .1);--shadow: 0 24px 80px rgba(72, 57, 31, .12);--accent: #dd7a29;--accent-strong: #b45618;--accent-soft: rgba(221, 122, 41, .14);--success: #2f8f6b;--success-soft: rgba(47, 143, 107, .12);--error: #ba4b4b;--error-soft: rgba(186, 75, 75, .12);--chip: rgba(255, 255, 255, .86)}*{box-sizing:border-box}html{color-scheme:light}body{margin:0;min-width:320px;min-height:100vh;font-family:var(--font-body);color:var(--text-primary);background:radial-gradient(circle at top left,rgba(231,168,86,.22),transparent 28%),radial-gradient(circle at top right,rgba(109,179,188,.18),transparent 24%),linear-gradient(180deg,var(--bg-tint) 0%,var(--bg-base) 100%)}button,input,textarea,select{font:inherit}button{cursor:pointer}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid rgba(221,122,41,.28);outline-offset:2px}#root{min-height:100vh}.app-shell{position:relative;min-height:100vh;overflow:hidden;padding:20px}.theme-male_default{--bg-base: #eef2f4;--bg-tint: #f8fafb;--surface: rgba(251, 253, 254, .86);--surface-strong: #fcfeff;--surface-soft: #e6edf1;--text-primary: #132630;--text-secondary: #56707d;--line: rgba(19, 38, 48, .11);--shadow: 0 24px 80px rgba(19, 38, 48, .12);--accent: #1d8d9f;--accent-strong: #106776;--accent-soft: rgba(29, 141, 159, .14)}.ambient-orb{position:absolute;width:280px;height:280px;border-radius:999px;filter:blur(28px);opacity:.55;pointer-events:none}.ambient-orb-left{top:-120px;left:-80px;background:#dd7a292e}.ambient-orb-right{right:-60px;top:120px;background:#1d8d9f26}.app-frame{position:relative;width:min(100%,1100px);margin:0 auto;padding:18px;border:1px solid var(--line);border-radius:32px;background:var(--surface);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.app-frame-profile{-webkit-backdrop-filter:none;backdrop-filter:none}.landing-frame{display:grid;gap:24px}.landing-topbar h1{max-width:12ch}.landing-hero{display:grid;grid-template-columns:1.25fr .95fr;gap:18px}.landing-card{padding:24px;border:1px solid var(--line);border-radius:24px;background:var(--surface-strong)}.landing-card-primary{background:linear-gradient(135deg,#fffffff2,#fff7e9d6),var(--surface-strong)}.landing-card h2,.auth-state-card h1{margin:0;font-family:var(--font-display);letter-spacing:-.02em}.landing-card h3{margin:0 0 12px}.landing-copy{margin:14px 0 0;color:var(--text-secondary);line-height:1.7}.landing-actions{margin-top:18px}.auth-login-button{min-width:100%}.auth-state-screen{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-state-card{width:min(100%,560px);padding:28px;border:1px solid var(--line);border-radius:28px;background:var(--surface);box-shadow:var(--shadow)}.auth-state-card p:last-child{margin-bottom:0;color:var(--text-secondary);line-height:1.6}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.topbar-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:12px;align-items:center}.user-badge{display:grid;gap:2px;min-height:44px;padding:10px 14px;border-radius:18px;background:var(--surface-strong);border:1px solid var(--line)}.user-badge strong{font-size:.95rem}.user-badge span{color:var(--text-secondary);font-size:.78rem}.topbar h1,.spotlight-card h2,.section-heading h2,.panel-card h3,.history-card h3,.candidate-card h3{margin:0;font-family:var(--font-display);letter-spacing:-.02em}.topbar h1{font-size:clamp(2rem,5vw,3.4rem);line-height:.98;max-width:10ch}.eyebrow,.section-kicker,.panel-kicker,.spotlight-label,.confidence-label,.history-date{margin:0 0 10px;font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-strong)}.backend-badge,.portion-pill{display:inline-flex;align-items:center;min-height:44px;padding:0 14px;border-radius:999px;background:var(--surface-strong);border:1px solid var(--line);color:var(--text-secondary);font-size:.92rem}.spotlight-card,.panel-card,.metric-card,.candidate-card,.history-card,.summary-card,.choice-card,.theme-swatch{border:1px solid var(--line);background:var(--surface-strong);border-radius:24px}.spotlight-card{display:grid;grid-template-columns:1.15fr 1fr;gap:18px;margin-top:20px;padding:22px;background:linear-gradient(135deg,#fffffff0,#fff8ecd1),var(--surface-strong)}.spotlight-copy{margin:0;align-self:end;color:var(--text-secondary);line-height:1.6}.tab-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}.tab-chip,.primary-button,.secondary-button,.ghost-button{min-height:48px;padding:0 16px;border-radius:16px;border:1px solid transparent;transition:transform .18s ease,background-color .18s ease,border-color .18s ease,box-shadow .18s ease}.tab-chip{background:var(--chip);color:var(--text-secondary)}.tab-chip.is-active{background:var(--accent-soft);color:var(--accent-strong);border-color:#dd7a292e}.primary-button{background:var(--accent);color:#fff}.secondary-button{background:var(--surface-soft);color:var(--text-primary);border-color:var(--line)}.ghost-button{background:transparent;border-color:var(--line);color:var(--text-secondary)}.primary-button.auth-login-button{justify-content:center}.tab-chip:hover,.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.history-card:hover,.choice-card:hover,.theme-swatch:hover{transform:translateY(-1px)}.primary-button:disabled,.secondary-button:disabled{cursor:not-allowed;opacity:.55;transform:none}.content-stack{display:grid;gap:16px;margin-top:18px}.section-heading,.candidate-head,.footer-actions,.result-row,.history-card,.summary-card{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-heading{align-items:flex-end}.status-banner,.empty-panel{min-height:52px;margin:0;padding:14px 16px;border-radius:18px;border:1px solid var(--line);color:var(--text-secondary);background:var(--surface-strong)}.status-banner.is-error{color:var(--error);background:var(--error-soft);border-color:#ba4b4b29}.status-banner.is-success{color:var(--success);background:var(--success-soft);border-color:#2f8f6b24}.status-banner.is-info{color:var(--text-primary);background:#c7e1ff73;border-color:#5b8ed633}.inline-disclaimer-note{margin:4px 0 2px;padding:9px 11px;border:1px solid var(--line);border-radius:12px;color:var(--text-secondary);background:var(--surface-soft);font-size:.9rem;line-height:1.6;overflow-wrap:break-word}.recommendation-panel .inline-disclaimer-note+.target-grid,.recommendation-panel .inline-disclaimer-note+.result-list{margin-top:4px}.consent-card{display:grid;gap:16px}.consent-intro-card{background:linear-gradient(135deg,#fffffffa,#fff8eceb),var(--surface-strong)}.consent-intro-card p:last-child{max-width:58ch;line-height:1.7}.consent-accordion-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0;border:0;background:transparent;color:inherit;text-align:left}.consent-accordion-icon{min-height:40px;display:inline-flex;align-items:center;padding:0 14px;border-radius:999px;background:var(--surface-soft);color:var(--accent-strong);font-size:.88rem;font-weight:700}.consent-summary{margin:0;color:var(--text-secondary);line-height:1.7;max-width:62ch}.consent-copy-stack{display:grid;gap:12px;padding-top:8px;border-top:1px solid var(--line)}.consent-copy-stack p{margin:0;color:var(--text-secondary);line-height:1.75}.consent-version{color:var(--text-muted);font-size:.88rem}.consent-checkbox-row{display:flex;align-items:flex-start;gap:12px;min-height:48px;padding:14px 16px;border-radius:18px;background:var(--surface-soft);color:var(--text-primary);line-height:1.6;overflow-wrap:anywhere}.consent-checkbox-row input{min-height:auto;width:20px;height:20px;margin:2px 0 0;accent-color:var(--accent)}.consent-card.is-expanded{box-shadow:inset 0 0 0 1px #dd7a2914}.consent-card.has-error{border-color:#ba4b4b47}.consent-card.has-error .consent-checkbox-row{background:var(--error-soft)}.consent-inline-error{margin:-6px 0 0;color:var(--error);font-size:.9rem;line-height:1.55}.consent-footer-actions{display:grid;gap:12px;padding:6px 2px 0}.consent-footer-actions .primary-button{width:100%}.legal-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:28px;padding-top:18px;border-top:1px solid var(--line)}.legal-footer-copy{margin:0;color:var(--text-secondary);line-height:1.7;max-width:46ch}.legal-link-list{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:8px}.legal-link-button{min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border:0;border-radius:999px;background:transparent;color:var(--accent-strong);font:inherit;font-size:.92rem;font-weight:700;text-decoration:underline;text-underline-offset:4px;cursor:pointer}.legal-link-button:hover,.legal-link-button:focus-visible{background:var(--surface-soft);outline:none}.legal-dialog-backdrop{position:fixed;inset:0;z-index:40;display:grid;place-items:center;padding:18px;background:#362b2357;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:legal-backdrop-fade .16s ease-out}.legal-dialog{width:min(620px,100%);max-height:min(760px,calc(100dvh - 36px));display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;border-radius:24px;border:1px solid var(--line);background:var(--surface-strong);box-shadow:var(--shadow);animation:legal-dialog-enter .18s ease-out}.legal-dialog-header{position:sticky;top:0;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 20px 14px;border-bottom:1px solid var(--line);background:var(--surface-strong)}.legal-dialog-header h3{margin:0}.legal-dialog-close{min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 14px;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);color:var(--accent-strong);font:inherit;font-size:.9rem;font-weight:700;cursor:pointer}.legal-dialog-body{display:grid;gap:16px;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:18px 20px 20px}@keyframes legal-backdrop-fade{0%{opacity:0}to{opacity:1}}@keyframes legal-dialog-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.legal-dialog-backdrop,.legal-dialog{animation:none}}.panel-grid,.metric-grid,.field-grid,.target-grid,.choice-grid{display:grid;gap:14px}.panel-grid{grid-template-columns:repeat(12,minmax(0,1fr))}.panel-grid>*{grid-column:span 12}.panel-card,.candidate-card{padding:20px}.quick-actions,.result-list,.candidate-stack,.history-stack{display:grid;gap:12px}.compact-list{margin:0;padding-left:20px;color:var(--text-secondary);line-height:1.7}.upload-dropzone{display:grid;gap:12px;padding:18px;border-radius:18px;border:1px dashed rgba(221,122,41,.35);background:linear-gradient(135deg,#dd7a2914,#1d8d9f0d);color:var(--text-secondary)}.upload-dropzone input{min-height:44px}.field-grid,.field-grid-wide{grid-template-columns:repeat(2,minmax(0,1fr))}.field-grid label,.profile-form label{display:grid;gap:8px;font-size:.94rem;color:var(--text-secondary)}input{min-height:48px;padding:0 14px;border-radius:14px;border:1px solid rgba(24,50,61,.14);background:#fff;color:var(--text-primary)}textarea{min-height:96px;padding:12px 14px;border-radius:14px;border:1px solid rgba(24,50,61,.14);background:#fff;color:var(--text-primary);resize:vertical}select{min-height:48px;padding:0 14px;border-radius:14px;border:1px solid rgba(24,50,61,.14);background:#fff;color:var(--text-primary)}.choice-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.choice-grid.two-columns{grid-template-columns:repeat(2,minmax(0,1fr))}.choice-card,.theme-swatch{display:grid;gap:8px;padding:16px;text-align:left;color:var(--text-secondary)}.choice-card.is-active,.theme-swatch.is-active{border-color:#dd7a2959;background:linear-gradient(180deg,#fff,#fff4e8f2)}.theme-sharp.is-active{border-color:#1d8d9f59;background:linear-gradient(180deg,#fff,#e9f7f9f2)}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.metric-card{display:grid;gap:6px;padding:18px}.metric-card span,.summary-card span,.target-grid span{color:var(--text-muted);font-size:.88rem}.metric-card strong,.summary-card strong,.target-grid strong{font-size:1.35rem;font-family:var(--font-display)}.target-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:14px}.target-grid>div,.summary-card{padding:14px 16px;border-radius:18px;background:var(--surface-soft)}.result-row{padding:14px 0;border-top:1px solid var(--line)}.result-row:first-child{border-top:0;padding-top:0}.result-row strong,.candidate-card h3,.history-card h3,.panel-card h3{font-size:1.08rem}.candidate-card{display:grid;gap:16px}.candidate-card-manual{border-color:#1d8d9f38;background:linear-gradient(180deg,#fff,#e9f7f9d1)}.candidate-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.candidate-kind-label{margin:0;color:var(--text-muted);font-size:.82rem;letter-spacing:.04em}.candidate-edit-grid{grid-template-columns:minmax(0,2fr) minmax(120px,1fr) minmax(110px,.9fr)}.candidate-remove-button{min-height:44px;padding:0 14px;border-radius:999px;border:1px solid rgba(24,50,61,.12);background:#ffffffeb;color:var(--text-secondary)}.candidate-support-row{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.candidate-support-copy{margin:0;font-size:.88rem;color:var(--text-secondary)}.candidate-support-copy-muted{color:var(--text-muted)}.add-food-button{width:100%}.reestimate-panel{display:grid;gap:14px}.reestimate-label{display:grid;gap:8px;color:var(--text-secondary)}.reestimate-suggestion-row{display:flex;justify-content:space-between;gap:12px;align-items:center}.empty-panel-card{display:grid;gap:14px}.result-row p,.history-card p,.summary-card p,.panel-card p,.candidate-card p{margin:4px 0 0;color:var(--text-secondary);line-height:1.55}.history-card{width:100%;padding:18px 20px;text-align:left;background:var(--surface-strong);border:1px solid var(--line)}.history-date{margin-bottom:6px}.helper-copy{color:var(--text-secondary);line-height:1.6;max-width:34ch}.profile-layout>.profile-form{grid-column:span 8}.profile-layout>.side-summary{grid-column:span 4}@media(max-width:1024px){.landing-hero{grid-template-columns:1fr}.choice-grid,.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.profile-layout>.profile-form,.profile-layout>.side-summary{grid-column:span 12}}@media(max-width:720px){.app-shell{padding:12px}.app-frame{padding:14px;border-radius:26px}.content-stack{gap:12px;margin-top:14px}.panel-grid{gap:12px}.panel-card{padding:16px;border-radius:20px}.status-banner,.empty-panel{min-height:46px;padding:11px 13px;border-radius:16px;line-height:1.55}.inline-disclaimer-note{padding:9px 10px;font-size:.88rem;line-height:1.58}.topbar,.spotlight-card,.footer-actions,.legal-footer,.candidate-head,.history-card{grid-template-columns:1fr;flex-direction:column;align-items:stretch}.topbar h1{max-width:none}.topbar-actions{width:100%;justify-content:flex-start}.tab-strip,.field-grid,.candidate-edit-grid,.field-grid-wide,.target-grid,.choice-grid,.choice-grid.two-columns,.metric-grid{grid-template-columns:1fr}.candidate-remove-button{width:100%}.candidate-support-row{flex-direction:column}.backend-badge,.tab-chip,.primary-button,.secondary-button,.ghost-button{width:100%;justify-content:center}.consent-accordion-toggle,.consent-checkbox-row{width:100%}.consent-card{gap:12px}.consent-intro-card p:last-child,.consent-summary{line-height:1.62}.consent-accordion-toggle{gap:10px}.consent-accordion-toggle h3{font-size:1.02rem;line-height:1.28}.consent-accordion-icon{min-height:36px;padding:0 11px;font-size:.84rem}.consent-copy-stack{gap:9px;padding-top:7px}.consent-copy-stack p{line-height:1.68}.consent-version{font-size:.84rem}.consent-checkbox-row{min-height:48px;gap:10px;padding:12px 13px;border-radius:16px;line-height:1.52}.consent-checkbox-row input{width:19px;height:19px}.consent-inline-error{margin-top:-4px;font-size:.86rem;line-height:1.5}.consent-footer-actions{gap:10px;padding-top:2px}.consent-footer-actions .helper-copy{line-height:1.5}.legal-link-list{justify-content:flex-start}.legal-dialog-backdrop{align-items:end;padding:10px 10px max(10px,env(safe-area-inset-bottom));place-items:end center}.legal-dialog{width:100%;max-height:min(82dvh,720px);border-radius:22px 22px 18px 18px;animation-name:legal-sheet-enter}.legal-dialog-header{flex-direction:column;gap:12px;padding:18px 18px 14px}.legal-dialog-close{width:100%}.legal-dialog-body{padding:16px 18px max(22px,env(safe-area-inset-bottom))}}@keyframes legal-sheet-enter{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
