@import "https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&display=swap";@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes gentlePulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes floatSoft{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}:root{--primary:#ee9042;--primary-dark:#d47a2e;--primary-light:#fff3e8;--secondary:#6bbfea;--blue-light:#e8f6fd;--tertiary:#f7d752;--yellow-light:#fff9e0;--quaternary:#6d97de;--error:#ff4d4f;--success:#5cb85c;--surface:#faf8f5;--surface-low:#f3f0eb;--surface-high:#eae6e0;--surface-white:#fff;--surface-dim:#d5d0c9;--text:#2d2926;--text-secondary:#6b6058;--text-hint:#9e9589;--text-disabled:#c5bfb7;--outline:#c5bfb7;--ghost-border:1px solid #ab99871f;--shadow-card:0 2px 16px #b48c6412, 0 1px 3px #b48c640a;--shadow-float:0 12px 40px #b48c641f, 0 4px 12px #b48c640f;--shadow-card-hover:0 8px 32px #b48c6424;--shadow-lg:0 16px 48px #b48c6424;--shadow-elevated:0 24px 64px #b48c6429, 0 8px 20px #b48c6414;--card-px:28px;--gap-sm:8px;--gap-md:16px;--gap-lg:24px;--gap-xl:36px;--radius:16px;--radius-lg:24px;--font-display:"DM Serif Display", Georgia, "Noto Serif SC", serif;--font-body:"DM Sans", -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", sans-serif;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce:all .35s cubic-bezier(.34, 1.56, .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}body:before{content:"";pointer-events:none;z-index:0;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px;position:fixed;inset:0}input,textarea,select,button{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none}a{color:inherit;text-decoration:none}.app-layout{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}.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-brand-text{font-family:var(--font-display);color:#6b4a2a;font-size:22px;font-weight:400}.topbar-nav{align-items:center;gap:4px;display:flex}.topbar-item{color:var(--text-hint);cursor:pointer;transition:var(--transition-smooth);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-smooth);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:.5s cubic-bezier(.22,1,.36,1) fadeInUp}.card{background:var(--surface-white);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:var(--card-px);transition:box-shadow .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}.card:hover{box-shadow:var(--shadow-float);transform:translateY(-4px)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:64px 32px;animation:.5s ease-out fadeInUp;display:flex}.empty-state-icon{color:var(--primary);justify-content:center;align-items:center;margin-bottom:20px;display:flex}.empty-state-text{color:var(--text-hint);margin:0;font-size:16px}.loading-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:100px 32px;display:flex}.loading-spinner{border:3px solid #ee90421f;border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;margin-bottom:20px;animation:.8s linear infinite loadingSpin}.loading-text{color:var(--text-hint);font-size:15px;animation:1.5s ease-in-out infinite gentlePulse}@keyframes loadingSpin{to{transform:rotate(360deg)}}.btn{cursor:pointer;height:44px;transition:var(--transition-smooth);letter-spacing:.01em;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:0 24px;font-size:14px;font-weight:600;display:inline-flex;position:relative}.btn:active{transform:scale(.96)}.btn-primary{background:linear-gradient(145deg, #f0a050, var(--primary));color:#fff;box-shadow:0 4px 16px #ee904240}.btn-primary:hover{background:linear-gradient(145deg, var(--primary), var(--primary-dark));transform:translateY(-2px);box-shadow:0 8px 24px #ee90424d}.btn-primary:active{transform:scale(.96)translateY(0)}.btn-ghost{background:var(--surface-low);color:var(--text)}.btn-ghost:hover{background:var(--surface-high);transform:translateY(-1px)}.btn-danger{color:var(--error);border:var(--ghost-border);background:0 0}.btn-danger:hover{background:#fff0f0;box-shadow:0 2px 8px #ff4d4f14}.form-field{margin-bottom:20px}.form-label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.form-input{background:var(--surface-low);width:100%;height:48px;transition:var(--transition-smooth);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-input.error{border-color:#ff4d4f4d;box-shadow:0 0 0 4px #ff4d4f0f}.tag{letter-spacing:.02em;transition:var(--transition-smooth);border-radius:999px;align-items:center;padding:4px 14px;font-size:12px;font-weight:600;display:inline-flex}.tag-default{background:var(--primary-light);color:#b06a20}.tag-health{background:var(--blue-light);color:#2e86ab}.home,.detail,.profile{animation:.5s cubic-bezier(.22,1,.36,1) fadeInUp}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:0 0}.main-content::-webkit-scrollbar-thumb{background:#b48c641f;border-radius:3px}.main-content::-webkit-scrollbar-thumb:hover{background:#b48c6438}::selection{color:var(--text);background:#ee904226}@keyframes loginFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes loginLogoFloat{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-6px)rotate(1deg)}}@keyframes loginGlowPulse{0%,to{opacity:.12;transform:scale(1)}50%{opacity:.2;transform:scale(1.05)}}@keyframes loginBgDrift{0%{transform:translate(0)scale(1)}33%{transform:translate(20px,-15px)scale(1.05)}66%{transform:translate(-10px,10px)scale(.98)}to{transform:translate(0)scale(1)}}@keyframes loginCardReveal{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.login-page{background:linear-gradient(170deg, #fffbf7 0%, var(--surface) 40%, #f0f4f8 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px;position:fixed;inset:0}.login-bg-glow-1{filter:blur(80px);pointer-events:none;background:radial-gradient(circle,#ee90421a 0%,#0000 70%);border-radius:50%;width:500px;height:500px;animation:20s ease-in-out infinite loginBgDrift;position:fixed;top:-10%;right:-10%}.login-bg-glow-2{filter:blur(80px);pointer-events:none;background:radial-gradient(circle,#6bbfea1a 0%,#0000 70%);border-radius:50%;width:400px;height:400px;animation:25s ease-in-out infinite reverse loginBgDrift;position:fixed;bottom:5%;left:-5%}.login-topbar{z-index:50;-webkit-backdrop-filter:blur(16px);background:#fff9;align-items:center;gap:10px;padding:18px 36px;animation:.6s ease-out loginFadeIn;display:flex;position:fixed;top:0;left:0;right:0}.login-topbar-paw{font-size:24px}.login-topbar-brand{color:#934b00;letter-spacing:-.3px;font-size:24px;font-weight:800}.login-center{z-index:1;flex-direction:column;align-items:center;width:100%;max-width:440px;padding:80px 24px 40px;display:flex;position:relative}.login-brand{text-align:center;margin-bottom:36px;animation:.7s ease-out loginFadeIn;position:relative}.login-logo-glow{filter:blur(30px);background:radial-gradient(circle,#ee904226 0%,#0000 70%);border-radius:50%;animation:4s ease-in-out infinite loginGlowPulse;position:absolute;inset:-30px}.login-logo-box{background:linear-gradient(165deg,#f0a050,#ee9042);border-radius:26px;justify-content:center;align-items:center;width:92px;height:92px;margin:0 auto 18px;animation:5s ease-in-out infinite loginLogoFloat;display:flex;position:relative;box-shadow:0 8px 32px #ee904233,0 2px 8px #ee904214}.login-title{color:var(--text);letter-spacing:-.3px;margin-bottom:6px;font-size:28px;font-weight:700}.login-subtitle{color:var(--text-secondary);opacity:.7;font-size:15px}.login-card{-webkit-backdrop-filter:blur(20px);background:#ffffffd9;border-radius:24px;width:100%;padding:32px 28px;animation:.8s cubic-bezier(.4,0,.2,1) .15s both loginCardReveal;box-shadow:0 12px 40px #ee904214,0 2px 8px #ee90420a}.login-tabs{background:var(--surface-low);border-radius:999px;margin-bottom:26px;padding:3px;display:flex}.login-tab{height:40px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:999px;flex:1;font-size:14px;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1)}.login-tab.active{color:var(--primary);background:#fff;box-shadow:0 2px 8px #ee90421a}.login-tab:not(.active):hover{color:var(--text)}.login-field{margin-bottom:20px;animation:.6s ease-out both loginFadeIn}.login-field:first-child{animation-delay:.3s}.login-field:nth-child(2){animation-delay:.4s}.login-label{color:var(--text-secondary);margin:0 0 8px 10px;font-size:13px;font-weight:600;display:block}.login-input-wrap{background:var(--surface-low);border:2px solid #0000;border-radius:16px;align-items:center;height:50px;padding:0 16px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.login-input-wrap:focus-within{background:var(--primary-light);border-color:#ee904233;box-shadow:0 4px 16px #ee904214}.login-prefix{color:var(--text);margin-right:8px;font-size:15px;font-weight:600}.login-input{background:0 0;flex:1;height:100%;font-size:15px}.login-input::placeholder{color:var(--text-hint);opacity:.5}.login-input-icon{opacity:.3;flex-shrink:0;margin-left:8px;font-size:16px;transition:opacity .2s}.login-input-wrap:focus-within .login-input-icon{opacity:.5;color:var(--primary)}.login-code-btn{background:linear-gradient(165deg, #f0a050, var(--primary));color:#fff;cursor:pointer;border-radius:999px;flex-shrink:0;height:34px;margin-left:8px;padding:0 16px;font-size:12px;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #ee904233}.login-code-btn:hover{background:linear-gradient(165deg, var(--primary), var(--primary-dark));transform:translateY(-1px);box-shadow:0 4px 12px #ee90424d}.login-code-btn.disabled{background:var(--surface-dim);color:var(--outline);cursor:default;box-shadow:none;transform:none}.login-error{color:var(--error);margin:-10px 0 14px 10px;font-size:12px;animation:.3s ease-out fadeInUp}.login-submit{background:linear-gradient(165deg, #f0a050, var(--primary));color:#fff;cursor:pointer;border-radius:24px;width:100%;height:50px;font-size:17px;font-weight:700;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 6px 20px #ee904240}.login-submit:after{content:"";pointer-events:none;background:linear-gradient(135deg,#fff3 0%,#0000 50%);position:absolute;inset:0}.login-submit:hover{background:linear-gradient(165deg, var(--primary), var(--primary-dark));transform:translateY(-2px);box-shadow:0 8px 28px #ee904259}.login-submit:active{transform:scale(.97)translateY(0);box-shadow:0 4px 12px #ee904233}.login-submit.loading{opacity:.7;cursor:wait;animation:1.5s ease-in-out infinite gentlePulse}.login-divider{align-items:center;padding:22px 0 14px;display:flex}.login-divider-line{background:linear-gradient(90deg,#0000,#abadaf26,#0000);flex:1;height:1px}.login-divider-text{color:#595c5e66;text-transform:uppercase;letter-spacing:2px;padding:0 14px;font-size:11px;font-weight:600}.login-social{justify-content:center;gap:32px;display:flex}.login-social-item{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;padding:0;display:flex}.login-social-icon{border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex;overflow:hidden}.login-social-item:hover .login-social-icon{transform:translateY(-2px);box-shadow:0 4px 16px #b48c641f}.login-social-label{color:#999;font-size:11px}.login-footer{color:var(--text-secondary);margin-top:32px;font-size:13px;animation:1s ease-out .5s both loginFadeIn}.login-footer a{color:var(--quaternary);font-weight:600;transition:color .2s}.login-footer a:hover{color:var(--primary);text-decoration:underline}.doc-modal-mask{z-index:2000;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.doc-modal{background:#fff;border-radius:20px;flex-direction:column;width:520px;max-width:90vw;max-height:80vh;animation:.25s ease-out aboutSlideUp;display:flex;box-shadow:0 24px 64px #b48c6429,0 8px 20px #b48c6414}.doc-modal-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.doc-modal-header h2{color:#2d2926;margin:0;font-size:18px;font-weight:700}.doc-modal-close{color:#999;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:24px}.doc-modal-close:hover{color:#333}.doc-modal-body{flex:1;padding:20px 24px 28px;overflow-y:auto}.doc-modal-date{color:#9e9589;margin-bottom:16px;font-size:12px}.doc-h3{color:#2d2926;margin:20px 0 6px;font-size:15px;font-weight:700}.doc-p{color:#666;white-space:pre-wrap;margin:0 0 12px;font-size:14px;line-height:1.8}.login-icp{text-align:center;color:#ccc;margin-top:12px;font-size:11px}.doc-page{background:#fff;max-width:680px;min-height:100vh;margin:0 auto}.doc-nav{z-index:10;background:#fff;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.doc-nav h1{color:#2d2926;margin:0;font-size:17px;font-weight:700}.doc-back{color:#2d2926;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}.doc-date{color:#9e9589;margin-bottom:20px;font-size:12px}.doc-body h3{color:#2d2926;margin:24px 0 8px;font-size:16px;font-weight:700}.doc-body h3:first-of-type{margin-top:0}.doc-body p{color:#666;margin:0 0 12px;font-size:14px;line-height:1.8}.home-fab{z-index:900;cursor:pointer;background:linear-gradient(135deg,#f0a54d,#ee9042);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:32px;right:32px;box-shadow:0 6px 20px #ee904259}.home-fab:hover{transform:scale(1.08);box-shadow:0 8px 28px #ee904273}.home-fab:active{transform:scale(.94)}.fab-overlay{z-index:1000;background:#00000059;justify-content:center;align-items:flex-end;animation:.2s ease-out fabOverlayIn;display:flex;position:fixed;inset:0}@keyframes fabOverlayIn{0%{opacity:0}to{opacity:1}}.fab-sheet{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:520px;padding:16px 24px 28px;animation:.25s ease-out fabSheetUp}@keyframes fabSheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.fab-sheet-handle{background:#d1d5d8;border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.fab-sheet-title{text-align:center;color:#2d2926;margin-bottom:16px;font-size:20px;font-weight:700}.fab-sheet-subtitle{color:#595c5e;margin-bottom:8px;padding-left:12px;font-size:14px;font-weight:600}.fab-sheet-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:14px;align-items:center;gap:16px;width:100%;padding:16px 14px;transition:background .15s;display:flex}.fab-sheet-item:hover{background:var(--surface-low)}.fab-sheet-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;display:flex}.fab-sheet-info{flex-direction:column;flex:1;display:flex}.fab-sheet-name{color:#2d2926;font-size:16px;font-weight:600}.fab-sheet-desc{color:#9e9589;margin-top:2px;font-size:13px}.fab-sheet-cat-avatar{background:linear-gradient(145deg,#fff3e8,#ffe8d0);border:2px solid #ee90421f;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.fab-sheet-cat-avatar img{object-fit:cover;width:100%;height:100%}.fab-sheet-cat-letter{color:#ee9042;font-size:16px;font-weight:700}.fab-sheet-back{color:#ee9042;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;width:100%;margin-top:4px;padding:10px 12px;font-size:14px;font-weight:600;display:block}.fab-sheet-back:hover{background:#fff3e8}.fab-sheet-cancel{background:var(--surface-low);color:#757779;cursor:pointer;text-align:center;border:none;border-radius:12px;width:100%;margin-top:10px;padding:14px;font-size:15px;transition:background .15s;display:block}.fab-sheet-cancel:hover{background:#eeeff1}@keyframes homeCardReveal{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes homeStatPop{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.home-loading{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:120px;display:flex}.home-loading:before{content:"";border:3px solid #ee90421f;border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;margin-bottom:20px;animation:.8s linear infinite loadingSpin;display:block}.home-loading-text{color:var(--text-hint);font-size:15px;animation:1.5s ease-in-out infinite gentlePulse}.home-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:140px 0;animation:.6s cubic-bezier(.22,1,.36,1) fadeInUp;display:flex}.home-empty-icon{color:var(--primary);margin-bottom:28px;font-size:72px;animation:3s ease-in-out infinite floatSoft}.home-empty h2{font-family:var(--font-display);color:var(--text);margin-bottom:8px;font-size:32px;font-weight:400}.home-empty p{color:var(--text-secondary);max-width:360px;font-size:16px;line-height:1.6}.home-header{justify-content:space-between;align-items:center;margin-bottom:36px;animation:.4s ease-out fadeInUp;display:flex}.home-title{font-family:var(--font-display);color:var(--text);letter-spacing:-.5px;font-size:36px;font-weight:400}.cat-grid{gap:var(--gap-lg);grid-template-columns:repeat(auto-fill,minmax(400px,1fr));margin-bottom:48px;display:grid}.cat-card{cursor:pointer;border-radius:20px;align-items:center;gap:24px;min-height:152px;padding:32px 36px;transition:box-shadow .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);animation:.55s cubic-bezier(.22,1,.36,1) both homeCardReveal;display:flex;position:relative;overflow:hidden}.cat-card:first-child{animation-delay:50ms}.cat-card:nth-child(2){animation-delay:.12s}.cat-card:nth-child(3){animation-delay:.19s}.cat-card:nth-child(4){animation-delay:.26s}.cat-card:hover{box-shadow:var(--shadow-float);transform:translateY(-6px)}.cat-card-avatar{background:linear-gradient(145deg,#fff3e8,#ffe4cc);border:3px solid #ee90421a;border-radius:22px;flex-shrink:0;justify-content:center;align-items:center;width:96px;height:96px;font-size:40px;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden;box-shadow:0 6px 20px #ee90421a}.cat-card-avatar img{object-fit:cover;width:100%;height:100%}.cat-card:hover .cat-card-avatar{border-color:#ee904233;transform:scale(1.04);box-shadow:0 8px 28px #ee904229}.cat-card-info{flex:1;min-width:0}.cat-card-name{font-family:var(--font-display);letter-spacing:-.3px;color:var(--text);margin-bottom:6px;font-size:28px;font-weight:400}.cat-card-breed{color:var(--text-secondary);margin-bottom:12px;font-size:14px}.cat-card-avatar-letter{font-family:var(--font-display);color:var(--primary);font-size:36px;font-weight:400;line-height:1}.encourage-bar{cursor:pointer;background:linear-gradient(135deg,#fffaf5,#fff6ed);border:1px solid #ee904214;border-radius:20px;align-items:center;gap:18px;margin-bottom:40px;padding:24px 32px;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex}.encourage-bar:hover{box-shadow:var(--shadow-float);border-color:#ee904226;transform:translateY(-4px)}.encourage-icon{font-size:28px}.encourage-content{flex:1}.encourage-content strong{color:var(--text);font-size:17px;font-weight:600;display:block}.encourage-content p{color:var(--text-hint);margin:4px 0 0;font-size:14px}.encourage-arrow{color:var(--text-disabled);font-size:24px;transition:transform .2s}.encourage-bar:hover .encourage-arrow{color:var(--primary);transform:translate(4px)}.home-section{margin-bottom:48px;animation:.5s ease-out .2s both fadeInUp}.home-section-title{font-family:var(--font-display);color:var(--text);align-items:center;gap:12px;margin-bottom:24px;font-size:22px;font-weight:400;display:flex}.home-section-title:before{content:"";background:linear-gradient(180deg, var(--primary), var(--tertiary));border-radius:2px;width:4px;height:24px;display:inline-block}.overview-grid{gap:var(--gap-lg);grid-template-columns:repeat(3,1fr);display:grid}.overview-card{text-align:center;border-radius:20px;flex-direction:column;align-items:center;padding:36px 24px;transition:all .35s cubic-bezier(.4,0,.2,1);animation:.55s cubic-bezier(.34,1.56,.64,1) both homeStatPop;display:flex;position:relative;overflow:hidden}.overview-card:first-child{animation-delay:.15s}.overview-card:nth-child(2){animation-delay:.25s}.overview-card:nth-child(3){animation-delay:.35s}.overview-card:before{content:"";opacity:.05;border-radius:50%;width:96px;height:96px;transition:all .35s;position:absolute;top:-24px;right:-24px}.overview-card:first-child:before{background:var(--primary)}.overview-card:nth-child(2):before{background:var(--secondary)}.overview-card:nth-child(3):before{background:var(--quaternary)}.overview-card:hover{box-shadow:var(--shadow-float);transform:translateY(-6px)}.overview-card:hover:before{opacity:.1;transform:scale(1.3)}.overview-value{font-family:var(--font-display);letter-spacing:-.5px;margin-bottom:10px;font-size:40px;font-weight:400;line-height:1}.overview-label{color:var(--text-secondary);letter-spacing:.03em;text-transform:uppercase;font-size:12px;font-weight:500}.tip-card{background:linear-gradient(135deg,#fffbf0,#fff9e0);border:1px solid #d4a01714;border-radius:16px;align-items:flex-start;gap:16px;max-width:440px;margin-top:28px;padding:20px 24px;display:flex}.tip-icon{font-size:22px}.tip-content{flex:1}.tip-content strong{color:#6f5d00;margin-bottom:6px;font-size:14px;display:block}.tip-content p{color:#8a7a3a;margin:0;font-size:13px;line-height:1.5}.cat-card-expense{color:var(--primary);margin-left:10px;font-size:13px;font-weight:500}.section-header{justify-content:space-between;align-items:center;display:flex}.section-link{color:var(--primary);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;font-size:14px;font-weight:500}.section-link:hover{opacity:.7}.timeline-list-home{padding-left:8px}.timeline-row-home{cursor:pointer;border-radius:14px;gap:18px;padding:16px 12px;transition:background .2s;display:flex;position:relative}.timeline-row-home:hover{background:#b48c6408}.timeline-dot-home{background:var(--primary);border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:7px;box-shadow:0 0 0 4px #ee90421a}.timeline-body-home{flex:1}.timeline-date-home{color:var(--text-hint);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.timeline-text-home{color:var(--text);margin:0;font-size:15px;line-height:1.65}.timeline-tags-home{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.timeline-thumb-home{object-fit:cover;border-radius:14px;width:100%;max-height:220px;margin-top:12px;display:block}.home-actions{align-items:center;gap:10px;display:flex}@keyframes detailSlideIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes detailContentFade{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes detailCardReveal{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.detail-back{color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:4px;margin-bottom:20px;padding:6px 12px 6px 6px;font-size:14px;transition:all .2s cubic-bezier(.4,0,.2,1);animation:.4s ease-out detailSlideIn;display:inline-flex}.detail-back:hover{color:var(--primary);background:var(--primary-light)}.detail-header{border-radius:20px;align-items:center;gap:28px;margin-bottom:32px;padding:32px 36px;animation:.45s ease-out fadeInUp;display:flex;position:relative;overflow:hidden}.detail-header:hover{transform:none}.detail-avatar{background:linear-gradient(145deg, var(--primary-light), #ffe8d0);border:3px solid #ee90421a;border-radius:24px;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;font-size:42px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden;box-shadow:0 4px 16px #ee904226}.detail-avatar img{object-fit:cover;width:100%;height:100%}.detail-header:hover .detail-avatar{transform:scale(1.03);box-shadow:0 6px 24px #ee904233}.detail-name{font-family:var(--font-display);letter-spacing:-.3px;color:var(--text);margin-bottom:4px;font-size:30px;font-weight:400}.detail-breed{color:var(--text-secondary);font-size:14px}.detail-tabs{background:var(--surface-white);box-shadow:var(--shadow-card);border-radius:14px;gap:4px;margin-bottom:28px;padding:5px;animation:.45s ease-out .1s both fadeInUp;display:flex}.detail-tab{cursor:pointer;color:var(--text-hint);letter-spacing:.01em;background:0 0;border-radius:10px;align-items:center;gap:6px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex;position:relative}.detail-tab:hover{color:var(--text);background:var(--surface-low)}.detail-tab.active{background:linear-gradient(165deg, var(--primary-light), #fff0de);color:var(--primary);box-shadow:0 2px 8px #ee90421a}.detail-tab.active:after{content:"";background:var(--primary);border-radius:2px;width:16px;height:3px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.detail-content{animation:.4s ease-out .15s both detailContentFade}.profile-fields{padding:0;overflow:hidden}.profile-fields:hover{box-shadow:var(--shadow-card);transform:none}.profile-row{justify-content:space-between;align-items:center;padding:16px 24px;transition:background .2s;display:flex}.profile-row:hover{background:#ee904205}.profile-label{color:var(--text-hint);font-size:14px;font-weight:500}.profile-value{font-size:14px;font-weight:600}.empty-hint{text-align:center;color:var(--text-hint);padding:48px;font-size:14px}.timeline-list{flex-direction:column;gap:14px;display:flex}.timeline-item{border-radius:16px;padding:24px 28px;animation:.4s ease-out both detailCardReveal;position:relative}.timeline-item:first-child{animation-delay:50ms}.timeline-item:nth-child(2){animation-delay:.1s}.timeline-item:nth-child(3){animation-delay:.15s}.timeline-item:nth-child(4){animation-delay:.2s}.timeline-item:nth-child(5){animation-delay:.25s}.timeline-item:before{content:"";background:linear-gradient(180deg, var(--primary), #ee904233);border-radius:0 2px 2px 0;width:3px;position:absolute;top:16px;bottom:16px;left:0}.timeline-date{color:var(--text-hint);letter-spacing:.03em;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.timeline-content{color:var(--text);font-size:15px;line-height:1.7}.timeline-tags{gap:6px;margin-top:10px;display:flex}.feeding-list{flex-direction:column;display:flex}.feeding-row{border-radius:10px;align-items:center;gap:14px;margin:0 -20px;padding:14px 20px;transition:background .2s;animation:.35s ease-out both detailContentFade;display:flex}.feeding-row:nth-child(odd){background:#ee904205}.feeding-row:hover{background:#ee90420d}.feeding-time{color:var(--text-secondary);font-variant-numeric:tabular-nums;width:52px;font-size:14px;font-weight:600}.feeding-brand{color:var(--text);flex:1;font-size:14px}.feeding-qty{color:var(--primary);background:var(--primary-light);border-radius:999px;padding:2px 10px;font-size:14px;font-weight:700}.weight-chart-placeholder{border-radius:var(--radius);background:linear-gradient(135deg,#6bbfea0f,#6bbfea05);border:1px dashed #6bbfea33;flex-direction:column;justify-content:center;align-items:center;margin-bottom:20px;padding:28px 24px;animation:.4s ease-out detailContentFade;display:flex}.weight-chart-label{color:var(--text-hint);letter-spacing:.02em;margin-bottom:8px;font-size:13px;font-weight:600}.weight-latest-value{font-family:var(--font-display);color:var(--secondary);letter-spacing:-.5px;font-size:40px;font-weight:400;line-height:1}.weight-latest-unit{color:var(--text-hint);margin-left:4px;font-size:16px;font-weight:600}.weight-list{flex-direction:column;display:flex}.weight-row{border-radius:10px;align-items:center;gap:14px;margin:0 -20px;padding:14px 20px;transition:background .2s;animation:.35s ease-out both detailContentFade;display:flex}.weight-row:nth-child(odd){background:#6bbfea08}.weight-row:hover{background:#6bbfea0f}.weight-date{font-variant-numeric:tabular-nums;width:100px;font-size:14px;font-weight:600}.weight-val{flex:1;font-size:15px;font-weight:500}.weight-diff{border-radius:999px;padding:2px 10px;font-size:13px;font-weight:700}.weight-diff.up{color:var(--primary);background:var(--primary-light)}.weight-diff.down{color:#2e86ab;background:var(--blue-light)}.timeline-item-header{justify-content:space-between;align-items:center;display:flex}.timeline-delete{color:#ccc;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:12px;transition:all .15s}.timeline-delete:hover{color:#ff4d4f;background:#ff4d4f14}.timeline-thumb{object-fit:cover;border-radius:8px;width:100%;max-height:180px;margin-top:8px;display:block}.tab-action-bar{justify-content:flex-end;margin-bottom:16px;display:flex}.btn-sm{gap:4px;padding:6px 16px;font-size:13px}.modal-mask{z-index:1000;background:#00000059;justify-content:center;align-items:center;animation:.2s ease-out aboutFadeIn;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:20px;width:480px;max-width:90vw;padding:32px;animation:.25s ease-out aboutSlideUp;box-shadow:0 24px 64px #b48c6429,0 8px 20px #b48c6414}.modal-field input,.modal-field textarea{color:#2d2926;box-sizing:border-box;border:1px solid #e8e6e3;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .15s}.modal-field input:focus,.modal-field textarea:focus{border-color:#ee9042}.modal-field textarea{resize:vertical;font-family:inherit}.gallery-grid-web{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.gallery-item-web{aspect-ratio:1;border-radius:14px;position:relative;overflow:hidden}.gallery-img-web{object-fit:cover;width:100%;height:100%;display:block}.gallery-play-web{color:#fff;background:#0000004d;justify-content:center;align-items:center;font-size:24px;display:flex;position:absolute;inset:0}.gallery-delete-web{color:#fff;cursor:pointer;opacity:0;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;transition:opacity .15s;display:flex;position:absolute;top:4px;right:4px}.gallery-item-web:hover .gallery-delete-web{opacity:1}.gallery-delete-web:hover{background:#ff4d4f}.timeline-item-actions{align-items:center;gap:4px;display:flex}.timeline-edit-btn{cursor:pointer;opacity:.4;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px;transition:opacity .15s}.timeline-edit-btn:hover{opacity:1}.detail-avatar-letter{color:var(--primary);font-size:28px;font-weight:700;line-height:1}.weight-chart-container{background:var(--surface-white);box-shadow:var(--shadow-card);border-radius:16px;margin-bottom:24px;padding:24px 28px;animation:.4s ease-out detailContentFade}.weight-chart-header{justify-content:space-between;align-items:baseline;margin-bottom:12px;display:flex}.weight-chart-svg{width:100%;height:auto;display:block}@keyframes uploadSpin{to{transform:rotate(360deg)}}.upload-spinner{vertical-align:middle;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;margin-right:4px;animation:.6s linear infinite uploadSpin;display:inline-block}.cat-form-title{font-family:var(--font-display);margin-bottom:28px;font-size:30px;font-weight:400}.cat-form-card{max-width:640px}.cf-field{margin-bottom:16px}.cf-field label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.cf-row{gap:12px;display:flex}.cf-row .cf-field{flex:1}.cf-gender{gap:8px;display:flex}.cf-gender-btn{background:var(--surface-high);color:#ccc;cursor:pointer;border:none;border-radius:999px;flex:1;height:40px;font-size:22px;font-weight:800;line-height:40px;transition:all .15s}.cf-gender-btn.active.male{color:#4a9ec9;background:#6bbfea40}.cf-gender-btn.active.female{color:#d9637e;background:#f58da640}.cf-textarea{resize:vertical;min-height:80px;padding:10px 14px}.cf-error{color:var(--error);margin-bottom:12px;font-size:12px}.cf-save{width:100%;margin-top:8px}.cf-avatar-upload{cursor:pointer;flex-direction:column;align-items:center;max-width:640px;margin-bottom:28px;display:flex}.cf-avatar-circle{background:var(--surface-low);border:3px dashed var(--outline);border-radius:50%;justify-content:center;align-items:center;width:104px;height:104px;transition:all .2s;display:flex;overflow:hidden}.cf-avatar-upload:hover .cf-avatar-circle{border-color:var(--primary);background:var(--primary-light)}.cf-avatar-img{object-fit:cover;width:100%;height:100%}.cf-avatar-hint{color:var(--text-hint);margin-top:8px;font-size:13px;transition:color .2s}.cf-avatar-upload:hover .cf-avatar-hint{color:var(--primary)}.cf-avatar-input{display:none}@keyframes profileReveal{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.profile-title{font-family:var(--font-display);color:var(--text);margin-bottom:36px;font-size:36px;font-weight:400;animation:.4s ease-out profileReveal}.profile-grid{grid-template-columns:320px 1fr;align-items:start;gap:32px;animation:.45s ease-out 50ms both profileReveal;display:grid}.profile-left{position:sticky;top:96px}.profile-hero-card{text-align:center;border-radius:20px;flex-direction:column;align-items:center;margin-bottom:16px;padding:40px 32px 32px;display:flex}.profile-hero-card:hover{transform:none}.profile-hero-avatar{background:linear-gradient(145deg, var(--primary-light), #ffe8d0);border:3px solid #ee90421a;border-radius:50%;justify-content:center;align-items:center;width:96px;height:96px;margin-bottom:20px;display:flex;overflow:hidden;box-shadow:0 6px 24px #ee90421f}.profile-hero-avatar img{object-fit:cover;width:100%;height:100%}.profile-hero-name{font-family:var(--font-display);color:var(--text);margin-bottom:6px;font-size:26px;font-weight:400}.profile-hero-phone{color:var(--text-hint);margin-bottom:2px;font-size:14px}.profile-hero-email{color:var(--text-hint);margin-bottom:0;font-size:13px}.profile-edit-btn{width:100%;margin-top:20px}.profile-stats-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.profile-stat-card{border-radius:16px;flex-direction:column;align-items:center;gap:8px;padding:20px 16px;display:flex}.profile-stat-card:hover{transform:translateY(-2px)}.profile-stat-num{font-family:var(--font-display);font-size:32px;font-weight:400;line-height:1}.profile-stat-lbl{color:var(--text-hint);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:500}.profile-right{flex-direction:column;gap:20px;display:flex}.profile-expense-bar{background:linear-gradient(135deg,#fffaf5,#fff6ed);border:1px solid #ee90420f;border-radius:20px;justify-content:space-between;align-items:center;padding:24px 32px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.profile-expense-bar:hover{box-shadow:var(--shadow-float);border-color:#ee90421f;transform:translateY(-3px)}.expense-bar-info{flex-direction:column;gap:4px;display:flex}.expense-bar-label{color:var(--text-hint);font-size:13px;font-weight:500}.expense-bar-value{font-family:var(--font-display);color:var(--primary);font-size:28px;font-weight:400}.expense-bar-arrow{color:var(--primary);font-size:14px;font-weight:500;transition:transform .2s}.profile-expense-bar:hover .expense-bar-arrow{transform:translate(4px)}.profile-settings{border-radius:20px;padding:8px 0;overflow:hidden}.profile-settings:hover{transform:none}.profile-section-title{color:var(--text-hint);text-transform:uppercase;letter-spacing:.08em;padding:12px 28px 8px;font-size:12px;font-weight:600}.profile-setting-item{cursor:pointer;align-items:center;gap:16px;padding:16px 28px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.profile-setting-item:hover{background:#b48c640a}.setting-icon-wrap{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.setting-info{flex-direction:column;flex:1;gap:2px;display:flex}.setting-name{color:var(--text);font-size:15px;font-weight:500}.setting-desc{color:var(--text-hint);font-size:13px}.setting-arrow{color:var(--text-disabled);font-size:18px;transition:transform .2s}.profile-setting-item:hover .setting-arrow{color:var(--text-hint);transform:translate(3px)}.profile-logout{color:var(--error);opacity:.5;cursor:pointer;background:0 0;align-items:center;gap:6px;padding:12px 0;font-size:14px;font-weight:600;transition:all .25s cubic-bezier(.4,0,.2,1);display:inline-flex}.profile-logout:hover{opacity:1}.about-mask{z-index:1000;background:#00000059;justify-content:center;align-items:center;animation:.2s ease-out aboutFadeIn;display:flex;position:fixed;inset:0}@keyframes aboutFadeIn{0%{opacity:0}to{opacity:1}}.about-modal{text-align:center;width:420px;box-shadow:var(--shadow-elevated);background:#fff;border-radius:24px;padding:44px 40px 36px;animation:.25s ease-out aboutSlideUp}@keyframes aboutSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.about-logo{margin-bottom:12px}.about-title{color:#2d2926;margin:0 0 4px;font-size:22px;font-weight:700}.about-version{color:#9e9589;background:#f3f0eb;border-radius:999px;padding:2px 10px;font-size:12px}.about-desc{color:#666;margin:16px 0 12px;font-size:14px;line-height:1.5}.about-features{color:#555;text-align:left;background:#faf8f5;border-radius:12px;flex-direction:column;gap:6px;margin-bottom:16px;padding:14px 18px;font-size:13px;display:flex}.about-slogan{color:#9e9589;margin:0 0 20px;font-size:13px}.about-close{color:#fff;cursor:pointer;background:linear-gradient(145deg,#f0a54d,#ee9042);border:none;border-radius:12px;width:100%;height:44px;font-size:15px;font-weight:600;transition:opacity .15s}.about-close:hover{opacity:.9}.help-section{margin-bottom:16px}.help-q{color:#2d2926;margin:0 0 8px;font-size:14px;font-weight:600}.help-a{color:#666;margin:0;font-size:13px;line-height:1.8}.lang-options{flex-direction:column;gap:8px;margin:16px 0 20px;display:flex}.lang-option{cursor:pointer;color:var(--text);background:#faf8f5;border-radius:12px;justify-content:space-between;align-items:center;padding:14px 18px;font-size:15px;font-weight:500;transition:all .2s;display:flex}.lang-option:hover{background:#ee90420f}.lang-option-active{background:var(--primary-light);color:var(--primary);font-weight:600}.lang-option-active:hover{background:var(--primary-light)}.lang-option-check{color:var(--primary);font-size:16px;font-weight:700}.expenses-page{max-width:960px;padding:0}.expenses-header h1{font-family:var(--font-display);color:var(--text);margin:0 0 32px;font-size:30px;font-weight:400}.expenses-summary{gap:24px;margin-bottom:32px;display:flex}.summary-card{box-shadow:var(--shadow-card);background:#fff;border-radius:20px;flex:1;padding:28px 32px;transition:box-shadow .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}.summary-card:hover{transform:translateY(-4px);box-shadow:0 8px 32px #ee904229}.summary-card.summary-main{flex:1.5}.summary-label{color:#9e9589;margin-bottom:4px;font-size:13px;display:block}.summary-amount{font-family:var(--font-display);color:var(--text);font-size:32px;font-weight:400}.summary-amount.secondary{color:var(--primary);font-size:24px}.summary-mom{margin-left:8px;font-size:13px;font-weight:500}.summary-mom.up{color:#e8913c}.summary-mom.down{color:#5cb85c}.expenses-breakdown{box-shadow:var(--shadow-card);background:#fff;border-radius:20px;margin-bottom:32px;padding:28px 32px;transition:box-shadow .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}.expenses-breakdown:hover{transform:translateY(-4px);box-shadow:0 8px 32px #ee904229}.expenses-breakdown h3{color:#2d2926;margin:0 0 16px;font-size:15px;font-weight:600}.breakdown-item{margin-bottom:12px}.breakdown-info{align-items:center;gap:8px;margin-bottom:6px;font-size:13px;display:flex}.breakdown-name{color:#2d2926;flex:1}.breakdown-pct{color:#9e9589;text-align:right;min-width:40px}.breakdown-amt{color:#2d2926;text-align:right;min-width:60px;font-weight:500}.breakdown-bar-bg{background:#faf8f5;border-radius:3px;height:6px;overflow:hidden}.breakdown-bar-fill{border-radius:3px;height:100%;transition:width .3s}.cat-dot{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.expenses-list-section{box-shadow:var(--shadow-card);background:#fff;border-radius:20px;padding:28px 32px;transition:box-shadow .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}.expenses-list-section:hover{transform:translateY(-4px);box-shadow:0 8px 32px #ee904229}.expenses-list-section h3{color:#2d2926;margin:0 0 16px;font-size:15px;font-weight:600}.expenses-loading,.expenses-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;animation:.5s ease-out fadeInUp;display:flex}.expenses-loading .loading-spinner{border:3px solid #ee904226;border-top-color:#ee9042;border-radius:50%;width:36px;height:36px;margin-bottom:16px;animation:.8s linear infinite loadingSpin}.expenses-loading .loading-text{color:#9e9589;font-size:14px;animation:1.5s ease-in-out infinite gentlePulse}.expenses-empty .empty-state-icon{color:var(--primary);justify-content:center;align-items:center;margin-bottom:16px;display:flex}.expenses-empty .empty-state-text{color:var(--text-hint);margin:0;font-size:15px}.expense-group{margin-bottom:20px}.expense-group-header{border-bottom:1px solid #f3f0eb;justify-content:space-between;margin-bottom:8px;padding:8px 0;display:flex}.expense-group-date{color:#2d2926;font-size:13px;font-weight:600}.expense-group-total{color:#9e9589;font-size:13px}.expense-row{align-items:center;gap:12px;padding:10px 0;display:flex}.expense-info{flex:1}.expense-name{color:#2d2926;font-size:14px;display:block}.expense-cat{color:#9e9589;margin-top:2px;font-size:12px;display:block}.expense-amount{color:#2d2926;font-size:15px;font-weight:600}.expenses-header{justify-content:space-between;align-items:center;display:flex}.expense-delete{color:#ccc;cursor:pointer;opacity:0;background:0 0;border:none;border-radius:6px;margin-left:8px;padding:4px 8px;font-size:16px;transition:all .15s}.expense-row:hover .expense-delete{opacity:1}.expense-delete:hover{color:#ff4d4f;background:#ff4d4f14}.expense-modal{width:480px}.ef-amount-row{align-items:baseline;gap:4px;margin-bottom:20px;display:flex}.ef-prefix{color:#ee9042;font-size:28px;font-weight:700}.ef-amount{color:#2d2926;background:0 0;border:none;outline:none;width:200px;font-family:inherit;font-size:32px;font-weight:700}.ef-amount::placeholder{color:#ddd}.ef-cat-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;display:grid}.ef-cat-cell{cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:10px 4px;transition:all .15s;display:flex}.ef-cat-cell:hover{background:var(--surface-low)}.ef-cat-cell.active{background:#fef0e1}.ef-cat-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.ef-cat-label{color:#666;font-size:12px}.ef-cat-cell.active .ef-cat-label{color:#ee9042;font-weight:600}.modal-mask{z-index:1000;background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:20px;max-width:90vw;padding:32px;box-shadow:0 24px 64px #b48c6429,0 8px 20px #b48c6414}.modal-title{color:#2d2926;margin:0 0 20px;font-size:18px;font-weight:700}.modal-field{margin-bottom:16px}.modal-field label{color:#9e9589;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.modal-field input{color:#2d2926;box-sizing:border-box;border:1px solid #e8e6e3;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:14px}.modal-field input:focus{border-color:#ee9042}.modal-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.ef-cat-chips{flex-wrap:wrap;gap:8px;display:flex}.ef-chip{background:var(--surface-low);color:#666;cursor:pointer;border-radius:999px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .15s}.ef-chip.active{color:#ee9042;background:#ee90421f;font-weight:600}.ef-chip:hover{background:#eeedeb}.ef-chip.active:hover{background:#ee90422e}.expenses-filter{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.expenses-load-more{text-align:center;padding:16px 0}.edit-profile{animation:.45s cubic-bezier(.4,0,.2,1) fadeInUp}.ep-title{font-family:var(--font-display);margin-bottom:32px;font-size:30px;font-weight:400}.ep-avatar-upload{cursor:pointer;flex-direction:column;align-items:center;max-width:560px;margin-bottom:24px;display:flex}.ep-avatar-circle{background:var(--surface-low);border:3px dashed var(--outline);border-radius:50%;justify-content:center;align-items:center;width:104px;height:104px;transition:all .2s;display:flex;overflow:hidden}.ep-avatar-upload:hover .ep-avatar-circle{border-color:var(--primary);background:var(--primary-light)}.ep-avatar-img{object-fit:cover;width:100%;height:100%}.ep-avatar-hint{color:var(--text-hint);margin-top:8px;font-size:13px;transition:color .2s}.ep-avatar-upload:hover .ep-avatar-hint{color:var(--primary)}.ep-avatar-input{display:none}.ep-form-card{max-width:640px}.ep-field{margin-bottom:20px}.ep-label{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.ep-error{color:var(--error);margin-top:4px;font-size:12px}.ep-bind-row{background:var(--surface-low);border-radius:var(--radius);align-items:center;gap:12px;min-height:44px;padding:0 14px;display:flex}.ep-bind-value{color:var(--text);flex:1;font-size:15px}.ep-bind-btn{border-radius:8px!important;height:32px!important;padding:0 14px!important;font-size:13px!important}.ep-save{width:100%;margin-top:8px}.ep-save.loading{opacity:.7;pointer-events:none}.ep-mask{z-index:1000;background:#00000059;justify-content:center;align-items:center;animation:.2s ease-out aboutFadeIn;display:flex;position:fixed;inset:0}.ep-modal{background:#fff;border-radius:20px;width:440px;padding:32px 28px 28px;animation:.25s ease-out aboutSlideUp;box-shadow:0 24px 64px #b48c6429,0 8px 20px #b48c6414}.ep-modal-title{color:var(--text);text-align:center;margin-bottom:20px;font-size:18px;font-weight:700}.ep-modal-field{margin-bottom:14px}.ep-code-row{gap:10px;display:flex}.ep-code-input{flex:1}.ep-send-btn{white-space:nowrap;flex-shrink:0;height:44px!important;padding:0 16px!important;font-size:13px!important}.ep-send-btn:disabled{opacity:.5;cursor:not-allowed}.ep-modal-actions{gap:10px;margin-top:20px;display:flex}.ep-modal-actions .btn{flex:1}.ep-modal-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.ec-page{animation:.45s cubic-bezier(.4,0,.2,1) fadeInUp}.ec-title{font-family:var(--font-display);color:var(--text);margin-bottom:28px;font-size:30px;font-weight:400}.ec-list-card{margin-bottom:20px;padding:0;overflow:hidden}.ec-loading,.ec-empty{text-align:center;color:var(--text-hint);padding:40px 20px;font-size:14px}.ec-item{align-items:center;gap:14px;padding:16px 24px;transition:background .15s;display:flex}.ec-item:nth-child(2n){background:#ee904204}.ec-item:hover{background:#ee904208}.ec-item-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.ec-item-name{flex:1;font-size:14px;font-weight:500}.ec-badge-system{color:var(--text-hint);background:var(--surface);border-radius:999px;align-items:center;gap:3px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.ec-item-delete{cursor:pointer;opacity:.5;background:0 0;border-radius:8px;justify-content:center;align-items:center;padding:6px;transition:background .15s;display:flex}.ec-item:hover .ec-item-delete{opacity:1}.ec-item-delete:hover{background:#d9534f14}.ec-add-btn{width:100%;margin-bottom:20px}.ec-add-form{margin-bottom:20px;padding:24px}.ec-form-title{margin-bottom:20px;font-size:16px;font-weight:700}.ec-form-field{margin-bottom:20px}.ec-error{color:var(--error);margin-top:6px;font-size:12px}.ec-icon-group{margin-bottom:12px}.ec-icon-group-label{color:var(--text-hint);margin-bottom:8px;font-size:12px;font-weight:600;display:block}.ec-icon-grid{flex-wrap:wrap;gap:8px;display:flex}.ec-icon-cell{background:var(--surface);cursor:pointer;border:2px solid #0000;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .15s;display:flex}.ec-icon-cell:hover{background:var(--surface-low);transform:scale(1.08)}.ec-icon-cell.active{border-color:var(--primary);background:var(--primary-light)}.ec-color-grid{flex-wrap:wrap;gap:10px;display:flex}.ec-color-cell{cursor:pointer;border:3px solid #0000;border-radius:50%;width:32px;height:32px;transition:all .15s;box-shadow:0 2px 6px #ee90421f}.ec-color-cell:hover{transform:scale(1.15)}.ec-color-cell.active{border-color:var(--text);box-shadow:0 0 0 2px #fff, 0 0 0 4px var(--text)}.ec-preview{background:var(--surface);border-radius:var(--radius);align-items:center;gap:12px;margin-bottom:20px;padding:14px 16px;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:15px;font-weight:600}.ec-form-actions{justify-content:flex-end;gap:12px;display:flex}.ec-mask{z-index:1000;background:#00000059;justify-content:center;align-items:center;animation:.2s ease-out ecFadeIn;display:flex;position:fixed;inset:0}@keyframes ecFadeIn{0%{opacity:0}to{opacity:1}}.ec-confirm-modal{background:#fff;border-radius:20px;width:400px;padding:32px 28px 24px;animation:.25s ease-out ecSlideUp;box-shadow:0 24px 64px #b48c6429,0 8px 20px #b48c6414}@keyframes ecSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ec-confirm-title{margin-bottom:10px;font-size:17px;font-weight:700}.ec-confirm-text{color:var(--text-secondary);margin-bottom:20px;font-size:14px;line-height:1.5}.ec-confirm-actions{justify-content:flex-end;gap:12px;display:flex}
