@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--c-ink:#1b1b1f;--c-ink-soft:#3f3f46;--c-ink-fade:#6b6b73;--c-line:#e9e7e2;--c-card:#fff;--c-bg:#f8f5f0;--c-accent:#ff6b35;--c-accent-strong:#f4511e;--c-accent-cool:#1d9a6c;--c-accent-sky:#1e88e5;--shadow-soft:0 18px 45px rgba(19,19,24,.08);--shadow-hard:0 10px 30px rgba(19,19,24,.12);--radius-xl:28px;--radius-lg:20px;--radius-md:14px;--radius-sm:10px}*,:after,:before{box-sizing:border-box}body{background:radial-gradient(circle at 8% 12%,rgba(255,227,204,.6),transparent 48%),radial-gradient(circle at 90% 20%,rgba(191,236,219,.6),transparent 45%),linear-gradient(120deg,#fffefb,#f8f5f0 52%,#f7f3ee);color:var(--c-ink);font-family:Space Grotesk,Plus Jakarta Sans,Segoe UI,sans-serif;margin:0;min-height:100vh;scroll-padding-top:120px;scroll-snap-type:y proximity}html{height:100%;-webkit-text-size-adjust:100%}body,html{overscroll-behavior:none}.btn,.icon-btn,a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}a{color:inherit;text-decoration:none}ul{display:grid;gap:10px;list-style:none;margin:18px 0;padding:0}ul li:before{color:var(--c-accent);content:"•";margin-right:8px}img{display:block;max-width:100%}.page-shell{flex-direction:column}.app-shell,.page-shell{display:flex;min-height:100vh}.app-shell{background:var(--c-bg)}.sidebar{background:#fff;border-right:1px solid hsla(43,14%,90%,.9);bottom:0;display:flex;flex-direction:column;gap:24px;left:0;padding:24px 18px;position:fixed;top:0;width:240px;z-index:45}.sidebar-top{align-items:center;display:flex;gap:12px;justify-content:space-between}.sidebar-toggle{height:34px;width:34px}.sidebar.collapsed{align-items:center;padding:20px 12px;width:80px}.sidebar-brand{align-items:center;display:flex;gap:10px}.sidebar-logo{border-radius:12px;box-sizing:border-box;display:block;height:44px;-o-object-fit:contain;object-fit:contain;padding:4px;width:44px}.sidebar-logo.compact,.sidebar.collapsed .sidebar-logo.full{display:none}.sidebar.collapsed .sidebar-logo.compact{display:block;transform:scale(.85)}.sidebar-nav{display:grid;gap:8px}.sidebar-group-toggle,.sidebar-nav a{align-items:center;background:transparent;border:none;border-radius:12px;color:var(--c-ink-soft);cursor:pointer;display:flex;font-weight:600;gap:10px;padding:10px 12px;text-align:left;width:100%}.sidebar.collapsed .sidebar-group-toggle,.sidebar.collapsed .sidebar-nav a{justify-content:center;position:relative}.sidebar.collapsed .sidebar-group-toggle span,.sidebar.collapsed .sidebar-nav a span{display:none}.sidebar.collapsed .sidebar-group-toggle:after,.sidebar.collapsed .sidebar-nav a:after{background:#1f1f22;border-radius:8px;box-shadow:var(--shadow-hard);color:#fff;content:attr(data-label);font-size:12px;left:calc(100% + 12px);opacity:0;padding:6px 10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap}.sidebar.collapsed .sidebar-group-toggle:hover:after,.sidebar.collapsed .sidebar-nav a:hover:after{opacity:1}.sidebar-group-toggle i,.sidebar-nav a i{font-size:16px}.sidebar-group-toggle:hover,.sidebar-group-toggle[aria-expanded=true],.sidebar-nav a.router-link-active,.sidebar-nav a:hover{background:#1d9a6c1f;color:var(--c-ink)}.sidebar-group{display:grid;gap:6px}.sidebar-group-toggle span{flex:1;text-align:left}.sidebar-subnav{display:grid;gap:4px;padding-left:10px}.sidebar-subnav a{align-items:center;background:#1d9a6c14;border-radius:10px;color:var(--c-ink-soft);display:flex;font-weight:600;gap:10px;padding:10px 12px}.sidebar-subnav a.router-link-active,.sidebar-subnav a:hover{background:#1d9a6c29;color:var(--c-ink)}.sidebar.collapsed .sidebar-group-toggle i:last-child,.sidebar.collapsed .sidebar-group-toggle span{display:none}.sidebar.collapsed .sidebar-group-toggle{justify-content:center;position:relative}.sidebar.collapsed .sidebar-subnav{display:none}.sidebar-download{display:grid;gap:10px;margin-top:auto}.sidebar-download-trigger{align-items:center;background:#1b1b1f0a;border:none;border-radius:12px;color:var(--c-ink);cursor:pointer;display:flex;font-weight:600;gap:10px;justify-content:space-between;padding:12px 14px}.sidebar-download-trigger .chevron{color:var(--c-ink-fade);font-size:12px;margin-left:auto}.sidebar-download-trigger span{flex:1;text-align:left}.sidebar-download-menu{display:grid;gap:6px;padding-left:6px}.sidebar-download-menu a{align-items:center;background:#1d9a6c14;border-radius:10px;color:var(--c-ink);display:flex;font-weight:600;gap:8px;padding:8px 12px}.sidebar-download-menu a:hover{background:#1d9a6c29}.sidebar.collapsed .sidebar-download-trigger .chevron,.sidebar.collapsed .sidebar-download-trigger span{display:none}.sidebar.collapsed .sidebar-download-trigger{justify-content:center;position:relative}.sidebar.collapsed .sidebar-download-trigger:after{background:#1f1f22;border-radius:8px;box-shadow:var(--shadow-hard);color:#fff;content:attr(data-label);font-size:12px;left:calc(100% + 12px);opacity:0;padding:6px 10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);white-space:nowrap}.sidebar.collapsed .sidebar-download-trigger:hover:after{opacity:1}.sidebar.collapsed .sidebar-download-menu{display:none}.app-content{display:flex;flex:1;flex-direction:column;margin-left:240px;min-height:100vh}.app-shell.collapsed .app-content{margin-left:80px}.mobile-nav{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffeb;border:1px solid hsla(43,14%,90%,.8);border-radius:999px;bottom:18px;box-shadow:0 18px 30px #1313181f;display:none;gap:6px;grid-auto-rows:auto;grid-template-columns:repeat(4,minmax(0,1fr));left:16px;padding:10px 14px;position:fixed;right:16px;z-index:90}.mobile-nav.open{border-radius:24px;padding-top:12px}.mobile-nav-extra{display:grid;gap:6px;grid-column:1/-1;grid-template-columns:repeat(2,minmax(0,1fr));max-height:0;opacity:0;pointer-events:none;transform:translateY(8px);transition:max-height .25s ease,opacity .2s ease,transform .2s ease}.mobile-nav.open .mobile-nav-extra{margin-bottom:4px;max-height:90px;opacity:1;pointer-events:auto;transform:translateY(0)}.mobile-nav a,.mobile-nav button{align-items:center;background:transparent;border:none;border-radius:16px;color:var(--c-ink-soft);cursor:pointer;display:flex;flex-direction:column;font-size:11px;font-weight:600;gap:4px;padding:8px 10px;transition:transform .2s ease,background .2s ease}.mobile-nav a i,.mobile-nav button i{font-size:18px}.mobile-nav a.router-link-active,.mobile-nav button.active{background:#1d9a6c29;color:var(--c-ink);transform:translateY(-4px)}.topbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb;border-bottom:1px solid hsla(43,14%,90%,.7);position:sticky;top:0;z-index:40}.topbar-inner{align-items:center;display:flex;gap:16px;justify-content:space-between;margin:0 auto;max-width:1240px;padding:18px 32px}.topbar-title h2{margin:0}.tracker-quick{align-items:center;display:flex;gap:10px}.tracker-quick-btn{align-items:center;background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:999px;color:var(--c-ink-soft);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12px;font-weight:600;gap:8px;min-height:36px;padding:8px 12px}.tracker-quick-btn small{color:var(--c-ink-fade);font-size:11px}.tracker-quick-btn.active{background:#1d9a6c1f;border-color:#1d9a6c66;color:var(--c-ink)}.tracker-quick-btn.active small{color:#0f6d4b}.tracker-quick-btn:disabled{cursor:wait;opacity:.6}.topbar-eyebrow{color:var(--c-ink-fade);font-size:12px;letter-spacing:.08em;margin:0;text-transform:uppercase}.user-area{position:relative}.user-trigger{align-items:center;background:#fff;border:1px solid rgba(27,27,31,.16);border-radius:999px;cursor:pointer;display:inline-flex;font-family:inherit;font-weight:600;gap:8px;padding:8px 12px}.user-trigger i{font-size:16px}.user-dropdown{background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:14px;box-shadow:var(--shadow-hard);display:grid;gap:6px;min-width:170px;padding:8px;position:absolute;right:0;top:calc(100% + 10px)}.user-dropdown button{align-items:center;background:transparent;border:none;border-radius:10px;color:var(--c-ink);cursor:pointer;display:flex;font-family:inherit;font-size:14px;gap:8px;padding:8px 10px;text-align:left}.user-dropdown button:hover{background:#ff6b351f}.user-dropdown .danger{color:#e53935}.main.app-main{padding:28px 28px 80px}.dashboard-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;margin-bottom:28px}.dashboard-actions{display:flex;gap:12px}.dashboard-grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}.tasks-card{display:grid;gap:20px}.tasks-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between}.task-add-row{align-items:center;background:#fff;border:1px solid hsla(43,14%,90%,.9);border-radius:16px;display:grid;gap:10px;grid-template-columns:1.5fr .8fr 1fr auto;padding:12px}.task-add-row input,.task-add-row select{background:#fff;border:1px solid rgba(27,27,31,.14);border-radius:12px;font-family:inherit;padding:8px 10px}.tasks-list{display:grid;gap:6px}.task-row{align-items:center;background:#fff;border:1px solid hsla(43,14%,90%,.8);border-radius:14px;display:grid;gap:10px;grid-template-columns:28px minmax(0,1fr) auto;padding:10px 12px}.task-row,.task-row-child{padding-left:calc(12px + var(--indent))}.task-row-child{background:#f7f7fb;grid-template-columns:1fr auto}.task-check{align-items:center;font-size:20px;justify-content:center}.task-check,.task-title{background:transparent;border:none;cursor:pointer;display:inline-flex}.task-title{color:var(--c-ink);gap:8px;padding:0;text-align:left}.task-meta,.task-title-wrap{align-items:center;display:inline-flex;gap:8px}.task-meta{justify-self:end}.task-due{font-size:12px;font-weight:600}.task-add-child,.task-toggle{background:transparent;border:none;color:var(--c-ink-fade);cursor:pointer;font-size:16px}.task-add-child{border:1px dashed rgba(27,27,31,.2);border-radius:10px;padding:4px}.task-child-inputs{align-items:center;display:grid;gap:10px;grid-template-columns:minmax(0,1.4fr) .8fr 1fr;padding-left:0}.task-child-inputs input,.task-child-inputs select{background:#fff;border:1px solid rgba(27,27,31,.14);border-radius:12px;font-family:inherit;padding:8px 10px}.task-child-actions{display:flex;gap:8px;justify-content:flex-end}.task-fab{align-items:center;background:var(--c-ink);border:none;border-radius:50%;bottom:120px;box-shadow:var(--shadow-hard);color:#fff;cursor:pointer;display:none;font-weight:600;height:54px;justify-content:center;position:fixed;right:18px;width:54px;z-index:95}.task-fab i{font-size:16px}.priority-urgent{color:#e5484d}.priority-important{color:#f0ad4e}.priority-medium{color:#1e88e5}.priority-normal{color:#9aa0a6}.profile-card{display:grid;gap:24px}.profile-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between}.profile-grid{display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}.tasks-group-wrap{display:grid;gap:16px;margin-top:16px}.task-group{background:#fff;border:1px solid hsla(43,14%,90%,.9);border-radius:16px;padding:14px}.task-group-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.task-group-header h3{font-size:16px;margin:0}.profile-section{background:#fff;border:1px solid hsla(43,14%,90%,.8);border-radius:16px;display:grid;gap:14px;padding:18px}.profile-section h3{margin:0}.card-title{align-items:center;display:flex;gap:10px}.card-title i{color:var(--c-ink-soft);font-size:18px}.compact-card{gap:10px;padding:16px}.security-action{align-items:center;background:#fff;border:1px solid rgba(27,27,31,.2);border-radius:999px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:10px;justify-content:center;padding:12px 18px}.security-action:hover{border-color:#1b1b1f59}.profile-actions{align-items:center;display:flex;flex-wrap:wrap;gap:14px}.save-message{color:var(--c-ink-fade);font-size:13px}.username-status{align-items:center;color:var(--c-ink-fade);display:inline-flex;font-size:12px;gap:8px;min-height:18px}.username-status.available{color:var(--c-accent-cool)}.username-status.taken{color:#e53935}.username-status.error{color:#b71c1c}.danger-zone{border-color:#e5393533}.confirm-check{align-items:center;color:var(--c-ink-soft);display:flex;font-size:14px;gap:10px}.confirm-check input{height:16px;width:16px}.btn.profile-inline{width:auto}.tasks-row:not(.header):not(.add-row):not(.child-row){cursor:pointer}.tasks-row.header{background:#f9f7f2;border:1px solid hsla(43,14%,90%,.8);color:var(--c-ink-fade);font-size:12px;letter-spacing:.08em;text-transform:uppercase}.tasks-row.add-row{background:#fffaf6}.task-title{align-items:center;display:flex;font-weight:600;gap:10px;padding-left:calc(6px + var(--indent, 0px))}.task-title input{border:1px solid rgba(27,27,31,.14);border-radius:12px;font-family:inherit;padding:8px 12px;width:100%}.task-status{background:#1b1b1f14;color:var(--c-ink);justify-content:center}.status-select,.task-status{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:600;padding:6px 10px;width:-moz-fit-content;width:fit-content}.status-select{gap:6px}.status-select select{background:transparent;border:none;color:inherit;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600}.status-select select:disabled{cursor:wait}.status-select .spinner{border-color:currentColor rgba(27,27,31,.2) rgba(27,27,31,.2)}.status-todo{background:#1e88e51f;color:#0b4f9c}.status-progressing{background:#ff6b3529;color:#b63b14}.status-on-hold{background:#78787824;color:#4a4a4a}.status-completed{background:#1d9a6c2e;color:#0f5132}.status-closed{background:#4caf502e;color:#1b5e20}.task-add-child{background:transparent;border:none;color:var(--c-ink-fade);cursor:pointer}.tasks-actions-col{align-items:center;display:flex;gap:8px;justify-content:flex-end}.tasks-row select{background:#fff;border:1px solid rgba(27,27,31,.14);border-radius:12px;font-family:inherit;padding:8px 12px;width:100%}.child-row{background:#f7f7fb}.stat-tile{display:grid;gap:8px}.status-breakdown{display:grid;gap:6px;margin-top:6px}.stat-list{display:grid;gap:6px;margin-top:8px}.stat-row,.status-row{align-items:center;color:var(--c-ink-soft);display:flex;font-size:12px;justify-content:space-between}.filter-card{display:grid;gap:18px}.filter-block{display:flex;flex-direction:column;gap:12px}.filter-title{color:var(--c-ink-soft);font-size:14px;font-weight:600;margin:0}.habit-pills{display:flex;flex-wrap:wrap;gap:10px}.habit-pill{align-items:center;background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:999px;cursor:pointer;display:inline-flex;font-size:13px;gap:8px;padding:8px 12px;transition:all .2s ease}.habit-pill input{opacity:0;pointer-events:none;position:absolute}.habit-pill input:disabled+span{color:var(--c-ink-fade)}.habit-pill.selected{background:#1d9a6c1f;border-color:#1d9a6c66;color:var(--c-ink)}.progress-card{display:grid;gap:18px}.progress-header{justify-content:space-between}.progress-actions,.progress-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.progress-actions{justify-content:flex-end}.mode-switch{background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:999px;display:inline-flex;gap:4px;padding:4px}.mode-switch button{align-items:center;background:transparent;border:none;border-radius:999px;color:var(--c-ink-soft);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12px;font-weight:600;gap:6px;padding:6px 12px}.mode-switch button.active{background:#1d9a6c24;color:var(--c-ink)}.mode-switch button i{font-size:14px}.progress-scroll,.progress-table{display:grid;gap:12px}.progress-scroll{max-height:340px;overflow:auto;padding-right:4px}.progress-row{align-items:center;display:grid;gap:12px;grid-template-columns:1.4fr 2fr .4fr}.progress-row.header{color:var(--c-ink-fade);font-size:13px;letter-spacing:.08em;text-transform:uppercase}.progress-name{font-weight:600}.progress-bar{background:#1b1b1f14;border-radius:999px;height:10px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(130deg,var(--c-accent),var(--c-accent-strong));border-radius:inherit;height:100%;transition:width .3s ease}.progress-fill.skeleton-fill{animation:shimmer 1.4s ease infinite;background:linear-gradient(90deg,#1b1b1f14,#1b1b1f2e,#1b1b1f14);background-size:200% 100%;width:100%}.progress-percent{font-weight:600;text-align:right}.chart-card{display:grid;gap:16px}.chart-header{gap:12px;justify-content:space-between}.chart-header,.chart-legend{align-items:center;display:flex;flex-wrap:wrap}.chart-legend{gap:14px}.legend-item{align-items:center;color:var(--c-ink-soft);display:inline-flex;font-size:13px;gap:8px}.legend-dot{border-radius:50%;height:10px;width:10px}.chart-wrap{background:linear-gradient(180deg,#fffffff2,#f9f6f1f2);border:1px solid hsla(43,14%,90%,.9);border-radius:18px;min-height:320px;overflow:hidden;position:relative;width:100%}.chart-svg{height:320px;width:100%}.chart-grid line{stroke:#1b1b1f14;stroke-dasharray:3 6}.chart-line{fill:none;filter:drop-shadow(0 8px 12px rgba(29,154,108,.15));stroke-linecap:round;stroke-linejoin:round;stroke-width:3}.chart-hover-line{stroke:#1b1b1f26;stroke-dasharray:4 6}.chart-hover-dot{fill:#fff;r:5;stroke-width:2}.chart-labels text{fill:#1b1b1f73;font-size:11px}.chart-tooltip{background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:14px;box-shadow:var(--shadow-soft);color:var(--c-ink);display:grid;font-size:12px;gap:6px;min-width:170px;padding:12px 14px;position:absolute;top:16px;transform:translate(-50%)}.chart-tooltip p{font-weight:600;margin:0}.tooltip-row{align-items:center;color:var(--c-ink-soft);display:flex;font-size:12px;gap:8px}.tooltip-dot{border-radius:50%;height:8px;width:8px}.tooltip-value{color:var(--c-ink);font-weight:600;margin-left:auto}.chart-loading{align-items:center;background:#ffffffd9;display:flex;gap:10px;inset:0;justify-content:center;position:absolute}.chart-loading,.empty-state{color:var(--c-ink-fade);font-size:14px}.habit-card{padding:28px}.habit-header{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between}.habit-filters{flex-wrap:wrap;gap:16px}.habit-filters,.search-field{align-items:center;display:flex}.search-field{background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:999px;gap:10px;padding:8px 12px;position:relative}.search-field input{border:none;font-family:inherit;font-size:14px;min-width:200px;outline:none}.search-field .spinner{border-color:#1b1b1f33;border-top-color:var(--c-ink)}.date-switch{align-items:center;background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:999px;padding:6px}.date-selects,.date-switch{display:flex;gap:8px}.date-selects select{background:transparent;border:none;font-family:inherit;font-size:14px;padding:6px 8px}.icon-btn{align-items:center;background:#1b1b1f0d;border:none;border-radius:999px;cursor:pointer;display:inline-flex;height:30px;justify-content:center;width:30px}.icon-btn.danger{background:#e539351f;color:#c62828}.habit-table-wrap{background:#fff;border:1px solid hsla(43,14%,90%,.9);border-radius:18px;margin-top:24px;max-height:460px;overflow:auto}.habit-grid{--day-count:30;--first-col:240px}.habit-grid,.habit-row{min-width:-moz-max-content;min-width:max-content}.habit-row{display:grid;grid-template-columns:var(--first-col) repeat(var(--day-count),42px)}.habit-cell{align-items:center;background:#fff;border-bottom:1px solid hsla(43,14%,90%,.7);border-right:1px solid hsla(43,14%,90%,.7);display:flex;justify-content:center;min-height:44px;padding:10px}.habit-header-row .habit-cell{background:#f9f7f2;font-weight:600;position:sticky;top:0;z-index:6}.habit-sticky{font-weight:600;justify-content:flex-start;left:0;padding-left:16px;position:sticky;z-index:4}.habit-header-row .habit-sticky{z-index:8}.habit-link,.habit-title{font-weight:600}.habit-link{background:transparent;border:none;color:var(--c-ink);cursor:pointer;font-family:inherit;text-align:left}.habit-link:hover{color:var(--c-accent-strong)}.habit-title-content{align-items:center;display:flex;gap:12px;justify-content:space-between;width:100%}.progress-donut{--progress:0;background:conic-gradient(var(--c-accent-cool) calc(var(--progress)*1%),rgba(27,27,31,.08) 0);border-radius:50%;color:var(--c-ink);display:grid;font-size:11px;font-weight:600;height:44px;place-items:center;position:relative;width:44px}.progress-donut:after{background:#fff;border-radius:50%;box-shadow:inset 0 0 0 1px #1b1b1f0d;content:"";inset:6px;position:absolute}.progress-donut span{position:relative;z-index:1}.skeleton-bar{animation:shimmer 1.4s ease infinite;background:linear-gradient(90deg,#1b1b1f14,#1b1b1f2e,#1b1b1f14);background-size:200% 100%;border-radius:999px;height:18px;width:100%}.habit-check-btn{align-items:center;background:transparent;border:none;cursor:pointer;display:inline-flex;height:24px;justify-content:center;padding:0;width:24px}.habit-check-btn i{font-size:18px}.habit-check-btn.locked{color:#b7b3ad}.habit-check-btn.empty{color:#d0cdc8}.habit-check-btn.checked{color:#1d9a6c}.habit-check-btn.warning{color:#d1a22c}.habit-check-btn:disabled{cursor:not-allowed;opacity:.55}.habit-add .habit-cell{background:#fffaf6}.habit-summary .habit-cell{background:#f8faf7}.summary-label{color:var(--c-ink-soft);font-weight:600}.summary-pill{color:var(--c-ink-fade);display:grid;font-size:11px;gap:2px}.tracker-card{display:grid;gap:24px;padding:28px}.tracker-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between}.tracker-actions{display:flex;flex-wrap:wrap;gap:10px}.tracker-live{align-items:center;background:#1d9a6c1f;border-radius:999px;color:#0f6d4b;display:inline-flex;font-size:12px;font-weight:600;gap:8px;padding:6px 12px}.tracker-dot{background:#1d9a6c;border-radius:50%;box-shadow:0 0 0 4px #1d9a6c33;height:8px;width:8px}.tracker-chart{display:grid;gap:14px;touch-action:pan-y}.chart-title{color:var(--c-ink);font-weight:600}.bar-chart{align-items:stretch;background:#fff;border:1px solid hsla(43,14%,90%,.9);border-radius:16px;display:grid;gap:8px;grid-template-columns:repeat(7,minmax(0,1fr));height:200px;padding:12px}.bar-item{align-items:end;color:var(--c-ink-fade);display:grid;font-size:12px;gap:4px;grid-template-rows:1fr auto auto;height:100%;justify-items:center;text-align:center;width:100%}.bar-item span{color:var(--c-ink);font-weight:600;line-height:1.1;width:100%}.bar-item small{font-size:11px;line-height:1.1;width:100%}.bar{align-self:end;background:linear-gradient(160deg,#1d9a6c,#3cc694);border-radius:12px;height:calc(var(--bar-percent, 0)*1%);justify-self:center;margin:0 auto;max-width:48px;min-height:6px;transition:height .3s ease;width:100%}.bar.empty{background:#1b1b1f1f;min-height:4px}.tracker-table{border:1px solid hsla(43,14%,90%,.9);border-radius:16px;display:grid;overflow:hidden;-webkit-overflow-scrolling:touch}.tracker-row{align-items:center;background:#fff;border-bottom:1px solid hsla(43,14%,90%,.7);display:grid;gap:12px;grid-template-columns:1.3fr 1.3fr .8fr .4fr;padding:12px 16px}.tracker-row.header{background:#f9f7f2;color:var(--c-ink-fade);font-size:12px;font-weight:600;text-transform:uppercase}.tracker-empty{padding:16px}.tracker-cell-btn{background:transparent;border:none;color:var(--c-ink);cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;text-align:left}.tracker-cell-btn:focus-visible{border-radius:8px;outline:2px solid rgba(29,154,108,.4)}.tracker-duration{color:var(--c-ink-soft);font-weight:600}.tracker-actions-col{display:flex;justify-content:flex-end}.summary-pill span{color:var(--c-ink);font-weight:600}.add-habit{align-items:center;display:flex;gap:10px;width:100%}.add-habit input{border:1px solid rgba(27,27,31,.14);border-radius:12px;flex:1;font-family:inherit;padding:8px 12px}.habit-placeholder{border:1px dashed rgba(27,27,31,.2);border-radius:4px;height:18px;width:18px}.habit-loading{align-items:center;color:var(--c-ink-fade);display:flex;font-size:14px;gap:10px;margin-top:16px}.view-switch{margin-left:auto}.calendar-wrap{background:#fff;border:1px solid hsla(43,14%,90%,.9);border-radius:18px;margin-top:24px;overflow:auto}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(120px,1fr));min-width:840px}.calendar-header{background:#f9f7f2;color:var(--c-ink-fade);font-size:12px;font-weight:600;letter-spacing:.08em;padding:12px 14px;text-transform:uppercase}.calendar-cell,.calendar-header{border-bottom:1px solid hsla(43,14%,90%,.7)}.calendar-cell{background:#fff;border-right:1px solid hsla(43,14%,90%,.7);cursor:pointer;display:flex;flex-direction:column;gap:8px;min-height:120px;padding:10px;text-align:left}.calendar-cell:disabled{cursor:default}.calendar-cell.empty{background:#fcfbf8;cursor:default}.calendar-day{color:var(--c-ink);font-weight:600}.calendar-tags{display:grid;gap:6px}.calendar-tag{background:#1d9a6c1f;border-radius:999px;color:var(--c-ink);font-weight:600;max-width:100%;overflow:hidden;padding:4px 8px;text-overflow:ellipsis;white-space:nowrap}.calendar-more,.calendar-tag{align-items:center;display:inline-flex;font-size:11px}.calendar-more{background:transparent;border:none;color:var(--c-ink-soft);cursor:pointer;gap:6px;padding:0}.date-habit-list{display:grid;gap:10px}.date-habit-item{align-items:center;color:var(--c-ink);display:flex;font-size:14px;gap:10px}.date-habit-item input{height:16px;width:16px}.modal-backdrop{background:#0f0f1266;display:grid;inset:0;padding:24px;place-items:center;position:fixed;z-index:120}.modal-card{background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:20px;box-shadow:var(--shadow-hard);display:grid;gap:16px;padding:24px;width:min(520px,100%)}.modal-card.confirm{max-width:480px}.modal-header{align-items:center;display:flex;justify-content:space-between}.modal-header h3{margin:0}.modal-body textarea{border:1px solid rgba(27,27,31,.16);border-radius:12px;font-family:inherit;font-size:15px;padding:12px 14px;resize:vertical}.log-count,.save-status{align-items:center;color:var(--c-ink-fade);display:flex;font-size:13px;gap:8px}.log-count strong{color:var(--c-ink)}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn.danger{background:#e5393514;border:1px solid rgba(229,57,53,.45);box-shadow:none;color:#b71c1c}.btn.danger:hover{background:#e539351f}.nav-wrap{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffe6;border-bottom:1px solid hsla(43,14%,90%,.6);left:0;position:fixed;right:0;top:0;z-index:50}.nav{display:grid;gap:24px;grid-template-columns:auto 1fr auto;margin:0 auto;max-width:1240px;padding:18px 28px}.brand,.nav{align-items:center}.brand{display:flex;font-size:22px;font-weight:700;gap:10px;letter-spacing:-.02em}.brand-logo{display:block;height:30px;width:auto}.brand-name{color:var(--c-ink);font-size:18px;font-weight:700}.nav-toggle{display:none}.desktop-only{display:inline-flex}.nav-links{color:var(--c-ink-soft);display:flex;font-size:15px;gap:24px;justify-content:center}.nav-links a{border-radius:999px;padding:8px 10px;transition:all .2s ease}.nav-links a.router-link-active,.nav-links a:hover{background:#ff6b351f;color:var(--c-ink)}.nav-dropdown{position:relative}.nav-dropdown-trigger{align-items:center;background:transparent;border:none;border-radius:999px;color:var(--c-ink-soft);cursor:pointer;display:inline-flex;font-family:inherit;font-size:15px;gap:6px;padding:8px 10px}.nav-dropdown-trigger:hover{background:#ff6b351f;color:var(--c-ink)}.nav-dropdown-menu{background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:12px;box-shadow:var(--shadow-hard);display:grid;gap:6px;left:0;min-width:180px;padding:8px;position:absolute;top:calc(100% + 8px);z-index:55}.nav-dropdown-menu a{align-items:center;border-radius:10px;color:var(--c-ink);display:flex;font-weight:600;gap:8px;padding:8px 10px}.nav-dropdown-menu a:hover{background:#1d9a6c1f}.nav-actions{align-items:center;display:flex;gap:12px}.mobile-menu-backdrop{background:#0c0c1066;inset:0;position:fixed;z-index:55}.mobile-menu{background:#fff;box-shadow:-18px 0 30px #14141a1f;display:flex;flex-direction:column;gap:22px;height:100%;padding:24px;position:fixed;right:0;top:0;width:min(320px,86vw);z-index:56}.mobile-menu-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.mobile-menu-links{display:grid;gap:8px}.mobile-menu-links a{border-radius:12px;color:var(--c-ink);font-weight:600;padding:10px 12px}.mobile-menu-links a:hover{background:#ff6b351f}.mobile-menu-toggle{align-items:center;background:#1b1b1f0a;border:none;border-radius:12px;color:var(--c-ink);cursor:pointer;display:flex;font-family:inherit;font-weight:600;gap:10px;justify-content:space-between;padding:10px 12px}.mobile-menu-sub{display:grid;gap:8px;padding-left:8px}.mobile-menu-sub a{align-items:center;background:#1b1b1f0a;border-radius:10px;color:var(--c-ink);display:flex;font-weight:600;gap:8px;padding:8px 10px}.mobile-menu-sub a:hover{background:#1d9a6c1f}.mobile-menu-actions{display:grid;gap:10px;margin-top:auto}.btn{align-items:center;border:1px solid transparent;border-radius:999px;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 18px;transition:transform .2s ease,box-shadow .2s ease}button.btn{background:transparent;cursor:pointer;font-family:inherit}.btn.primary{background:linear-gradient(130deg,var(--c-accent),var(--c-accent-strong));box-shadow:0 12px 25px #ff6b3559;color:#fff}.btn.ghost{background:#fff;border-color:#1b1b1f33;color:var(--c-ink)}.btn:hover{transform:translateY(-1px)}.btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.spinner{animation:spin .8s linear infinite;border:2px solid hsla(0,0%,100%,.35);border-radius:50%;border-top-color:#fff;height:16px;width:16px}.spinner-sm{border-width:2px;height:14px;width:14px}.btn.ghost .spinner{border-color:#1b1b1f40;border-top-color:var(--c-ink)}.main{flex:1;padding:110px 24px 72px}.section{margin:0 auto 56px;max-width:1240px}.hero{display:grid;gap:40px;grid-template-columns:1.15fr .85fr}.eyebrow,.hero{align-items:center}.eyebrow{background:#1e88e524;border-radius:999px;color:#0b4f9c;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:6px 14px}.hero h1{font-size:clamp(38px,4vw,56px);letter-spacing:-.03em;line-height:1.05;margin:18px 0 14px}.hero p{color:var(--c-ink-fade);font-size:17px;line-height:1.6;margin-bottom:22px}.hero-actions{display:flex;flex-wrap:wrap;gap:14px}.download-links{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.download-links a{align-items:center;display:inline-flex;gap:8px}.home .snap-section{scroll-margin-top:120px;scroll-snap-align:start}.feature-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.preview-section{position:relative}.preview-showcase{align-items:center;display:grid;gap:36px;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr)}.preview-showcase.reverse{grid-template-columns:minmax(0,1.1fr) minmax(0,1fr)}.preview-showcase.reverse .preview-content{order:2}.preview-showcase.reverse .preview-stack{order:1}.preview-content ul{margin-top:16px}.preview-stack{min-height:360px;position:relative}.preview-frame{background:linear-gradient(145deg,#ffffffe6,#fff1e5d9);border:1px solid hsla(43,14%,90%,.9);border-radius:24px;box-shadow:0 22px 40px #13131829;padding:12px;position:relative}.preview-frame img{border-radius:18px;display:block;width:100%}.preview-frame-pc{width:min(720px,100%)}.preview-frame-mobile{background:linear-gradient(145deg,#ffffffeb,#ffe8d6e0);bottom:-16px;box-shadow:0 18px 32px #13131833;padding:10px;position:absolute;right:-12px;width:min(240px,48%)}.hero-visual{background:linear-gradient(160deg,#ffffffeb,#ffffffb3),radial-gradient(circle at top,rgba(255,107,53,.18),transparent 55%),radial-gradient(circle at bottom,rgba(29,154,108,.2),transparent 55%);border:1px solid hsla(43,14%,90%,.8);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);overflow:hidden;padding:30px;position:relative}.hero-visual:after{background:radial-gradient(circle,rgba(255,107,53,.4),transparent 70%);content:"";height:160px;position:absolute;right:-60px;top:-60px;width:160px}.stats-grid{display:grid;gap:18px;margin-top:22px}.stat-card{background:var(--c-card);border:1px solid hsla(43,14%,90%,.9);border-radius:var(--radius-md);box-shadow:0 12px 20px #1111180d;padding:18px 20px}.stat-value{font-size:22px;font-weight:700}.stat-label{color:var(--c-ink-fade);font-size:13px}.grid{display:grid;gap:22px}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:var(--c-card);border:1px solid hsla(43,14%,90%,.95);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:24px}.card h3{margin-top:0}.pill{align-items:center;background:#1d9a6c24;border-radius:999px;color:#0f5132;display:inline-flex;font-size:12px;font-weight:600;gap:8px;padding:6px 12px}.form-wrap{background:var(--c-card);border:1px solid hsla(43,14%,90%,.95);border-radius:var(--radius-xl);box-shadow:var(--shadow-hard);margin:0 auto;max-width:520px;padding:32px}.form-wrap h2{font-size:28px;margin-top:0}.form-field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.form-field label{font-size:14px;font-weight:600}.form-field input{border:1px solid rgba(27,27,31,.16);border-radius:12px;font-family:inherit;font-size:15px;padding:12px 14px}.form-field input:focus{border-color:#ff6b35b3;outline:2px solid rgba(255,107,53,.4)}.rules{color:var(--c-ink-fade);font-size:13px;gap:6px;list-style:disc;margin:12px 0 0;padding-left:18px}.rules li:before{content:none}.rules li.is-valid{color:var(--c-accent-cool)}.form-foot{align-items:center;color:var(--c-ink-fade);display:flex;font-size:14px;justify-content:space-between}.pricing-card{overflow:hidden;position:relative}.pricing-card.highlight{background:linear-gradient(160deg,#fffffff2,#fff5eef2);border:2px solid rgba(255,107,53,.5)}.pricing-amount{font-size:36px;font-weight:700;margin:16px 0 6px}.badge{background:#1e88e529;border-radius:999px;color:#0b4f9c;font-size:12px;font-weight:600;padding:6px 12px;position:absolute;right:18px;top:18px}.support-card{background:var(--c-card);border:1px solid hsla(43,14%,90%,.95);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:24px}.footer{background:#ffffffeb;border-top:1px solid hsla(43,14%,90%,.8);padding:40px 24px 24px}.footer-grid{display:grid;gap:24px;grid-template-columns:1.5fr 1fr 1fr;margin:0 auto;max-width:1150px}.footer-brand{font-size:20px;font-weight:700}.footer-logo{display:block;height:28px;width:auto}.footer-text{color:var(--c-ink-fade);margin-bottom:16px;margin-top:10px}.footer-title{font-weight:600;margin-bottom:10px}.footer-links a,.footer-links p{color:var(--c-ink-fade);display:block;margin:6px 0}.text-link{color:var(--c-accent);font-weight:600}.footer-bottom{color:var(--c-ink-fade);font-size:13px;margin:24px auto 0;max-width:1150px}.toast-host{bottom:24px;display:grid;gap:12px;position:fixed;right:24px;z-index:80}.toast{align-items:center;background:#fff;border:1px solid rgba(27,27,31,.12);border-radius:14px;box-shadow:var(--shadow-hard);display:flex;font-size:14px;gap:12px;min-width:240px;padding:14px 18px}.toast-success{border-left:4px solid var(--c-accent-cool)}.toast-error{border-left:4px solid #e53935}.toast-info{border-left:4px solid var(--c-accent-sky)}.toast-close{background:transparent;border:none;color:var(--c-ink-fade);cursor:pointer;font-size:12px;margin-left:auto}.reveal{animation:rise-in .7s ease both;animation-delay:var(--delay,0s)}@keyframes rise-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:0 50%}to{background-position:-200% 50%}}@media(max-width:980px){.grid.cols-2,.grid.cols-3,.hero{grid-template-columns:1fr}.nav{align-items:center;display:flex;grid-template-columns:none;justify-content:space-between;text-align:left}.nav-links{display:none}.nav-actions{gap:10px;justify-content:flex-end}.nav-toggle{display:inline-flex}.desktop-only{display:none}.footer-grid{grid-template-columns:1fr}.toast-host{left:16px;right:16px}.preview-showcase{grid-template-columns:1fr}.preview-showcase.reverse .preview-content{order:1}.preview-showcase.reverse .preview-stack{order:2}.preview-stack{min-height:320px}.preview-frame-mobile{bottom:-10px;right:6px;width:min(220px,46%)}.stats-grid{grid-template-columns:1fr}.hero-visual{padding:24px}.preview-showcase{gap:24px}.app-shell{flex-direction:column}.sidebar{align-items:center;flex-direction:row;height:auto;justify-content:space-between;padding:16px 20px;position:sticky}.sidebar,.sidebar.collapsed{width:100%}.app-shell.collapsed .app-content{margin-left:0}.sidebar-nav{display:flex;gap:10px}.app-content{margin-left:0}.topbar-inner{align-items:center;flex-direction:row;justify-content:space-between;padding:18px 20px}.habit-header{align-items:flex-start;flex-direction:column}.habit-filters,.search-field{width:100%}.search-field input{min-width:0;width:100%}.date-switch{justify-content:space-between;width:100%}.view-switch{justify-content:center;margin-left:0;width:100%}.calendar-grid{min-width:700px}.calendar-cell{min-height:100px}.dashboard-grid{display:flex;gap:12px;grid-template-columns:none;overflow-x:auto;padding:6px 16px 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.dashboard-grid::-webkit-scrollbar{display:none}.dashboard-grid .stat-tile{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#ffffffd1,#ffd6b8b3),radial-gradient(circle at top right,rgba(255,107,53,.22),transparent 55%);border:1px solid hsla(0,0%,100%,.6);border-radius:24px;box-shadow:0 14px 30px #13131829;min-width:78%;overflow:hidden;scroll-snap-align:center}.dashboard-grid .stat-tile .footer-text,.dashboard-grid .stat-tile .stat-label{color:#1b1b1fb3}.progress-row{gap:8px;grid-template-columns:1fr}.progress-percent{text-align:left}.progress-scroll{max-height:300px}.profile-grid{grid-template-columns:1fr}.tracker-row{grid-template-columns:1fr 1fr .8fr .4fr}.chart-svg{height:280px}}@media(max-width:600px){.main{padding-top:140px}.sidebar{display:none}.mobile-nav{display:grid}.main.app-main{background:#fff;padding:0 0 140px}.topbar-inner{padding:14px 16px}.topbar-title h2{font-size:16px}.app-content{background:#fff}.main.app-main .section{margin:0;max-width:none;padding:0}.main.app-main .card{border-left:none;border-radius:0;border-right:none;box-shadow:none}.tasks-card{padding-left:0;padding-right:0}.user-trigger{padding:8px}.dashboard-actions,.dashboard-header>div:first-child,.habit-header>div:first-child,.tasks-header>div:first-child,.tracker-header>div:first-child,.user-trigger .user-caret,.user-trigger .user-name{display:none}.dashboard-header{margin-bottom:12px}.btn{justify-content:center;width:100%}.btn.profile-inline,.nav-actions .btn{width:auto}.date-selects select,.modal-body textarea,.status-select select,input[type=email],input[type=password],input[type=search],input[type=text],select,textarea{font-size:16px}.task-add-row{display:none}.task-fab{display:inline-flex}.task-row{border-left:none;border-radius:0;border-right:none;padding:12px 14px}.task-child-inputs{grid-template-columns:1fr}.task-child-actions{justify-content:space-between}.tracker-quick{gap:6px}.tracker-quick-btn span{display:none}.tracker-table{overflow-x:auto}.tracker-row{min-width:520px}.bar-chart{height:180px;padding:12px}.hero-actions{flex-direction:column}.download-links{width:100%}.download-links a{justify-content:center;width:100%}.hero{gap:24px}.feature-tags{justify-content:center}.preview-showcase{gap:18px}.preview-frame{border-radius:20px;padding:10px}.preview-frame img{border-radius:14px}.preview-stack{min-height:280px}.preview-frame-mobile{bottom:auto;margin:-36px auto 0;position:relative;right:auto;width:min(260px,70%)}.dashboard-actions{width:100%}.habit-pill{justify-content:space-between;width:100%}.chart-wrap{min-height:260px}.chart-svg{height:260px}.calendar-grid{min-width:620px}.calendar-cell{min-height:90px}.habit-sticky{left:auto;position:static;z-index:auto}.habit-header-row .habit-sticky{z-index:auto}.modal-backdrop{align-items:flex-end;display:flex;justify-content:center;padding:0}.modal-card{border-radius:20px 20px 0 0;max-height:88vh;overflow:auto;padding:20px;width:100%}.modal-card.confirm{max-width:none}.tracker-header{align-items:center}.tracker-actions{justify-content:space-between;width:100%}.tracker-actions .btn{padding:8px 12px;width:auto}.tracker-live{font-size:11px;padding:4px 10px}.mobile-nav{gap:4px;padding:8px 10px}.mobile-nav a,.mobile-nav button{font-size:10px;padding:6px}.mobile-nav a i,.mobile-nav button i{font-size:16px}}
