@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&family=Inter:wght@400;500;600&display=swap";:root{--paper: #fbf6ec;--paper-deep: #f4ecdb;--ink: #15202a;--ink-soft: #4a5763;--ink-mute: #8593a0;--line: #ead9b8;--line-soft: #f0e4cb;--teal: #1f5a5d;--teal-deep: #133e41;--teal-light: #cfe1dd;--teal-mist: #e6efeb;--coral: #e07a4f;--coral-deep: #b75a37;--sand: #ecc88b;--rose: #e8b8a8;--berry: #8a3d50;--water: #5fa9b3;--water-light: #b9dde2;--r-sm: 10px;--r-md: 16px;--r-lg: 24px;--r-xl: 32px;--shadow-sm: 0 1px 2px rgba(31, 26, 15, .04), 0 4px 14px rgba(31, 26, 15, .04);--shadow-md: 0 2px 4px rgba(31, 26, 15, .04), 0 14px 32px rgba(31, 26, 15, .07);--shadow-lg: 0 8px 24px rgba(31, 26, 15, .06), 0 30px 60px rgba(31, 26, 15, .1);--serif: "Fraunces", ui-serif, Georgia, "Iowan Old Style", serif;--sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0}body{min-height:100vh;font-family:var(--sans);color:var(--ink);background:radial-gradient(900px 500px at 8% -10%,rgba(232,184,168,.35),transparent 60%),radial-gradient(900px 500px at 100% 0%,rgba(207,225,221,.55),transparent 60%),radial-gradient(700px 400px at 50% 110%,rgba(236,200,139,.35),transparent 60%),var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.35;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 .25  0 0 0 0 .2  0 0 0 0 .15  0 0 0 .045 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");z-index:0}body>*{position:relative;z-index:1}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}a{color:var(--teal)}.muted{color:var(--ink-mute)}.hidden{display:none!important}.error{color:var(--berry);min-height:1.2em;margin:8px 0 0;font-size:13px}.primary{appearance:none;background:var(--ink);color:var(--paper);border:0;padding:12px 18px;border-radius:999px;font-weight:600;letter-spacing:.01em;box-shadow:0 1px #fff3 inset,var(--shadow-sm);transition:transform .15s ease,background .2s ease}.primary:hover{background:var(--teal-deep);transform:translateY(-1px)}.primary:active{transform:translateY(0)}.primary.small{padding:8px 14px;font-size:13px}.ghost{appearance:none;background:transparent;color:var(--ink);border:1px solid var(--line);padding:9px 14px;border-radius:999px;font-weight:500;transition:background .15s ease,border-color .15s ease}.ghost:hover{background:var(--paper-deep);border-color:var(--ink-mute)}.ghost.danger{color:var(--berry);border-color:#8a3d5059}.ghost.danger:hover{background:#8a3d5014}.chip{appearance:none;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:500;color:var(--ink-soft);transition:transform .15s ease,background .2s ease,border-color .2s ease;display:inline-flex;align-items:center;gap:6px}.chip:hover{background:var(--teal-mist);border-color:var(--teal);color:var(--teal-deep);transform:translateY(-1px)}.chip[data-quick=food]:hover{background:#fceee2;border-color:var(--coral);color:var(--coral-deep)}.auth-page{min-height:100vh;display:grid;place-items:center;padding:32px 16px}.auth-shell{width:100%;max-width:980px;display:grid;grid-template-columns:1.1fr 1fr;gap:0;background:var(--paper);border-radius:var(--r-xl);border:1px solid var(--line);box-shadow:var(--shadow-lg);overflow:hidden}.auth-art{position:relative;background:radial-gradient(ellipse at 30% 30%,var(--rose) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,var(--teal-light) 0%,transparent 55%),linear-gradient(135deg,var(--paper-deep),var(--paper));padding:40px 36px;display:flex;flex-direction:column;justify-content:space-between;min-height:520px}.auth-art .eyebrow{font-family:var(--serif);font-style:italic;font-size:14px;letter-spacing:.04em;color:var(--teal-deep)}.auth-art .headline{font-family:var(--serif);font-weight:600;font-size:clamp(34px,4.5vw,46px);line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin:16px 0 14px}.auth-art .headline em{font-style:italic;color:var(--coral-deep);font-weight:500}.auth-art .lede{font-size:15px;line-height:1.6;color:var(--ink-soft);max-width:36ch}.auth-art .scene{flex:1;display:grid;place-items:center;padding:12px 0}.auth-art .credit{font-size:11px;color:var(--ink-mute);letter-spacing:.04em;text-transform:uppercase}.auth-form-wrap{padding:44px 36px;display:flex;flex-direction:column;justify-content:center}.auth-form-wrap .brand-row{display:flex;align-items:center;gap:8px;font-family:var(--serif);font-style:italic;font-size:18px;color:var(--teal-deep);margin-bottom:28px}.auth-form-wrap h2{font-family:var(--serif);font-weight:600;font-size:28px;letter-spacing:-.01em;margin:0 0 4px}.auth-form-wrap .sub{color:var(--ink-soft);margin:0 0 22px;font-size:14px}.tabs{display:flex;gap:4px;background:var(--paper-deep);padding:4px;border-radius:999px;margin-bottom:18px}.tab{flex:1;border:0;background:transparent;padding:9px 14px;border-radius:999px;color:var(--ink-mute);font-weight:500;font-size:14px;transition:background .2s ease,color .2s ease}.tab.active{background:var(--paper);color:var(--ink);box-shadow:0 1px 2px #0000000d}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-form label{display:flex;flex-direction:column;gap:6px;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute)}.auth-form input{padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:var(--paper);font-size:15px;transition:border-color .2s ease,box-shadow .2s ease}.auth-form input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px #1f5a5d1f}.auth-form .primary{margin-top:6px}.divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:var(--ink-mute);font-size:11px;letter-spacing:.12em;text-transform:uppercase}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 14px;background:var(--paper);border:1px solid var(--line);border-radius:12px;color:var(--ink);text-decoration:none;font-weight:500}.google-btn:hover{background:var(--paper-deep)}@media (max-width: 800px){.auth-shell{grid-template-columns:1fr}.auth-art{min-height:280px;padding:32px 28px}.auth-form-wrap{padding:32px 28px}}.app-page{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--line-soft);backdrop-filter:blur(6px);background:#fbf6ecd1;position:sticky;top:0;z-index:10}.brand{display:flex;align-items:center;gap:8px;font-family:var(--serif);font-style:italic;font-weight:500;font-size:19px;letter-spacing:-.01em;color:var(--teal-deep)}.brand .paw{width:22px;height:22px;display:inline-grid;place-items:center}.topbar-right{display:flex;align-items:center;gap:14px}.user-chip{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft);padding:6px 12px;border-radius:999px;background:var(--paper-deep);border:1px solid var(--line-soft)}.user-chip .avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--water));color:var(--paper);font-weight:600;font-size:11px;display:grid;place-items:center}.app-main{flex:1;width:100%;max-width:1180px;margin:0 auto;padding:28px;display:flex;flex-direction:column;gap:24px}.cat-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.cat-tab{appearance:none;display:inline-flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:8px 14px 8px 8px;cursor:pointer;transition:transform .15s ease,border-color .2s ease,box-shadow .2s ease}.cat-tab:hover{transform:translateY(-1px);border-color:var(--ink-mute)}.cat-tab.active{border-color:var(--teal);box-shadow:0 0 0 4px #1f5a5d1a;background:var(--teal-mist)}.cat-tab .face{width:30px;height:30px;border-radius:50%;background:var(--paper-deep);display:grid;place-items:center;flex-shrink:0;border:1px solid var(--line-soft)}.cat-tab.active .face{background:var(--paper);border-color:var(--teal-light)}.cat-tab .nm{font-weight:600;font-size:14px}.cat-tab .wt{color:var(--ink-mute);font-size:12px}.cat-add{appearance:none;background:transparent;border:1px dashed var(--line);color:var(--ink-soft);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:500;transition:background .15s ease,border-color .15s ease,color .15s ease}.cat-add:hover{background:var(--paper-deep);border-color:var(--teal);color:var(--teal-deep)}.empty-state{text-align:center;padding:80px 24px;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);box-shadow:var(--shadow-sm)}.empty-state h2{font-family:var(--serif);font-weight:600;font-size:32px;letter-spacing:-.01em;margin:16px 0 8px}.empty-state p{color:var(--ink-soft);margin:0 0 24px}.empty-state .empty-art{display:inline-block}.hero{display:grid;grid-template-columns:1.1fr 1fr;gap:24px;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:28px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(450px 300px at 8% 0%,rgba(232,184,168,.25),transparent 60%),radial-gradient(420px 320px at 100% 100%,rgba(207,225,221,.45),transparent 60%);pointer-events:none}.hero>*{position:relative}.hero-left{display:flex;flex-direction:column;gap:14px;min-width:0}.cat-name{font-family:var(--serif);font-weight:600;font-size:clamp(34px,4vw,46px);letter-spacing:-.02em;margin:0;line-height:1}.cat-name em{font-style:italic;color:var(--coral-deep);font-weight:500}.cat-meta{color:var(--ink-soft);margin:0;font-size:14px}.cat-actions{display:flex;gap:8px;margin-top:4px}.figures{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:auto;padding-top:16px}.figure{background:var(--paper-deep);border-radius:var(--r-md);padding:14px 16px;border:1px solid var(--line-soft)}.figure .label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute)}.figure .value{font-family:var(--serif);font-weight:600;font-size:30px;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1.1;display:block;margin-top:2px}.figure .unit{font-size:12px;color:var(--ink-mute)}.figure.target .value{color:var(--teal-deep)}.figure.today .value{color:var(--ink)}.figure.left .value{color:var(--coral-deep)}.figure.left.done .value{color:var(--teal)}.formula-note{font-size:11px;line-height:1.55;color:var(--ink-mute);margin:10px 0 0}.formula-note sup{font-size:9px}.hero-right{display:grid;place-items:center;position:relative;min-height:320px}.scene{position:relative;width:100%;max-width:360px;aspect-ratio:1 / 1;display:grid;place-items:center}.scene svg{width:100%;height:100%;overflow:visible}.scene .pct{position:absolute;bottom:6px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);font-family:var(--serif);font-weight:600;padding:4px 12px;border-radius:999px;font-size:13px;letter-spacing:.02em;box-shadow:var(--shadow-sm);font-variant-numeric:tabular-nums}.scene .pct.full{background:var(--teal)}@media (max-width: 820px){.hero{grid-template-columns:1fr}.hero-right{order:-1}.scene{max-width:280px}}.row-cards{display:grid;grid-template-columns:1.2fr 1fr;gap:24px}@media (max-width: 820px){.row-cards{grid-template-columns:1fr}}.card{background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-xl);padding:24px;box-shadow:var(--shadow-sm)}.card h3{font-family:var(--serif);font-weight:600;font-size:18px;margin:0 0 14px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.card h3 .ico{color:var(--teal)}.log-form{display:flex;flex-direction:column;gap:14px}.log-form .row{display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:10px}@media (max-width: 600px){.log-form .row{grid-template-columns:1fr}}.log-form label{display:flex;flex-direction:column;gap:6px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute)}.log-form input,.log-form select{padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:var(--paper);font-size:14px;transition:border-color .15s ease,box-shadow .2s ease}.log-form input:focus,.log-form select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px #1f5a5d1f}.quick{display:flex;align-items:center;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--ink-mute);letter-spacing:.04em;text-transform:uppercase}.quick .label{font-size:11px}.drop-ico{width:12px;height:12px;display:inline-block;fill:var(--water)}.history{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.day{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.day .mini{position:relative;width:100%;aspect-ratio:1 / 1;max-width:56px}.day .mini svg{width:100%;height:100%}.day .dow{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute)}.day .ml{font-family:var(--serif);font-weight:600;font-size:13px;font-variant-numeric:tabular-nums}.day.today .dow{color:var(--coral-deep);font-weight:600}.timeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.timeline li{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--paper-deep);border:1px solid var(--line-soft);border-radius:var(--r-md)}.timeline .src{display:inline-flex;align-items:center;gap:6px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:999px;background:var(--teal-mist);color:var(--teal-deep);font-weight:600}.timeline .src.food{background:#fceee2;color:var(--coral-deep)}.timeline .amt{font-family:var(--serif);font-weight:600;font-size:16px;font-variant-numeric:tabular-nums}.timeline .when{color:var(--ink-mute);font-size:12px;flex:1}.timeline .del{appearance:none;background:transparent;border:0;color:var(--ink-mute);font-size:18px;line-height:1;padding:0 4px;cursor:pointer;border-radius:6px}.timeline .del:hover{color:var(--berry);background:#8a3d5014}.timeline .empty{color:var(--ink-mute);padding:12px;text-align:center;font-style:italic;background:transparent;border:1px dashed var(--line)}.dialog{border:0;padding:0;width:min(560px,92vw);border-radius:var(--r-xl);background:var(--paper);box-shadow:var(--shadow-lg)}.dialog::backdrop{background:#15202a59;backdrop-filter:blur(4px)}.dialog form{padding:28px;display:flex;flex-direction:column;gap:14px}.dialog h3{font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:-.01em;margin:0 0 4px}.dialog label{display:flex;flex-direction:column;gap:6px;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute)}.dialog input,.dialog select{padding:11px 12px;border:1px solid var(--line);border-radius:12px;background:var(--paper);font-size:14px;transition:border-color .15s ease,box-shadow .2s ease}.dialog input:focus,.dialog select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px #1f5a5d1f}.dialog .row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (max-width: 600px){.dialog .row{grid-template-columns:1fr}}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.lang-toggle{display:inline-flex;background:var(--paper-deep);border:1px solid var(--line-soft);border-radius:999px;padding:3px;gap:2px}.lang-toggle button{appearance:none;background:transparent;border:0;padding:5px 11px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--ink-mute);cursor:pointer;transition:background .15s ease,color .15s ease}.lang-toggle button:hover{color:var(--ink)}.lang-toggle button.active{background:var(--paper);color:var(--ink);box-shadow:0 1px 2px #0000000d}.auth-page .lang-toggle:not(.inline){position:fixed;top:18px;right:18px;z-index:5}.acct-form{padding:28px;display:flex;flex-direction:column;gap:16px}.acct-form h3{font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:-.01em;margin:0}.acct-info{background:var(--paper-deep);border:1px solid var(--line-soft);border-radius:var(--r-md);padding:14px 16px;display:flex;flex-direction:column;gap:8px}.acct-row{display:flex;align-items:baseline;gap:12px;font-size:14px}.acct-row .lbl{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);width:100px;flex-shrink:0}.acct-row .val{font-weight:500}.acct-danger{border:1px solid rgba(138,61,80,.25);background:#8a3d500a;border-radius:var(--r-md);padding:16px;display:flex;flex-direction:column;gap:10px}.acct-danger h4{font-family:var(--serif);font-weight:600;font-size:16px;margin:0;color:var(--berry);letter-spacing:-.01em}.acct-danger p{font-size:13px;line-height:1.55;margin:0}.acct-danger .ghost.danger{align-self:flex-start}.primary.danger{background:var(--berry)}.primary.danger:hover{background:#6b2e3e}html[lang=zh-HK]{--serif: "Fraunces", "Noto Serif TC", "Source Han Serif TC", "Microsoft JhengHei", PMingLiU, ui-serif, Georgia, serif;--sans: "Inter", "Noto Sans TC", "PingFang HK", "Microsoft JhengHei", -apple-system, BlinkMacSystemFont, system-ui, sans-serif}html[lang=zh-HK] .auth-form label,html[lang=zh-HK] .log-form label,html[lang=zh-HK] .dialog label,html[lang=zh-HK] .figure .label,html[lang=zh-HK] .quick .label,html[lang=zh-HK] .timeline .src,html[lang=zh-HK] .day .dow{letter-spacing:.04em;text-transform:none}html[lang=zh-HK] .formula-note{line-height:1.7}.diet-section{margin-top:4px;padding:14px 14px 12px;border:1px solid var(--line-soft);border-radius:var(--r-md);background:var(--paper-deep);display:flex;flex-direction:column;gap:10px}.diet-section h4{font-family:var(--serif);font-weight:600;font-size:14px;letter-spacing:-.005em;margin:0;color:var(--teal-deep)}.muted.small{font-size:12px;line-height:1.5;margin:0}.diet-hint{font-size:12px;color:var(--teal-deep);background:var(--teal-mist);border-radius:8px;padding:8px 10px;display:none}.diet-hint.show{display:block}.wet-pct-label.dim{opacity:.35;pointer-events:none}.sub-figures{margin-top:10px;grid-template-columns:repeat(3,1fr);gap:10px}.sub-figures .figure{padding:10px 12px;background:var(--paper);border:1px solid var(--line-soft)}.sub-figures .figure .value{font-size:20px}.sub-figures .figure .label{font-size:10px;letter-spacing:.06em}.sub-figures .figure.auto-food .value{color:var(--coral-deep)}.sub-figures .figure.logged-drunk .value{color:var(--teal-deep)}.sub-figures .figure.logged-food .value{color:var(--coral-deep)}.tips-card{background:linear-gradient(180deg,var(--paper) 0%,var(--teal-mist) 200%)}.tips-list{list-style:none;padding:0;margin:12px 0 0;display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media (max-width: 700px){.tips-list{grid-template-columns:1fr}}.tips-list li{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--r-md);font-size:13.5px;line-height:1.55}.tips-list li .tip-ico{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--teal-mist);display:grid;place-items:center;color:var(--teal-deep);font-family:var(--serif);font-weight:600;font-size:14px}.tips-list li.priority .tip-ico{background:#fceee2;color:var(--coral-deep)}@keyframes shimmer{0%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.02);filter:brightness(1.06)}to{transform:scale(1);filter:brightness(1)}}.scene.celebrate .bowl-wrap{animation:shimmer 1.4s ease-out 1}@keyframes splash{0%{opacity:0;transform:translateY(-8px) scale(.6)}40%{opacity:1;transform:translateY(0) scale(1.05)}to{opacity:0;transform:translateY(2px) scale(1)}}.splash-fx{position:absolute;left:50%;top:28%;transform:translate(-50%);font-family:var(--serif);font-weight:600;color:var(--coral-deep);pointer-events:none;font-size:22px;animation:splash .8s ease-out 1}@keyframes wave-roll{0%{transform:translate(0)}to{transform:translate(-50%)}}.water-wave{animation:wave-roll 6s linear infinite}
