:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,PingFang SC,sans-serif;--bg: #ffffff;--mint: #f1fbf6;--mint-strong: #e2f7ec;--surface: rgba(255, 255, 255, .92);--text: #13211a;--muted: #63736a;--subtle: #91a099;--line: #dfeae4;--green: #17a86b;--green-dark: #0e7d50;--green-soft: #dcf5e8;--lemon: #f4c84a;--lemon-soft: #fff6cf;--coral: #ef6b59;--coral-soft: #fff0ed;--shadow: 0 20px 60px rgba(28, 74, 48, .12);--soft-shadow: 0 10px 30px rgba(28, 74, 48, .08)}*{box-sizing:border-box}html{min-width:320px;min-height:100%;background:var(--bg)}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh;background:radial-gradient(circle at 50% -120px,rgba(23,168,107,.17),transparent 300px),linear-gradient(180deg,var(--mint),#ffffff 42%);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea{font:inherit}button{cursor:pointer;-webkit-tap-highlight-color:transparent}button,input,textarea{border-radius:8px}button:focus-visible,input:focus-visible,textarea:focus-visible{outline:3px solid rgba(23,168,107,.2);outline-offset:2px}.app-shell{width:min(100%,450px);min-height:100vh;min-height:100dvh;margin:0 auto;padding:env(safe-area-inset-top) 10px 92px}.phone-stage{position:relative;min-height:100vh;min-height:100dvh}.app-header{position:sticky;z-index:10;top:0;display:flex;align-items:center;justify-content:space-between;gap:14px;margin:0 -10px;padding:14px 18px 12px;background:#f3fbf7db;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid rgba(223,234,228,.74)}.brand-line{display:flex;align-items:center;gap:10px;min-width:0}.brand-mark{display:grid;flex:0 0 auto;width:42px;height:42px;place-items:center;border:1px solid rgba(23,168,107,.25);border-radius:8px;background:linear-gradient(145deg,var(--green),var(--green-dark));color:#fff;font-size:23px;font-weight:900;box-shadow:0 14px 26px #17a86b3d}.brand-line h1,.brand-line p,.progress-copy h2,.progress-copy p,.section-title h2,.section-title p,.report-hero p,.report-hero h2,.report-hero span,.review-card h2,.strategy-card h2,.strategy-card p,.install-card h2,.install-card p,.sync-card h2,.sync-card p{margin:0}.brand-line h1{font-size:25px;line-height:1;letter-spacing:0}.brand-line p{margin-top:5px;color:var(--muted);font-size:13px;line-height:1.2;white-space:nowrap}.header-actions{display:flex;align-items:center;gap:7px}.round-button,.date-chip,.share-button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;border:1px solid var(--line);background:#ffffffdb;color:var(--text)}.round-button{width:38px}.date-chip{gap:5px;padding:0 10px;color:var(--green-dark);font-size:13px;font-weight:850}.mobile-main{padding:14px 0 0}.screen-flow{display:grid;gap:14px}.progress-hero,.week-strip-card,.review-card,.report-hero,.strategy-card,.install-card,.sync-card{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--soft-shadow)}.progress-hero{position:relative;display:grid;grid-template-columns:78px minmax(0,1fr) 36px;gap:12px;align-items:center;min-height:122px;padding:14px;overflow:hidden}.progress-hero:before{position:absolute;top:0;right:0;bottom:0;left:0;content:"";background:linear-gradient(135deg,#dcf5e8f5,#ffffff94);pointer-events:none}.progress-hero.gold:before{background:linear-gradient(135deg,var(--lemon-soft),rgba(255,255,255,.62))}.progress-hero.coral:before{background:linear-gradient(135deg,var(--coral-soft),rgba(255,255,255,.62))}.progress-hero>*{position:relative}.progress-orbit{display:grid;width:78px;height:78px;place-items:center;border-radius:50%;background:conic-gradient(var(--green) var(--progress),#dfe9e3 0deg)}.progress-orbit div{display:grid;width:58px;height:58px;place-items:center;border-radius:50%;background:#fff;box-shadow:inset 0 0 0 1px #dfeae4e6}.progress-orbit strong{margin-bottom:-16px;font-size:29px;line-height:1}.progress-orbit span{color:var(--muted);font-size:14px;font-weight:850}.progress-copy{min-width:0}.progress-copy p{color:var(--green-dark);font-size:13px;font-weight:850}.progress-copy h2{margin-top:5px;font-size:21px;line-height:1.16;letter-spacing:0}.progress-copy span{display:block;margin-top:6px;color:var(--muted);font-size:13px;line-height:1.45}.share-button{width:36px;min-height:36px;color:var(--green-dark)}.week-strip-card{padding:9px}.week-strip-card.compact{margin-top:-4px}.week-strip{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:7px}.week-day{display:grid;gap:4px;justify-items:center;min-width:0;min-height:64px;padding:7px 3px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--muted)}.week-day span{font-size:12px;font-weight:760}.week-day i{display:grid;width:24px;height:24px;place-items:center;border-radius:8px;background:var(--mint);color:var(--muted);font-size:12px;font-style:normal;font-weight:850}.week-day strong{color:var(--text);font-size:13px;line-height:1}.week-day.win i{background:var(--green);color:#fff}.week-day.today{border-color:#17a86b6b}.week-day.selected{border-color:#17a86ba8;box-shadow:inset 0 0 0 1px #17a86b33}.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;padding:2px 2px 0}.section-title.tight{align-items:flex-start;padding:0}.section-title h2{font-size:20px;line-height:1.2}.section-title p{margin-top:5px;color:var(--muted);font-size:13px;line-height:1.45}.section-title>span{flex:0 0 auto;color:var(--green-dark);font-size:13px;font-weight:850}.habit-list{display:grid;gap:9px}.habit-row{display:grid;grid-template-columns:26px 38px minmax(0,1fr) 32px;gap:9px;align-items:center;width:100%;min-height:70px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);text-align:left;box-shadow:0 8px 22px #1c4a300e;transition:transform .16s ease,border-color .16s ease,background .16s ease}.habit-row:active,.quick-button:active,.bottom-nav button:active{transform:scale(.985)}.habit-row.done{border-color:#17a86b6b;background:linear-gradient(90deg,#dcf5e8f0,#fffffff5)}.habit-index{color:var(--green-dark);font-size:24px;font-weight:900;text-align:center}.habit-symbol,.habit-check{display:grid;place-items:center;border-radius:8px}.habit-symbol{width:38px;height:38px;background:var(--mint);color:var(--green-dark)}.habit-row.done .habit-symbol{background:var(--green);color:#fff}.habit-text{display:grid;gap:3px;min-width:0}.habit-text span{display:flex;align-items:baseline;flex-wrap:wrap;gap:7px}.habit-text strong{font-size:16px;line-height:1.2}.habit-text em{color:var(--subtle);font-size:12px;font-style:normal;font-weight:800}.habit-text small{overflow:hidden;color:var(--muted);font-size:12px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.habit-check{width:30px;height:30px;border:1px solid var(--line);color:#fff}.habit-row.done .habit-check{border-color:var(--green);background:var(--green)}.quick-action{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:2px 0}.quick-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;border:0;border-radius:8px;background:var(--green);color:#fff;font-size:15px;font-weight:900;box-shadow:0 18px 38px #17a86b47}.quick-action span{display:grid;width:48px;height:48px;place-items:center;border:1px solid var(--line);border-radius:8px;background:#ffffffeb;color:var(--green-dark);font-size:14px;font-weight:900;box-shadow:var(--soft-shadow)}.bottom-nav{position:fixed;z-index:25;right:max(10px,calc((100vw - 430px)/2 + 10px));bottom:max(10px,env(safe-area-inset-bottom));left:max(10px,calc((100vw - 430px)/2 + 10px));display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px;padding:7px;border:1px solid rgba(223,234,228,.9);border-radius:8px;background:#ffffffeb;box-shadow:0 18px 52px #1c4a302e;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.bottom-nav button{display:grid;gap:4px;min-height:52px;place-items:center;border:0;border-radius:8px;background:transparent;color:var(--muted);font-size:12px;font-weight:850}.bottom-nav button.active{background:var(--green-soft);color:var(--green-dark)}.report-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px;background:linear-gradient(135deg,var(--mint-strong),#ffffff)}.report-hero p,.report-hero span,.report-medal span{color:var(--muted);font-size:13px;font-weight:760}.report-hero h2{margin-top:4px;font-size:46px;line-height:1}.report-hero span{display:block;margin-top:7px}.report-medal{display:grid;justify-items:center;gap:5px;min-width:96px;padding:14px 10px;border:1px solid rgba(23,168,107,.24);border-radius:8px;background:#fffc;color:var(--green-dark)}.report-medal strong{font-size:18px}.day-list{display:grid;gap:8px}.day-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:10px;align-items:center;width:100%;min-height:64px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);text-align:left}.day-row.selected{border-color:#17a86b8c;background:var(--mint)}.day-row span{display:grid;gap:4px;font-weight:850}.day-row em{color:var(--muted);font-size:12px;font-style:normal;font-weight:650}.day-row strong{color:var(--green-dark);font-size:18px}.day-row i{min-width:48px;padding:5px 8px;border-radius:8px;background:var(--green-soft);color:var(--green-dark);font-size:12px;font-style:normal;font-weight:850;text-align:center}.review-card{display:grid;gap:13px;padding:16px}.review-card textarea,.text-input{width:100%;border:1px solid var(--line);background:var(--mint);color:var(--text);font-size:15px}.review-card textarea{min-height:148px;resize:vertical;padding:13px 14px;line-height:1.6}.text-input{min-height:48px;padding:0 13px}.review-card textarea::placeholder,.text-input::placeholder{color:#98a7a0}.segmented-control{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.segmented-control button{min-height:46px;border:1px solid var(--line);background:#fff;color:var(--muted);font-size:14px;font-weight:850}.segmented-control button.selected{border-color:#17a86b7a;background:var(--green-soft);color:var(--green-dark)}.strategy-card{display:flex;gap:12px;align-items:flex-start;padding:16px;background:linear-gradient(135deg,var(--green-soft),#ffffff)}.strategy-card svg{flex:0 0 auto;color:var(--green-dark)}.strategy-card h2,.install-card h2{font-size:18px;line-height:1.25}.strategy-card p,.install-card p{margin-top:8px;color:var(--muted);font-size:14px;line-height:1.6}.settings-list{display:grid;gap:8px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;min-height:72px;padding:13px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);text-align:left;box-shadow:0 8px 22px #1c4a300b}.settings-row.action{cursor:pointer}.settings-row.danger{color:#af3f32}.settings-row span{display:grid;gap:5px}.settings-row strong{font-size:16px}.settings-row em{color:var(--muted);font-size:13px;font-style:normal;line-height:1.45}.settings-row svg{flex:0 0 auto;color:var(--green-dark)}.settings-row.danger svg{color:#af3f32}.settings-row input{position:absolute;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}.sync-card{display:grid;gap:13px;padding:16px}.sync-card .section-title svg{flex:0 0 auto;color:var(--green-dark)}.sync-secret{display:grid;gap:8px}.sync-secret span{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:13px;font-weight:850}.sync-secret input{width:100%;min-height:48px;border:1px solid var(--line);background:var(--mint);color:var(--text);padding:0 13px;font-size:15px}.sync-status{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:44px;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:#fff}.sync-status strong{font-size:14px;line-height:1.35}.sync-status em{flex:0 0 auto;color:var(--muted);font-size:12px;font-style:normal;font-weight:760}.sync-status.success{border-color:#17a86b59;background:var(--green-soft)}.sync-status.error{border-color:#ef6b5961;background:var(--coral-soft)}.sync-status.syncing{border-color:#f4c84a94;background:var(--lemon-soft)}.sync-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px}.sync-actions button{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:48px;border:1px solid rgba(23,168,107,.35);background:#fff;color:var(--green-dark);font-size:14px;font-weight:900}.sync-actions button:first-child{border-color:var(--green);background:var(--green);color:#fff}.install-card{padding:16px}.toast{position:fixed;z-index:50;right:max(22px,calc((100vw - 430px)/2 + 22px));bottom:calc(86px + env(safe-area-inset-bottom));left:max(22px,calc((100vw - 430px)/2 + 22px));padding:12px 14px;border-radius:8px;background:#13211aeb;color:#fff;font-size:14px;font-weight:760;text-align:center;box-shadow:0 14px 40px #13211a33}@media(min-width:760px){body{background:radial-gradient(circle at 50% -120px,rgba(23,168,107,.14),transparent 360px),linear-gradient(180deg,var(--mint),#ffffff 48%)}.app-shell{padding-top:18px}.phone-stage{min-height:calc(100vh - 36px);border:1px solid rgba(223,234,228,.9);border-radius:8px;background:#ffffff8f;box-shadow:var(--shadow);overflow:clip}.app-header{margin:0}}@media(max-width:370px){.app-shell{padding-right:8px;padding-left:8px}.progress-hero{grid-template-columns:78px minmax(0,1fr)}.progress-orbit{width:78px;height:78px}.progress-orbit div{width:58px;height:58px}.progress-orbit strong{font-size:28px}.share-button{position:absolute;top:10px;right:10px}.habit-row{grid-template-columns:24px 36px minmax(0,1fr) 30px;gap:8px}.habit-symbol{width:36px;height:36px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important}}
