@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700&display=swap";:root{--accent: #e07b4c;--accent-soft: #f0a06a;--accent-muted: #f5c9a8;--accent-bg: rgba(224, 123, 76, .08);--accent-hover: #cc6a3d;--bg-page: #faf8f5;--bg-card: #ffffff;--bg-subtle: #f7f5f2;--bg-hover: #f2efeb;--text-primary: #2d2a26;--text-secondary: #6b6560;--text-muted: #9c9590;--text-light: #b8b2aa;--border: #e8e4df;--border-light: #f0ece7;--habit-grid-outline: rgba(107, 101, 96, .82);--shadow-sm: 0 1px 3px rgba(45, 42, 38, .04);--shadow-md: 0 4px 12px rgba(45, 42, 38, .06);--shadow-lg: 0 8px 24px rgba(45, 42, 38, .08);--sage: #a8b5a0;--sage-bg: rgba(168, 181, 160, .12);--warm-blue: #7a9eb8;--warm-blue-bg: rgba(122, 158, 184, .1);--success: #7cb87a;--success-bg: rgba(124, 184, 122, .12);--warning: #e0a84c;--warning-bg: rgba(224, 168, 76, .12);--danger: #d64545;--danger-bg: rgba(214, 69, 69, .12);--danger-hover: #b53535;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-smooth: .35s cubic-bezier(.4, 0, .2, 1)}body.dark-mode{--accent: #f0945e;--accent-soft: #e07b4c;--accent-muted: #a85a3a;--accent-bg: rgba(240, 148, 94, .12);--accent-hover: #f7a87a;--bg-page: #1a1918;--bg-card: #252321;--bg-subtle: #2d2a28;--bg-hover: #363330;--text-primary: #f5f3f0;--text-secondary: #b8b2aa;--text-muted: #8a847c;--text-light: #6b6560;--border: #3a3632;--border-light: #2d2a28;--habit-grid-outline: rgba(245, 243, 240, .8);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--sage: #8a9c82;--sage-bg: rgba(138, 156, 130, .15);--warm-blue: #6a8ea8;--warm-blue-bg: rgba(106, 142, 168, .15);--success: #6aa868;--success-bg: rgba(106, 168, 104, .15);--warning: #d09840;--warning-bg: rgba(208, 152, 64, .15);--danger: #e05e5e;--danger-bg: rgba(224, 94, 94, .15);--danger-hover: #f07070}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-page);color:var(--text-primary);line-height:1.65;font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.page{max-width:1240px;margin:0 auto;padding:48px 32px 100px;display:flex;flex-direction:column;gap:28px}.eyebrow{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:6px}h1{font-size:2rem;font-weight:700;color:var(--text-primary);letter-spacing:-.025em;line-height:1.25;margin-bottom:6px}h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}h3{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:14px}p{margin:4px 0;color:var(--text-secondary)}.hero,.header{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}.search-input:focus{border-color:var(--accent-muted)}.search-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;margin-top:4px;max-height:300px;overflow-y:auto}.search-result-item{display:flex;align-items:center;gap:10px;padding:10px 14px;width:100%;text-align:left;border:none;background:transparent;cursor:pointer;font-size:.85rem;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-hover)}.search-type{font-size:.9rem}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.header-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.sync-status{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--border);font-size:.72rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-subtle)}.sync-status.synced{color:var(--success);border-color:color-mix(in srgb,var(--success) 35%,transparent);background:color-mix(in srgb,var(--success-bg) 70%,transparent)}.sync-status.syncing{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,transparent);background:var(--accent-bg)}.sync-status.error{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 35%,transparent);background:var(--danger-bg)}.sync-status.offline{color:var(--text-secondary);border-color:var(--border)}.header-main{display:flex;align-items:center;gap:24px;flex:1}.header-progress{display:flex;flex-direction:column;align-items:center;gap:4px}.header-progress-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.progress-bar{position:relative;width:100%;height:8px;background:var(--bg-subtle);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-soft) 100%);border-radius:4px;transition:width .4s ease}.progress-bar-label{position:absolute;right:0;top:-20px;font-size:.75rem;font-weight:600;color:var(--text-secondary)}.progress-bar-wrapper{position:relative;padding-top:22px}.progress-ring-container{position:relative;display:inline-flex;align-items:center;justify-content:center}.progress-ring{transform:rotate(-90deg)}.progress-ring-bg{stroke:var(--border)}.progress-ring-fill{stroke:var(--accent);transition:stroke-dashoffset .5s ease}.progress-ring-text{position:absolute;font-size:.9rem;font-weight:700;color:var(--text-primary)}.card{background:var(--bg-card);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);display:flex;flex-direction:column;gap:22px;transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.subcard{background:var(--bg-subtle);border-radius:var(--radius-lg);padding:22px;display:flex;flex-direction:column;gap:16px;border:1px solid var(--border-light)}.stats-chart{display:flex;align-items:flex-end;gap:8px;height:180px;padding:16px 0}.stats-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:transform var(--transition-fast)}.stats-bar-container:hover{transform:translateY(-2px)}.stats-bar-container.current .stats-bar{border:2px solid var(--accent)}.stats-bar-container.current .stats-bar-label{color:var(--accent);font-weight:700}.stats-bar-label{font-size:.7rem;font-weight:600;color:var(--text-muted)}.stats-bar{width:100%;height:120px;background:var(--bg-card);border-radius:var(--radius-sm);position:relative;overflow:hidden;display:flex;align-items:flex-end}.stats-bar-fill{width:100%;height:var(--bar-progress, 0%);background:linear-gradient(180deg,var(--accent) 0%,var(--accent-soft) 100%);border-radius:var(--radius-sm);transition:height .5s ease,width .5s ease;min-height:2px}.stats-bar-value{font-size:.65rem;font-weight:600;color:var(--text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stats-summary{text-align:center}.stats-goals-focus{text-align:left;border:1px solid color-mix(in srgb,var(--accent) 28%,var(--border));background:linear-gradient(165deg,color-mix(in srgb,var(--accent-bg) 75%,transparent),var(--bg-card))}.stats-goals-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.stats-goals-count{min-width:34px;height:34px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:.84rem;font-weight:800;color:#fff;background:linear-gradient(160deg,var(--accent),var(--accent-soft))}.stats-goal-list{display:flex;flex-direction:column;gap:12px;text-align:left}.stats-goal-card{display:grid;grid-template-columns:36px 1fr;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));background:linear-gradient(135deg,color-mix(in srgb,var(--accent-bg) 50%,transparent),color-mix(in srgb,var(--bg-card) 88%,transparent));box-shadow:0 1px #00000005}.stats-goal-index{width:36px;height:36px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:800;color:#fff;background:linear-gradient(165deg,var(--accent),var(--accent-soft));flex-shrink:0}.stats-goal-content{min-width:0;display:flex;flex-direction:column;gap:4px}.stats-goal-title{display:block;font-size:.98rem;line-height:1.3}.stats-goal-metric{font-size:.8rem;line-height:1.3;display:inline-flex;width:fit-content;max-width:100%;padding:3px 8px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 20%,var(--border));background:color-mix(in srgb,var(--accent-bg) 55%,var(--bg-subtle));color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-big-number{font-size:3rem;font-weight:800;color:var(--accent);line-height:1;margin:12px 0}.stats-comparison{display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px}.stats-current{display:flex;flex-direction:column;align-items:center;gap:4px}.stats-week-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stats-week-value{font-size:2.5rem;font-weight:800;color:var(--text-primary)}.stats-trend{font-size:.9rem;font-weight:600;padding:6px 14px;border-radius:var(--radius-md)}.stats-trend.up{color:var(--success);background:var(--success-bg)}.stats-trend.down{color:#c75a5a;background:#c75a5a1a}.stats-trend.neutral{color:var(--text-muted);background:var(--bg-subtle)}.goal-tracking-list{display:flex;flex-direction:column;gap:20px}.goal-tracking-item{display:flex;flex-direction:column;gap:8px}.goal-tracking-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.goal-tracking-info{display:flex;flex-direction:column;gap:2px;min-width:0}.goal-tracking-info strong{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.goal-tracking-info .muted{font-size:.8rem}.goal-tracking-badge{flex-shrink:0;font-size:.8rem;font-weight:700;padding:4px 10px;border-radius:var(--radius-md)}.goal-tracking-badge.high{color:var(--success);background:var(--success-bg)}.goal-tracking-badge.mid{color:var(--accent);background:var(--accent-bg)}.goal-tracking-badge.low{color:#c75a5a;background:#c75a5a1a}.goal-week-grid{display:flex;gap:8px;align-items:center;padding:4px 0;flex-wrap:wrap}.goal-week-chip{box-sizing:border-box;width:48px;min-width:48px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;transition:transform var(--transition-fast),box-shadow var(--transition-fast);cursor:default;border:1px solid rgba(0,0,0,.05);flex-shrink:0}.drag-handle{cursor:grab;color:var(--text-secondary);touch-action:none;user-select:none;-webkit-user-select:none;display:flex;align-items:center;justify-content:center;font-size:1.1rem;line-height:1;align-self:center;margin-right:8px;opacity:.72;transition:opacity .2s,background-color .2s,color .2s;padding:4px;border-radius:4px;background:color-mix(in srgb,var(--bg-subtle) 70%,transparent);border:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.drag-handle:hover{opacity:1;background-color:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.drag-handle:active{cursor:grabbing}.goal-week-chip:hover{transform:scale(1.15);box-shadow:var(--shadow-md)}.goal-week-chip.high{background:var(--success);color:#fff;border-color:#fff3}.goal-week-chip.mid{background:var(--accent);color:#fff;border-color:#fff3}.goal-week-chip.low{background:var(--warning);color:#fff;border-color:#fff3}.goal-week-chip.zero{background:var(--danger);color:#fff;opacity:.7;border-color:#fff3}.goal-week-chip.empty{background:var(--bg-subtle);color:var(--text-light);border:1px dashed var(--border)}.habit-toggle-row{display:flex;flex-wrap:wrap;gap:8px}.habit-chip{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg-subtle);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;color:var(--text)}.habit-chip:hover{border-color:var(--accent);background:var(--accent-bg);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.habit-chip.done{border-color:var(--success);background:#4caf501a}.habit-chip-emoji{font-size:1.1rem}.habit-chip-label{font-weight:600}.habit-chip-check{font-size:.9rem;opacity:.8}.habit-tracker-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.habit-tracker-topbar-right{display:flex;align-items:center;gap:8px}.habit-mini-label{font-size:.74rem;font-weight:700;color:var(--text-secondary);background:var(--bg-subtle);border:1px solid var(--border);border-radius:999px;padding:4px 10px}.habit-tracker-mode-btn{padding:7px 12px;font-size:.78rem}.habit-tracker-mode-btn.active{border-color:color-mix(in srgb,var(--danger) 50%,var(--border));background:color-mix(in srgb,var(--danger-bg) 75%,transparent);color:var(--danger)}.habit-tracker-mode-hint{margin:0 0 10px;font-size:.78rem;color:var(--text-secondary)}.habit-tracker-section{display:flex;flex-direction:column;gap:14px}.habit-tracker-section.compact{gap:12px}.habit-tracker-item{display:flex;flex-direction:column;gap:8px;padding:14px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border);transition:background var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.habit-tracker-section.compact .habit-tracker-item{padding:10px 12px}.habit-tracker-item:hover{background:var(--bg-hover)}.habit-tracker-item.edit-mode{border-color:color-mix(in srgb,var(--danger) 35%,var(--border))}.habit-tracker-item.delete-armed{border-color:var(--danger);background:color-mix(in srgb,var(--danger-bg) 78%,var(--bg-subtle));box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--danger) 25%,transparent)}.habit-tracker-main{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.habit-tracker-toggle{width:100%;background:none;border:none;padding:8px;border-radius:var(--radius-sm);text-align:left;cursor:pointer;color:inherit;transition:background var(--transition-fast)}.habit-tracker-toggle:hover{background:color-mix(in srgb,var(--accent-bg) 60%,transparent)}.habit-tracker-toggle.locked{cursor:default}.habit-tracker-toggle.locked:hover{background:transparent}.habit-tracker-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.habit-tracker-header>*{pointer-events:none}.habit-tracker-info{display:flex;align-items:center;gap:8px}.habit-tracker-emoji{font-size:1.3rem}.habit-tracker-title{font-weight:700;font-size:.95rem}.habit-tracker-meta{display:flex;align-items:center;gap:10px}.habit-tracker-meta-grid,.habit-tracker-side{display:flex;align-items:center;gap:8px}.habit-tracker-caret{color:var(--text-muted);font-size:1.1rem;line-height:1;pointer-events:none;transition:transform var(--transition-fast)}.habit-tracker-caret.open{transform:translateY(1px)}.habit-tracker-expand-btn{align-self:flex-start;padding:6px 10px;font-size:.74rem;border-radius:var(--radius-sm)}.habit-mini-grid{display:grid;grid-template-columns:repeat(7,12px);gap:3px;padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card)}.habit-mini-cell{width:12px;height:12px;border-radius:3px;border:1px solid transparent}.habit-mini-cell.done{background:var(--success)}.habit-mini-cell.missed{background:color-mix(in srgb,var(--danger) 78%,var(--danger-bg));border-color:color-mix(in srgb,var(--danger) 60%,transparent)}.habit-mini-cell.missed.pending-today{background:transparent;border-color:var(--habit-grid-outline)}.habit-mini-cell.inactive{border-color:var(--border);opacity:.75}.habit-mini-cell.today{outline:1.5px solid var(--accent);outline-offset:0}.habit-delete-controls{display:flex;align-items:center;gap:6px}.habit-delete-controls button{padding:6px 10px;font-size:.74rem}.habit-heatmap-panel{margin-top:6px;border-radius:var(--radius-sm);border:1px solid var(--border);background:color-mix(in srgb,var(--bg-card) 90%,transparent);--habit-heatmap-meta-h: 28px}.habit-heatmap-panel-meta{position:sticky;top:0;z-index:3;min-height:var(--habit-heatmap-meta-h);display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.7rem;font-weight:700;color:var(--text-secondary);padding:5px 8px;border-bottom:1px solid var(--border-light);background:color-mix(in srgb,var(--bg-card) 95%,transparent)}.habit-heatmap-panel-title{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;color:var(--text-primary);font-weight:700}.habit-heatmap-panel-range{flex-shrink:0}.habit-heatmap-scroll{max-height:220px;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable;padding:0 8px 8px}.habit-heatmap-wrap{margin-top:0}.habit-streak-badge{display:flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;background:#ff980026;color:var(--accent);font-size:.75rem;font-weight:700}.habit-success-rate{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:12px}.habit-success-rate.high{background:#4caf5026;color:var(--success)}.habit-success-rate.mid{background:#ff980026;color:var(--accent)}.habit-success-rate.low{background:#c75a5a26;color:var(--danger)}.habit-heatmap{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:0}.habit-heatmap-week-label{grid-column:1 / -1;font-size:.6rem;color:var(--text-light);font-weight:600;padding:2px 0 0;opacity:.6}.habit-heatmap-cell{aspect-ratio:1;border-radius:3px;transition:transform var(--transition-fast);cursor:default;min-width:0;width:100%;margin:0;padding:0;background:transparent;color:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none;line-height:1;display:block;border:1px solid transparent}.habit-heatmap-cell.clickable{cursor:pointer}.habit-heatmap-cell.clickable:hover{transform:scale(1.18);z-index:1}.habit-heatmap-cell.done{background:var(--success);border-color:color-mix(in srgb,var(--success) 40%,transparent)}.habit-heatmap-cell.missed{background:color-mix(in srgb,var(--danger) 78%,var(--danger-bg));border-color:color-mix(in srgb,var(--danger) 60%,transparent)}.habit-heatmap-cell.missed.pending-today{background:transparent;border-color:var(--habit-grid-outline)}.habit-heatmap-cell.inactive{background:color-mix(in srgb,var(--border-light) 65%,transparent);opacity:.75;border:1px solid var(--border)}.habit-heatmap-cell.future{background:color-mix(in srgb,var(--habit-grid-outline) 8%,transparent);opacity:1;border:2px dashed var(--habit-grid-outline)}.habit-heatmap-cell.today{border-radius:4px;box-shadow:none;outline:2px solid var(--accent);outline-offset:-1px}.habit-heatmap-cell.spacer{visibility:hidden;border-color:transparent;pointer-events:none}.habit-heatmap-cell.clickable:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.habit-heatmap-cell.flash{animation:habitCellFlash .18s ease}@keyframes habitCellFlash{0%{transform:scale(1);box-shadow:0 0 color-mix(in srgb,var(--accent) 20%,transparent)}45%{transform:scale(1.06);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 20%,transparent)}to{transform:scale(1);box-shadow:0 0 color-mix(in srgb,var(--accent) 0%,transparent)}}.habit-heatmap-dayrow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:4px 3px;margin-bottom:6px;position:sticky;top:var(--habit-heatmap-meta-h);z-index:2;background:color-mix(in srgb,var(--bg-card) 90%,transparent);border:1px solid var(--border-light);border-radius:6px}.habit-heatmap-dayrow span{font-size:.52rem;text-align:center;color:var(--text-light);font-weight:700;opacity:.7}.habit-settings-list{display:flex;flex-direction:column;gap:8px}.habit-settings-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-subtle);gap:12px}.habit-settings-item-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.habit-settings-item-info .emoji{font-size:1.2rem}.habit-settings-item-info .title{font-weight:600;font-size:.9rem}.habit-settings-item-info .meta{font-size:.75rem;color:var(--text-light)}.habit-settings-form{display:flex;flex-direction:column;gap:10px;padding:12px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border)}.habit-settings-form-row{display:flex;gap:8px;align-items:center}.habit-settings-form-row input,.habit-settings-form-row select{flex:1;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.85rem}.habit-emoji-picker{display:flex;flex-wrap:wrap;gap:4px}.habit-emoji-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-subtle);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.habit-emoji-btn:hover{border-color:var(--accent);transform:scale(1.15)}.habit-emoji-btn.selected{border-color:var(--accent);background:var(--accent-bg)}.habit-freq-chips{display:flex;gap:4px;flex-wrap:wrap}.habit-freq-chip{padding:4px 10px;border-radius:12px;border:1px solid var(--border);background:var(--bg-subtle);cursor:pointer;font-size:.75rem;transition:all var(--transition-fast)}.habit-freq-chip:hover{border-color:var(--accent)}.habit-freq-chip.selected{border-color:var(--accent);background:var(--accent-bg);color:var(--accent);font-weight:700}.completion-chart-container{display:flex;flex-direction:column;gap:16px}.completion-chart{width:100%;height:160px;overflow:visible}.chart-grid-line{stroke:var(--border-light);stroke-width:.5;stroke-dasharray:3 3}.chart-area{fill:var(--accent-bg);opacity:.6}.chart-line{fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.chart-dot{fill:var(--accent);stroke:var(--bg-card);stroke-width:2;transition:r var(--transition-fast)}.chart-dot:hover{r:5}.chart-label{fill:var(--text-muted);font-size:6px;font-weight:600}.completion-breakdown{display:flex;flex-wrap:wrap;gap:8px}.completion-week-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-md);background:var(--bg-subtle);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem}.completion-week-pill:hover{background:var(--bg-hover);transform:translateY(-1px)}.completion-week-pill.active{border:1.5px solid var(--accent);background:var(--accent-bg)}.pill-label{font-weight:700;color:var(--text-secondary)}.pill-value{font-weight:700}.pill-value.high{color:var(--success)}.pill-value.mid{color:var(--accent)}.pill-value.low{color:#c75a5a}.pill-detail{color:var(--text-muted);font-size:.75rem}.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px}.divider{border:none;border-top:1px solid var(--border);margin:10px 0}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px}label{display:flex;flex-direction:column;gap:7px;font-size:.85rem;font-weight:500;color:var(--text-secondary)}input,select,textarea{padding:13px 16px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);font-size:.925rem;font-family:inherit;color:var(--text-primary);transition:var(--transition-fast)}input:hover,select:hover,textarea:hover{border-color:var(--text-light)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}input::placeholder{color:var(--text-light)}textarea{min-height:110px;resize:vertical;line-height:1.6}.notes-field{min-height:50px;font-size:.85rem;background:var(--bg-subtle);border:1px dashed var(--border);padding:10px 12px;border-radius:var(--radius-md);width:100%;margin-top:8px;resize:none}.notes-field:focus{border-style:solid;border-color:var(--accent-muted);background:var(--bg-card)}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239c9590'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:44px}button,.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;font-weight:600;font-size:.875rem;font-family:inherit;color:var(--text-primary);transition:var(--transition-fast);flex-direction:row;width:auto}button:hover,.button:hover{background:var(--bg-hover);border-color:var(--text-light)}button:active,.button:active{transform:scale(.98)}button.primary{background:var(--accent);color:#fff;border:none;box-shadow:0 2px 8px #e07b4c40}button.primary:hover{background:var(--accent-hover);box-shadow:0 4px 12px #e07b4c4d}button:disabled{opacity:.45;cursor:not-allowed;transform:none!important}button.danger{background:var(--danger);color:#fff;border:none}button.danger:hover{background:var(--danger-hover);box-shadow:0 4px 12px #d645454d}button.ghost-danger{background:transparent;color:var(--text-secondary);border-color:transparent}button.ghost-danger:hover{background:var(--danger-bg);color:var(--danger)}.icon-btn{padding:10px 12px;font-size:1.1rem;line-height:1}.import-btn{display:inline-flex;align-items:center;padding:10px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;font-weight:500;font-size:.875rem;color:var(--text-primary);transition:all var(--transition-fast)}.import-btn:hover{background:var(--bg-hover);border-color:var(--accent-muted)}.tabs{display:inline-flex;gap:4px;background:var(--bg-subtle);padding:5px;border-radius:var(--radius-md);border:1px solid var(--border-light)}.tabs button{border-radius:var(--radius-sm);padding:10px 22px;background:transparent;border:none;color:var(--text-secondary);font-weight:500}.tabs button:hover{background:var(--bg-hover);color:var(--text-primary)}.tabs button.active{background:var(--bg-card);color:var(--accent);box-shadow:var(--shadow-sm)}.list{display:flex;flex-direction:column;gap:10px}.list-item{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--bg-card);border-radius:var(--radius-md);padding:16px 18px;border:1px solid var(--border-light);transition:var(--transition-fast)}.list-item.done{background:var(--bg-subtle);border-color:var(--border)}.list-item.done strong{text-decoration:line-through;text-decoration-thickness:2px;text-decoration-color:var(--text-muted)}.list-item.done .muted{color:var(--text-secondary)}.list-item:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.list-item.column{flex-direction:column;align-items:stretch}.list-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.list-actions{display:flex;gap:10px;align-items:center}.inline-fields{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.inline-fields input{flex:1;min-width:100px}.block-counter{display:grid;grid-template-columns:minmax(0,1fr) auto auto;grid-template-areas:"range value input";align-items:center;gap:10px}.block-counter-shell{width:min(380px,100%);margin-left:auto}.block-progress-row{width:100%;display:flex;align-items:center}.block-counter-value{grid-area:value;min-width:76px;font-size:.76rem;font-weight:600;color:var(--text-secondary);text-align:center;padding:4px 8px;border-radius:999px;background:var(--bg-subtle);border:1px solid var(--border);justify-self:end}.block-counter input[type=range]{width:100%;min-width:0;flex:initial}.block-counter-range{grid-area:range;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:999px;background:var(--border);outline:none;width:100%}.block-counter-range::-webkit-slider-runnable-track{height:6px;border-radius:999px;background:transparent}.block-counter-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;border:2px solid var(--bg-card);background:var(--accent);box-shadow:0 0 0 1px #00000014;margin-top:-4px}.block-counter-range::-moz-range-track{height:6px;border-radius:999px;background:transparent}.block-counter-range::-moz-range-thumb{width:14px;height:14px;border-radius:50%;border:2px solid var(--bg-card);background:var(--accent);box-shadow:0 0 0 1px #00000014}.block-counter input[type=number]{width:68px}.block-counter-input{grid-area:input;width:72px;text-align:center;justify-self:end}.block-counter-placeholder{width:min(320px,100%);margin-left:auto;min-height:32px}.block-content{flex:1;display:flex;flex-direction:column;gap:8px}.block-title-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;gap:10px}.block-title{min-width:0;overflow-wrap:anywhere}.block-meta-row{display:flex;align-items:center;gap:10px;width:100%}.block-link{font-size:.85rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.block-link-empty{min-height:20px}.block-delete-x{width:26px;min-width:26px;height:26px;padding:0;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--text-light);font-size:.9rem;line-height:1}.block-delete-x:hover{border-color:color-mix(in srgb,var(--danger) 28%,transparent);background:color-mix(in srgb,var(--danger-bg) 72%,transparent);color:var(--danger)}.list-item.touch-drag-active{border-color:color-mix(in srgb,var(--accent) 45%,var(--border));background:color-mix(in srgb,var(--accent-bg) 48%,var(--bg-card));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent)}.list-item.touch-drag-over{border-color:color-mix(in srgb,var(--accent) 30%,var(--border));background:color-mix(in srgb,var(--bg-hover) 70%,var(--bg-card))}.week-goal-row,.week-target-row{align-items:flex-start;gap:12px;width:100%}.week-goal-main,.week-target-main{flex:1;min-width:0}.week-goal-display,.week-target-body{min-width:0}.week-goal-display{display:flex;flex-direction:column;gap:4px}.week-goal-title,.week-goal-metric,.week-target-title,.week-target-summary{white-space:normal;overflow-wrap:anywhere}.week-goal-row.editing,.week-target-item.editing{border-color:color-mix(in srgb,var(--accent) 28%,var(--border));background:color-mix(in srgb,var(--accent-bg) 38%,var(--bg-card))}.week-row-actions,.week-target-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.week-edit-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.week-edit-btn{padding:8px 10px;font-size:.95rem;line-height:1;color:var(--text-secondary);background:var(--bg-subtle);border:1px solid var(--border-light)}.week-edit-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border)}.week-inline-edit{width:100%;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,220px);gap:8px}.week-target-head{display:flex;align-items:flex-start;width:100%;min-width:0}.week-target-body{display:flex;flex-direction:column;gap:4px;flex:1}.week-target-edit-fields{width:100%;display:grid;grid-template-columns:minmax(0,1fr) 96px 120px;gap:8px}.week-target-done{min-width:18px;text-align:center;font-weight:600}.week-target-controls{justify-content:space-between;width:min(360px,100%)}.week-target-stepper{display:inline-flex;align-items:center;gap:6px;padding:0;border:none;background:transparent}.week-target-stepper button{width:32px;min-width:32px;height:32px;padding:0;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);font-weight:700}.week-target-stepper button:hover{background:var(--bg-hover);border-color:var(--text-light)}.week-target-actions{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.journal-view{gap:16px}.journal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.journal-subtitle{margin-top:4px}.journal-add-btn{min-height:36px}.journal-entry-form{gap:12px}.journal-composer-type-row{display:flex;flex-wrap:wrap;gap:8px}.journal-feed-toolbar{display:grid;gap:12px}.journal-filter-row{display:grid;gap:6px}.journal-filter-label{font-size:.75rem;font-weight:700;letter-spacing:.02em;color:var(--text-muted);text-transform:uppercase}.journal-filter-chip-row{display:flex;flex-wrap:wrap;gap:8px}.journal-filter-chip{min-height:30px;padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg-subtle);color:var(--text-secondary);font-size:.78rem;font-weight:600}.journal-filter-chip:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.journal-filter-chip.active{background:color-mix(in srgb,var(--accent) 92%,white);border-color:color-mix(in srgb,var(--accent) 80%,var(--border));color:#fff}.journal-feed-root{display:grid;gap:12px}.journal-month-group{display:grid;gap:10px}.journal-month-toggle{width:100%;min-height:38px;padding:8px 10px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-subtle);color:var(--text-primary);display:flex;align-items:center;justify-content:space-between;gap:12px;font-weight:700;text-align:left}.journal-month-toggle:hover{background:var(--bg-hover);border-color:var(--border)}.journal-month-meta{min-width:24px;height:24px;padding:0 8px;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);display:inline-flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700}.journal-card-list{display:grid;gap:10px}.journal-card,.journal-entry-card{position:relative;padding:14px 16px;border:1px solid var(--border-light);border-radius:var(--radius-md);background:var(--bg-card);display:flex;flex-direction:column;gap:6px;min-height:92px}.journal-card.clickable,.journal-entry-card.clickable{cursor:pointer}.journal-card.clickable:hover,.journal-entry-card.clickable:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.journal-card-date{display:inline-flex;align-items:center;width:fit-content;max-width:100%;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:var(--bg-subtle);color:var(--text-secondary);font-size:.75rem;font-weight:600}.journal-card h4,.journal-entry-card h4{font-size:.94rem;font-weight:700;line-height:1.35}.journal-card p,.journal-entry-card p{margin:0;font-size:.84rem;line-height:1.45}.journal-entry-meta-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px;padding-right:28px}.journal-entry-type{display:inline-flex;align-items:center;min-height:22px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);font-size:.72rem;font-weight:700;letter-spacing:.01em}.journal-entry-type.daily{background:color-mix(in srgb,var(--accent-bg) 72%,var(--bg-card));border-color:color-mix(in srgb,var(--accent) 32%,var(--border));color:var(--accent-hover)}.journal-entry-type.weekly{background:color-mix(in srgb,var(--warm-blue-bg) 78%,var(--bg-card));border-color:color-mix(in srgb,var(--warm-blue) 32%,var(--border));color:color-mix(in srgb,var(--warm-blue) 76%,var(--text-primary))}.journal-entry-type.custom{background:var(--bg-subtle);color:var(--text-secondary)}.journal-entry-signal-row{display:inline-flex;flex-wrap:wrap;gap:4px}.journal-entry-signal{display:inline-flex;align-items:center;min-height:22px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:var(--bg-subtle);color:var(--text-secondary);font-size:.71rem;font-weight:700;letter-spacing:.01em}.journal-entry-signal.win{background:color-mix(in srgb,var(--success-bg) 84%,var(--bg-card));border-color:color-mix(in srgb,var(--success) 34%,var(--border));color:var(--success)}.journal-entry-signal.challenge{background:color-mix(in srgb,var(--danger-bg) 84%,var(--bg-card));border-color:color-mix(in srgb,var(--danger) 34%,var(--border));color:var(--danger)}.journal-entry-signal.next_step{background:color-mix(in srgb,var(--warning-bg) 86%,var(--bg-card));border-color:color-mix(in srgb,var(--warning) 35%,var(--border));color:color-mix(in srgb,var(--warning) 70%,#6a4f00)}.journal-entry-signal.note{background:var(--bg-subtle);border-color:var(--border);color:var(--text-secondary)}.journal-entry-lines{display:grid;gap:5px}.journal-entry-line{margin:0;font-size:.83rem;line-height:1.45}.journal-entry-line.positive{color:var(--success)}.journal-entry-line.negative{color:var(--danger)}.journal-entry-line.neutral,.journal-entry-preview{color:var(--text-secondary)}.journal-delete-x{position:absolute;right:8px;top:8px;width:24px;min-width:24px;height:24px;padding:0;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--text-light);font-size:.85rem;line-height:1}.journal-delete-x:hover{border-color:color-mix(in srgb,var(--danger) 28%,transparent);background:color-mix(in srgb,var(--danger-bg) 72%,transparent);color:var(--danger)}.warning-text{color:color-mix(in srgb,var(--warning) 72%,var(--text-primary));font-size:.84rem}.error-text{color:var(--danger);font-size:.84rem}.empty{font-style:normal;color:var(--text-muted);text-align:center;padding:24px;background:var(--bg-subtle);border-radius:var(--radius-md);border:1px dashed var(--border)}.hint{font-size:.8rem;color:var(--text-muted);margin-top:2px}.sortable{min-height:50px}.draggable{cursor:grab;position:relative;transition:transform .15s ease,opacity .15s ease,box-shadow .15s ease}.draggable:active{cursor:grabbing}.draggable.dragging{opacity:.5;transform:scale(.98);box-shadow:0 8px 25px #00000026;background:var(--bg-card);z-index:10}.draggable:not(.dragging):hover{box-shadow:0 2px 10px #00000014;transform:translateY(-1px)}.list-item.draggable:before{content:"⋮⋮";position:absolute;left:8px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:.9rem;opacity:0;transition:opacity .15s ease}.list-item.draggable:hover:before{opacity:.5}.template-section{margin-top:8px}.template-section h4{margin:0 0 12px;font-size:.9rem;color:var(--text-secondary)}.template-list{display:flex;flex-direction:column;gap:8px}.template-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-light)}.button-row{display:flex;gap:8px;flex-wrap:wrap}.button-row.compact{gap:4px}.button-row.compact button{padding:6px 10px;font-size:.8rem}.muted{color:var(--text-secondary);font-size:.875rem}.banner{background:var(--accent-bg);border:1px solid var(--accent-muted);padding:14px 20px;border-radius:var(--radius-md);color:var(--accent-hover);font-weight:500;font-size:.9rem;display:flex;align-items:center;justify-content:space-between;gap:12px}.banner-actions{display:flex;align-items:center;gap:8px}.safety-banner{background:color-mix(in srgb,var(--warm-blue-bg) 70%,transparent);border-color:color-mix(in srgb,var(--warm-blue) 30%,transparent);color:var(--text-primary)}.warning-banner{background:color-mix(in srgb,var(--danger-bg) 70%,transparent);border-color:color-mix(in srgb,var(--danger) 35%,transparent);color:var(--danger)}.toggle{display:flex;align-items:center;gap:10px;font-size:.875rem;cursor:pointer;color:var(--text-secondary);font-weight:500}.toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer;border-radius:4px}.week-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.chip{padding:12px 14px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);font-weight:500;font-size:.85rem;text-align:center;transition:var(--transition-fast);cursor:pointer;color:var(--text-secondary)}.chip:hover{border-color:var(--text-light);background:var(--bg-hover);color:var(--text-primary)}.chip.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #e07b4c33}.score{display:flex;flex-direction:column;gap:8px}.score-line{display:flex;align-items:center;gap:12px}.badge{display:inline-block;padding:5px 12px;border-radius:20px;font-weight:600;font-size:.8rem;background:var(--bg-subtle);color:var(--text-secondary)}.badge.green{background:var(--success-bg);color:#4a7a48}.badge.yellow{background:var(--warning-bg);color:#9a7a30}.badge.red{background:#c864641f;color:#a05050}.score-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.score-card{background:var(--bg-card);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border-light);display:flex;flex-direction:column;gap:6px}.section-actions{display:flex;align-items:flex-end;justify-content:flex-end}.weeks{display:grid;grid-template-columns:repeat(auto-fit,minmax(56px,1fr));gap:6px}.week-chip{display:flex;align-items:center;justify-content:center;gap:4px;padding:7px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card);font-size:.8rem;font-weight:500;color:var(--text-secondary);transition:var(--transition-fast)}.week-chip:hover{border-color:var(--accent-muted);color:var(--text-primary)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d2a2666;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:1100;animation:fadeIn .2s ease}.modal{background:var(--bg-card);border-radius:var(--radius-xl);padding:28px;max-width:420px;width:100%;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:16px;animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}@media (max-width: 680px){.page{padding:28px 18px 80px}h1{font-size:1.65rem}.card{padding:22px}.header{flex-direction:column;align-items:stretch}.header-main{width:100%}.header-right{width:100%;flex-direction:row;justify-content:flex-end;align-items:center;gap:10px}.header-actions{gap:6px;justify-content:flex-end}.header-actions .sync-status,.header-actions .header-history-btn{display:none}.search-container{order:1}.search-input{width:122px}.search-input:focus,.search-container:focus-within .search-input{width:164px}.search-results{left:auto;right:0;width:min(290px,calc(100vw - 36px))}.stats-chart{flex-direction:column;align-items:stretch;height:auto;gap:10px;padding:8px 0 0}.stats-bar-container{width:100%;flex-direction:row;align-items:center;gap:8px}.stats-bar-label{width:34px;flex:0 0 34px;text-align:left}.stats-bar{width:100%;height:14px;border-radius:999px;align-items:center}.stats-bar-fill{height:100%;width:var(--bar-progress, 0%);border-radius:999px;background:linear-gradient(90deg,var(--accent) 0%,var(--accent-soft) 100%)}.stats-bar-value{width:38px;flex:0 0 38px;text-align:right;font-size:.72rem}.stats-card{padding:18px;gap:14px}.stats-card .subcard{padding:14px;gap:10px}.stats-card h3{margin-bottom:8px}.stats-card .goal-tracking-list{gap:12px}.stats-card .goal-tracking-item{gap:6px}.stats-card .stats-goal-list{gap:8px}.stats-card .stats-goal-card{grid-template-columns:30px 1fr;gap:10px;padding:10px 12px}.stats-card .stats-goal-index{width:30px;height:30px;font-size:.76rem}.stats-card .stats-big-number{font-size:2.35rem;margin:6px 0}.stats-card .stats-comparison{padding:10px;gap:8px}.stats-card .stats-week-value{font-size:2.1rem}.stats-card .goal-week-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;align-items:stretch;width:100%}.stats-card .goal-week-chip{width:100%;min-width:0;height:34px;font-size:.72rem;border-radius:7px}.stats-card .goal-week-chip:hover{transform:none;box-shadow:none}.list-item{flex-direction:column;align-items:flex-start}.block-title-row{width:100%;grid-template-columns:minmax(0,1fr) auto;align-items:flex-start}.block-meta-row{width:100%;align-items:stretch;gap:6px}.block-progress-row{width:100%}.toggle-row{width:100%;justify-content:flex-start;gap:6px;flex-wrap:wrap}.toggle-label{font-size:.74rem}.toggle-status{min-width:92px;margin-left:auto;padding:2px 8px;font-size:.72rem}.block-counter-shell,.block-counter-placeholder{width:100%;margin-left:0}.block-counter{width:100%;grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"range range" "value input";gap:8px}.block-counter input[type=range]{width:100%;min-width:0}.block-counter-value{min-width:0;text-align:left;padding:3px 6px;justify-self:start}.block-counter input[type=number],.block-counter-input{width:72px;justify-self:end}.list-row{flex-direction:column;align-items:flex-start;width:100%}.inline-fields,.week-goal-row,.week-target-row{width:100%}.week-row-actions,.week-target-controls{width:100%;justify-content:flex-start;gap:10px}.week-inline-edit{grid-template-columns:1fr}.week-target-edit-fields{grid-template-columns:repeat(2,minmax(0,1fr))}.week-target-edit-fields input:first-child{grid-column:1 / -1}.week-edit-actions{width:100%}.week-edit-actions button{flex:1 1 0;min-width:0}.week-target-stepper{padding:4px}.week-target-stepper button{width:26px;min-width:26px;height:26px}.week-target-actions{width:100%;justify-content:flex-start}.week-target-actions .ghost-danger{margin-left:auto}.journal-header{flex-direction:column;align-items:stretch}.journal-add-btn{width:100%}.journal-filter-chip-row{gap:6px}.journal-filter-chip{min-height:32px;padding:5px 10px}.journal-month-toggle{min-height:40px;padding:8px 10px}.journal-entry-card,.journal-card{padding:12px;min-height:86px}.journal-entry-meta-row{padding-right:34px}.journal-delete-x{right:6px;top:6px;width:30px;min-width:30px;height:30px}.week-grid{grid-template-columns:repeat(2,1fr)}.habit-tracker-topbar{align-items:flex-start;gap:8px}.habit-tracker-topbar-right{width:100%;justify-content:flex-end;gap:6px}.habit-mini-label{font-size:.68rem;padding:3px 8px}.habit-tracker-main{grid-template-columns:1fr;gap:8px}.habit-tracker-item{padding:10px;gap:7px}.habit-tracker-header{flex-direction:column;align-items:flex-start;gap:6px}.habit-tracker-meta{width:100%;justify-content:space-between;gap:8px}.habit-tracker-meta-grid{flex:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center;gap:6px;min-width:0}.habit-streak-badge,.habit-success-rate{width:100%;justify-content:center;text-align:center;min-width:0}.habit-success-rate.solo{grid-column:1 / -1}.habit-tracker-side{width:100%;justify-content:space-between;gap:10px;flex-wrap:wrap}.habit-mini-grid{grid-template-columns:repeat(7,12px);gap:2px;padding:6px}.habit-mini-cell{width:12px;height:12px}.habit-delete-controls{justify-content:flex-end;width:100%}.habit-tracker-expand-btn{width:100%;align-self:stretch;text-align:center}.habit-heatmap-scroll{max-height:172px;padding:5px 6px 6px}.habit-heatmap-panel{--habit-heatmap-meta-h: 24px}.habit-heatmap-panel-meta{padding:3px 6px;font-size:.64rem}.habit-heatmap-panel-title{font-size:.66rem}.habit-heatmap-panel-range{font-size:.6rem}.habit-heatmap-dayrow{margin-bottom:4px;padding:2px}.habit-heatmap-dayrow span{font-size:.5rem}.habit-heatmap-cell{width:12px;height:12px;border-radius:3px;background-color:transparent;border-color:transparent;opacity:1}.habit-heatmap-cell.done{background-color:var(--success);border-color:color-mix(in srgb,var(--success) 40%,transparent);opacity:1}.habit-heatmap-cell.missed{background:color-mix(in srgb,var(--danger) 78%,var(--danger-bg));border-color:color-mix(in srgb,var(--danger) 60%,transparent);opacity:1}.habit-heatmap-cell.missed.pending-today{background:transparent;border-color:var(--habit-grid-outline);opacity:1}.habit-heatmap-cell.future{background:color-mix(in srgb,var(--habit-grid-outline) 8%,transparent);border:2px dashed var(--habit-grid-outline);opacity:1}.habit-heatmap-cell.inactive{border:1px solid var(--border);opacity:.75}.habit-heatmap-cell.spacer{border-color:transparent;opacity:0}.habit-heatmap-cell.today{border-radius:3px;outline:1.5px solid var(--accent);outline-offset:-1px}.tabs{width:100%}.tabs button{flex:1}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}::selection{background:var(--accent-muted);color:var(--text-primary)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none}.toggle-switch{position:relative;width:44px;height:24px;border-radius:12px;background:var(--border);border:none;cursor:pointer;transition:background var(--transition-base);flex-shrink:0}.toggle-switch.toggle-on{background:var(--accent)}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform var(--transition-base)}.toggle-switch.toggle-on .toggle-thumb{transform:translate(20px)}.toggle-row{display:flex;align-items:center;gap:8px}.toggle-label{font-size:.8rem;font-weight:600;letter-spacing:.02em;color:var(--text-secondary);transition:all var(--transition-base)}.toggle-status{min-width:110px;font-size:.76rem;font-weight:600;color:var(--text-secondary);text-align:center;padding:3px 9px;border-radius:999px;border:1px solid var(--border);background:var(--bg-subtle)}.toggle-status.done{color:var(--success);border-color:#7cb87a73;background:var(--success-bg)}.toggle-status.pending{color:var(--text-secondary)}.readonly-banner{border-color:color-mix(in srgb,var(--accent) 30%,var(--border));background:linear-gradient(135deg,var(--accent-bg),transparent);color:var(--text-primary)}.readonly-note{margin-top:10px;margin-bottom:2px;padding:8px 10px;border-radius:var(--radius-sm);border:1px dashed color-mix(in srgb,var(--accent) 35%,var(--border));background:color-mix(in srgb,var(--accent-bg) 75%,transparent);color:var(--text-secondary);font-size:.82rem}.readonly-fieldset{border:0;margin:0;padding:0;display:contents}.readonly-fieldset[disabled]{opacity:.8}.toggle-label.done{text-decoration:line-through;color:var(--text-muted)}.task-done .task-title{text-decoration:line-through;color:var(--text-muted);transition:all var(--transition-base)}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn var(--transition-fast)}.settings-modal{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:90%;max-width:500px;max-height:80vh;overflow-y:auto;animation:slideUp var(--transition-smooth)}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.settings-header h2{margin:0;font-size:1.25rem}.settings-close{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:4px;color:var(--text-secondary)}.settings-section{padding:16px 24px;border-bottom:1px solid var(--border-light)}.settings-section:last-child{border-bottom:none}.settings-section h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:16px}.settings-row label{flex:1;font-size:.95rem}.settings-row .button{flex:none}.settings-auth-box{display:flex;flex-direction:column;gap:10px;padding:8px 0 2px}.settings-auth-box input{width:100%}.sync-conflict-box{margin-top:8px;padding:10px 12px;border-radius:var(--radius-md);border:1px solid color-mix(in srgb,var(--warning) 35%,transparent);background:color-mix(in srgb,var(--warning-bg) 70%,transparent)}.sync-conflict-box p{margin:0 0 8px;color:var(--text-primary);font-size:.84rem}.sync-error{color:var(--danger)}.settings-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:.5rem 2rem .5rem .6rem;border-radius:6px;border:1px solid var(--border);background-color:var(--bg-card);color:var(--text);background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%),linear-gradient(to right,transparent,transparent);background-position:calc(100% - 16px) 50%,calc(100% - 12px) 50%,100% 0;background-size:5px 5px,5px 5px,2rem 100%;background-repeat:no-repeat}.search-container{position:relative;flex:0 0 auto}.search-input{width:120px;padding:8px 12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);font-size:.875rem;transition:width var(--transition-smooth),box-shadow var(--transition-base)}.search-input:focus,.search-container:focus-within .search-input{width:260px;border-color:var(--accent-muted);box-shadow:0 0 0 3px var(--accent-bg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.archive-banner{background:var(--warning-bg);border-bottom:1px solid var(--warning);color:#bfa32a;padding:12px 24px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:90;margin:-48px -32px 28px;font-weight:600;font-size:.9rem}body.dark-mode .archive-banner{color:#dbb35e}.archive-banner button{padding:6px 14px;font-size:.8rem;background:var(--bg-card);border:1px solid var(--warning);color:var(--text-primary);height:auto}.archive-banner button:hover{background:var(--warning-bg)}.add-habit-btn{border-style:dashed!important;border-color:var(--border)!important;opacity:.8}.add-habit-btn:hover{border-color:var(--accent)!important;background:var(--bg-hover)!important;opacity:1}.text-btn{background:transparent!important;border:none!important;padding:4px 8px!important;color:var(--text-secondary)!important;font-weight:500!important;font-size:.8rem}.text-btn:hover{color:var(--text-primary)!important;background:var(--bg-hover)!important;text-decoration:underline}@media (max-width: 390px){.week-goal-row,.week-target-item{padding:12px;gap:8px}.week-row-actions,.week-target-controls{gap:8px}.week-row-actions .ghost-danger{margin-left:auto}.week-target-controls{flex-direction:column;align-items:stretch;width:100%}.week-target-stepper{width:100%;justify-content:space-between}.week-target-stepper button{width:30px;min-width:30px;height:30px}.week-target-done{min-width:24px;font-size:.82rem}.week-edit-actions,.week-target-actions{width:100%;gap:6px}.week-edit-actions button,.week-target-actions button{padding:8px 10px;font-size:.78rem}.week-target-actions{justify-content:flex-start}.week-target-actions .ghost-danger{margin-left:auto}.week-inline-edit input,.week-target-edit-fields input{font-size:.85rem}.week-target-edit-fields{grid-template-columns:1fr}.week-target-edit-fields input:first-child{grid-column:auto}}@media (max-width: 680px) and (pointer: coarse){.drag-handle{min-width:44px;min-height:44px;margin-right:4px}.block-delete-x{width:44px;min-width:44px;height:44px;border-radius:10px;font-size:1rem}.week-edit-btn{min-width:44px;min-height:44px;padding:0 12px}.week-row-actions button,.week-target-actions button,.week-edit-actions button{min-height:44px}.week-target-stepper button{width:44px;min-width:44px;height:44px}}
