:root{--bg: #0f1110;--card: #181b19;--card-soft: #20241f;--ink: #f7f3ea;--muted: #9b9488;--line: #2f352f;--green: #87d59a;--green-deep: #163323;--green-soft: #203b2a;--orange: #ff7347;--shadow: 0 22px 60px rgba(0, 0, 0, .34)}:root[data-theme=light]{--bg: #f6f1e7;--card: #fffaf1;--card-soft: #efe8db;--ink: #171512;--muted: #6f675c;--line: #d8cebd;--green: #4d9661;--green-deep: #dbeedc;--green-soft: #d9ecd8;--orange: #d86439;--shadow: 0 18px 50px rgba(55, 37, 18, .12)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 50% -10%,rgba(135,213,154,.14),transparent 28rem),var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}:root[data-theme=light] body{background:radial-gradient(circle at 50% -10%,rgba(77,150,97,.12),transparent 28rem),var(--bg)}button{border:0;font:inherit;cursor:pointer}.app{width:min(1180px,100%);margin:0 auto;padding:18px 16px calc(112px + env(safe-area-inset-bottom))}.site-footer{display:flex;align-items:center;justify-content:center;gap:12px;padding:28px 0 8px;color:var(--muted);font-size:.78rem}.site-footer a{color:inherit;text-decoration:none}.site-footer a:hover,.site-footer a:focus-visible{color:var(--ink)}.topbar[hidden],.site-footer[hidden]{display:none!important}.legal-page{width:min(720px,100%);margin:0 auto;padding:24px 16px 48px}.legal-back{display:inline-block;margin-bottom:18px;color:var(--muted);text-decoration:none}.legal-card{border:1px solid var(--line);border-radius:30px;background:var(--card);box-shadow:var(--shadow);padding:24px}.legal-card p{margin:0;color:var(--muted);font-size:.78rem;font-weight:900;text-transform:uppercase}.legal-card h1{margin:6px 0 0;font-size:clamp(2rem,8vw,3rem);line-height:1}.legal-copy{display:grid;gap:12px;margin-top:22px}.legal-copy p{color:var(--ink);font-size:.98rem;font-weight:450;line-height:1.5;text-transform:none}.topbar,.section-head,.leader-row{display:flex;align-items:center}.topbar{justify-content:space-between;margin-bottom:22px}.topbar p,.counter p,.section-head p{margin:0;color:var(--muted);font-size:.78rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.topbar-brand,.topbar-cta{border:0;background:transparent}.topbar-brand{padding:0;color:var(--ink);font-size:1.15rem;font-weight:950}.topbar-cta{padding:0;color:var(--muted);font-size:.88rem;font-weight:700;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.16em}.topbar-cta:hover,.topbar-cta:focus-visible{color:var(--ink);outline:none}.auth-card{display:grid;gap:16px;border:1px solid var(--line);border-radius:30px;background:var(--card);box-shadow:var(--shadow);margin-top:18px;padding:28px}.home-view[hidden],.auth-card[hidden],.auth-login[hidden],.invite-gate[hidden],.main-view[hidden],.app-panel[hidden],.bottom-nav[hidden]{display:none}.app-panel{display:grid}.home-view{display:grid;gap:18px;min-height:calc(100svh - 58px - env(safe-area-inset-bottom))}.home-hero{display:grid;gap:20px;min-height:calc(100svh - 58px - env(safe-area-inset-bottom));align-content:center;justify-items:center;padding:10px 0 18px;text-align:center}.home-hero p,.home-section>p,.home-faq>p{margin:0;color:var(--muted);font-size:.78rem;font-weight:900;text-transform:uppercase}.home-hero h1{max-width:13ch;margin:0 auto;font-size:clamp(3rem,9.5vw,6.15rem);line-height:.98;letter-spacing:-.04em}.home-hero h1 span{color:var(--orange)}.home-copy{max-width:34rem;margin:0 auto;color:var(--muted)!important;font-size:clamp(1.1rem,3.4vw,1.55rem)!important;font-weight:450!important;line-height:1.38;text-transform:none!important}.home-note{color:#f7f3eab8!important;font-size:.78rem!important;font-weight:600!important;letter-spacing:0;text-transform:none!important}.home-actions{display:grid;gap:10px}.home-invite-form{display:grid;grid-template-columns:minmax(0,1fr) 48px;align-items:center;width:min(100%,42rem);margin-top:-6px;border:1px solid var(--line);border-radius:22px;background:var(--card-soft);padding:6px}.home-invite-form input{min-height:52px;border:0;background:transparent;color:var(--ink);padding:0 16px;font:inherit}.home-invite-form input::placeholder{color:var(--muted)}.home-invite-form input:focus,.home-login-link:focus-visible{outline:2px solid rgba(247,243,234,.22);outline-offset:2px}.home-invite-submit{display:grid;width:48px;height:48px;place-items:center;border-radius:16px;background:#f7f3ea14;color:var(--ink);font-size:1.1rem;font-weight:950}.home-invite-submit:hover,.home-invite-submit:focus-visible{background:#f7f3ea24;outline:none}.home-primary,.home-secondary{min-height:60px;border-radius:22px;font-weight:950}.home-primary{background:var(--orange);color:#fff;box-shadow:0 18px 42px #f1734540}.home-secondary{border:1px solid var(--line);background:var(--card-soft);color:var(--ink)}.home-login-link{border:0;background:transparent;color:var(--ink);font:inherit;font-weight:700;text-decoration:underline;text-underline-offset:.18em}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.home-section,.home-faq{border:1px solid var(--line);border-radius:30px;background:var(--card);box-shadow:var(--shadow);padding:18px}.home-section,.home-faq{display:grid;gap:14px}.home-steps-section{border:0;border-radius:0;background:transparent;box-shadow:none;padding:42px 0 24px}.home-faq{border:0;border-radius:0;background:transparent;box-shadow:none;padding:18px 0}.home-features-section{border:0;border-radius:0;background:transparent;box-shadow:none;padding:48px 0 36px;text-align:center}.home-section h2,.home-faq h2{margin:0;font-size:clamp(2rem,6vw,3.25rem);line-height:1}.home-features-section h2{font-size:clamp(2.8rem,8.5vw,5rem);letter-spacing:-.04em}.home-section-copy{max-width:42rem;color:var(--muted)!important;font-size:clamp(1.05rem,2.8vw,1.35rem)!important;font-weight:450!important;line-height:1.45!important;text-transform:none!important}.home-features-section .home-section-copy{max-width:52rem;margin:0 auto 34px}.home-feature-grid{display:grid;gap:10px}.home-feature-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;text-align:left}.home-feature-grid article{border-radius:22px;background:var(--card-soft);padding:14px}.home-feature-grid article{min-height:268px;border:1px solid var(--line);border-radius:30px;background:var(--bg);box-shadow:0 14px 30px #00000038;padding:34px 32px 30px}.home-feature-grid span,.home-steps span{color:var(--green);font-size:.78rem;font-weight:950}.home-feature-grid span{display:grid;width:60px;height:60px;place-items:center;color:var(--orange)}.home-feature-grid svg{width:48px;height:48px;fill:currentColor}.home-feature-grid h3{margin:34px 0 12px;color:var(--ink);font-size:1.6rem;line-height:1.05}.leaderboard-copy{margin:2px 0 0;color:var(--muted);font-size:.98rem;line-height:1.45}.home-feature-grid p,.home-faq details p{margin:0;color:var(--muted);font-weight:400;line-height:1.48}.home-steps{margin:0;padding-left:1.25rem;display:grid;gap:10px;color:var(--ink);font-size:clamp(1.05rem,2.8vw,1.35rem);line-height:1.45;text-align:left}.home-faq details{border-top:1px solid var(--line);padding-top:12px}.home-faq summary{display:flex;align-items:center;justify-content:space-between;gap:16px;cursor:pointer;font-weight:950}.home-faq summary::marker{content:""}.home-faq summary:after{content:"›";flex:0 0 auto;color:var(--ink);font-size:1.4rem;line-height:1;transform:rotate(90deg)}.home-faq details:not([open]) summary:after{transform:rotate(0)}.home-faq details p{margin-top:8px}.auth-card h1{margin:0;font-size:clamp(2rem,8vw,3.35rem);line-height:1}.auth-card p,.auth-card span{color:var(--muted);font-weight:900}.auth-card p{margin:0}.auth-card form{display:grid;gap:14px}.auth-login,.invite-gate{display:grid;gap:18px}.auth-card label{display:grid;gap:9px}.auth-card input{min-height:60px;border:1px solid var(--line);border-radius:20px;background:var(--card-soft);color:var(--ink);font:inherit;font-weight:800;padding:0 18px}.auth-card input::placeholder{color:#69665f}.auth-button{min-height:60px;border-radius:20px;background:var(--orange);color:#fff;font-weight:950}.auth-button:disabled{cursor:default;opacity:.56}.auth-divider{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;color:var(--muted);font-size:.76rem;font-weight:900;text-transform:uppercase}.auth-divider:before,.auth-divider:after{content:"";height:1px;background:var(--line)}.google-button{display:flex;min-height:60px;align-items:center;justify-content:center;gap:12px;border:1px solid var(--line);border-radius:20px;background:var(--card-soft);color:var(--ink);font-weight:950}.google-button-primary{background:var(--ink);color:var(--bg);box-shadow:0 16px 36px #f7f3ea14}.google-button span{display:grid;width:30px;height:30px;place-items:center;border-radius:50%;background:var(--ink);color:var(--bg);font-weight:950}.google-button-primary span{background:var(--bg);color:var(--ink)}.change-invite{width:max-content;justify-self:center;background:transparent;color:var(--muted);font-size:.82rem;font-weight:900;text-decoration:underline;text-underline-offset:.18em}.counter{display:grid;place-items:center;min-height:315px;text-align:center;padding:30px 18px}.counter h1{margin:6px 0 0;font-size:clamp(7rem,36vw,14rem);line-height:.84;letter-spacing:0}.counter h1.bump{animation:score-bump .42s cubic-bezier(.2,1.7,.35,1)}.counter strong{display:block;color:var(--ink);font-size:clamp(1.35rem,6vw,2.3rem);letter-spacing:0}.actions{display:grid;grid-template-columns:1fr;gap:10px;margin-top:14px}.add-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.add-button{min-height:82px;border-radius:24px;background:var(--orange);color:#fff;font-size:clamp(1.45rem,7vw,2.2rem);font-weight:950;box-shadow:0 18px 42px #f1734547;transition:transform .14s ease}.add-button:active{transform:scale(.98)}.add-button.pop{animation:button-pop .42s cubic-bezier(.2,1.7,.35,1)}.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}.leaderboard-card{border:0;background:transparent;box-shadow:none}.stats article{display:grid;align-content:center;justify-items:center;min-height:86px;border-radius:24px;padding:14px 10px;text-align:center}.stats strong{display:block;font-size:1.5rem;line-height:1}.stats span{display:block;margin-top:7px;color:var(--muted);font-size:.75rem;font-weight:850;line-height:1.15}.leaderboard-card{margin-top:0;border-radius:0;padding:0}.week-card{margin-top:30px;padding:0}.goal-card{margin-top:26px}.goal-card[hidden]{display:none}.goal-card-head{margin-bottom:14px}.goal-card-head h2{margin:0;font-size:1.18rem;line-height:1.1}.week-card-head{margin-top:0}.goal-rings{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.goal-ring-item{display:grid;justify-items:center;gap:7px;min-width:0;border-radius:24px;background:var(--card-soft);padding:14px 10px;text-align:center}.goal-ring-visual{position:relative;display:grid;width:126px;max-width:100%;aspect-ratio:1;place-items:center}.goal-ring-visual svg{position:absolute;inset:0;width:100%;height:100%;transform:rotate(-90deg)}.goal-ring-track{fill:none;stroke:#f7f3ea26;stroke-width:12}.goal-ring-progress{fill:none;stroke-width:12;stroke-linecap:round;stroke-dasharray:327;stroke-dashoffset:var(--goal-offset);transition:stroke-dashoffset .42s cubic-bezier(.22,1,.36,1)}.goal-ring-center{position:absolute;inset:0;z-index:1;display:grid;align-content:center;gap:4px;justify-items:center;text-align:center}.goal-ring-visual strong{color:var(--ink);font-size:2.5rem;font-weight:950;line-height:.85}.goal-ring-visual span{color:var(--muted);font-size:.82rem;font-weight:500}.goal-ring-item p,.goal-ring-item small{margin:0}.goal-ring-item p{color:var(--ink);font-size:.95rem;font-weight:950}.goal-ring-item small{color:var(--muted);font-size:.86rem;font-weight:450;line-height:1.2}.goal-ring-item.complete .goal-ring-track{stroke:#85d7972e}.section-head{justify-content:space-between;gap:12px;margin-bottom:12px}.section-head h2{margin:2px 0 0;font-size:1.18rem;line-height:1.1}.section-head span{color:var(--green);font-size:.82rem;font-weight:900;text-align:right}.week-list{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:7px}.week-total{display:grid;gap:2px;margin-top:10px;color:var(--muted);font-size:.86rem;font-weight:450;line-height:1.2}.week-total strong,.week-total small{color:var(--muted);font-size:inherit;font-weight:inherit}.week-total .consistency-line{color:var(--muted)}.week-total .consistency-line strong{color:var(--ink);font-weight:900}.day-chip{display:grid;min-height:76px;align-content:center;justify-items:center;border-radius:18px;background:var(--card-soft);padding:10px 4px;text-align:center}.day-chip.level-0{background:#20231f}.day-chip.level-1{background:#203b2a}.day-chip.level-2{background:#255c34}.day-chip.level-3{background:#357f45}.day-chip.level-4{background:#49a85b}.day-chip.today{outline:2px solid var(--green)}.day-chip span{color:var(--muted);font-size:.7rem;font-weight:900;text-transform:uppercase}.day-chip small{display:block;margin-top:4px;color:var(--muted);font-size:.6rem;font-weight:500}.day-chip strong{display:block;margin-top:8px;color:var(--ink);font-size:clamp(1rem,4.5vw,1.35rem);line-height:1}.leaderboard{display:grid;gap:8px}.scoreboard-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin:18px 0 12px;border:1px solid var(--line);border-radius:18px;background:var(--card-soft);padding:5px}.scoreboard-tabs button{min-height:38px;border-radius:13px;background:transparent;color:var(--muted);font-size:.78rem;font-weight:900}.scoreboard-tabs button.active{background:var(--green-soft);color:var(--ink)}.leader-row{display:grid;grid-template-columns:36px 1fr auto;gap:10px;min-height:64px;border-radius:20px;background:var(--card-soft);padding:9px 22px 9px 10px}.leader-row.you{outline:2px solid var(--green);background:var(--green-soft)}.leader-row:first-child{background:#3b2d1f}.place{display:grid;width:36px;height:36px;place-items:center;border-radius:50%;background:#111311;font-weight:950}.person strong,.person span{display:block}.person span{margin-top:3px;color:var(--muted);font-size:.78rem;font-weight:800}.score{color:var(--green);font-weight:950;padding-left:16px}.toast{position:fixed;right:16px;bottom:calc(96px + env(safe-area-inset-bottom));left:16px;display:none;width:min(360px,calc(100% - 32px));margin:0 auto;border-radius:18px;background:#f7f3eaf5;color:var(--bg);padding:13px 16px;text-align:left;font-weight:900;box-shadow:0 16px 38px #1715123d;z-index:18}.toast.show{display:flex;align-items:center;justify-content:space-between;gap:18px}.toast button{flex:0 0 auto;background:transparent;color:var(--orange);font-size:.78rem;font-weight:950;letter-spacing:0}.bottom-nav{position:fixed;right:12px;bottom:calc(10px + env(safe-area-inset-bottom));left:12px;z-index:30;display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) 66px;gap:6px;width:min(700px,calc(100% - 24px));margin:0 auto;border:1px solid rgba(247,243,234,.1);border-radius:28px;background:#181b19e6;box-shadow:0 18px 50px #0000006b;padding:8px;backdrop-filter:blur(18px)}.nav-item,.nav-profile{display:grid;min-height:62px;place-items:center;border-radius:22px;background:transparent;color:#f7f3ea7a;font-size:.7rem;font-weight:900;line-height:1;transition:color .16s ease,background .16s ease,transform .16s ease}.nav-item{gap:5px}.nav-item span{font-size:.64rem}.nav-item svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.3}.nav-item.active{background:#87d59a21;color:var(--ink)}.nav-item:active,.nav-profile:active{transform:scale(.96)}.nav-profile{gap:4px;color:var(--muted)}.nav-profile span{display:grid;width:42px;height:42px;place-items:center;border-radius:50%;background:var(--green);color:var(--bg);font-size:1rem;font-weight:950}.nav-profile small{color:var(--muted);font-size:.64rem;font-weight:900}.profile-sheet[hidden],.analytics-sheet[hidden]{display:none}.profile-sheet{position:fixed;inset:0;z-index:40;display:grid;align-items:end}.analytics-sheet{width:100%;margin:0;padding:0}.analytics-sheet .sheet-backdrop,.analytics-sheet .sheet-close{display:none}.sheet-backdrop{position:absolute;inset:0;background:#00000085}.sheet-panel{position:relative;z-index:1;width:min(720px,calc(100% - 24px));max-height:calc(100vh - 24px - env(safe-area-inset-bottom));overflow:auto;margin:0 auto calc(12px + env(safe-area-inset-bottom));border:1px solid var(--line);border-radius:30px;background:var(--card);box-shadow:0 28px 80px #0000007a;padding:18px}.sheet-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.sheet-head p{margin:0;color:var(--muted);font-size:.78rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.sheet-head h2{margin:3px 0 0;font-size:1.6rem}.profile-title-row{display:flex;align-items:center;gap:8px}.edit-username-button{display:grid;width:34px;height:34px;flex:0 0 auto;place-items:center;border-radius:50%;background:var(--card-soft);color:var(--green)}.edit-username-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.2}.profile-email,.profile-public-hint{display:block;margin-top:4px;color:var(--muted);font-size:.78rem;font-weight:750;line-height:1.2}.profile-public-hint{margin-top:0;color:#f7f3ea75;font-weight:650}.sheet-close{display:grid;width:42px;height:42px;place-items:center;border-radius:50%;background:var(--card-soft);color:var(--ink);font-size:1.5rem;font-weight:900}.profile-section,.username-box{display:grid;gap:0;margin-top:18px;border-radius:22px;background:#f7f3ea06;padding:0 16px}.profile-section{border:1px solid rgba(247,243,234,.08)}.profile-section-head{padding:16px 0}.profile-section-head h3,.theme-box h3{margin:0;color:var(--ink);font-size:1.08rem;line-height:1.1}.profile-section-head p,.theme-box p,.settings-row small,.settings-actions p,.danger-row small,.invite-box small{margin:4px 0 0;color:var(--muted);font-size:.78rem;font-weight:550;line-height:1.35;text-transform:none}.theme-box{grid-template-columns:minmax(0,1fr) auto;align-items:center;column-gap:16px;padding:16px}.theme-toggle{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;width:132px;border:1px solid var(--line);border-radius:999px;background:var(--bg);padding:4px}.theme-toggle button{min-height:34px;border-radius:999px;background:transparent;color:var(--muted);font-size:.78rem;font-weight:850}.theme-toggle button.active{background:var(--green);color:var(--bg)}.settings-row,.danger-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(112px,160px);gap:16px;align-items:center;border-top:1px solid rgba(247,243,234,.08);padding:14px 0}.settings-row strong,.danger-row strong{display:block;color:var(--ink);font-size:.98rem;line-height:1.2}.settings-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center;border-top:1px solid rgba(247,243,234,.08);padding:14px 0 16px}.username-box[hidden],.goal-box[hidden]{display:none}.username-box label,.invite-box label{display:grid;gap:7px}.username-box span,.username-box p,.goal-box span{margin:0;color:var(--muted);font-size:.78rem;font-weight:900}.username-box span{text-transform:uppercase}.username-box input,.goal-box input,.invite-box input{width:100%;min-height:50px;border:1px solid var(--line);border-radius:18px;background:var(--card-soft);color:var(--ink);font:inherit;font-size:.86rem;font-weight:750;padding:0 12px}.invite-code-box,.create-invite-button,.save-username-button,.save-goals-button,.daily-reset-button,.logout-button{min-height:52px;border-radius:18px;font-weight:950}.invite-code-box{width:100%;min-height:56px;border:1px solid var(--line);background:var(--card-soft);color:var(--ink);padding:0 14px;text-align:left;font-size:1.05rem;font-weight:950;transition:transform .16s ease,box-shadow .18s ease,background .18s ease}.invite-code-box[hidden]{display:block;opacity:.5}.invite-actions{display:grid;grid-template-columns:minmax(0,1fr) 52px;gap:10px;align-items:center;padding-bottom:16px}.create-invite-button{min-height:52px;padding:0;border:1px solid var(--line);background:var(--card-soft);color:var(--muted);font-size:1.15rem;line-height:1;transition:transform .16s ease,box-shadow .18s ease,background .18s ease}.invite-code-box:active,.create-invite-button:active,.invite-code-box.is-working,.create-invite-button.is-working{transform:scale(.985)}.invite-code-box.is-confirmed,.create-invite-button.is-confirmed{border-color:var(--green);background:var(--card-soft);color:var(--ink);box-shadow:0 0 0 3px #85d79747,0 16px 42px #85d79747;transform:translateY(-1px) scale(1.01)}.create-invite-button.is-confirmed{background:var(--green-soft);color:var(--ink)}.create-invite-button:disabled{cursor:default;opacity:.55}.save-username-button,.save-goals-button{background:var(--green);color:var(--bg)}.save-goals-button{min-width:136px}.save-goals-button:disabled{cursor:default;opacity:.55}.danger-box{border-color:#ff734761;background:#ff734712}.danger-box .profile-section-head h3,.danger-row strong{color:var(--orange)}.danger-row{border-top-color:#ff73473d}.daily-reset-button{border:1px solid rgba(255,115,71,.52);background:#ff73471a;color:var(--orange)}.daily-reset-button.confirming{background:var(--orange);color:#fff;transform:scale(.99)}.daily-reset-button:disabled{cursor:default;opacity:.45}.save-username-button:disabled{cursor:default;opacity:.55}.logout-button{width:100%;border:1px solid rgba(255,115,71,.42);background:#ff73471a;color:var(--orange)}.analytics-panel{display:grid;gap:14px;width:100%;margin:0 auto}.analytics-hero{display:grid;justify-items:center;border-radius:26px;background:var(--green-soft);padding:20px;text-align:center}.analytics-hero span,.analytics-hero small,.analytics-grid span,.analytics-divider span,.heatmap-head span,.heatmap-head small{color:var(--muted);font-size:.76rem;font-weight:650;line-height:1.05;text-transform:uppercase}.analytics-hero strong{color:var(--ink);font-size:clamp(4rem,24vw,7rem);line-height:.9}.analytics-grid span{white-space:normal}.analytics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.analytics-period-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.analytics-grid article{display:grid;gap:8px;align-content:center;min-height:102px;border:1px solid var(--line);border-radius:22px;background:var(--card-soft);padding:14px}.analytics-grid strong{color:var(--ink);font-size:1.75rem;line-height:1}.analytics-divider{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center;margin:2px 0}.analytics-divider:before,.analytics-divider:after{content:"";height:1px;background:var(--line)}.heatmap-card{border:1px solid var(--line);border-radius:24px;background:var(--card-soft);padding:16px}.heatmap-head{display:grid;grid-template-columns:1fr auto;align-items:center;gap:12px;margin-bottom:12px}.heatmap-head h3{margin:3px 0 0;font-size:1.18rem;text-transform:capitalize}.heatmap-head small{grid-column:1 / -1;font-weight:600;text-transform:none}.heatmap-controls{display:inline-grid;grid-template-columns:repeat(2,38px);gap:8px}.heatmap-controls button{display:grid;width:38px;height:38px;place-items:center;border:1px solid var(--line);border-radius:12px;background:var(--card);color:var(--ink);font-size:1.4rem;font-weight:900;line-height:1}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:7px;margin-bottom:7px;padding-bottom:8px;border-bottom:1px solid var(--line)}.calendar-weekdays span{color:var(--muted);font-size:.72rem;font-weight:900;text-align:center}.heatmap-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:7px}.heatmap-cell{display:grid;aspect-ratio:1.04;min-height:0;align-content:center;justify-items:center;gap:3px;border:1px solid rgba(247,243,234,.05);border-radius:12px;background:#232822;box-shadow:inset 0 1px #f7f3ea08;padding:6px;text-align:center;transition:transform .16s ease,border-color .16s ease,background .16s ease}.heatmap-cell.empty{visibility:hidden}.heatmap-cell span{color:#f7f3ea8a;font-size:clamp(.47rem,1.4vw,.62rem);font-weight:750;line-height:1;text-transform:uppercase}.heatmap-cell strong{color:var(--ink);font-size:clamp(.95rem,2.8vw,1.35rem);line-height:1}.heatmap-cell.level-0 strong{color:#f7f3ea47}.heatmap-cell.level-1{background:#293f2b}.heatmap-cell.level-2{background:#365b31}.heatmap-cell.level-3{background:#4f7a38}.heatmap-cell.level-4{background:#68a843}.heatmap-cell.level-5{background:linear-gradient(135deg,#8bd790,#f77b48)}.heatmap-cell.level-5 span,.heatmap-cell.level-5 strong,.heatmap-cell.level-4 span,.heatmap-cell.level-4 strong{color:#0f1110}.heatmap-cell.today{border-color:var(--ink);outline:2px solid rgba(247,243,234,.82);outline-offset:2px}.heatmap-cell.streak{box-shadow:inset 0 -3px #f7f3ea8c,0 10px 24px #85d7971f}.heatmap-legend{display:flex;align-items:center;gap:5px;margin-top:13px;color:var(--muted);font-size:.68rem;font-weight:850;text-transform:uppercase}.heatmap-legend i{display:block;width:13px;height:13px;border-radius:4px;background:#232822}.heatmap-legend .level-1{background:#293f2b}.heatmap-legend .level-2{background:#365b31}.heatmap-legend .level-3{background:#4f7a38}.heatmap-legend .level-4{background:#68a843}.heatmap-legend .level-5{background:linear-gradient(135deg,#8bd790,#f77b48)}@media(max-width:560px){.theme-box,.settings-row,.danger-row,.settings-actions{grid-template-columns:1fr}.theme-toggle{width:100%}.home-feature-grid{grid-template-columns:1fr}.home-feature-grid article{min-height:188px}.heatmap-cell{border-radius:8px;padding:5px}}.burst-layer{position:fixed;inset:0;z-index:7;pointer-events:none;overflow:hidden}.spark{position:absolute;width:9px;height:9px;border-radius:50%;background:var(--spark-color, var(--green));opacity:0;transform:translate(-50%,-50%) scale(.4);animation:spark-fly .72s ease-out forwards}@keyframes score-bump{0%{transform:scale(1)}45%{transform:scale(1.08)}to{transform:scale(1)}}@keyframes button-pop{0%{transform:scale(1);filter:brightness(1)}38%{transform:scale(1.04);filter:brightness(1.15)}to{transform:scale(1);filter:brightness(1)}}@keyframes spark-fly{0%{opacity:0;transform:translate(-50%,-50%) scale(.35)}18%{opacity:1}to{opacity:0;transform:translate(calc(-50% + var(--spark-x)),calc(-50% + var(--spark-y))) scale(1)}}@media(min-width:760px){body{display:grid;place-items:start center}.app{display:block;padding-top:36px}.topbar{margin-bottom:0}.counter{min-height:380px;margin-top:22px}}@media(max-width:520px){.week-list{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:380px){.app{padding-right:12px;padding-left:12px}.counter{min-height:285px}.stats{gap:8px}.add-grid{gap:6px}.add-button{min-height:72px;border-radius:20px}}
