@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Lora:wght@400;500;600;700&display=swap";:root{--primary:#ee9042;--primary-dark:#d47a2a;--primary-light:#fff3e8;--secondary:#6bbfea;--blue-light:#e8f6fd;--tertiary:#f7d752;--yellow-light:#fff9e0;--quaternary:#7b8ec2;--error:#ff4d4f;--success:#5cb85c;--warning:#faad14;--border:#b48c6426;--border-hover:#b48c6440;--text-h1:28px;--text-h1-weight:700;--text-h2:20px;--text-h2-weight:700;--text-h3:16px;--text-h3-weight:600;--text-body:14px;--text-body-weight:400;--text-label:13px;--text-label-weight:600;--text-meta:12px;--text-meta-weight:400;--surface:#faf8f5;--surface-low:#f3f0eb;--surface-high:#ede9e4;--surface-white:#fff;--surface-dim:#d5d0c9;--paper-cream:#fff9f2;--paper-warm:#fff5eb;--paper-line:#b48c640a;--paper-dot:#b48c640f;--sidebar-width:240px;--sidebar-bg:#fff;--sidebar-active:#fff3e8;--sidebar-border:#b48c6414;--content-max-width:1400px;--text:#2c2f31;--text-secondary:#6b6058;--text-hint:#9e9589;--text-disabled:#c5bfb7;--outline:#c5bfb7;--shadow-card:0 2px 16px #b48c6412, 0 1px 3px #b48c640a;--shadow-float:0 12px 40px #b48c641f, 0 4px 12px #b48c640f;--shadow-lg:0 16px 48px #b48c6424;--shadow-elevated:0 24px 64px #b48c6429, 0 8px 20px #b48c6414;--card-journal:0 2px 12px #b48c640f, 0 1px 2px #b48c640a;--card-journal-hover:0 4px 20px #b48c641a, 0 2px 6px #b48c640f;--card-polaroid:0 4px 16px #b48c641f, 0 1px 4px #b48c640f;--card-px:28px;--gap-sm:8px;--gap-md:16px;--gap-lg:24px;--gap-xl:36px;--radius-xs:6px;--radius-sm:8px;--radius-md:12px;--radius:16px;--radius-lg:22px;--radius-xl:28px;--radius-pill:9999px;--font-display:"Plus Jakarta Sans", "PingFang SC", "Microsoft YaHei", sans-serif;--font-serif:"Lora", "Noto Serif SC", Georgia, serif;--font-body:"PingFang SC", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Microsoft YaHei", "Segoe UI", sans-serif;--transition:all .2s cubic-bezier(.25, .1, .25, 1);--transition-spring:all .3s cubic-bezier(.34, 1.3, .64, 1);--transition-page:all .4s cubic-bezier(.22, 1, .36, 1);--transition-gentle:all .3s cubic-bezier(.25, .46, .45, .94);--transition-spring-soft:all .35s cubic-bezier(.34, 1.3, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}svg{vertical-align:middle}body{font-family:var(--font-body);background:var(--surface);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.6}input,textarea,select,button{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none}button:focus-visible{outline-offset:2px;outline:2px solid #e8913c66}a{color:inherit;text-decoration:none}::selection{color:var(--text);background:#e8913c26}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#b48c641a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#b48c6433}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes gentlePulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes loadingSpin{to{transform:rotate(360deg)}}.app-layout{flex-direction:column;min-height:100vh;display:flex}.topbar{z-index:100;-webkit-backdrop-filter:blur(20px);background:#ffffffd1;border-bottom:1px solid #b48c640f;position:sticky;top:0}.topbar-inner{align-items:center;gap:40px;max-width:1280px;height:64px;margin:0 auto;padding:0 48px;display:flex}.topbar-brand{flex-shrink:0;align-items:center;gap:10px;display:flex}.topbar-video-wrap{border-radius:10px;flex-shrink:0;width:34px;height:34px;overflow:hidden}.topbar-video-wrap video{object-fit:cover;pointer-events:none;width:100%;height:100%;display:block}.topbar-brand-text{letter-spacing:-.03em;color:var(--primary-dark);font-size:22px;font-weight:800;line-height:1}.topbar-nav{align-items:center;gap:2px;display:flex}.topbar-item{color:var(--text-hint);cursor:pointer;transition:var(--transition);background:0 0;border-radius:999px;align-items:center;gap:8px;padding:8px 20px;font-size:14px;font-weight:500;display:flex}.topbar-item:hover{color:var(--text);background:#b48c640f}.topbar-item.active{background:var(--primary-light);color:#b06a20;font-weight:600}.topbar-right{align-items:center;gap:12px;margin-left:auto;display:flex}.topbar-avatar{background:linear-gradient(135deg, var(--primary-light), #ffe8d0);cursor:pointer;width:36px;height:36px;transition:var(--transition);border:2px solid #ee904214;border-radius:50%;justify-content:center;align-items:center;display:flex;overflow:hidden}.topbar-avatar:hover{border-color:#ee904233;box-shadow:0 2px 12px #ee90421f}.topbar-avatar img{object-fit:cover;width:100%;height:100%}.main-content{flex:1;width:100%;max-width:1280px;margin:0 auto;padding:40px 48px 72px;animation:.35s fadeInUp}.card{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:var(--card-px);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-float)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:56px 32px;display:flex}.empty-state-icon{color:var(--primary);margin-bottom:16px}.empty-state-text{color:var(--text-hint);margin:0;font-size:15px}.loading-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:80px 32px;display:flex}.loading-spinner{border:2.5px solid #e8913c1f;border-top-color:var(--primary);border-radius:50%;width:32px;height:32px;margin-bottom:16px;animation:.7s linear infinite loadingSpin}.loading-text{color:var(--text-hint);font-size:14px;animation:1.5s ease-in-out infinite gentlePulse}.btn{cursor:pointer;height:44px;transition:var(--transition);border-radius:12px;justify-content:center;align-items:center;gap:6px;padding:0 24px;font-size:14px;font-weight:600;display:inline-flex;position:relative}.btn:active{transform:scale(.97)}.btn-primary:hover{background:linear-gradient(145deg, var(--primary), var(--primary-dark));box-shadow:0 6px 20px #ee90424d}.btn-ghost{background:var(--surface-low);color:var(--text)}.btn-ghost:hover{background:var(--surface-high)}.btn-danger{color:var(--error);background:0 0;border:1px solid #e2555526}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input{background:var(--surface-low);width:100%;height:48px;transition:var(--transition);border:2px solid #0000;border-radius:12px;padding:0 16px;font-size:15px}.form-input:focus{background:var(--primary-light);border-color:#ee904226;box-shadow:0 0 0 4px #ee90420f}.form-textarea{background:var(--surface-low);width:100%;min-height:80px;transition:var(--transition);resize:vertical;border:2px solid #0000;border-radius:12px;padding:12px 16px;font-family:inherit;font-size:15px}.form-row{gap:12px;display:flex}.form-row>.form-field{flex:1}.tag{border-radius:999px;align-items:center;padding:3px 12px;font-size:12px;font-weight:600;display:inline-flex}.tag-default{background:var(--primary-light);color:var(--primary-dark)}.tag-health{background:var(--blue-light);color:#2e86ab}.home,.detail,.profile{animation:.35s fadeInUp}.ant-card{border-radius:var(--radius);box-shadow:var(--shadow-card);border:none;transition:box-shadow .2s}.ant-card:hover{box-shadow:var(--shadow-float)}.ant-card .ant-card-head{border-bottom:1px solid var(--surface-low);min-height:auto;padding:16px 24px 0;font-size:15px;font-weight:600}.ant-card .ant-card-head-title{padding:0 0 12px}.ant-card .ant-card-body{padding:20px 24px}.ant-btn-primary{border:none;font-weight:600;box-shadow:0 2px 8px #ee904233}.ant-btn-primary:hover{box-shadow:0 4px 14px #ee904247}.ant-btn-primary:active{transform:scale(.98)}.ant-btn-default{border-color:var(--surface-high);color:var(--text-secondary);font-weight:500}.ant-btn-default:hover{border-color:var(--primary);color:var(--primary)}.ant-input:focus,.ant-input-focused,.ant-input-affix-wrapper:focus,.ant-input-affix-wrapper-focused,.ant-input-number:focus,.ant-input-number-focused,.ant-picker:focus,.ant-picker-focused{border-color:#ee904266;box-shadow:0 0 0 3px #ee904214}.ant-modal .ant-modal-content{box-shadow:var(--shadow-elevated);border:none;border-radius:16px;outline:none;overflow:hidden}.ant-modal .ant-modal-header{border-bottom:1px solid var(--surface-low);padding:14px 24px 10px}.ant-modal .ant-modal-title{font-size:17px;font-weight:700}.ant-modal .ant-modal-body{padding:16px 24px}.ant-modal .ant-modal-footer{border-top:1px solid var(--surface-low);padding:14px 24px}.ant-modal .ant-modal-close{box-shadow:none;color:var(--text-disabled);border:none;outline:none;transition:color .15s}.ant-modal .ant-modal-close:hover{color:var(--text-secondary);background:var(--surface-low)}.ant-modal .ant-modal-close:focus,.ant-modal .ant-modal-close:focus-visible{box-shadow:none;border:none;outline:none}.ant-btn:focus,.ant-btn:focus-visible{box-shadow:none;outline:none}.ant-modal-wrap:focus,.ant-modal-wrap:focus-visible,.ant-modal-content:focus,.ant-modal-content:focus-visible{box-shadow:none;border:none;outline:none}.ant-tabs .ant-tabs-ink-bar{background:var(--primary)}.ant-tabs .ant-tabs-tab{color:var(--text-hint);font-weight:500}.ant-tabs .ant-tabs-tab:hover{color:var(--text-secondary)}.ant-tabs .ant-tabs-tab-active .ant-tabs-tab-btn{color:var(--primary);font-weight:600}.ant-tag{border:none;border-radius:999px;font-size:12px;font-weight:600}.ant-segmented{background:#f3f0eb;border-radius:10px;padding:3px}.ant-segmented .ant-segmented-item{border-radius:8px;transition:all .2s}.ant-segmented .ant-segmented-item-selected{color:var(--primary-dark);background:#fff;font-weight:600;box-shadow:0 1px 4px #b48c641a}.ant-segmented .ant-segmented-item:not(.ant-segmented-item-selected):hover{color:var(--text-secondary)}.ant-segmented .ant-segmented-thumb{background:#fff;border-radius:8px;box-shadow:0 1px 4px #b48c641a}.ant-form-item .ant-form-item-label>label{color:var(--text-secondary);font-size:13px;font-weight:500}.ant-statistic .ant-statistic-content-value{font-family:var(--font-display)}.ant-statistic .ant-statistic-title{color:var(--text-hint);font-size:12px}.ant-descriptions .ant-descriptions-item-label{color:#9e9589;font-weight:500}.ant-timeline .ant-timeline-item-head{border-color:var(--primary)}.ant-timeline .ant-timeline-item-head-custom{background:0 0}.ant-empty .ant-empty-description{color:var(--text-hint)}.ant-progress .ant-progress-bg{border-radius:3px}.ant-progress .ant-progress-inner{background:#f3f0eb}.ant-steps .ant-steps-item-finish .ant-steps-item-icon{border-color:var(--primary)}.ant-steps .ant-steps-item-finish .ant-steps-item-icon>.ant-steps-icon{color:var(--primary)}.ant-popconfirm .ant-popconfirm-buttons .ant-btn-primary{box-shadow:none}.ant-modal-confirm .ant-modal-confirm-title{font-size:17px;font-weight:700}.ant-modal-confirm .ant-modal-confirm-content{color:var(--text-secondary);font-size:14px}.ant-modal-confirm .ant-btn-default{border-color:var(--surface-high)}.ant-modal-confirm .ant-btn-primary:not(.ant-btn-dangerous){box-shadow:none}.ant-float-btn-primary{box-shadow:0 4px 16px #ee90424d}.ant-float-btn-primary:hover{box-shadow:0 6px 20px #ee904266}.ant-layout-header .ant-menu-horizontal{line-height:56px}.ant-layout-header .ant-menu-horizontal>.ant-menu-item,.ant-layout-header .ant-menu-horizontal>.ant-menu-item-selected{border-radius:8px;height:36px;margin:0 2px;padding:0 16px;line-height:36px;top:0}.ant-layout-header .ant-menu-horizontal>.ant-menu-item:after,.ant-layout-header .ant-menu-horizontal>.ant-menu-item-selected:after{display:none!important}.ant-layout-header .ant-menu-horizontal>.ant-menu-item-selected{background:var(--primary-light);color:var(--primary-dark);font-weight:600}.ant-layout-header .ant-menu-horizontal>.ant-menu-item:not(.ant-menu-item-selected){color:var(--text-hint)}.ant-layout-header .ant-menu-horizontal>.ant-menu-item:not(.ant-menu-item-selected):hover{color:var(--text);background:#b48c640f}.ant-badge .ant-badge-count{box-shadow:0 0 0 2px #fff}.ant-picker-dropdown .ant-picker-cell-selected .ant-picker-cell-inner{background:var(--primary)}.ant-picker-dropdown .ant-picker-today-btn,.ant-typography a,.ant-typography-link,.ant-btn-link{color:var(--primary)}.ant-typography a:hover,.ant-typography-link:hover,.ant-btn-link:hover{color:var(--primary-dark)}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pawGlow{0%,to{box-shadow:0 0 #ee904200}50%{box-shadow:0 0 24px 8px #ee90421f}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=900px){.journal-content{padding:24px 20px 60px}.journal-topbar{padding:0 20px}}.polaroid-card{box-shadow:var(--card-polaroid);cursor:pointer;background:#fff;border-radius:4px;padding:10px 10px 36px;transition:transform .3s,box-shadow .3s}.polaroid-img-wrap{background:var(--paper-cream);border-radius:2px;position:relative;overflow:hidden}.polaroid-placeholder{background:linear-gradient(135deg, var(--paper-cream), var(--paper-warm));animation:2s ease-in-out infinite gentlePulse;position:absolute;inset:0}.polaroid-img{object-fit:cover;opacity:0;width:100%;height:100%;transition:opacity .4s;display:block}.polaroid-img.loaded{opacity:1}.polaroid-caption{color:var(--text-hint);text-align:center;font-size:12px;font-family:var(--font-serif);letter-spacing:.03em;margin-top:10px}.chip-selector{flex-wrap:wrap;gap:8px;display:flex}.chip{border-radius:var(--radius-pill);border:1.5px solid var(--border);background:var(--surface-white);color:var(--text-secondary);cursor:pointer;transition:var(--transition);padding:4px 14px;font-family:inherit;font-size:13px}.chip:hover{border-color:var(--primary);color:var(--primary)}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.health-day{text-align:center;border-radius:var(--radius-sm);background:var(--surface-white);cursor:pointer;min-width:48px;transition:var(--transition);flex:1;padding:10px 6px}.health-day:hover{background:var(--paper-warm)}.health-day.has-events{background:#fff3e8}.health-day-label{color:var(--text-hint);margin-bottom:2px;font-size:11px}.health-day-date{color:var(--text);font-size:14px;font-weight:600;font-family:var(--font-serif)}.health-day-dots{justify-content:center;gap:3px;margin-top:4px;display:flex}.health-day-dot{background:var(--primary);border-radius:50%;width:5px;height:5px}.avatar-uploader{cursor:pointer;background:var(--paper-cream);border:2px dashed var(--border);width:100px;height:100px;transition:var(--transition);border-radius:16px;position:relative;overflow:hidden}.avatar-uploader:hover{border-color:var(--primary)}.avatar-uploader:hover .avatar-uploader-overlay{opacity:1}.avatar-uploader img{object-fit:cover;width:100%;height:100%;display:block}.avatar-uploader-placeholder{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.avatar-uploader-overlay{opacity:0;background:#00000059;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.avatar-preview-img{object-fit:contain;border-radius:8px;width:100%;max-height:300px}.media-grid-2,.media-grid-4{grid-template-columns:1fr 1fr}.circular-progress-label{color:var(--text-hint);text-align:center;margin-top:4px;font-size:11px}@keyframes loginFadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes loginLogoFloat{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-8px)rotate(3deg)}}@keyframes loginGlowPulse{0%,to{opacity:.08;transform:scale(1)}50%{opacity:.14;transform:scale(1.1)}}.login-page{background:var(--surface);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background-image:radial-gradient(circle, var(--paper-dot) 1px, transparent 1px);pointer-events:none;opacity:.6;background-size:28px 28px;position:fixed;inset:0}.login-bg-glow-1,.login-bg-glow-2{filter:blur(80px);pointer-events:none;border-radius:50%;position:fixed}.login-bg-glow-1{background:radial-gradient(circle,#ee904212 0%,#0000 70%);width:400px;height:400px;animation:6s ease-in-out infinite loginGlowPulse;top:-10%;right:-10%}.login-bg-glow-2{background:radial-gradient(circle,#6bbfea0f 0%,#0000 70%);width:300px;height:300px;bottom:5%;left:-5%}.login-center{z-index:1;flex-direction:column;align-items:center;width:100%;max-width:400px;padding:24px 24px 40px;display:flex;position:relative}.login-brand{text-align:center;margin-bottom:32px;animation:.7s cubic-bezier(.22,1,.36,1) both loginFadeInUp;position:relative}.login-logo-glow{filter:blur(30px);background:radial-gradient(circle,#ee90421a 0%,#0000 70%);border-radius:50%;animation:4s ease-in-out infinite loginGlowPulse;position:absolute;inset:-20px}.login-logo-box{background:linear-gradient(135deg,#f0a050 0%,#ee9042 100%);border-radius:24px;justify-content:center;align-items:center;width:88px;height:88px;margin:0 auto 18px;animation:5s ease-in-out infinite loginLogoFloat;display:flex;position:relative;box-shadow:0 8px 32px #ee904240}.login-title{color:var(--text);letter-spacing:-.02em;margin-bottom:6px;font-size:26px;font-weight:800}.login-subtitle{color:var(--text-hint);opacity:.7;font-size:14px;font-weight:500}.login-card{background:var(--surface-white);width:100%;box-shadow:var(--shadow-card);border-radius:20px;padding:28px 24px;animation:.7s cubic-bezier(.22,1,.36,1) .12s both loginFadeInUp}.login-tabs{background:var(--surface-low);border-radius:14px;margin-bottom:24px;padding:3px;display:flex}.login-tab{height:38px;color:var(--text-hint);cursor:pointer;background:0 0;border:none;border-radius:12px;flex:1;font-size:14px;font-weight:600;transition:all .3s cubic-bezier(.22,1,.36,1)}.login-tab:hover:not(.active){color:var(--text-secondary)}.login-tab.active{background:var(--surface-white);color:var(--primary);font-weight:700;box-shadow:0 2px 10px #ee90421a}.login-field{margin-bottom:18px;animation:.4s cubic-bezier(.22,1,.36,1) both loginFadeInUp}.login-field:nth-child(2){animation-delay:50ms}.login-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 8px 4px;font-size:11px;font-weight:700;display:block}.login-card .ant-input-filled,.login-card .ant-input-password .ant-input-filled,.login-card .ant-input-affix-wrapper-filled{background:var(--surface-low);border:2px solid #0000;border-radius:14px;height:44px;font-size:15px;transition:all .3s cubic-bezier(.22,1,.36,1)}.login-card .ant-input-filled:focus,.login-card .ant-input-filled:hover,.login-card .ant-input-affix-wrapper-filled:focus,.login-card .ant-input-affix-wrapper-filled:hover,.login-card .ant-input-affix-wrapper-focused{background:var(--primary-light);border-color:#ee90422e;box-shadow:0 4px 16px #ee904214}.login-card .ant-input::placeholder{color:var(--text-hint);opacity:.5}.login-code-btn.ant-btn{white-space:nowrap;border-radius:14px;flex-shrink:0;height:44px;font-weight:700}.login-submit.ant-btn{background:linear-gradient(135deg,#f0a050 0%,#ee9042 100%);border:none;border-radius:14px;height:44px;margin-top:6px;font-size:16px;font-weight:700;transition:all .25s cubic-bezier(.22,1,.36,1);box-shadow:0 4px 20px #ee904240}.login-submit.ant-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px #ee904259}.login-submit.ant-btn:active{transform:scale(.98);box-shadow:0 2px 12px #ee904233}.login-error{color:var(--error);margin:-6px 0 12px 4px;font-size:12px;animation:.25s loginFadeInUp}.login-mode-switch{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:13px}.login-divider.ant-divider{color:var(--text-disabled);letter-spacing:1px;margin:22px 0 16px;font-size:11px;font-weight:600}.login-divider.ant-divider:before,.login-divider.ant-divider:after{border-color:#b48c6414}.login-social{justify-content:center;gap:28px;display:flex}.login-social-item{cursor:pointer;flex-direction:column;align-items:center;gap:6px;transition:transform .15s;display:flex}.login-social-item:hover{transform:translateY(-2px)}.login-social-label{color:var(--text-hint);font-size:11px}.login-footer{color:var(--text-hint);text-align:center;margin-top:28px;font-size:12px}.login-footer a{color:var(--quaternary);font-weight:600}.login-footer a:hover{text-decoration:underline}.login-icp{text-align:center;color:var(--text-disabled);margin-top:10px;font-size:11px}.login-card input:-webkit-autofill{-webkit-box-shadow:0 0 0 40px var(--primary-light) inset;-webkit-text-fill-color:var(--text);transition:background-color 5000s ease-in-out}.login-card input:-webkit-autofill:hover{-webkit-box-shadow:0 0 0 40px var(--primary-light) inset;-webkit-text-fill-color:var(--text);transition:background-color 5000s ease-in-out}.login-card input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 40px var(--primary-light) inset;-webkit-text-fill-color:var(--text);transition:background-color 5000s ease-in-out}.doc-page{background:#fff;max-width:680px;min-height:100vh;margin:0 auto}.doc-nav{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;background:#fffffff2;border-bottom:1px solid #f3f0eb;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.doc-nav h1{color:#2c2f31;margin:0;font-size:17px;font-weight:700}.doc-back{color:#2c2f31;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:4px 0;font-size:14px;display:flex}.doc-back:hover{color:#ee9042}.doc-body{padding:24px 24px 60px}.doc-body h2{color:#2c2f31;margin:0 0 4px;font-size:18px;font-weight:700}.doc-date{color:#9e9589;margin-bottom:20px;font-size:12px}.doc-body h3{color:#2c2f31;margin:20px 0 8px;font-size:15px;font-weight:600}.doc-body p{color:#6b6058;margin:6px 0;font-size:14px;line-height:1.8}.doc-body ul{color:#6b6058;margin:6px 0 12px;padding-left:20px;font-size:14px;line-height:1.8}.doc-body strong{color:#2c2f31}.doc-body a{color:#ee9042}.sidebar{width:var(--sidebar-width);background:var(--surface-white);border-right:1px solid var(--sidebar-border);z-index:100;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar-header{border-bottom:1px solid var(--sidebar-border);padding:20px 20px 16px}.sidebar-logo{cursor:pointer;align-items:center;gap:10px;margin-bottom:14px;padding:4px 0;display:flex}.sidebar-logo-icon{width:28px;height:28px;color:var(--primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo-text{color:var(--primary-dark);letter-spacing:-.02em;font-size:18px;font-weight:800;font-family:var(--font-display)}.sidebar-cat-area{position:relative}.sidebar-cat{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);align-items:center;gap:10px;padding:8px 10px;display:flex}.sidebar-cat:hover{background:var(--surface-low)}.sidebar-cat-avatar{background:var(--primary-light);border:2px solid #ee90421f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;overflow:hidden}.sidebar-cat-avatar img{object-fit:cover;width:100%;height:100%}.sidebar-cat-info{flex:1;min-width:0}.sidebar-cat-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-cat-breed{color:var(--text-hint);font-size:11px}.sidebar-cat-chevron{color:var(--text-hint);transition:transform .2s}.sidebar-cat-area.open .sidebar-cat-chevron{transform:rotate(180deg)}.sidebar-cat-dropdown{background:var(--surface-white);border-radius:var(--radius-md);box-shadow:var(--shadow-elevated);border:1px solid var(--sidebar-border);z-index:200;padding:6px;animation:.15s ease-out scaleIn;position:absolute;top:calc(100% + 4px);left:0;right:0}.sidebar-cat-dropdown-item{cursor:pointer;transition:var(--transition);border-radius:8px;align-items:center;gap:10px;padding:8px 10px;display:flex}.sidebar-cat-dropdown-item:hover{background:var(--surface-low)}.sidebar-cat-dropdown-item.active{background:var(--primary-light)}.sidebar-cat-dropdown-item .sidebar-cat-avatar{width:28px;height:28px}.sidebar-cat-dropdown-item .sidebar-cat-name{font-size:13px}.sidebar-cat-dropdown-add{cursor:pointer;transition:var(--transition);color:var(--primary);background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;width:100%;padding:8px 10px;font-size:13px;font-weight:500;display:flex}.sidebar-cat-dropdown-add:hover{background:var(--primary-light)}.sidebar-nav{flex:1;padding:12px 12px 8px}.sidebar-divider{background:#b48c640f;height:1px;margin:8px 12px}.sidebar-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;display:flex;position:relative}.sidebar-item:hover{background:var(--surface-low);color:var(--text)}.sidebar-item.active{background:var(--primary-light);color:var(--primary-dark);font-weight:600}.sidebar-item.active:before{content:"";background:var(--primary);border-radius:0 2px 2px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-item-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:12px 12px 16px}.search-mask{z-index:1100;background:#00000059;justify-content:center;align-items:flex-start;padding-top:12vh;animation:.12s ease-out searchFadeIn;display:flex;position:fixed;inset:0}@keyframes searchFadeIn{0%{opacity:0}to{opacity:1}}.search-panel{background:var(--surface-white);border-radius:var(--radius-lg);width:560px;max-width:92vw;box-shadow:var(--shadow-elevated);animation:.18s ease-out searchSlideDown;overflow:hidden}@keyframes searchSlideDown{0%{opacity:0;transform:translateY(-12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.search-input-wrap{border-bottom:1px solid #b48c640f;align-items:center;gap:10px;padding:16px 20px;display:flex}.search-input-icon{color:var(--text-hint);flex-shrink:0}.search-input{height:28px;color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:16px}.search-input::placeholder{color:var(--text-disabled)}.search-kbd{color:var(--text-disabled);background:var(--surface-low);border-radius:5px;flex-shrink:0;padding:2px 7px;font-family:monospace;font-size:11px}.search-results{max-height:400px;padding:8px 0;overflow-y:auto}.search-group-label{color:var(--text-hint);text-transform:uppercase;letter-spacing:.05em;padding:10px 20px 4px;font-size:11px;font-weight:600}.search-item{cursor:pointer;align-items:center;gap:12px;padding:10px 20px;transition:background .1s;display:flex}.search-item:hover{background:#ee90420a}.search-item-avatar{background:var(--primary-light);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;overflow:hidden}.search-item-avatar img{object-fit:cover;width:100%;height:100%}.search-item-avatar span{color:var(--primary);font-size:14px;font-weight:700}.search-item-info{flex:1;min-width:0}.search-item-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.search-item-meta{color:var(--text-hint);margin-top:1px;font-size:12px}.search-item-amount{color:var(--primary);flex-shrink:0;font-size:14px;font-weight:600}.search-empty{text-align:center;color:var(--text-hint);padding:32px 20px;font-size:13px}.search-loading{text-align:center;color:var(--text-hint);padding:24px 20px;font-size:13px}.search-footer{color:var(--text-disabled);text-align:center;border-top:1px solid #b48c640f;padding:10px 20px;font-size:11px}.notif-bell{cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;padding:6px;display:flex;position:relative}.notif-bell:hover{background:#b48c640f}.notif-badge{background:var(--error);color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px}.notif-dropdown{background:var(--surface-white);border-radius:var(--radius);width:360px;max-height:480px;box-shadow:var(--shadow-elevated);z-index:200;animation:.15s ease-out scaleIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden}.notif-read-all{color:var(--primary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:5px;padding:2px 6px;font-size:12px;font-weight:500}.notif-read-all:hover{background:var(--primary-light)}.notif-list{max-height:380px;padding:4px 0;overflow-y:auto}.notif-item{cursor:pointer;gap:12px;padding:12px 18px;transition:background .1s;display:flex}.notif-item.unread:hover{background:#ee90420f}.notif-dot.read{background:var(--surface-dim)}.notif-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.notif-content{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:2px;font-size:12px;display:-webkit-box;overflow:hidden}.journal-layout{background:var(--surface);min-height:100vh;display:flex}.journal-main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-width:0;display:flex}.journal-topbar{z-index:50;-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--paper-line);background:#faf8f5d9;align-items:center;gap:12px;height:56px;padding:0 40px;display:flex;position:sticky;top:0}.journal-topbar-left{align-items:center;gap:10px;min-width:0;display:flex}.journal-topbar-icon{width:20px;height:20px;color:var(--primary);flex-shrink:0}.journal-topbar-title{color:var(--text);letter-spacing:-.01em;white-space:nowrap;font-size:16px;font-weight:700}.journal-topbar-date{color:var(--text-hint);font-size:12px;font-family:var(--font-serif);white-space:nowrap}.journal-topbar-dot{background:var(--text-hint);opacity:.4;border-radius:50%;flex-shrink:0;width:3px;height:3px}.journal-topbar-spacer{flex:1}.journal-topbar-actions{align-items:center;gap:4px;display:flex}.journal-topbar-btn{cursor:pointer;width:34px;height:34px;color:var(--text-hint);transition:var(--transition);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.journal-topbar-btn:hover{background:var(--surface-low);color:var(--text)}.journal-topbar-avatar{cursor:pointer;background:var(--primary-light);width:34px;height:34px;color:var(--primary);transition:var(--transition);border:2px solid #ee90421a;border-radius:50%;overflow:hidden}.journal-topbar-avatar:hover{border-color:#ee904240}.journal-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:32px 48px 80px;animation:.4s cubic-bezier(.22,1,.36,1) pageEnter;position:relative}.journal-content:before{content:"";top:56px;left:var(--sidebar-width);background-image:radial-gradient(circle, var(--paper-dot) 1px, transparent 1px);pointer-events:none;z-index:0;opacity:.3;background-size:24px 24px;position:fixed;bottom:0;right:0}.journal-content>*{z-index:1;position:relative}.cat-pill{border:1.5px solid var(--border);background:var(--surface-white);cursor:pointer;transition:var(--transition);color:var(--text-secondary);border-radius:999px;align-items:center;gap:5px;height:28px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:500;display:inline-flex}.cat-pill img{object-fit:cover;border-radius:50%;width:18px;height:18px}.cat-pill-letter{background:var(--primary-light);width:18px;height:18px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:inline-flex}.cat-pill:hover{border-color:var(--primary);color:var(--primary)}.cat-pill.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary-dark);font-weight:600}.notif-dropdown{background:var(--surface-white);border-radius:var(--radius);width:340px;box-shadow:var(--shadow-elevated);z-index:200;border:1px solid #b48c6414;position:absolute;top:calc(100% + 8px);right:-20px;overflow:hidden}.notif-header{border-bottom:1px solid var(--paper-line);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.notif-header-title{color:var(--text);font-size:14px;font-weight:600}.notif-read-all{color:var(--primary);cursor:pointer;background:0 0;border:none;font-size:12px;font-weight:500}.notif-read-all:hover{color:var(--primary-dark)}.notif-list{max-height:360px;overflow-y:auto}.notif-empty{text-align:center;color:var(--text-hint);padding:32px 16px;font-size:13px}.notif-item{cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--paper-line);align-items:flex-start;gap:10px;padding:12px 16px;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--surface-low)}.notif-item.unread{background:var(--paper-cream)}.notif-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.notif-dot.unread{background:var(--primary)}.notif-dot.read{background:var(--text-hint);opacity:.3}.notif-body{flex:1;min-width:0}.notif-title{color:var(--text);margin-bottom:2px;font-size:13px;font-weight:500}.notif-content{color:var(--text-hint);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.notif-time{color:var(--text-hint);margin-top:4px;font-size:11px}.journal-card{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);transition:var(--transition);padding:24px}.polaroid-card{background:var(--surface-white);border-radius:var(--radius-sm);box-shadow:var(--card-polaroid);transition:var(--transition-spring-soft);padding:12px 12px 40px;transform:rotate(-1deg)}.polaroid-card:nth-child(2n){transform:rotate(1deg)}.polaroid-card:hover{box-shadow:var(--shadow-float);transform:rotate(0)scale(1.02)}.polaroid-card img{aspect-ratio:1;object-fit:cover;border-radius:4px;width:100%;display:block}.polaroid-card-caption{text-align:center;color:var(--text-secondary);font-size:12px;font-family:var(--font-serif);margin-top:8px}.section-divider{align-items:center;gap:16px;margin:32px 0;display:flex}.section-divider-line{background:linear-gradient(90deg, transparent, var(--paper-dot), transparent);flex:1;height:1px}.section-divider-icon{width:32px;height:32px;color:var(--text-hint);opacity:.5}.empty-state-legacy{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.empty-state-legacy-icon{background:linear-gradient(135deg, var(--primary-light), var(--paper-cream));border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:20px;animation:3s ease-in-out infinite pawGlow;display:flex}.empty-state-legacy-title{color:var(--text);font-size:22px;font-weight:700;font-family:var(--font-display);margin-bottom:8px}.empty-state-legacy-desc{color:var(--text-hint);margin-bottom:24px;font-size:14px}.circular-progress{justify-content:center;align-items:center;display:inline-flex;position:relative}.circular-progress svg{transform:rotate(-90deg)}.circular-progress-text{text-align:center;position:absolute}.circular-progress-value{color:var(--text);font-size:24px;font-weight:700;font-family:var(--font-serif);line-height:1}.circular-progress-label{color:var(--text-hint);margin-top:2px;font-size:11px}.health-week-strip{gap:4px;padding:12px 0;display:flex;overflow-x:auto}.week-day{text-align:center;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);flex:0 0 48px;padding:8px 4px}.week-day:hover{background:var(--surface-low)}.week-day.active{background:var(--primary-light)}.week-day-name{color:var(--text-hint);font-size:11px}.week-day-num{color:var(--text);font-size:18px;font-weight:600;font-family:var(--font-serif)}.week-day-dots{justify-content:center;gap:3px;margin-top:4px;display:flex}.week-day-dot{border-radius:50%;width:5px;height:5px}.warm-input{border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--surface-white);height:44px;color:var(--text);transition:var(--transition);font-size:14px;font-family:var(--font-body);padding:0 16px}.warm-input:focus{border-color:var(--primary);background:var(--primary-light);outline:none;box-shadow:0 0 0 3px #ee90421a}.warm-textarea{border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--surface-white);color:var(--text);transition:var(--transition);font-size:14px;font-family:var(--font-body);resize:vertical;min-height:100px;padding:12px 16px}.warm-textarea:focus{border-color:var(--primary);background:var(--primary-light);outline:none;box-shadow:0 0 0 3px #ee90421a}.page-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.page-back-btn{font-size:var(--text-meta);color:var(--text-hint);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;display:inline-flex}.page-back-btn:hover{background:var(--surface-low);color:var(--text)}.page-title{font-size:var(--text-h2);font-weight:var(--text-h2-weight);color:var(--text);font-family:var(--font-body);margin:0}.chip{border-radius:var(--radius-pill);color:var(--text-hint);background:var(--surface-low);cursor:pointer;transition:var(--transition);border:none;padding:5px 16px;font-family:inherit;font-size:12px;font-weight:500}.chip:hover{color:var(--text-secondary);background:var(--surface-high)}.chip.active{background:var(--primary-light);color:var(--primary-dark);font-weight:600}.form-label{font-size:var(--text-label);font-weight:var(--text-label-weight);color:var(--text-secondary);margin-bottom:6px;display:block}.form-field{margin-bottom:14px}.form-row-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.empty-state{text-align:center;flex-direction:column;align-items:center;padding:80px 24px;animation:.6s cubic-bezier(.22,1,.36,1) both fadeInUp;display:flex}.empty-state-hero{margin-bottom:40px;position:relative}.empty-state-glow{background:radial-gradient(circle,#ee904226 0%,#0000 70%);border-radius:50%;animation:3s ease-in-out infinite gentlePulse;position:absolute;inset:-30px}.empty-state-ring{background:#fff;border:3px solid #ee90420f;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;animation:4s ease-in-out infinite float;display:flex;position:relative;box-shadow:0 0 0 6px #ee90420a,0 12px 40px #ee904229}.empty-state-title{color:var(--text);font-size:32px;font-weight:800;font-family:var(--font-display);margin-bottom:8px}.empty-state-desc{color:var(--text-secondary);margin-bottom:0;font-size:16px}.empty-state-btn{background:linear-gradient(135deg, #f0a050, var(--primary));color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;height:48px;margin-top:32px;padding:0 36px;font-family:inherit;font-size:16px;font-weight:700;transition:all .25s cubic-bezier(.22,1,.36,1);display:inline-flex;box-shadow:0 6px 24px #ee904240}.empty-state-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #ee904259}.empty-compact{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:56px 28px;display:flex}.empty-compact p{color:var(--text-hint);margin-top:12px;font-size:14px}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);border:none;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, #f0a050, var(--primary));color:#fff;box-shadow:0 2px 8px #ee904233}.btn-primary:hover{box-shadow:0 4px 14px #ee904247}.btn-ghost{color:var(--text-secondary);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#e8383a}.loading-state{color:var(--text-hint);justify-content:center;align-items:center;gap:12px;padding:80px;font-size:14px;display:flex}.loading-spinner{border:2px solid var(--surface-low);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.form-textarea{background:var(--surface-low);border-radius:var(--radius-md);width:100%;min-height:72px;transition:var(--transition);resize:vertical;border:1.5px solid #0000;padding:10px 14px;font-family:inherit;font-size:14px}.form-textarea:focus{background:var(--primary-light);border-color:#e8913c26}.weight-unit-toggle{background:var(--surface-low);border-radius:var(--radius-pill);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;flex-shrink:0;align-items:center;gap:2px;padding:5px 12px;transition:background .15s;display:flex}.weight-unit-toggle:hover{background:var(--surface-high)}.weight-unit-opt{color:var(--text-hint);font-size:13px;font-weight:600;transition:color .15s}.weight-unit-opt.active{color:var(--primary)}.weight-unit-sep{color:var(--text-disabled);margin:0 2px;font-size:11px}@media (width<=900px){.journal-content{padding:24px 20px 60px}.journal-topbar{padding:0 20px}}.tip-carousel{flex-direction:column;gap:12px;display:flex}.tip-carousel-card{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);padding:20px 24px}.tip-carousel-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.tip-carousel-category{border-radius:var(--radius-pill);color:#fff;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.tip-carousel-source{color:var(--text-hint);font-size:11px}.tip-carousel-content h4{color:var(--text);margin:0 0 8px;font-size:16px;font-weight:700}.tip-carousel-content p{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.7}.tip-carousel-controls{justify-content:center;align-items:center;gap:16px;display:flex}.tip-carousel-btn{border:1.5px solid var(--border);background:var(--surface-white);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;display:flex}.tip-carousel-btn:hover{border-color:var(--primary);color:var(--primary)}.tip-carousel-random{width:28px;height:28px}.tip-carousel-counter{color:var(--text-hint);font-size:13px;font-family:var(--font-serif);text-align:center;min-width:60px}.media-grid{gap:6px;display:grid}.media-grid-1{grid-template-columns:1fr}.media-grid-1 .media-grid-item{max-width:280px}.media-grid-1 .media-grid-img{aspect-ratio:4/3}.media-grid-2,.media-grid-4{grid-template-columns:1fr 1fr}.media-grid:not(.media-grid-1):not(.media-grid-2):not(.media-grid-4){grid-template-columns:1fr 1fr 1fr}.media-grid-item{cursor:pointer;border-radius:8px;transition:transform .2s;position:relative;overflow:hidden}.media-grid-item:hover{transform:scale(1.02)}.media-grid-img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.media-grid-play{background:#0003;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.media-grid-more{color:#fff;background:#0006;justify-content:center;align-items:center;font-size:24px;font-weight:700;display:flex;position:absolute;inset:0}.journal-card{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);padding:20px 24px;transition:box-shadow .3s}.journal-card:hover{box-shadow:0 4px 20px #b48c641f}.journal-card-header{border-bottom:1px dashed var(--paper-line);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;display:flex}.journal-card-title h3{color:var(--text);align-items:center;gap:8px;margin:0;font-size:16px;font-weight:700;display:flex}.journal-card-title h3:before{content:"";background:var(--primary);border-radius:2px;width:3px;height:16px;display:inline-block}.journal-card-extra{flex-shrink:0}.home-loading{flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:120px;display:flex}.home-loading-text{color:var(--text-hint);font-size:14px;animation:1.5s ease-in-out infinite gentlePulse}.home-empty{flex-direction:column;justify-content:center;align-items:center;padding:80px 24px;animation:.6s cubic-bezier(.22,1,.36,1) both fadeInUp;display:flex}.home-empty-hero{margin-bottom:40px;position:relative}.home-empty-glow{background:radial-gradient(circle,#ee904226 0%,#0000 70%);border-radius:50%;animation:3s ease-in-out infinite gentlePulse;position:absolute;inset:-30px}.home-empty-ring{background:#fff;border:3px solid #ee90420f;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;animation:4s ease-in-out infinite float;display:flex;position:relative;box-shadow:0 0 0 6px #ee90420a,0 12px 40px #ee904229}.home-empty-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.03em;margin-bottom:8px;font-size:32px;font-weight:800}.home-empty-desc{color:var(--text-secondary);margin-bottom:0;font-size:16px}.home-empty-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f0a050,#ee9042);border:none;border-radius:18px;align-items:center;gap:8px;height:48px;margin-top:32px;padding:0 36px;font-size:16px;font-weight:700;transition:all .25s cubic-bezier(.22,1,.36,1);display:flex;box-shadow:0 6px 24px #ee904240}.home-empty-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #ee904259}.home-empty-tip{background:var(--yellow-light);border-radius:14px;align-items:flex-start;gap:14px;width:100%;max-width:480px;margin-top:48px;padding:18px 22px;display:flex;box-shadow:0 2px 12px #f7d7521a}.home-empty-tip-icon{background:#f7d75240;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.home-empty-tip-label{color:#7a6520;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px;font-size:11px;font-weight:700}.home-empty-tip-text{color:var(--text-secondary);font-size:13px;line-height:1.7}.home-hero{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);cursor:pointer;margin-bottom:16px;padding:20px 24px;transition:box-shadow .3s}.home-hero:hover{box-shadow:0 4px 20px #b48c641f}.home-hero-inner{align-items:center;gap:16px;display:flex}.home-hero-avatar{width:72px;height:72px;color:var(--primary);background:linear-gradient(145deg,#fff3e8,#ffe4cc) 50%/cover;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;font-size:28px;font-weight:700;line-height:1;display:flex;overflow:hidden}.home-hero-info{flex:1;min-width:0}.home-hero-name{font-family:var(--font-display);color:var(--text);margin-bottom:2px;font-size:20px;font-weight:400}.home-hero-meta{color:var(--text-hint);font-size:12px}.home-hero-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.home-tag-weight{align-items:center;gap:3px;margin:0;font-size:11px;display:inline-flex}.home-tag-neutered{color:#ee9042;background:#fff3e8;border-color:#ffd6a8;margin:0;font-size:11px}.home-tag-birthday{color:#d4a017;background:#fff9e0;border-color:#f7d752;margin:0;font-size:11px}.home-tag-birthday.birthday-today{color:#e74c3c;background:#ffe8e8;border-color:#ffb3b3}.home-hero-remark{color:#9e9589;-webkit-line-clamp:1;-webkit-box-orient:vertical;margin-top:6px;font-size:11px;line-height:1.5;display:-webkit-box;overflow:hidden}.home-hero-stats{border-left:1px solid #f3f0eb;flex-shrink:0;gap:20px;padding-left:20px;display:flex}.home-hero-stat{text-align:center}.home-hero-stat-value{font-family:var(--font-serif);font-size:20px;font-weight:700;line-height:1}.home-hero-stat-value.expense{color:var(--primary)}.home-hero-stat-value.weight{color:#6bbfea}.home-hero-stat-value.photos{color:#6d97de}.home-hero-stat-label{color:var(--text-hint);margin-top:4px;font-size:10px}.home-switcher-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.home-cat-pills{gap:8px;display:flex}.home-cat-pill{background:var(--surface-white);box-shadow:var(--shadow-card);cursor:pointer;transition:var(--transition);color:var(--text);border:1.5px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:5px 14px 5px 5px;font-family:inherit;font-size:13px;font-weight:600;display:flex}.home-cat-pill img{object-fit:cover;border-radius:50%;width:24px;height:24px}.home-cat-pill:hover{box-shadow:var(--shadow-float)}.home-cat-pill.active{background:var(--primary-light);color:var(--primary-dark);border-color:#ee904240}.home-add-btn{border-radius:10px}.home-row-grid{grid-template-columns:1fr;gap:16px;margin-bottom:16px;display:grid}.home-timeline{padding-left:4px}.home-timeline-row{cursor:pointer;border-radius:10px;gap:14px;padding:8px 4px;transition:background .15s;display:flex}.home-timeline-row:hover{background:#b48c6408}.home-timeline-left{flex-direction:column;flex-shrink:0;align-items:center;padding-top:4px;display:flex}.home-timeline-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 0 3px #ee90421a}.home-timeline-line{background:#ee90421a;flex:1;width:1.5px;margin-top:4px}.home-timeline-row:last-child .home-timeline-line{display:none}.home-timeline-body{flex:1;min-width:0}.home-timeline-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.home-timeline-date{color:var(--text-hint);font-size:12px;font-weight:500}.home-timeline-tip-icon{border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.home-timeline-content{color:var(--text);font-size:14px;line-height:1.6}.home-timeline-media{margin-top:8px}.home-timeline-tags{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.home-timeline-tag{color:#ee9042;background:#fff3e8;border-color:#ffd6a8;margin:0;font-size:11px}@media (width<=900px){.home-hero-stats{gap:14px}.home-hero-stat-value{font-size:16px}}@media (width<=600px){.home-hero-inner{flex-direction:column;gap:12px}.home-hero-avatar{width:80px;height:80px}.home-hero-stats{border-top:1px solid #f3f0eb;border-left:none;justify-content:space-around;width:100%;padding-top:12px;padding-left:0}.home-switcher-row{flex-direction:column;align-items:stretch;gap:12px}.home-cat-pills{justify-content:center}}.detail{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.detail-loading{justify-content:center;padding:120px;display:flex}.detail-back{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:8px;align-items:center;gap:4px;margin-bottom:8px;padding:5px 10px 5px 4px;font-size:13px;display:inline-flex}.detail-back:hover{color:var(--primary);background:var(--primary-light)}.detail-header{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);align-items:center;gap:20px;margin-bottom:16px;padding:24px;display:flex}.detail-avatar{background:linear-gradient(145deg,#fff3e8,#ffe8d0) 50%/cover;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex;overflow:hidden}.detail-avatar-letter{color:var(--primary);font-size:26px;font-weight:700;line-height:1}.detail-info{flex:1;min-width:0}.detail-name{font-family:var(--font-display);color:var(--text);margin-bottom:4px;font-size:24px;font-weight:600}.detail-meta{color:var(--text-secondary);font-size:13px}.detail-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.detail-tag-weight{align-items:center;gap:3px;margin:0;font-size:11px;display:inline-flex}.detail-tag-neutered{color:#ee9042;background:#fff3e8;border-color:#ffd6a8;margin:0;font-size:11px}.detail-actions{flex-wrap:wrap;flex-shrink:0;gap:8px;display:flex}.detail-tabs{background:var(--surface-low);border-radius:12px;gap:4px;margin-bottom:20px;padding:4px;display:flex}.detail-tab{cursor:pointer;color:var(--text-hint);transition:var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:5px;padding:8px 18px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.detail-tab:hover{color:var(--text-secondary)}.detail-tab.active{background:var(--surface-white);color:var(--primary);font-weight:600;box-shadow:0 1px 4px #b48c6414}.detail-profile-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.detail-profile-row{flex-direction:column;gap:4px;display:flex}.detail-profile-label{color:var(--text-hint);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.detail-profile-value{color:var(--text);font-size:15px;font-weight:600}.detail-profile-remark{border-top:1px dashed var(--paper-line);flex-direction:column;gap:4px;margin-top:20px;padding-top:16px;display:flex}.detail-timeline-list{flex-direction:column;gap:16px;display:flex}.detail-timeline-item{gap:14px;padding:12px 8px;display:flex;position:relative}.detail-timeline-left{flex-direction:column;flex-shrink:0;align-items:center;padding-top:4px;display:flex}.detail-timeline-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;box-shadow:0 0 0 3px #ee90421a}.detail-timeline-line{background:#ee90421a;flex:1;width:1.5px;margin-top:4px}.detail-timeline-item:last-child .detail-timeline-line{display:none}.detail-timeline-header{align-items:center;gap:8px;margin-bottom:4px;display:flex}.detail-timeline-date{color:var(--text-hint);font-size:12px;font-weight:600}.detail-timeline-tip-icon{border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.detail-timeline-actions{gap:4px;margin-left:auto;display:flex}.detail-timeline-content{color:var(--text);font-size:14px;line-height:1.7}.detail-timeline-media{margin-top:8px}.detail-timeline-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.detail-timeline-tag{color:#ee9042;background:#fff3e8;border-color:#ffd6a8;margin:0;font-size:11px}.detail-weight-list{flex-direction:column;gap:4px;display:flex}.detail-weight-row{border-radius:8px;align-items:center;gap:12px;padding:10px 14px;transition:background .15s;display:flex}.detail-weight-row:hover{background:#5eaed40a}.detail-weight-date{font-variant-numeric:tabular-nums;width:100px;color:var(--text-secondary);font-size:13px;font-weight:600}.detail-weight-value{color:var(--text);flex:1;font-size:14px;font-weight:500}.detail-weight-diff{border-radius:999px;margin:0;padding:2px 8px;font-size:12px;font-weight:700}.detail-weight-diff.up{color:#d4a017;background:#fff9e0}.detail-weight-diff.down{color:#2e86ab;background:#e8f4f8}.detail-gallery{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;display:grid}.detail-gallery-item{aspect-ratio:1;border-radius:12px;transition:transform .2s;position:relative;overflow:hidden}.detail-gallery-item:hover{transform:scale(1.02)}.detail-gallery-item img{object-fit:cover;width:100%;height:100%;display:block}.detail-gallery-delete{color:#fff;cursor:pointer;opacity:0;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;transition:opacity .15s;display:flex;position:absolute;top:4px;right:4px}.detail-gallery-item:hover .detail-gallery-delete{opacity:1}.detail-gallery-delete:hover{background:var(--error)}@media (width<=768px){.detail-header{flex-direction:column;align-items:flex-start}.detail-actions{justify-content:flex-start;width:100%}.detail-gallery{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.cat-form{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.cat-form-loading{justify-content:center;padding:120px;display:flex}.cf-back-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:8px;align-items:center;gap:4px;margin-bottom:8px;padding:5px 10px 5px 4px;font-size:13px;display:inline-flex}.cf-back-btn:hover{color:var(--primary);background:var(--primary-light)}.cf-grid{grid-template-columns:220px 1fr;align-items:start;gap:20px;display:grid}.cf-avatar-card{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);flex-direction:column;align-items:center;padding:28px;display:flex;position:sticky;top:80px}.cf-avatar-circle{border:3px dashed var(--border);cursor:pointer;width:120px;height:120px;transition:var(--transition);background:var(--paper-cream);border-radius:50%;justify-content:center;align-items:center;display:flex;overflow:hidden}.cf-avatar-circle:hover{border-color:var(--primary)}.cf-avatar-circle.has-avatar{border-style:solid;border-color:var(--primary)}.cf-avatar-img{object-fit:cover;width:100%;height:100%}.cf-avatar-btn{color:#9e9589;margin-top:12px;font-size:13px}.cf-form{margin-top:4px}.cf-section-label{color:var(--text-hint);text-transform:uppercase;letter-spacing:1.5px;margin-top:16px;margin-bottom:12px;font-size:11px;font-weight:700}.cf-section-label:first-child{margin-top:0}.cf-row-2col{grid-template-columns:1fr 1fr;gap:16px;display:grid}.cf-chips{flex-wrap:wrap;gap:8px;display:flex}.cf-chip{border-radius:var(--radius-pill);border:1.5px solid var(--border);background:var(--surface-white);cursor:pointer;transition:var(--transition);-webkit-user-select:none;user-select:none;padding:6px 16px;font-size:13px}.cf-chip:hover{border-color:var(--primary)}.cf-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.cf-picker-trigger{border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);background:var(--surface-white);justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.cf-picker-trigger:hover{border-color:var(--primary)}.cf-picker-value{color:var(--text);font-size:14px}.cf-picker-placeholder{color:var(--text-hint);font-size:14px}.cf-actions{border-top:1px dashed var(--paper-line);justify-content:flex-end;gap:12px;margin-top:20px;padding-top:20px;display:flex}.cf-picker-grid{grid-template-columns:repeat(4,1fr);gap:8px;max-height:300px;display:grid;overflow-y:auto}.cf-picker-option{text-align:center;border:1.5px solid var(--border);cursor:pointer;transition:var(--transition);border-radius:8px;padding:8px 12px;font-size:13px}.cf-picker-option:hover{border-color:var(--primary)}.cf-picker-option.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary-dark);font-weight:600}.cf-custom-input{border-top:1px solid #f3f0eb;gap:8px;margin-top:16px;padding-top:12px;display:flex}.cf-date-picker,.cf-input-number{height:44px}@media (width<=768px){.cf-grid{grid-template-columns:1fr}.cf-avatar-card{position:static}.cf-row-2col{grid-template-columns:1fr}.cf-picker-grid{grid-template-columns:repeat(3,1fr)}}.profile-page{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.profile-grid{gap:var(--gap-lg);grid-template-columns:300px 1fr;align-items:start;display:grid}.profile-left{position:sticky;top:88px}.profile-card{text-align:center;flex-direction:column;align-items:center;padding:32px 24px;display:flex}.profile-card-name{color:var(--text);margin-bottom:4px;font-size:18px;font-weight:700}.profile-card-bio{color:var(--text-hint);margin-bottom:10px;font-size:12px;line-height:1.5}.profile-card-pills{flex-wrap:wrap;justify-content:center;gap:6px;margin-bottom:10px;display:flex}.profile-pill-gender{border-radius:999px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.profile-pill-gender.male{color:#4a9ec9;background:#e8f6fd}.profile-pill-gender.female{color:#d9637e;background:#fde8f0}.profile-pill-tag{color:var(--text-secondary);background:var(--surface-low);border-radius:999px;align-items:center;padding:2px 10px;font-size:11px;font-weight:500;display:inline-flex}.profile-pill-tag.profile-pill-orange{color:#ee9042;background:#fff3e8}.profile-card-email{color:var(--text-hint);margin-bottom:14px;font-size:11px}.profile-edit-btn{border-radius:var(--radius-md);width:100%;height:40px}.profile-stats-grid{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:14px;display:grid}.profile-stat{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);flex-direction:column;align-items:center;padding:16px 8px;display:flex}.profile-stat-value{font-size:28px;font-weight:700;font-family:var(--font-serif);line-height:1}.profile-stat-label{color:var(--text-hint);margin-top:4px;font-size:11px}.profile-right{flex-direction:column;gap:20px;display:flex}.profile-settings-card,.profile-support-card{padding:16px 0}.profile-settings-list{flex-direction:column;display:flex}.profile-setting-item{cursor:pointer;align-items:center;gap:14px;padding:12px 24px;transition:background .15s;display:flex}.profile-setting-item:hover{background:#b48c6408}.profile-setting-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.profile-setting-info{flex:1;min-width:0}.profile-setting-title{color:var(--text);font-size:14px;font-weight:500}.profile-setting-desc{color:var(--text-hint);margin-top:1px;font-size:12px}.profile-setting-chevron{color:var(--text-disabled);flex-shrink:0;transition:transform .15s}.profile-setting-item:hover .profile-setting-chevron{color:var(--text-hint);transform:translate(2px)}.profile-logout-btn{color:#ff4d4f;cursor:pointer;background:#ff4d4f0a;border:1.5px solid #ff4d4f26;border-radius:12px;width:100%;height:44px;font-family:inherit;font-size:14px;font-weight:600;transition:all .15s}.profile-logout-btn:hover{background:#ff4d4f14;border-color:#ff4d4f40}.profile-logout-btn:active{transform:scale(.98)}.expenses-page{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.expenses-loading{justify-content:center;padding:120px;display:flex}.expenses-empty{flex-direction:column;align-items:center;padding:80px 24px;animation:.6s cubic-bezier(.22,1,.36,1) both fadeInUp;display:flex}.expenses-empty-hero{margin-bottom:40px;position:relative}.expenses-empty-glow{background:radial-gradient(circle,#ee904226 0%,#0000 70%);border-radius:50%;animation:3s ease-in-out infinite gentlePulse;position:absolute;inset:-30px}.expenses-empty-ring{background:#fff;border:3px solid #ee90420f;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;animation:4s ease-in-out infinite float;display:flex;position:relative;box-shadow:0 0 0 6px #ee90420a,0 12px 40px #ee904229}.expenses-empty-title{font-family:var(--font-display);color:var(--text);margin-bottom:8px;font-size:32px;font-weight:800}.expenses-empty-desc{color:var(--text-secondary);margin-bottom:0;font-size:16px}.expenses-empty-btn{background:linear-gradient(135deg, #f0a050, var(--primary));color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;height:48px;margin-top:32px;padding:0 36px;font-size:16px;font-weight:700;transition:all .25s cubic-bezier(.22,1,.36,1);display:flex;box-shadow:0 6px 24px #ee904240}.expenses-empty-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #ee904259}.expenses-empty-state{animation:.4s pageEnter}.expenses-empty-inner{flex-direction:column;align-items:center;padding:40px 20px;display:flex}.expenses-empty-inner-title{color:var(--text);margin-bottom:6px;font-size:18px;font-weight:700}.expenses-empty-inner-desc{color:var(--text-hint);margin-bottom:20px;font-size:13px}.expenses-cat-switcher{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:16px;display:flex}.expenses-cat-pill{border:1.5px solid var(--border);background:var(--surface-white);cursor:pointer;transition:var(--transition);color:var(--text-secondary);border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:600;display:flex}.expenses-cat-pill img{object-fit:cover;border-radius:50%;width:20px;height:20px}.expenses-cat-pill:hover{border-color:var(--primary)}.expenses-cat-pill.active{background:var(--primary-light);color:var(--primary);border-color:#ee90424d}.expenses-summary-bar{margin-bottom:20px}.expenses-summary-row{align-items:center;gap:24px;display:flex}.expenses-summary-main{flex:1}.expenses-summary-label{color:var(--text-hint);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.expenses-summary-amount{font-family:var(--font-serif);color:var(--primary);align-items:center;gap:8px;font-size:32px;font-weight:700;display:flex}.expenses-summary-tag{margin:0;font-size:12px;font-weight:700}.expenses-summary-tag.up{color:#d4a017;background:#fff3e8;border-color:#f7d752}.expenses-summary-tag.down{color:#27ae60;background:#e8f8ee;border-color:#a8e6cf}.expenses-summary-divider{background:#f3f0eb;width:1px;height:40px}.expenses-summary-side{text-align:center;min-width:80px}.expenses-summary-side-value{font-family:var(--font-serif);color:var(--text);font-size:20px;font-weight:700}.expenses-summary-side-value.muted{color:var(--text-hint)}.expenses-summary-side-label{color:var(--text-hint);font-size:11px}.expenses-grid{gap:var(--gap-lg);grid-template-columns:280px 1fr;align-items:start;display:grid}.expenses-left{position:sticky;top:88px}.expenses-right{min-width:0}.expense-category-row{margin-bottom:16px}.expense-category-row:last-child{margin-bottom:0}.expense-category-header{justify-content:space-between;align-items:center;margin-bottom:6px;font-size:13px;display:flex}.expense-category-name{align-items:center;gap:8px;font-weight:500;display:flex}.expense-category-amount{color:var(--text-hint)}.expense-date-group{margin-bottom:20px}.expense-date-header{color:var(--text-secondary);justify-content:space-between;padding:8px 0;font-size:13px;font-weight:600;display:flex}.expense-date-total{color:var(--text-hint);font-weight:500}.expense-row{border-radius:10px;align-items:center;gap:12px;margin:0 -8px;padding:10px 8px;transition:background .12s;display:flex}.expense-row:hover{background:#ee904205}.expense-cat-dot{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.expense-row-body{flex:1;min-width:0}.expense-row-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.expense-row-meta{color:var(--text-hint);margin-top:1px;font-size:12px}.expense-row-amount{font-family:var(--font-serif);flex-shrink:0;font-size:15px;font-weight:700}.expense-delete-btn{opacity:0;color:var(--text-disabled);transition:opacity .12s}.expense-row:hover .expense-delete-btn{opacity:1}.expense-delete-btn:hover{color:var(--error)!important}.expenses-load-more{text-align:center;padding-top:12px}.expenses-fab{background:var(--primary);color:#fff;cursor:pointer;z-index:100;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:20px;transition:all .2s;display:flex;position:fixed;bottom:32px;right:32px;box-shadow:0 6px 24px #ee904259}.expenses-fab:hover{transform:scale(1.05);box-shadow:0 8px 32px #ee904273}.expenses-fab:active{transform:scale(.95)}.expense-category-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.expense-category-option{cursor:pointer;border:1.5px solid #0000;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;transition:all .15s;display:flex}.expense-category-icon{border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.expense-category-name{color:var(--text-secondary);font-size:11px}.expense-category-name.active{color:var(--primary);font-weight:600}.expense-amount-input{width:100%;font-size:24px}.expense-form-cats{flex-wrap:wrap;gap:8px;display:flex}.expense-form-cat-pill{border:1.5px solid var(--border);background:var(--surface-white);cursor:pointer;transition:var(--transition);color:var(--text-secondary);border-radius:999px;align-items:center;gap:6px;padding:5px 12px;font-family:inherit;font-size:13px;font-weight:500;display:flex}.expense-form-cat-pill img{object-fit:cover;border-radius:50%;width:20px;height:20px}.expense-form-cat-pill:hover{border-color:var(--primary)}.expense-form-cat-pill.active{background:var(--primary-light);color:var(--primary);border-color:#ee90424d}.expense-form-row-2col{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=900px){.expenses-grid{grid-template-columns:1fr}.expenses-left{position:static}.expenses-summary-row{flex-wrap:wrap;gap:16px}.expenses-summary-divider{display:none}.expense-category-grid{grid-template-columns:repeat(3,1fr)}}.ep-page{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.ep-page-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.ep-back-btn{font-size:var(--text-meta);color:var(--text-hint);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;display:inline-flex}.ep-back-btn:hover{background:var(--surface-low);color:var(--text)}.ep-page-title{font-size:var(--text-h2);font-weight:var(--text-h2-weight);color:var(--text);margin:0}.ep-grid{gap:var(--gap-lg);grid-template-columns:280px 1fr;align-items:start;display:grid}.ep-left{position:sticky;top:88px}.ep-avatar-card{flex-direction:column;align-items:center;padding:32px 24px;display:flex}.ep-avatar-wrap{flex-direction:column;align-items:center;margin-bottom:16px;display:flex}.ep-avatar-placeholder{cursor:pointer;width:120px;height:120px;transition:var(--transition);background:#fff3e8 50%/cover;border-radius:50%;justify-content:center;align-items:center;display:flex}.ep-avatar-placeholder:hover{opacity:.85}.ep-avatar-name{color:var(--text);margin-top:12px;font-size:16px;font-weight:600}.ep-change-btn{color:var(--text-hint);font-size:13px}.ep-change-btn:hover{color:var(--primary)}.ep-right{padding:24px}.ep-section-title{color:var(--text-hint);border-bottom:1px solid var(--paper-line);margin-bottom:16px;padding-bottom:8px;font-size:13px;font-weight:600}.ep-field{margin-bottom:16px}.ep-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.ep-chips{gap:8px;display:flex}.ep-chip{color:var(--text-secondary);background:var(--surface);cursor:pointer;transition:var(--transition);border:1.5px solid #0000;border-radius:999px;padding:6px 16px;font-size:13px;font-weight:500}.ep-chip:hover{background:var(--surface-low)}.ep-chip.active{color:var(--primary);background:var(--primary-light);border-color:var(--primary)}.ep-row-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.ep-actions{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}.ec-page{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.ec-page-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.ec-back-btn{font-size:var(--text-meta);color:var(--text-hint);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;display:inline-flex}.ec-back-btn:hover{background:var(--surface-low);color:var(--text)}.ec-page-title{font-size:var(--text-h2);font-weight:var(--text-h2-weight);color:var(--text);margin:0}.ec-list{flex-direction:column;display:flex}.ec-list-item{border-bottom:1px solid var(--paper-line);justify-content:space-between;align-items:center;gap:12px;padding:12px 0;display:flex}.ec-list-item:last-child{border-bottom:none}.ec-item-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.ec-item-name{color:var(--text);flex:1;min-width:0;font-size:14px;font-weight:500}.ec-system-tag{color:var(--text-hint);background:var(--surface-low);border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.ec-delete-btn{cursor:pointer;color:var(--error);transition:var(--transition);background:0 0;border:none;border-radius:6px;align-items:center;padding:5px;display:flex}.ec-delete-btn:hover{background:#ff4d4f0f}.ec-add-btn{border-radius:var(--radius-md);height:40px;margin-top:16px}.ec-form-label{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:600}.ec-group-label{color:var(--text-hint);margin-bottom:6px;font-size:11px;font-weight:600}.ec-icon-option{background:var(--surface);cursor:pointer;width:36px;height:36px;transition:var(--transition);border:1.5px solid #0000;border-radius:9px;justify-content:center;align-items:center;display:flex}.ec-icon-option:hover{background:var(--surface-low)}.ec-icon-option.active{background:var(--primary-light)}.ec-color-row{flex-wrap:wrap;gap:8px;display:flex}.ec-color-dot{cursor:pointer;width:28px;height:28px;transition:var(--transition);border:2.5px solid #0000;border-radius:50%}.ec-color-dot:hover{transform:scale(1.12)}.ec-preview{background:var(--surface);border-radius:11px;align-items:center;gap:10px;padding:12px 14px;display:flex}.ec-preview-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.ec-preview-name{color:var(--text);font-size:14px;font-weight:600}.ai-chat-mask{z-index:1100;background:#00000040;justify-content:flex-end;display:flex;position:fixed;inset:0}.ai-chat-panel{background:#fff;width:720px;max-width:100vw;height:100vh;animation:.25s ease-out aiSlideIn;display:flex;box-shadow:-8px 0 40px #b48c641f}@keyframes aiSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.ai-sidebar{background:#faf8f5;border-right:1px solid #f3f0eb;flex-direction:column;flex-shrink:0;width:220px;display:flex}.ai-sidebar-header{border-bottom:1px solid #f3f0eb;justify-content:space-between;align-items:center;padding:16px;display:flex}.ai-sidebar-title{color:#2d2926;font-size:14px;font-weight:700}.ai-sidebar-list{flex:1;padding:8px;overflow-y:auto}.ai-conv-item{cursor:pointer;border-radius:8px;align-items:center;gap:8px;margin-bottom:2px;padding:10px 12px;transition:background .12s;display:flex}.ai-conv-item:hover{background:#eae6e0}.ai-conv-item.active{background:#fff3e8}.ai-conv-title{color:#2d2926;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.ai-conv-item.active .ai-conv-title{color:#b06a20;font-weight:600}.ai-conv-delete{opacity:0;flex-shrink:0;transition:opacity .12s}.ai-conv-item:hover .ai-conv-delete{opacity:1}.ai-main{flex-direction:column;flex:1;min-width:0;display:flex}.ai-main-header{border-bottom:1px solid #f3f0eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.ai-main-title{color:#2d2926;align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.ai-messages{flex-direction:column;flex:1;gap:20px;padding:20px 24px;display:flex;overflow-y:auto}.ai-msg{gap:12px;max-width:90%;display:flex}.ai-msg-user{flex-direction:row-reverse;align-self:flex-end}.ai-msg-assistant{align-self:flex-start}.ai-msg-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.ai-msg-user .ai-msg-avatar{color:#fff;background:#ee9042}.ai-msg-assistant .ai-msg-avatar{color:#ee9042;background:#fff3e8}.ai-msg-body{flex:1;min-width:0}.ai-msg-bubble{border-radius:14px;padding:12px 16px;font-size:14px;line-height:1.7}.ai-msg-user .ai-msg-bubble{color:#fff;background:#ee9042;border-bottom-right-radius:4px}.ai-msg-assistant .ai-msg-bubble{color:#2d2926;background:#f5f2ee;border-bottom-left-radius:4px}.ai-msg-images{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.ai-msg-images img{object-fit:cover;cursor:pointer;border-radius:8px;width:80px;height:80px}.ai-msg-actions{opacity:0;gap:2px;margin-top:6px;transition:opacity .15s;display:flex}.ai-msg:hover .ai-msg-actions{opacity:1}.ai-msg-action-btn{cursor:pointer;color:#c5bfb7;background:0 0;border:none;border-radius:4px;padding:3px 6px;font-size:13px;transition:all .12s}.ai-msg-action-btn:hover{color:#6b6058;background:#f3f0eb}.ai-msg-action-btn.active-like{color:#ee9042}.ai-msg-action-btn.active-dislike{color:#ff4d4f}.ai-disclaimer{color:#9e9589;margin-top:6px;padding:0 4px;font-size:11px}.ai-cursor{vertical-align:text-bottom;background:#ee9042;width:2px;height:16px;margin-left:2px;animation:.8s ease-in-out infinite aiCursorBlink;display:inline-block}@keyframes aiCursorBlink{0%,to{opacity:1}50%{opacity:0}}.ai-typing-dots{gap:4px;padding:14px 16px;display:flex}.ai-typing-dot{background:#d5d0c9;border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite aiDotBounce}.ai-typing-dot:nth-child(2){animation-delay:.15s}.ai-typing-dot:nth-child(3){animation-delay:.3s}@keyframes aiDotBounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}.ai-input-area{border-top:1px solid #f3f0eb;flex-shrink:0;padding:12px 20px}.ai-input-row{background:#f5f2ee;border-radius:14px;align-items:flex-end;gap:8px;padding:8px 12px;display:flex}.ai-input-textarea{color:#2d2926;resize:none;background:0 0;border:none;outline:none;flex:1;min-height:24px;max-height:120px;font-family:inherit;font-size:14px;line-height:1.5}.ai-input-textarea::placeholder{color:#c5bfb7}.ai-input-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.ai-welcome{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px 32px;display:flex}.ai-welcome-icon{margin-bottom:16px;font-size:48px}.ai-welcome-title{color:#2d2926;margin-bottom:6px;font-size:20px;font-weight:700}.ai-welcome-desc{color:#9e9589;max-width:300px;margin-bottom:24px;font-size:13px;line-height:1.6}.ai-suggestions{grid-template-columns:1fr 1fr;gap:8px;width:100%;max-width:400px;display:grid}.ai-suggestion{color:#6b6058;cursor:pointer;text-align:left;background:#faf8f5;border:1px solid #f3f0eb;border-radius:10px;padding:12px 14px;font-size:13px;transition:all .12s}.ai-suggestion:hover{color:#b06a20;background:#fff3e8;border-color:#ee904233}.ai-markdown{font-size:14px;line-height:1.8}.ai-markdown p{margin:0 0 8px}.ai-markdown p:last-child{margin-bottom:0}.ai-markdown strong{color:#2d2926;font-weight:700}.ai-markdown ul,.ai-markdown ol{margin:6px 0;padding-left:18px}.ai-markdown li{margin-bottom:4px}.ai-markdown code{color:#b06a20;background:#ee904214;border-radius:4px;padding:1px 6px;font-size:13px}.ai-markdown blockquote{color:#6b6058;background:#ee904208;border-left:3px solid #ee9042;border-radius:0 6px 6px 0;margin:8px 0;padding:4px 12px}.ai-markdown h1,.ai-markdown h2,.ai-markdown h3{margin:10px 0 4px;font-size:15px;font-weight:700}@media (width<=800px){.ai-sidebar{display:none}.ai-chat-panel{width:100vw}}.ai-followups{flex-wrap:wrap;gap:8px;margin-top:8px;padding-left:44px;display:flex}.ai-followup-btn{color:#6b6058;cursor:pointer;background:#faf8f5;border:1px solid #f3f0eb;border-radius:999px;padding:8px 14px;font-size:12px;transition:all .15s}.ai-followup-btn:hover{color:#b06a20;background:#fff3e8;border-color:#ee904233}.health-page{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.health-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.health-title{font-size:var(--text-h1);font-weight:var(--text-h1-weight);color:var(--text)}.health-header-actions{align-items:center;gap:10px;display:flex}.health-grid{gap:var(--gap-lg);grid-template-columns:260px 1fr;align-items:start;display:grid}.health-sidebar{position:sticky;top:88px}.health-cat-selector{background:var(--surface-low);width:100%;height:44px;color:var(--text);cursor:pointer;transition:var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%239E9589' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;border:1.5px solid #0000;border-radius:11px;padding:0 14px;font-size:14px;font-weight:500}.health-cat-selector:focus{background-color:var(--primary-light);border-color:#e8913c26}.health-stats-card{margin-top:16px;padding:20px}.health-stats-card:hover{transform:none}.health-stats-title{font-family:var(--font-display);color:var(--text);margin-bottom:16px;font-size:18px;font-weight:400}.health-stat-row{justify-content:space-between;align-items:center;padding:8px 0;display:flex}.health-stat-row+.health-stat-row{border-top:1px solid #b48c640d}.health-stat-label{color:var(--text-secondary);font-size:12px}.health-stat-value{font-family:var(--font-display);color:var(--primary);font-size:22px;font-weight:400}.health-stat-date{color:var(--text-hint);text-align:right;margin-top:1px;font-size:11px}.health-quick-actions{flex-direction:column;gap:6px;margin-top:16px;display:flex}.health-quick-btn{background:var(--surface-white);width:100%;color:var(--text);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-card);border-radius:11px;align-items:center;gap:8px;padding:10px 14px;font-size:13px;font-weight:500;display:flex}.health-quick-btn:hover{background:var(--primary-light);box-shadow:var(--shadow-float)}.health-tabs{background:var(--surface-low);border-radius:11px;gap:3px;margin-bottom:20px;padding:3px;display:flex}.health-tab{text-align:center;color:var(--text-hint);cursor:pointer;transition:var(--transition);background:0 0;border-radius:9px;flex:1;padding:9px 0;font-size:13px;font-weight:500}.health-tab:hover{color:var(--text-secondary)}.health-tab.active{background:var(--surface-white);color:var(--primary);font-weight:600;box-shadow:0 1px 4px #b48c6414}.status-badge{border-radius:999px;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.status-badge.normal{color:var(--success);background:#5cb85c1a}.status-badge.soon{color:var(--primary-dark);background:#ee90421a}.status-badge.expired{color:var(--error);background:#ff4d4f1a}.health-empty-state{flex-direction:column;align-items:center;padding:80px 24px;animation:.6s cubic-bezier(.22,1,.36,1) both fadeInUp;display:flex}.health-empty-hero{margin-bottom:40px;position:relative}.health-empty-glow{background:radial-gradient(circle,#ee904226 0%,#0000 70%);border-radius:50%;animation:3s ease-in-out infinite gentlePulse;position:absolute;inset:-30px}.health-empty-ring{background:#fff;border:3px solid #ee90420f;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;animation:4s ease-in-out infinite float;display:flex;position:relative;box-shadow:0 0 0 6px #ee90420a,0 12px 40px #ee904229}.health-empty-title{font-family:var(--font-display);color:var(--text);margin-bottom:8px;font-size:32px;font-weight:800}.health-empty-desc{color:var(--text-secondary);margin-bottom:0;font-size:16px}.health-empty-btn{background:linear-gradient(135deg, #f0a050, var(--primary));color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;height:48px;margin-top:32px;padding:0 36px;font-size:16px;font-weight:700;transition:all .25s cubic-bezier(.22,1,.36,1);display:flex;box-shadow:0 6px 24px #ee904240}.health-empty-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #ee904259}.health-empty-content{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:56px 28px;display:flex}.health-empty-content p{color:var(--text-hint);margin-top:12px;font-size:14px}.health-header-btn{color:var(--text-hint);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:5px;padding:6px 12px;font-size:12px;display:inline-flex}.health-header-btn:hover{background:var(--surface-low);color:var(--text)}.health-stats-row{gap:var(--gap-lg);margin-bottom:var(--gap-lg);grid-template-columns:260px 1fr;align-items:start;display:grid}.health-tab-actions{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.health-tab-title{font-family:var(--font-display);color:var(--text);margin:0;font-size:18px;font-weight:700}.health-record-list .health-record-row{border-bottom:1px solid var(--paper-line)}.health-record-list .health-record-row:last-child{border-bottom:none}.health-record-row{grid-template-columns:100px 1fr 130px 110px 90px 56px;align-items:center;gap:10px;padding:12px 4px;transition:background .12s;display:grid}.health-record-row:hover{background:#b48c6408}.health-record-date{color:var(--text);font-size:13px;font-weight:500}.health-record-type{color:var(--text);font-size:13px}.health-record-hospital,.health-record-next{color:var(--text-secondary);font-size:12px}.health-record-actions{justify-content:flex-end;gap:2px;display:flex}.health-record-action-btn{cursor:pointer;opacity:0;background:0 0;border-radius:7px;justify-content:center;align-items:center;padding:5px;transition:background .12s;display:flex}.health-record-row:hover .health-record-action-btn{opacity:1}.health-record-action-btn:hover{background:#b48c640f}.health-record-type-badge{justify-content:center;display:flex}.health-status-badge{border-radius:999px;justify-content:center;align-items:center;padding:2px 10px;font-size:11px;font-weight:600;display:inline-flex}.medical-card{border-radius:var(--radius);background:var(--surface-white);box-shadow:var(--card-journal);border:1px solid var(--paper-line);padding:20px 24px;transition:box-shadow .3s}.medical-card-btns{gap:4px;display:flex}.medical-card-btn{cursor:pointer;background:0 0;border-radius:7px;justify-content:center;align-items:center;padding:5px;transition:background .12s;display:flex}.medical-card-btn:hover{background:#b48c640f}.health-loading{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px;display:flex}.health-loading-spinner{border:3px solid var(--surface-low);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.form-input{border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--surface-white);width:100%;height:40px;color:var(--text);transition:var(--transition);padding:0 12px;font-family:inherit;font-size:14px}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #ee904214}.health-filter-chips{gap:6px;margin-bottom:16px;display:flex}.health-chip{color:var(--text-hint);background:var(--surface-low);cursor:pointer;transition:var(--transition);border:none;border-radius:999px;padding:5px 16px;font-size:12px;font-weight:500}.health-chip:hover{color:var(--text-secondary);background:var(--surface-high)}.health-chip.active{background:var(--primary-light);color:var(--primary-dark);font-weight:600}.deworming-type-badge{background:var(--surface-low);color:var(--text-secondary);border-radius:999px;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.health-list-card{border-radius:var(--radius);padding:0;overflow:hidden}.health-list-card:hover{box-shadow:var(--shadow-card);transform:none}.medical-card-list{flex-direction:column;gap:12px;display:flex}.medical-card{border-radius:var(--radius);padding:20px 24px}.medical-card:hover{box-shadow:var(--shadow-float)}.medical-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:10px;display:flex}.medical-card-date{color:var(--text-hint);font-size:12px;font-weight:500}.medical-card-cost{font-family:var(--font-display);color:var(--primary);font-size:20px;font-weight:400}.medical-card-reason{color:var(--text);margin-bottom:6px;font-size:15px;font-weight:600}.medical-card-detail{color:var(--text-secondary);margin-bottom:10px;font-size:12px;line-height:1.6}.medical-card-footer{justify-content:space-between;align-items:center;display:flex}.medical-card-rx{color:#2e86ab;background:var(--blue-light);border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.medical-card-actions{gap:4px;display:flex}.reminder-list{flex-direction:column;display:flex}.reminder-item{border-left:3px solid var(--surface-high);gap:14px;padding:14px 18px;transition:background .12s;display:flex}.reminder-item:hover{background:#b48c6405}.reminder-item.reminder-expired{border-left-color:var(--error)}.reminder-item.reminder-soon{border-left-color:var(--primary)}.reminder-item.reminder-normal{border-left-color:var(--success)}.reminder-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.reminder-expired .reminder-dot{background:var(--error);box-shadow:0 0 0 3px #e255551a}.reminder-soon .reminder-dot{background:var(--primary);box-shadow:0 0 0 3px #e8913c1a}.reminder-normal .reminder-dot{background:var(--success);box-shadow:0 0 0 3px #5cb85c1a}.reminder-body{flex:1}.reminder-date{color:var(--text-hint);margin-bottom:3px;font-size:12px;font-weight:500}.reminder-desc{color:var(--text);font-size:13px;line-height:1.5}.reminder-cat{color:var(--text-hint);margin-top:3px;font-size:11px}.health-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:56px 28px;display:flex}.health-empty-icon{margin-bottom:14px;font-size:40px}.health-empty-text{color:var(--text-hint);margin-bottom:16px;font-size:14px}.health-no-cat{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:100px 28px;display:flex}.health-no-cat-icon{margin-bottom:16px;font-size:52px}.health-no-cat h2{color:var(--text);margin-bottom:6px;font-size:24px;font-weight:700}.health-no-cat p{color:var(--text-hint);font-size:14px}.health-modal-mask{z-index:1000;background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.health-modal{border-radius:var(--radius-lg);width:440px;max-height:85vh;box-shadow:var(--shadow-elevated);background:#fff;padding:28px;animation:.2s ease-out scaleIn;overflow-y:auto}.health-modal-title{font-family:var(--font-display);color:var(--text);margin-bottom:20px;font-size:22px;font-weight:400}.health-modal-actions{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.rx-section{margin-top:6px}.rx-section-title{color:var(--text-secondary);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12px;font-weight:600;display:flex}.rx-item{grid-template-columns:1fr 1fr auto;align-items:start;gap:6px;margin-bottom:6px;display:grid}.rx-remove-btn{cursor:pointer;color:var(--error);background:0 0;border-radius:7px;justify-content:center;align-items:center;padding:10px 5px;font-size:16px;display:flex}.rx-remove-btn:hover{background:#e255550d}.health-confirm-modal{border-radius:var(--radius-lg);width:380px;box-shadow:var(--shadow-elevated);background:#fff;padding:28px 24px 22px;animation:.2s ease-out scaleIn}.health-confirm-title{margin-bottom:8px;font-size:16px;font-weight:700}.health-confirm-text{color:var(--text-secondary);margin-bottom:18px;font-size:13px;line-height:1.5}.health-confirm-actions{justify-content:flex-end;gap:10px;display:flex}.health-config-link{color:var(--text-hint);cursor:pointer;background:0 0;align-items:center;gap:5px;padding:0;font-size:12px;transition:color .12s;display:inline-flex}.health-config-link:hover{color:var(--primary)}.hc-page{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.hc-page-header{align-items:center;gap:16px;margin-bottom:24px;display:flex}.hc-back-btn{font-size:var(--text-meta);color:var(--text-hint);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;display:inline-flex}.hc-back-btn:hover{background:var(--surface-low);color:var(--text)}.hc-page-title{font-size:var(--text-h2);font-weight:var(--text-h2-weight);color:var(--text);margin:0}.hc-grid{gap:var(--gap-lg);grid-template-columns:1fr 1fr;align-items:start;display:grid}.hc-card{padding:20px 24px}.hc-list{flex-direction:column;display:flex}.hc-list-item{border-bottom:1px solid var(--paper-line);justify-content:space-between;align-items:center;gap:12px;padding:12px 0;display:flex}.hc-list-item:last-child{border-bottom:none}.hc-item-info{flex:1;min-width:0}.hc-item-name{color:var(--text);font-size:14px;font-weight:500}.hc-item-code{color:var(--text-hint);margin-top:2px;font-size:11px}.hc-item-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.hc-edit-link{color:var(--primary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:13px;font-weight:500}.hc-edit-link:hover{background:var(--primary-light)}.hc-system-tag{color:var(--text-hint);background:var(--surface-low);border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.hc-delete-btn{cursor:pointer;color:var(--error);transition:var(--transition);background:0 0;border:none;border-radius:6px;align-items:center;padding:5px;display:flex}.hc-delete-btn:hover{background:#ff4d4f0f}.hc-inline-edit{align-items:center;gap:6px;display:flex}.hc-add-btn{border-radius:var(--radius-md);height:40px;margin-top:16px}.hc-tip{color:var(--text-hint);margin-top:12px;font-size:12px;line-height:1.6}.hc-loading{color:var(--text-hint);justify-content:center;align-items:center;gap:12px;padding:80px;font-size:14px;display:flex}.hc-spinner{border:2px solid var(--surface-low);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}.docviewer{background:var(--surface);flex-direction:column;height:100vh;display:flex}.docviewer-topbar{-webkit-backdrop-filter:blur(24px);z-index:10;background:#ffffffc7;border-bottom:1px solid #b48c640f;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 40px;display:flex;position:relative}.docviewer-topbar-brand{align-items:center;gap:10px;display:flex;position:absolute;left:50%;transform:translate(-50%)}.docviewer-topbar-logo{border-radius:7px;width:28px;height:28px}.docviewer-topbar-title{color:var(--text);font-size:16px;font-weight:700}.docviewer-back{color:var(--text);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:6px 0;font-size:14px;font-weight:500;transition:color .15s;display:flex}.docviewer-back:hover{color:var(--primary)}.docviewer-newtab{color:var(--primary);cursor:pointer;background:#e8913c0f;border:none;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:600;transition:background .15s}.docviewer-newtab:hover{background:#e8913c1f}.docviewer-frame{border:none;flex:1;width:100%}.docviewer-list{overflow-y:overlay;scrollbar-width:thin;scrollbar-color:#b48c6426 transparent;flex:1;padding:36px 64px 80px;overflow-y:auto}.docviewer-list::-webkit-scrollbar{width:6px}.docviewer-list::-webkit-scrollbar-track{background:0 0}.docviewer-list::-webkit-scrollbar-thumb{background:#b48c6426;border-radius:3px}.docviewer-list::-webkit-scrollbar-thumb:hover{background:#b48c644d}.docviewer-inner{width:100%;max-width:1120px;margin:0 auto}.docviewer-section{color:var(--text-secondary,#6b6058);text-transform:uppercase;letter-spacing:.1em;border-bottom:2px solid #ee904226;margin:32px 0 12px 2px;padding-bottom:6px;font-size:13px;font-weight:700;display:inline-block}.docviewer-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:8px;display:grid}.docviewer-card{cursor:pointer;background:#fff;border-radius:20px;align-items:center;gap:18px;padding:24px 28px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 2px 16px #b48c6412}.docviewer-card:hover{transform:translateY(-3px);box-shadow:0 12px 36px #b48c6424}.docviewer-card:active{transform:scale(.99)}.docviewer-card-icon{object-fit:contain;border-radius:16px;flex-shrink:0;width:52px;height:52px}.docviewer-card-info{flex-direction:column;flex:1;gap:3px;display:flex}.docviewer-card-name{color:var(--text);font-size:15px;font-weight:600}.docviewer-card-desc{color:var(--text-hint);font-size:12px}.docviewer-card-arrow{color:var(--text-disabled,#d5d0c9);flex-shrink:0;font-size:22px;transition:transform .2s,color .2s}.docviewer-card:hover .docviewer-card-arrow{color:var(--primary);transform:translate(4px)}.docviewer-footer{text-align:center;color:var(--text-disabled,#d5d0c9);margin-top:56px;font-size:12px}@media (width<=960px){.docviewer-list{padding:40px 36px 60px}.docviewer-grid{grid-template-columns:repeat(2,1fr)}.docviewer-hero-title{font-size:32px}}@media (width<=640px){.docviewer-list{padding:28px 20px 60px}.docviewer-grid{grid-template-columns:1fr}.docviewer-hero-title{font-size:24px}.docviewer-hero-logo{border-radius:20px;width:64px;height:64px}.docviewer-card{border-radius:16px;padding:18px 20px}.docviewer-card-icon{width:44px;height:44px}}.dashboard{animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.dash-loading{justify-content:center;align-items:center;gap:var(--gap-lg);flex-direction:column;padding:120px;display:flex}.dash-loading-text{color:var(--text-hint);font-size:14px;animation:1.5s ease-in-out infinite gentlePulse}.dash-loading-small{justify-content:center;padding:24px;display:flex}.dash-empty{flex-direction:column;align-items:center;padding:80px 24px;animation:.6s cubic-bezier(.22,1,.36,1) both fadeInUp;display:flex}.dash-empty-hero{margin-bottom:40px;position:relative}.dash-empty-glow{background:radial-gradient(circle,#ee904226 0%,#0000 70%);border-radius:50%;animation:3s ease-in-out infinite gentlePulse;position:absolute;inset:-30px}.dash-empty-ring{background:#fff;border:3px solid #ee90420f;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;animation:4s ease-in-out infinite float;display:flex;position:relative;box-shadow:0 0 0 6px #ee90420a,0 12px 40px #ee904229}.dash-empty-title{font-family:var(--font-display);color:var(--text);margin-bottom:8px;font-size:32px;font-weight:800}.dash-empty-desc{color:var(--text-secondary);margin-bottom:0;font-size:16px}.dash-empty-btn{background:linear-gradient(135deg, #f0a050, var(--primary));color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;height:48px;margin-top:32px;padding:0 36px;font-size:16px;font-weight:700;transition:all .25s cubic-bezier(.22,1,.36,1);display:flex;box-shadow:0 6px 24px #ee904240}.dash-empty-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px #ee904259}.dash-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.dash-title{font-family:var(--font-display);color:var(--text);font-size:24px;font-weight:700}.dash-filters{align-items:center;gap:8px;display:flex}.dash-grid{gap:var(--gap-lg);grid-template-columns:1fr 1fr;display:grid}.dash-grid-full{grid-column:1/-1}.dash-chart-wrap{position:relative}.dash-chart-svg{width:100%;height:auto;display:block}.dash-chart-subtitle{color:var(--text-hint);font-size:12px}.dash-insight-text{color:var(--text-secondary);white-space:pre-line;margin:0;font-size:14px;line-height:1.8}.dash-cal{padding:4px 0}.dash-cal-nav{align-items:center;gap:12px;margin-bottom:16px;display:flex}.dash-cal-nav-btn{cursor:pointer;color:var(--text-hint);transition:var(--transition);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:16px}.dash-cal-nav-btn:hover{background:var(--surface-low);color:var(--text)}.dash-cal-month{font-family:var(--font-serif);color:var(--text);font-size:18px;font-weight:600}.dash-cal-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.dash-cal-weekday{text-align:center;color:var(--text-hint);padding:6px 0;font-size:11px;font-weight:600}.dash-cal-day{aspect-ratio:1;color:var(--text);cursor:default;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:3px;font-size:13px;transition:background .12s;display:flex;position:relative}.dash-cal-day.today{background:var(--primary-light);color:var(--primary);font-weight:700}.dash-cal-day.empty{color:#0000;cursor:default}.dash-cal-day.has-events{cursor:pointer}.dash-cal-day.has-events:hover{background:var(--surface-low)}.dash-cal-dots{gap:2px;display:flex;position:absolute;bottom:4px}.dash-cal-dot{border-radius:50%;width:5px;height:5px}.dash-cal-dot.vaccination{background:var(--primary)}.dash-cal-dot.deworming{background:var(--secondary)}.dash-cal-dot.medical{background:var(--error)}.dash-cal-dot.reminder{background:var(--tertiary)}.dash-cal-popover{z-index:10;background:var(--surface-white);box-shadow:var(--shadow-float);border-radius:12px;min-width:200px;margin-top:4px;padding:12px 14px;animation:.15s ease-out scaleIn;position:absolute;top:100%;left:50%;transform:translate(-50%)}.dash-cal-event{color:var(--text);align-items:center;gap:8px;padding:5px 0;font-size:12px;display:flex}.dash-cal-event-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.dash-cal-event-cat{color:var(--text-hint);margin-left:auto;font-size:11px}@media (width<=900px){.dash-grid{grid-template-columns:1fr}.dash-grid-full{grid-column:1}}.report{max-width:960px;margin:0 auto;animation:.4s cubic-bezier(.22,1,.36,1) pageEnter}.report-loading{justify-content:center;padding:120px;display:flex}.report-empty{justify-content:center;padding:80px 24px;display:flex}.report-back-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border-radius:8px;align-items:center;gap:4px;margin-bottom:8px;padding:5px 10px 5px 4px;font-size:13px;display:inline-flex}.report-back-btn:hover{color:var(--primary);background:var(--primary-light)}.report-hero{text-align:center;background:linear-gradient(160deg, var(--surface-white) 60%, #ee90420a);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);margin-bottom:24px;padding:48px 32px 40px}.report-year-tag{background:var(--primary-light);color:var(--primary);border-radius:999px;margin-bottom:12px;padding:4px 16px;font-size:12px;font-weight:700;display:inline-block}.report-cat-name{font-family:var(--font-display);color:var(--text);margin:0 0 4px;font-size:36px;font-weight:400}.report-subtitle{color:var(--text-hint);margin:0;font-size:14px}.report-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.report-stat-card{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--card-journal);border:1px solid var(--paper-line);text-align:center;transition:var(--transition);padding:24px 20px}.report-stat-card:hover{box-shadow:0 4px 20px #b48c641f}.report-stat-icon{color:var(--primary);margin-bottom:8px;font-size:22px}.report-stat-icon.photo{color:#6bbfea}.report-stat-icon.health{color:#6d97de}.report-stat-value{font-family:var(--font-serif);margin-bottom:4px;font-size:28px;font-weight:700;line-height:1}.report-stat-value.expense{color:var(--primary)}.report-stat-value.photos{color:#6bbfea}.report-stat-value.health{color:#6d97de}.report-stat-label{color:var(--text-hint);font-size:12px;font-weight:500}.report-yuan{font-size:20px;font-weight:700}.report-weight-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.report-weight-item{text-align:center;background:var(--paper-bg);border-radius:12px;padding:16px 12px}.report-weight-value{font-family:var(--font-serif);color:#6bbfea;font-size:22px;font-weight:700}.report-weight-label{color:var(--text-hint);margin-top:4px;font-size:11px}.report-row-2col{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.report-expense-summary{flex-direction:column;gap:12px;display:flex}.report-expense-total{flex-direction:column;align-items:center;display:flex}.report-expense-amount{font-family:var(--font-serif);color:var(--primary);font-size:32px;font-weight:700}.report-expense-label{color:var(--text-hint);font-size:12px}.report-expense-top{color:var(--text-secondary);text-align:center;font-size:13px}.report-health-stats{justify-content:space-around;display:flex}.report-health-item{text-align:center}.report-health-count{font-family:var(--font-serif);color:#6d97de;font-size:28px;font-weight:700}.report-health-label{color:var(--text-hint);margin-top:4px;font-size:12px}.report-milestones{flex-direction:column;gap:0;display:flex}.report-milestone{gap:14px;padding:12px 0;display:flex}.report-milestone-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px;box-shadow:0 0 0 3px #ee90421a}.report-milestone-content{flex-direction:column;gap:2px;display:flex}.report-milestone-date{color:var(--text-hint);font-size:12px;font-weight:500}.report-milestone-desc{color:var(--text);font-size:14px}.report-narrative{white-space:pre-line;color:var(--text);font-size:14px;line-height:2}.report-narrative-cta{text-align:center;padding:16px}@media (width<=768px){.report-stats-grid,.report-weight-grid{grid-template-columns:repeat(2,1fr)}.report-row-2col{grid-template-columns:1fr}.report-hero{padding:32px 20px}.report-cat-name{font-size:28px}}
