:root{--cream:#fffaf2;--surface:#fff;--orange:#ff7a1a;--orange-soft:#fff0df;--coral:#ff7d67;--blue:#609ef7;--green:#52b977;--brown:#392118;--muted:#8b7c74;--line:#f1dfcf;--shadow:0 14px 36px #6f442317}*{box-sizing:border-box}button,input,textarea,select{font:inherit}button{cursor:pointer}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline-offset:2px;outline:3px solid #ff7a1a40}body{color:var(--brown);background:#f4eee7;margin:0;font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif}#root{min-height:100vh}.app-page,.form-page,.login-page{background:var(--cream);width:min(100%,480px);min-height:100vh;margin:0 auto;position:relative}.app-page{padding-bottom:92px}.page-content{padding:0 20px 32px}.page-header,.simple-header{grid-template-columns:44px 1fr auto;align-items:center;height:72px;padding:14px 20px;display:grid}.page-header h1{text-align:center;margin:0;font-size:24px}.brand-paw{color:var(--orange)}.header-action{justify-content:flex-end;min-width:44px;display:flex}.icon-button{width:44px;height:44px;color:var(--brown);background:0 0;border:0;border-radius:50%;place-items:center;display:grid}.text-button{color:var(--orange);background:0 0;border:0;padding:10px;font-weight:700}.primary,.secondary{border:1px solid var(--orange);border-radius:16px;justify-content:center;align-items:center;gap:8px;min-height:50px;padding:0 20px;font-weight:700;display:inline-flex}.primary{color:#fff;background:linear-gradient(135deg,#ff8b27,#ff6815);box-shadow:0 10px 22px #ff701838}.secondary{color:var(--orange);background:#fff}.small-primary{background:var(--orange);color:#fff;border:0;border-radius:999px;padding:10px 18px;font-weight:700}.sticky-action{z-index:3;width:calc(100% - 40px);margin:22px 20px 0;position:sticky;bottom:82px}.bottom-nav{border-top:1px solid var(--line);z-index:10;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffffff5;grid-template-columns:repeat(4,1fr);width:min(100%,480px);height:74px;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-nav a{color:#9a9795;flex-direction:column;justify-content:center;align-items:center;gap:5px;font-size:12px;text-decoration:none;display:flex}.bottom-nav a.active{color:var(--orange);font-weight:700}.toast{color:#fff;z-index:30;box-shadow:var(--shadow);white-space:nowrap;background:#38251f;border-radius:999px;padding:12px 18px;position:fixed;bottom:95px;left:50%;transform:translate(-50%)}.login-page{flex-direction:column;justify-content:space-between;padding:56px 28px 32px;display:flex;overflow:hidden}.login-page:before{content:"";background:#ffe8c8;border-radius:50%;width:330px;height:330px;position:absolute;top:-120px;right:-120px}.pet-hero{justify-content:center;align-items:center;gap:2px;height:250px;display:flex;position:relative}.pet-hero span{filter:drop-shadow(0 18px 16px #683c1f26);font-size:110px}.pet-hero span:last-child{transform:translate(-18px,30px)scale(.85)}.eyebrow{color:var(--orange);letter-spacing:.18em;font-weight:800}.login-page h1{margin:12px 0;font-size:38px;line-height:1.25}.login-page p{color:var(--muted);line-height:1.8}.test-guide{border:1px solid var(--line);background:#ffffffc7;border-radius:18px;grid-template-columns:1fr 1fr;gap:8px;padding:15px;display:grid;position:relative}.test-guide strong,.test-guide small{grid-column:1/-1}.test-guide span{font-size:13px}.test-guide small{color:var(--muted);margin-top:3px}.login-actions{text-align:center;gap:12px;display:grid}.login-actions small{color:#aaa09a}.form-page{padding-bottom:40px}.form-page form,.app-page form,.handoff-form{gap:17px;padding:0 22px;display:grid}.form-intro{text-align:center}.form-intro h1{margin:12px 0 6px;font-size:27px}.form-intro p{color:var(--muted);margin:0 0 18px}.upload-avatar{background:var(--orange-soft);border:2px dashed #ffc078;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:112px;height:112px;margin:0 auto;font-size:54px;display:flex}.upload-avatar small{color:var(--orange);font-size:12px}label{gap:8px;font-weight:700;display:grid}input,textarea,select{border:1px solid var(--line);width:100%;min-height:48px;color:var(--brown);background:#fff;border-radius:14px;padding:12px 14px}textarea{resize:vertical;min-height:96px}.field-error,.form-error{color:#d64d3e;margin:0;font-size:13px}.field-label{font-weight:700}.segmented{background:#f5eadf;border-radius:16px;grid-template-columns:repeat(2,1fr);gap:8px;padding:5px;display:grid}.segmented button,.type-grid button{min-height:42px;color:var(--muted);background:0 0;border:0;border-radius:12px}.segmented button.selected,.type-grid button.selected{color:var(--orange);background:#fff;font-weight:800;box-shadow:0 5px 14px #53311914}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.type-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.type-grid button{border:1px solid var(--line);background:#fff}.danger-button{color:#d64d3e;background:0 0;border:0;justify-content:center;align-items:center;gap:8px;min-height:48px;font-weight:700;display:flex}.upload-box{min-height:120px;color:var(--orange);border:2px dashed #e7cbb4;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:5px;display:flex}.upload-box small{color:var(--muted)}.home-header{justify-content:space-between;align-items:flex-start;padding:30px 0 16px;display:flex}.home-header h1{margin:4px 0;font-size:28px}.home-header small{color:var(--muted)}.pet-card,.family-banner,.settings-pets{border:1px solid var(--line);text-align:left;width:100%;box-shadow:var(--shadow);background:#fff;border-radius:22px;align-items:center;gap:14px;padding:16px;display:flex}.pet-card>span:nth-child(2),.family-banner span,.settings-pets div{flex:1;gap:4px;display:grid}.pet-card small,.family-banner small,.settings-pets small{color:var(--muted)}.large-avatar{background:#ffddb2;border-radius:50%;place-items:center;width:72px;height:72px;font-size:44px;display:grid}.care-progress{background:linear-gradient(135deg,#fff0df,#fff8ec);border:1px solid #f8d8b9;border-radius:24px;grid-template-columns:120px 1fr;align-items:center;gap:18px;margin:16px 0;padding:18px;display:grid}.care-progress h2{margin:5px 0;font-size:20px}.care-progress p{color:var(--muted);font-size:13px}.progress-ring{border:10px solid #ffd8ad;border-top-color:var(--orange);border-right-color:var(--orange);text-align:center;border-radius:50%;place-content:center;width:112px;height:112px;display:grid;transform:rotate(-30deg)}.progress-ring>*{transform:rotate(30deg)}.progress-ring strong{font-size:27px}.progress-ring span{color:var(--muted);font-size:12px}.week-strip{border:1px solid var(--line);background:#fff;border-radius:18px;grid-template-columns:repeat(7,1fr);margin-bottom:20px;padding:14px 10px;display:grid}.week-strip span{place-items:center;gap:7px;display:grid}.week-strip small{color:var(--muted);font-size:11px}.week-strip i{background:var(--blue);border-radius:50%;width:5px;height:5px}.week-strip .today{color:var(--orange)}.section-title{justify-content:space-between;align-items:center;margin:20px 0 10px;display:flex}.section-title h2{margin:0;font-size:19px}.section-title button{color:var(--muted);background:0 0;border:0}.shortcut-grid{border:1px solid var(--line);background:#fff;border-radius:20px;grid-template-columns:repeat(4,1fr);padding:14px 6px;display:grid}.shortcut-grid button{background:0 0;border:0;place-items:center;gap:7px;font-size:12px;display:grid}.shortcut-grid svg{width:44px;height:44px;color:var(--blue);background:#eaf3ff;border-radius:14px;padding:10px}.shortcut-grid button:nth-child(2) svg{color:var(--orange);background:#fff0df}.shortcut-grid button:nth-child(3) svg{color:var(--green);background:#e8f8ee}.shortcut-grid button:nth-child(4) svg{color:#9367da;background:#f3eaff}.list-surface{border:1px solid var(--line);background:#fff;border-radius:20px;overflow:hidden}.task-row,.expense-row,.member-row{text-align:left;background:#fff;border:0;border-bottom:1px solid #f3e8df;align-items:center;gap:12px;width:100%;min-height:76px;padding:12px 14px;display:flex}.task-row:last-child,.expense-row:last-child,.member-row:last-child{border-bottom:0}.task-row>div,.expense-row>span,.member-row>span:nth-child(2){flex:1;gap:4px;display:grid}.task-row small,.expense-row small,.member-row small{color:var(--muted)}.task-icon{width:42px;height:42px;color:var(--orange);background:var(--orange-soft);border-radius:14px;place-items:center;display:grid}.task-icon.done{color:var(--green);background:#e8f8ee}.outline-mini{color:var(--orange);border:1px solid var(--orange);background:#fff;border-radius:999px;padding:7px 13px}.done-text{color:var(--green);font-size:13px}.family-banner{box-shadow:none;background:#fff5e8;margin-top:16px}.family-banner>svg{color:var(--orange)}.profile-hero,.detail-hero,.members-hero{text-align:center;padding:16px 0 24px}.profile-hero .large-avatar{margin:0 auto}.profile-hero h2,.detail-hero h2{margin:10px 0 5px;font-size:28px}.profile-hero p,.detail-hero p,.members-hero p{color:var(--muted)}.status-chip{color:var(--green);background:#e6f7ec;border-radius:999px;padding:7px 13px;font-size:13px;display:inline-block}.info-list,.soft-panel,.expense-total,.record-summary,.category-list{border:1px solid var(--line);background:#fff;border-radius:20px;margin-bottom:16px;padding:8px 16px}.info-row{border-bottom:1px solid #f4e9df;justify-content:space-between;align-items:center;gap:16px;min-height:50px;display:flex}.info-row:last-child{border-bottom:0}.info-row span{color:var(--muted)}.info-row strong{text-align:right}.soft-panel{padding:18px}.soft-panel h2{margin:0 0 12px;font-size:18px}.soft-panel p{line-height:1.7}.soft-panel small{color:var(--muted)}.stats{text-align:center;grid-template-columns:repeat(3,1fr);display:grid}.stats span{color:var(--muted);gap:5px;font-size:12px;display:grid}.stats b{color:var(--brown);font-size:22px}.pet-chip{border:1px solid var(--line);background:#fff;border-radius:999px;align-items:center;gap:5px;padding:4px 9px;font-weight:700;display:flex}.pet-avatar{font-size:25px}.calendar-card{border:1px solid var(--line);background:#fff;border-radius:22px;padding:18px 12px}.month-title{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.month-title strong{font-size:20px}.calendar-grid{text-align:center;grid-template-columns:repeat(7,1fr);align-items:center;gap:7px;display:grid}.calendar-grid button{aspect-ratio:1;background:0 0;border:0;border-radius:50%;position:relative}.calendar-grid button i{background:var(--orange);border-radius:50%;width:4px;height:4px;position:absolute;bottom:4px;left:50%}.calendar-grid .selected-day{background:var(--orange);color:#fff;font-weight:800}.circle-check{border:2px solid var(--orange);background:#fff;border-radius:50%;width:28px;height:28px}.done-button{color:var(--green);background:#e7f8ed;border:0;border-radius:999px;padding:7px 10px}.filter-tabs{gap:8px;padding-bottom:12px;display:flex;overflow:auto}.filter-tabs button{color:var(--muted);background:#fff;border:0;border-radius:999px;padding:9px 15px}.filter-tabs button.active{background:var(--orange);color:#fff}.record-summary{text-align:center;grid-template-columns:repeat(3,1fr);padding:14px;display:grid}.record-summary span{color:var(--muted);font-size:12px;display:grid}.record-summary b{color:var(--brown);font-size:20px}.timeline-item{text-align:left;background:0 0;border:0;align-items:center;gap:13px;width:100%;padding:14px 4px;display:flex}.timeline-item>div{flex:1;gap:4px;display:grid}.timeline-item strong{font-size:17px}.timeline-item small,.timeline-item p{color:var(--muted);margin:0}.timeline-icon{width:45px;height:45px;color:var(--blue);background:#e9f3ff;border-radius:15px;place-items:center;display:grid}.expense-total{text-align:center;padding:25px}.expense-total h2{margin:8px;font-size:38px}.expense-total p{color:var(--muted);font-size:12px}.budget-bar{background:#f3e7dd;border-radius:9px;height:8px;overflow:hidden}.budget-bar i{background:linear-gradient(90deg,var(--orange),var(--coral));height:100%;display:block}.category-list{padding:12px 16px}.category-list div{justify-content:space-between;padding:10px 0;display:flex}.category-list i{background:var(--orange);border-radius:50%;width:9px;height:9px;margin-right:9px;display:inline-block}.expense-row>svg{color:var(--orange)}.expense-row>b{color:#d65446}.handoff-card{box-shadow:var(--shadow);background:#fffdf8;border:8px solid #fff;border-radius:25px;outline:1px solid #f4dcc4;padding:22px}.handoff-card>h2{text-align:center;font-size:25px}.bunting{color:var(--orange);letter-spacing:10px}.handoff-pet{border-bottom:1px dashed #ebcba9;align-items:center;gap:15px;padding:14px 0;display:flex}.handoff-pet>span{font-size:65px}.handoff-pet strong{font-size:23px}.handoff-pet p{color:var(--muted)}.handoff-card section{border-bottom:1px dashed #ebcba9;padding:12px 0}.handoff-card section h3{color:var(--orange);margin:0 0 8px}.handoff-card section p{margin:0;line-height:1.6}.handoff-card>small{text-align:center;color:var(--muted);padding-top:16px;display:block}.dual-actions{grid-template-columns:1fr 1fr;gap:10px;margin-top:16px;display:grid}.dual-actions>*{padding:0 8px}.members-hero>svg{background:var(--orange-soft);width:62px;height:62px;color:var(--orange);border-radius:20px;padding:15px}.member-avatar{color:#a44f13;background:#ffe1bd;border-radius:50%;place-items:center;width:45px;height:45px;font-weight:800;display:grid}.user-profile{align-items:center;gap:14px;padding:20px 0;display:flex}.user-profile>div{flex:1}.user-profile h2,.user-profile p{margin:4px}.user-profile p{color:var(--muted)}.settings-list{border:1px solid var(--line);background:#fff;border-radius:20px;margin:18px 0;overflow:hidden}.settings-list button{text-align:left;background:#fff;border:0;border-bottom:1px solid #f2e6dc;align-items:center;gap:13px;width:100%;min-height:70px;padding:12px 15px;display:flex}.settings-list button:last-child{border-bottom:0}.settings-list button>svg:first-child{color:var(--orange)}.settings-list button span{flex:1;gap:4px;display:grid}.settings-list small{color:var(--muted)}.empty-state{text-align:center;color:var(--muted);padding:35px}.empty-state>svg{color:#ddbda2}.feedback-intro{background:#fff0df;border:1px solid #f7d4ae;border-radius:20px;align-items:center;gap:14px;margin-bottom:18px;padding:16px;display:flex}.feedback-intro>svg{color:var(--orange);width:38px;height:38px}.feedback-intro h2,.feedback-intro p{margin:3px}.feedback-intro p{color:var(--muted);font-size:13px}.feedback-form{padding:0!important}.feedback-success{text-align:center;padding:70px 20px}.feedback-success>svg{width:74px;height:74px;color:var(--green);background:#e6f7ec;border-radius:50%;padding:18px}.feedback-success h2{font-size:27px}.feedback-success p{color:var(--muted);line-height:1.7}.feedback-success .primary{margin-top:18px}@media (width>=700px){.app-page,.form-page,.login-page{border-radius:28px;min-height:calc(100vh - 32px);margin:16px auto;overflow:hidden;box-shadow:0 24px 70px #42291824}.bottom-nav{border-radius:0 0 28px 28px;bottom:16px}}html{background:#f4eee7}body{min-width:320px;min-height:100vh}
