*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#22263a;--surface3:#2c3050;--border:#ffffff12;--border2:#ffffff21;--text:#e8eaf0;--text-dim:#7b82a0;--text-muted:#4a5075;--accent:#6c63ff;--accent-glow:#6c63ff38;--teal:#00d9a6;--teal-glow:#00d9a633;--danger:#ff6b6b;--warn:#ffd93d;--blue:#4fc3f7;--orange:#ff8a65;--sidebar-w:260px;--topbar-h:60px;--radius:12px;--radius-sm:8px;--font:"Inter",system-ui,sans-serif;--mono:"JetBrains Mono",monospace;--trans:.17s ease}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden}.app-shell{width:100%;min-height:100dvh;display:flex}.loading-screen{min-height:100dvh;color:var(--text-dim);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);z-index:200;height:100dvh;transition:transform var(--trans);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 18px 14px;display:flex}.logo{align-items:center;gap:10px;display:flex}.logo-img{object-fit:cover;border-radius:8px;flex-shrink:0;width:32px;height:32px;display:block}.logo-img-lg{border-radius:16px;width:72px;height:72px}.logo-text{letter-spacing:-.3px;background:linear-gradient(135deg,#fff,var(--accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:17px;font-weight:700}.sidebar-close{color:var(--text-dim);cursor:pointer;transition:all var(--trans);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:18px;display:none}.sidebar-close:hover{color:var(--text);background:var(--surface3)}.sidebar-nav{flex-direction:column;flex:1;gap:3px;padding:14px 10px;display:flex;overflow-y:auto}.nav-item{color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);transition:all var(--trans);text-align:left;background:0 0;border:none;align-items:center;gap:11px;width:100%;padding:11px 13px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-glow);color:#fff;box-shadow:inset 2px 0 0 var(--accent)}.nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:15px}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:14px 12px 18px;display:flex}.month-selector{background:var(--surface2);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.month-nav{color:var(--text-dim);cursor:pointer;transition:color var(--trans);background:0 0;border:none;padding:0 4px;font-size:20px;line-height:1}.month-nav:hover{color:var(--accent)}.current-month{color:var(--text);font-size:12.5px;font-weight:600;font-family:var(--mono)}.backup-controls{gap:8px;display:flex}.backup-btn{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);color:var(--text-dim);font-size:11px;font-weight:600;font-family:var(--font);cursor:pointer;text-align:center;transition:all var(--trans);letter-spacing:.3px;flex:1;padding:7px 6px;display:block}.backup-btn:hover{background:var(--surface3);color:var(--text);border-color:var(--accent)}.backup-btn.restore:hover{border-color:var(--teal);color:var(--teal)}.backup-modal{max-width:420px}.backup-modal-desc{color:var(--text-dim);margin:-4px 0 4px;font-size:13px;line-height:1.55}.backup-option-btn{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);text-align:left;cursor:pointer;transition:all var(--trans);align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.backup-option-btn:hover:not(:disabled){border-color:var(--accent);background:var(--surface3)}.backup-option-btn:disabled{opacity:.45;cursor:not-allowed}.backup-option-btn strong{margin-bottom:3px;font-size:13.5px;font-weight:600;display:block}.backup-option-btn small{color:var(--text-dim);font-size:11.5px;line-height:1.45;display:block}.backup-option-icon{background:var(--accent-glow);width:36px;height:36px;color:var(--accent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.backup-option-icon.drive{color:#4285f4;font-family:var(--font);background:#4285f426;font-size:16px}.backup-modal-hint{color:var(--text-dim);margin:0;font-size:12px}.drive-backup-list{flex-direction:column;gap:8px;margin-top:4px;display:flex}.drive-backup-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin:0;font-size:11px;font-weight:700}.drive-backup-item{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);width:100%;color:var(--text);font-family:var(--font);text-align:left;cursor:pointer;transition:all var(--trans);flex-direction:column;align-items:flex-start;gap:2px;padding:11px 14px;display:flex}.drive-backup-item:hover:not(:disabled){border-color:var(--teal);background:var(--surface3)}.drive-backup-item:disabled{opacity:.5;cursor:not-allowed}.drive-backup-name{font-size:13px;font-weight:600}.drive-backup-date{color:var(--text-dim);font-size:11px}.sync-btn{width:100%;margin-top:0}.sync-btn.syncing{color:#4285f4;border-color:#4285f4}.sync-btn.sync-error{border-color:var(--red);color:var(--red)}.sync-status-card{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);flex-direction:column;gap:8px;padding:12px 14px;display:flex}.sync-status-row{justify-content:space-between;align-items:center;gap:12px;font-size:12px;display:flex}.sync-status-label{color:var(--text-dim)}.sync-status-value{color:var(--text);text-align:right;font-weight:600}.sync-status-value.mono{font-family:var(--mono);font-size:11px;font-weight:500}.sync-status-value.sync-syncing{color:#4285f4}.sync-status-value.sync-synced{color:var(--teal)}.sync-status-value.sync-error{color:var(--red)}.sync-toggle-row{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius-sm);cursor:pointer;align-items:flex-start;gap:12px;padding:12px 14px;display:flex}.sync-toggle-row input{accent-color:var(--accent);flex-shrink:0;margin-top:3px}.sync-toggle-row strong{color:var(--text);margin-bottom:3px;font-size:13.5px;font-weight:600;display:block}.sync-toggle-row small{color:var(--text-dim);font-size:11.5px;line-height:1.45;display:block}.page-header{justify-content:space-between;align-items:center;gap:12px;min-height:36px;margin-bottom:16px;display:flex}.page-header-action-only{justify-content:flex-end;margin-bottom:12px}.page-header-title{margin:0;font-size:18px;font-weight:600}.add-btn-sm{padding:7px 14px;font-size:12px}.today-header-right{flex-direction:column;align-items:flex-end;gap:10px;display:flex}.onetime-section{margin-bottom:22px}.onetime-section-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin:0 0 10px;font-size:12px;font-weight:700}.today-item.overdue{border-color:#ff6b6b59}.cat-card-actions{align-items:center;gap:10px;display:flex}.cat-edit-btn{border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;font-size:10px;font-weight:600;font-family:var(--font);background:0 0;border-radius:6px;padding:3px 8px}.cat-edit-btn:hover{border-color:var(--accent);color:var(--text)}.cat-item-btn{text-align:left;cursor:pointer;width:100%;font-family:var(--font);color:inherit;background:0 0;border:none;padding:6px 0}.cat-empty{color:var(--text-dim);margin:0;padding:4px 0;font-size:12px}.form-group select{background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--font);border-radius:8px;width:100%;padding:9px 11px;font-size:13.5px}.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.duration-custom-input{margin-top:8px}.schedule-tabs{align-items:center;gap:6px;min-height:14px;margin-bottom:0;display:flex}.schedule-tab{text-transform:uppercase;letter-spacing:.5px;color:var(--text);cursor:pointer;font-size:11.5px;font-weight:600;font-family:var(--font);transition:color var(--trans),opacity var(--trans);background:0 0;border:none;padding:0;line-height:1}.schedule-tab:not(.active){color:var(--text-dim);opacity:.5;text-decoration:line-through}.schedule-tab-sep{text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);opacity:.7;font-size:11.5px;font-weight:600;line-height:1}.time-range-hint{color:var(--text-dim);margin:6px 0 0;font-size:11px}.install-banner{margin-top:2px}.install-btn{background:linear-gradient(135deg,var(--accent),#9c55ff);border-radius:var(--radius-sm);color:#fff;width:100%;font-family:var(--font);cursor:pointer;transition:opacity var(--trans);letter-spacing:.3px;border:none;padding:9px;font-size:12px;font-weight:700}.install-btn:hover{opacity:.85}.main-wrapper{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;min-height:100dvh;display:flex}.topbar{height:var(--topbar-h);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:100;background:#0f1117eb;align-items:center;gap:14px;padding:0 22px 0 18px;display:flex;position:sticky;top:0}.hamburger{cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:8px;display:none}.hamburger span{background:var(--text-dim);width:20px;height:2px;transition:background var(--trans);border-radius:2px;display:block}.hamburger:hover span{background:var(--text)}.topbar-title{flex:1;font-size:15px;font-weight:600}.add-btn{background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;transition:all var(--trans);white-space:nowrap;box-shadow:0 0 18px var(--accent-glow);border:none;border-radius:8px;padding:9px 18px;font-size:13px;font-weight:600}.add-btn:hover{background:#7b74ff;transform:translateY(-1px)}.content{flex:1;padding:22px;overflow:hidden}.view{display:none}.view.active{display:block}.tracker-controls{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filter-tabs{flex-wrap:wrap;gap:6px;display:flex}.filter-tab{background:var(--surface);border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);transition:all var(--trans);border-radius:20px;padding:6px 14px}.filter-tab:hover{background:var(--surface2);color:var(--text)}.filter-tab.active{background:var(--accent-glow);border-color:var(--accent);color:#fff}.legend{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.legend-item{color:var(--text-dim);align-items:center;gap:5px;font-size:11px;display:flex}.dot{border-radius:3px;width:10px;height:10px}.dot.done{background:var(--teal)}.dot.skip{background:var(--text-muted)}.dot.na{background:var(--surface3);border:1px solid var(--border2)}.tracker-scroll-wrap{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);overflow-x:auto}.tracker-table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.tracker-table thead th{background:var(--surface2);color:var(--text-dim);font-family:var(--mono);text-align:center;white-space:nowrap;border-bottom:1px solid var(--border2);z-index:10;padding:9px 5px;font-size:11px;font-weight:500;position:sticky;top:0}.tracker-table thead th.item-col{text-align:left;min-width:160px;max-width:200px;padding-left:14px}.sticky-col{z-index:20;background:var(--surface2);position:sticky;left:0}.item-row:hover .sticky-col,.item-row:hover .day-cell{background:#6c63ff0f}.item-name-cell{background:var(--surface);z-index:5;border-right:1px solid var(--border2);padding:9px 12px 9px 14px;position:sticky;left:0}.item-row:hover .item-name-cell{background:#6c63ff0d}.item-label{align-items:center;gap:7px;display:flex}.item-color-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.item-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:130px;font-weight:500;overflow:hidden}.item-meta{flex-wrap:wrap;gap:5px;margin-top:3px;margin-left:15px;display:flex}.item-cat-tag,.item-time-tag,.item-goal-tag{white-space:nowrap;border-radius:10px;padding:1px 5px;font-size:9.5px;font-weight:500}.item-cat-tag{background:var(--surface3);color:var(--text-dim)}.item-time-tag{color:var(--blue);font-family:var(--mono);background:#4fc3f724}.item-goal-tag{color:var(--warn);background:#ffd93d1f}.item-edit-btn{color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--trans);background:0 0;border:none;border-radius:4px;flex-shrink:0;margin-left:auto;padding:2px 5px;font-size:12px}.item-row:hover .item-edit-btn{opacity:1}.item-edit-btn:hover{background:var(--surface3);color:var(--text)}.day-cell{text-align:center;border-bottom:1px solid var(--border);transition:background var(--trans);min-width:34px;padding:7px 3px}.day-cell.today-col{background:#6c63ff12}.check-wrap{justify-content:center;align-items:center;display:flex}.cell-checkbox{appearance:none;border:1.5px solid var(--border2);background:var(--surface2);cursor:pointer;border-radius:6px;place-content:center;width:22px;height:22px;transition:all .13s;display:grid;position:relative}.cell-checkbox:hover{border-color:var(--accent);background:var(--accent-glow)}.cell-checkbox:checked{background:var(--teal);border-color:var(--teal);box-shadow:0 0 8px var(--teal-glow)}.cell-checkbox:checked:after{content:"";border-bottom:2px solid #0f1117;border-left:2px solid #0f1117;width:11px;height:7px;display:block;transform:rotate(-45deg)translateY(-1px)}.cell-checkbox.skipped{background:var(--surface3);border-color:var(--text-muted)}.cell-checkbox.skipped:after{content:"–";color:var(--text-muted);font-size:12px;font-weight:700;display:block}.day-head{position:relative}.day-head.today{color:var(--accent)!important}.day-head.today:after{content:"";background:var(--accent);border-radius:50%;width:4px;height:4px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.row-summary-cell{border-left:1px solid var(--border2);border-bottom:1px solid var(--border);white-space:nowrap;padding:7px 9px}.row-summary{text-align:center}.row-pct{font-family:var(--mono);font-size:11.5px;font-weight:600}.row-bar{background:var(--surface3);border-radius:2px;width:38px;height:4px;margin:4px auto 0;overflow:hidden}.row-bar-fill{border-radius:2px;height:100%;transition:width .4s}.na-cell{background:var(--surface);opacity:.25;border-radius:6px;width:22px;height:22px;margin:auto}.future-cell{background:var(--surface);border:1px dashed var(--border2);opacity:.3;border-radius:6px;width:22px;height:22px;margin:auto}.today-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:24px;display:flex}.today-date{letter-spacing:-.4px;font-size:24px;font-weight:700}.today-sub{color:var(--text-dim);margin-top:4px;font-size:12px}.today-progress{align-items:center;gap:14px;display:flex}.progress-ring-wrap{width:64px;height:64px;position:relative}.progress-ring{width:64px;height:64px;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:var(--surface3);stroke-width:5px}.ring-fill{fill:none;stroke:var(--teal);stroke-width:5px;stroke-linecap:round;stroke-dasharray:163.36;stroke-dashoffset:163.36px;filter:drop-shadow(0 0 5px var(--teal));transition:stroke-dashoffset .5s}.ring-label{font-family:var(--mono);place-content:center;font-size:12px;font-weight:600;display:grid;position:absolute;inset:0}.progress-text{color:var(--text-dim);font-size:13px;font-family:var(--mono)}.today-list{flex-direction:column;gap:9px;display:flex}.today-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--trans);-webkit-user-select:none;user-select:none;align-items:center;gap:13px;padding:14px 16px;display:flex}.today-item:hover{border-color:var(--border2);background:var(--surface2)}.today-item.done{opacity:.6}.today-item.done .today-item-name{color:var(--text-dim);text-decoration:line-through}.today-check{border:2px solid var(--border2);background:var(--surface2);border-radius:7px;flex-shrink:0;place-content:center;width:24px;height:24px;font-size:13px;transition:all .13s;display:grid}.today-item.done .today-check{background:var(--teal);border-color:var(--teal);color:#0f1117;box-shadow:0 0 10px var(--teal-glow)}.today-item-color{border-radius:2px;flex-shrink:0;width:4px;height:34px}.today-item-info{flex:1;min-width:0}.today-item-name{white-space:nowrap;text-overflow:ellipsis;transition:color var(--trans);font-size:14px;font-weight:500;overflow:hidden}.today-item-meta{color:var(--text-dim);flex-wrap:wrap;gap:8px;margin-top:3px;font-size:11px;display:flex}.today-item-time{color:var(--blue);font-family:var(--mono)}.today-item-goal{color:var(--warn)}.compare-controls{margin-bottom:22px}.compare-selectors{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.compare-month-picker{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);flex:1;min-width:160px;padding:14px 16px}.compare-month-picker label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:11px;font-weight:600;display:block}.month-pick-row{justify-content:space-between;align-items:center;display:flex}.mpick-nav{color:var(--text-dim);cursor:pointer;transition:color var(--trans);background:0 0;border:none;padding:0 6px;font-size:20px;line-height:1}.mpick-nav:hover{color:var(--accent)}.mpick-label{font-size:14px;font-weight:600;font-family:var(--mono);color:var(--text)}.compare-vs{color:var(--text-muted);align-self:center;padding:0 4px;font-size:16px;font-weight:700}.compare-summary-bar{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px;display:grid}.cmp-month-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.cmp-month-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:12px;font-weight:600}.cmp-month-pct{font-family:var(--mono);font-size:32px;font-weight:700;line-height:1}.cmp-month-sub{color:var(--text-dim);margin-top:4px;font-size:11px}.cmp-winner-badge{background:var(--teal-glow);color:var(--teal);border:1px solid var(--teal);border-radius:10px;margin-top:6px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.compare-table-wrap{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);overflow-x:auto}.compare-table{border-collapse:collapse;width:100%;font-size:13px}.compare-table th{background:var(--surface2);color:var(--text-dim);text-align:left;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap;border-bottom:1px solid var(--border2);padding:10px 14px;font-size:11px;font-weight:600}.compare-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 14px}.compare-table tr:last-child td{border-bottom:none}.compare-table tr:hover td{background:#6c63ff0a}.cmp-item-label{align-items:center;gap:8px;display:flex}.cmp-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.cmp-pct-cell{font-family:var(--mono);font-size:13px;font-weight:600}.cmp-bar-wrap{align-items:center;gap:8px;display:flex}.cmp-bar{background:var(--surface3);border-radius:3px;flex:1;min-width:60px;height:6px;overflow:hidden}.cmp-bar-fill{border-radius:3px;height:100%;transition:width .5s}.cmp-delta{font-family:var(--mono);white-space:nowrap;font-size:11px;font-weight:600}.cmp-delta.up{color:var(--teal)}.cmp-delta.down{color:var(--danger)}.cmp-delta.same{color:var(--text-muted)}.stats-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;transition:border-color var(--trans);padding:20px 16px}.stat-card:hover{border-color:var(--border2)}.stat-value{font-family:var(--mono);color:var(--accent);margin-bottom:7px;font-size:34px;font-weight:700;line-height:1}.stat-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:500}.heatmap-section,.top-items-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:20px}.section-heading{color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;font-size:12px;font-weight:600}.heatmap{flex-wrap:wrap;gap:4px;display:flex}.heatmap-cell{background:var(--surface2);cursor:default;width:26px;height:26px;transition:transform var(--trans);border-radius:5px;position:relative}.heatmap-cell:hover{z-index:2;transform:scale(1.15)}.hm-tooltip{background:var(--surface3);color:var(--text);white-space:nowrap;pointer-events:none;opacity:0;z-index:10;font-size:10px;font-family:var(--mono);border-radius:6px;padding:4px 8px;transition:opacity .1s;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}.heatmap-cell:hover .hm-tooltip{opacity:1}.perf-item{align-items:center;gap:10px;margin-bottom:9px;display:flex}.perf-item-name{white-space:nowrap;text-overflow:ellipsis;flex:0 0 150px;font-size:13px;font-weight:500;overflow:hidden}.perf-bar-wrap{background:var(--surface3);border-radius:4px;flex:1;height:7px;overflow:hidden}.perf-bar-fill{border-radius:4px;height:100%;transition:width .5s}.perf-pct{font-family:var(--mono);color:var(--text-dim);text-align:right;flex:0 0 36px;font-size:11.5px}.goals-intro{margin-bottom:20px}.goals-hint{color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;font-size:13px;line-height:1.7}.goals-hint strong{color:var(--text)}.goals-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.goal-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--trans);cursor:pointer;padding:18px}.goal-card:hover{border-color:var(--border2)}.goal-card-header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:12px;display:flex}.goal-card-title{align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.goal-card-badge{white-space:nowrap;border-radius:10px;flex-shrink:0;padding:3px 9px;font-size:10px;font-weight:700}.badge-active{color:var(--teal);background:#00d9a626;border:1px solid #00d9a64d}.badge-done{color:var(--accent);background:#6c63ff26;border:1px solid #6c63ff4d}.badge-overdue{color:var(--danger);background:#ff6b6b26;border:1px solid #ff6b6b4d}.badge-upcoming{color:var(--warn);background:#ffd93d1f;border:1px solid #ffd93d40}.badge-nodates{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border2)}.goal-dates{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.goal-date-chip{background:var(--surface2);color:var(--text-dim);font-size:10.5px;font-family:var(--mono);border-radius:8px;padding:3px 9px}.goal-date-chip span{color:var(--text);font-weight:600}.goal-progress-wrap{margin-bottom:10px}.goal-progress-bar{background:var(--surface3);border-radius:4px;height:8px;margin-bottom:5px;overflow:hidden}.goal-progress-fill{border-radius:4px;height:100%;transition:width .5s}.goal-progress-labels{color:var(--text-dim);font-size:10.5px;font-family:var(--mono);justify-content:space-between;display:flex}.goal-stats-row{flex-wrap:wrap;gap:10px;display:flex}.goal-stat{text-align:center;background:var(--surface2);border-radius:8px;flex:1;min-width:60px;padding:8px 6px}.goal-stat-val{font-family:var(--mono);margin-bottom:3px;font-size:16px;font-weight:700;line-height:1}.goal-stat-lbl{color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px;font-size:9.5px}.goal-target-text{color:var(--text-dim);border-top:1px solid var(--border);margin-top:10px;padding-top:10px;font-size:11.5px;font-style:italic}.goal-target-text span{color:var(--warn)}.categories-list{grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px;display:grid}.category-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--trans);padding:18px}.category-card:hover{border-color:var(--border2)}.cat-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cat-card-name{font-size:14px;font-weight:600}.cat-card-count{color:var(--text-dim);background:var(--surface2);font-size:11.5px;font-family:var(--mono);border-radius:12px;padding:3px 9px}.cat-progress{background:var(--surface3);border-radius:3px;height:6px;margin-bottom:8px;overflow:hidden}.cat-progress-fill{border-radius:3px;height:100%;transition:width .5s}.cat-pct{color:var(--text-dim);font-size:11.5px;font-family:var(--mono)}.cat-items{flex-direction:column;gap:5px;margin-top:12px;display:flex}.cat-item-row{color:var(--text-dim);align-items:center;gap:7px;font-size:12px;display:flex}.cat-item-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-overlay.active{display:flex}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:16px;width:100%;max-width:490px;animation:.2s modalIn;overflow:hidden}@keyframes modalIn{0%{opacity:0;transform:translateY(18px)scale(.97)}to{opacity:1;transform:none}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.modal-header h3{font-size:15px;font-weight:600}.modal-close{color:var(--text-dim);cursor:pointer;transition:all var(--trans);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:17px}.modal-close:hover{background:var(--surface3);color:var(--text)}.modal-body{flex-direction:column;gap:14px;max-height:72vh;padding:18px 22px;display:flex;overflow-y:auto}.modal-body::-webkit-scrollbar{width:4px}.modal-body::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:2px}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:11.5px;font-weight:600}.form-group input,.form-group textarea{background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-family:var(--font);transition:border-color var(--trans);resize:none;border-radius:8px;width:100%;padding:9px 11px;font-size:13.5px}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-group input[type=date],.form-group input[type=time]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}.form-row{gap:12px;display:flex}.form-group.half{flex:1}.color-picker{flex-wrap:wrap;gap:7px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:8px;flex-shrink:0;width:27px;height:27px;transition:all .13s}.color-swatch:hover{transform:scale(1.1)}.color-swatch.active{border-color:#fff;transform:scale(1.12);box-shadow:0 0 0 2px #ffffff40}.days-picker{flex-wrap:wrap;gap:5px;display:flex}.day-chip{border:1px solid var(--border2);background:var(--surface2);color:var(--text-dim);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);transition:all var(--trans);border-radius:20px;padding:6px 11px}.day-chip:hover{border-color:var(--accent);color:var(--text)}.day-chip.active{background:var(--accent-glow);border-color:var(--accent);color:#fff}.days-shortcuts{gap:7px;margin-top:7px;display:flex}.shortcut{border:1px solid var(--border2);color:var(--text-dim);cursor:pointer;font-size:11px;font-weight:600;font-family:var(--font);transition:all var(--trans);background:0 0;border-radius:6px;padding:4px 11px}.shortcut:hover{border-color:var(--accent);color:var(--accent)}.modal-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:10px;padding:14px 22px 18px;display:flex}.modal-footer-right{gap:9px;margin-left:auto;display:flex}.btn-primary{background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;transition:all var(--trans);border:none;border-radius:8px;padding:9px 22px;font-size:13.5px;font-weight:600}.btn-primary:hover{background:#7b74ff;transform:translateY(-1px)}.btn-ghost{background:var(--surface2);color:var(--text-dim);border:1px solid var(--border2);font-family:var(--font);cursor:pointer;transition:all var(--trans);border-radius:8px;padding:9px 16px;font-size:13.5px;font-weight:500}.btn-ghost:hover{color:var(--text);background:var(--surface3)}.btn-danger{color:var(--danger);font-family:var(--font);cursor:pointer;transition:all var(--trans);background:#ff6b6b21;border:1px solid #ff6b6b47;border-radius:8px;padding:9px 16px;font-size:13.5px;font-weight:600}.btn-danger:hover{background:#ff6b6b38}.confirm-modal{max-width:370px;padding:26px 26px 22px}.confirm-modal h3{margin-bottom:9px;font-size:16px;font-weight:600}.confirm-modal p{color:var(--text-dim);margin-bottom:22px;font-size:13.5px;line-height:1.65}.empty-state{text-align:center;color:var(--text-dim);padding:70px 20px}.empty-state.hidden{display:none}.empty-icon{color:var(--accent);opacity:.35;margin-bottom:14px;font-size:44px}.empty-logo{opacity:.85;margin-bottom:14px}.empty-state p{font-size:14.5px;line-height:1.7}.empty-state strong{color:var(--text)}.toast{background:var(--surface3);color:var(--text);border:1px solid var(--border2);z-index:2000;opacity:0;pointer-events:none;white-space:nowrap;border-radius:10px;padding:11px 20px;font-size:13.5px;font-weight:500;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .3s;position:fixed;bottom:26px;left:50%;transform:translate(-50%)translateY(70px);box-shadow:0 8px 30px #00000080}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px}.sidebar-backdrop{z-index:150;-webkit-backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}.sidebar-backdrop.visible{display:block}@media (max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:800px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:8px 0 40px #00000080}.sidebar-close{display:block}.main-wrapper{margin-left:0}.hamburger{display:flex}.content{padding:14px}.legend{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:26px}.today-date{font-size:19px}.form-row,.compare-selectors{flex-direction:column}.compare-summary-bar{grid-template-columns:1fr}.perf-item-name{flex:0 0 110px}.goals-grid{grid-template-columns:1fr}}@media (max-width:500px){.stats-grid{grid-template-columns:1fr 1fr;gap:9px}.stat-card{padding:14px 12px}.stat-value{font-size:22px}.heatmap-cell{width:21px;height:21px}.topbar{padding:0 12px}.add-btn{padding:8px 12px;font-size:12px}}.lock-screen{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex}.lock-card{background:var(--surface);border:1px solid var(--border2);text-align:center;border-radius:20px;width:100%;max-width:360px;padding:32px 28px}.lock-logo{justify-content:center;align-items:center;gap:10px;margin-bottom:24px;display:flex}.lock-title{letter-spacing:-.3px;margin-bottom:8px;font-size:20px;font-weight:700}.lock-sub{color:var(--text-dim);margin-bottom:28px;font-size:13px;line-height:1.5}.pin-dots{justify-content:center;gap:12px;margin-bottom:20px;display:flex}.pin-dot{border:2px solid var(--border2);background:0 0;border-radius:50%;width:12px;height:12px;transition:all .15s}.pin-dot.filled{background:var(--accent);border-color:var(--accent);box-shadow:0 0 10px var(--accent-glow)}.lock-error{color:var(--danger);margin-bottom:16px;font-size:13px}.lock-success{color:var(--teal);margin-bottom:16px;font-size:13px}.pin-pad{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px;display:grid}.pin-key{background:var(--surface2);height:52px;color:var(--text);font-size:20px;font-weight:600;font-family:var(--mono);cursor:pointer;transition:all var(--trans);border:none;border-radius:12px}.pin-key:hover:not(:disabled){background:var(--surface3);color:#fff}.pin-key:active:not(:disabled){transform:scale(.96)}.pin-key:disabled{opacity:.5;cursor:not-allowed}.pin-key.empty{visibility:hidden;pointer-events:none}.lock-submit{width:100%;margin-bottom:8px}.lock-timeout-setup{border-top:1px solid var(--border);text-align:left;margin-top:20px;padding-top:20px}.lock-timeout-setup label,.lock-timeout-picker label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:11px;font-weight:600;display:block}.lock-timeout-options{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.lock-timeout-btn{background:var(--surface2);border:1px solid var(--border2);color:var(--text-dim);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--trans);border-radius:8px;flex:1;padding:9px 12px}.lock-timeout-btn:hover{border-color:var(--accent);color:var(--text)}.lock-timeout-btn.active{background:var(--accent-glow);border-color:var(--accent);color:#fff}.lock-hint{color:var(--text-dim);margin-bottom:12px;font-size:12px;line-height:1.5}.lock-now-btn{width:100%;margin-top:14px}.security-btn{width:100%}.security-tabs{gap:6px;margin-bottom:16px;display:flex}.security-tab{background:var(--surface2);border:1px solid var(--border2);color:var(--text-dim);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--trans);border-radius:8px;flex:1;padding:8px 10px}.security-tab:hover{color:var(--text)}.security-tab.active{background:var(--accent-glow);border-color:var(--accent);color:#fff}
