*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--bg: #f1f5f9;--bg-header: #ffffff;--bg-card: #ffffff;--bg-card-hover:#f8fafc;--bg-modal: #ffffff;--bg-input: #f8fafc;--bg-col: #f8fafc;--bg-today-col: #eef2ff;--bg-toggle: #e2e8f0;--text: #1e293b;--text-muted: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--border-focus: #6366f1;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 25px rgba(0,0,0,.12), 0 4px 10px rgba(0,0,0,.06);--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: #eef2ff;--c-done: #22c55e;--c-partial: #eab308;--c-not-done: #cbd5e1;--c-late: #3b82f6;--c-cancelled: #94a3b8;--bg-done: #f0fdf4;--bg-partial: #fefce8;--bg-not-done: #ffffff;--bg-late: #eff6ff;--bg-cancelled: #f1f5f9;--t-done: #15803d;--t-partial: #92400e;--t-not-done: #475569;--t-late: #1d4ed8;--t-cancelled: #64748b;--danger: #ef4444;--danger-hover: #dc2626;--danger-light: #fef2f2;--r-sm: 6px;--r: 8px;--r-lg: 12px;--r-xl: 16px;--tr: .15s ease}[data-theme=dark]{--bg: #0f172a;--bg-header: #1e293b;--bg-card: #1e293b;--bg-card-hover:#263042;--bg-modal: #1e293b;--bg-input: #0f172a;--bg-col: #131f30;--bg-today-col: #1c1f3a;--bg-toggle: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--text-light: #475569;--border: #334155;--shadow-xs: 0 1px 2px rgba(0,0,0,.25);--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 6px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2);--shadow-lg: 0 10px 25px rgba(0,0,0,.4), 0 4px 10px rgba(0,0,0,.25);--accent-light: #1e1f4e;--bg-done: #052e16;--bg-partial: #1c1407;--bg-not-done: #1e293b;--bg-late: #0c1d3e;--bg-cancelled: #1e293b;--t-done: #4ade80;--t-partial: #fde047;--t-not-done: #94a3b8;--t-late: #60a5fa;--t-cancelled: #64748b;--danger-light: #2d0a0a}html{font-size:16px;-webkit-text-size-adjust:100%;height:100%;overflow-x:hidden}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column;transition:background var(--tr),color var(--tr);line-height:1.5;overflow-x:hidden}#root,.app{flex:1;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;background:var(--bg-header);border-bottom:1px solid var(--border);padding:0 24px;height:68px;display:flex;align-items:center;gap:16px;transition:background var(--tr),border-color var(--tr);box-shadow:var(--shadow-xs)}.header-left{display:flex;align-items:center;gap:8px;flex-shrink:0}.app-logo{width:38px;height:38px;background:var(--accent);color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--tr)}.app-logo.app-logo-habit{background:#22c55e}.app-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.3px}.header-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}.current-period{font-size:17px;font-weight:600;color:var(--text);min-width:180px;text-align:center;white-space:nowrap}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:0}.btn-icon{width:38px;height:38px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--tr),color var(--tr);flex-shrink:0}.btn-icon:hover{background:var(--bg-toggle);color:var(--text)}.today-btn{padding:0 14px;height:34px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--text-muted);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background var(--tr),color var(--tr),border-color var(--tr)}.today-btn:hover{background:var(--bg-toggle);color:var(--text);border-color:var(--accent)}[data-theme=light] .icon-sun,[data-theme=dark] .icon-moon{display:none}[data-theme=dark] .icon-sun{display:block}.view-toggle{display:flex;background:var(--bg-toggle);border-radius:var(--r-sm);padding:2px;gap:2px}.vs,.theme-btn-mobile,.settings-btn-mobile{display:none}.app-header[data-view=month] .settings-btn-mobile{display:flex}.settings-wrapper{position:relative}.settings-menu{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);z-index:200;background:var(--bg-modal);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);min-width:180px;display:flex;flex-direction:column;overflow:hidden}.settings-menu-item{display:flex;align-items:center;gap:10px;padding:12px 16px;background:transparent;border:none;color:var(--text);font-size:15px;font-family:var(--font);cursor:pointer;text-align:left;width:100%;transition:background var(--tr);white-space:nowrap}.settings-menu-item:hover{background:var(--bg-toggle)}.settings-menu-item+.settings-menu-item{border-top:1px solid var(--border)}.view-btn{padding:5px 14px;border-radius:5px;border:none;background:transparent;color:var(--text-muted);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;transition:background var(--tr),color var(--tr);white-space:nowrap}.view-btn.active{background:var(--bg-modal);color:var(--text);box-shadow:var(--shadow-xs)}.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:var(--r);border:none;font-family:var(--font);font-size:15px;font-weight:500;cursor:pointer;transition:background var(--tr),color var(--tr);white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--bg-toggle);color:var(--text)}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.calendar-main{flex:1;overflow:hidden;display:flex;flex-direction:column}.week-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.week-pills{display:none;gap:4px;padding:8px 12px;background:var(--bg-header);border-bottom:1px solid var(--border);overflow-x:auto}.week-pill{flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:6px 10px;border-radius:var(--r);border:none;background:transparent;cursor:pointer;font-family:var(--font);transition:background var(--tr);gap:2px}.week-pill:hover{background:var(--bg-toggle)}.week-pill.active{background:var(--accent-light)}.week-pill-name{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.week-pill-num{font-size:15px;font-weight:700;color:var(--text);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%}.week-pill.active .week-pill-num{background:var(--accent);color:#fff}.week-pill.today .week-pill-num{color:var(--accent)}.week-pill.active.today .week-pill-num{background:var(--accent);color:#fff}.week-grid{flex:1;display:grid;grid-template-columns:repeat(7,minmax(160px,1fr));overflow-x:auto;overflow-y:auto;border-top:1px solid var(--border)}.day-col{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-col);min-height:calc(100vh - 69px);transition:background var(--tr)}.day-col:last-child{border-right:none}.day-col.is-today{background:var(--bg-today-col)}.day-head{position:sticky;top:0;z-index:10;padding:14px 14px 10px;background:var(--bg-header);border-bottom:1px solid var(--border);text-align:center;transition:background var(--tr)}.day-col.is-today .day-head{background:var(--accent-light)}.day-name{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.day-num{font-size:28px;font-weight:700;line-height:1.2;margin-top:4px}.day-num-badge{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;cursor:pointer;transition:background var(--tr),color var(--tr)}.day-num-badge:hover{background:var(--bg-toggle)}.day-col.is-today .day-num-badge{background:var(--accent);color:#fff}.day-col.is-today .day-num-badge:hover{background:var(--accent-hover)}.day-col.is-today .day-num{color:var(--accent)}.day-col.ds-complete{background:#22c55e1f}.day-col.ds-partial{background:#3b82f61f}.day-col.ds-insufficient{background:#ef44441f}.day-col.ds-complete.is-today{background:#22c55e2e}.day-col.ds-partial.is-today{background:#3b82f62e}.day-col.ds-insufficient.is-today{background:#ef44442e}.day-col.ds-complete .day-head{background:#22c55e1a}.day-col.ds-partial .day-head{background:#3b82f61a}.day-col.ds-insufficient .day-head{background:#ef44441a}.tasks-list{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:7px;min-height:60px}.task-card{position:relative;background:var(--bg-card);border-radius:var(--r);border:1px solid var(--border);border-left:5px solid var(--c-not-done);padding:10px 11px 10px 13px;cursor:pointer;transition:box-shadow var(--tr),transform var(--tr),background var(--tr);display:flex;align-items:flex-start;gap:9px;box-shadow:var(--shadow-xs);-webkit-user-select:none;user-select:none}.task-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.task-card:active{transform:translateY(0)}.task-card[data-status=done]{border-left-color:var(--c-done);background:var(--bg-done)}.task-card[data-status=partially_done]{border-left-color:var(--c-partial);background:var(--bg-partial)}.task-card[data-status=not_done]{border-left-color:var(--c-not-done);background:var(--bg-not-done)}.task-card[data-status=done_late]{border-left-color:var(--c-late);background:var(--bg-late)}.task-card[data-status=cancelled]{border-left-color:var(--c-cancelled);background:var(--bg-cancelled);opacity:.7}.task-card-body{flex:1;min-width:0;text-align:center}.task-title{font-size:15px;font-weight:500;color:var(--text);line-height:1.4;word-break:break-word}.task-card[data-status=done] .task-title{color:var(--t-done)}.task-card[data-status=partially_done] .task-title{color:var(--t-partial)}.task-card[data-status=done_late] .task-title{color:var(--t-late)}.task-card[data-status=cancelled] .task-title{color:var(--t-cancelled);text-decoration:line-through}.task-desc{font-size:13px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.task-toggle-btn{flex-shrink:0;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--c-not-done);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--tr),border-color var(--tr),color var(--tr);color:transparent;margin-top:1px}.task-toggle-btn:hover{background:var(--c-not-done);border-color:var(--c-not-done);color:#fff}.task-card[data-status=done] .task-toggle-btn,.task-card[data-status=done_late] .task-toggle-btn{background:var(--c-done);border-color:var(--c-done);color:#fff}.task-card[data-status=done] .task-toggle-btn:hover{background:transparent;color:transparent;border-color:var(--c-not-done)}.task-card[data-status=partially_done] .task-toggle-btn{border-color:var(--c-partial)}.task-card[data-status=done_late] .task-toggle-btn{background:var(--c-late);border-color:var(--c-late)}.add-task-btn{width:100%;margin:2px 0 8px;padding:9px 11px;border-radius:var(--r);border:1.5px dashed var(--border);background:transparent;color:var(--text-light);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:border-color var(--tr),color var(--tr),background var(--tr)}.add-task-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.sortable-ghost{opacity:.4}.sortable-drag{opacity:1!important;box-shadow:var(--shadow-md)!important;transform:rotate(1deg) scale(1.02)!important}.month-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.month-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));border-bottom:1px solid var(--border);background:var(--bg-header)}.month-weekday{padding:11px 4px;text-align:center;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-right:1px solid var(--border)}.month-weekday:last-child{border-right:none}.month-grid{flex:1;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:auto;overflow-y:auto;border-left:1px solid var(--border)}.month-cell{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:10px;background:var(--bg-col);cursor:pointer;transition:background var(--tr);display:flex;flex-direction:column;gap:5px;min-height:120px}.month-more-mobile{display:none}.month-cell:hover{background:var(--bg-card-hover)}.month-cell.is-today{background:var(--bg-today-col)}.month-cell.other-month{opacity:.45}.month-cell.ds-complete{background:#22c55e1f}.month-cell.ds-partial{background:#3b82f61f}.month-cell.ds-insufficient{background:#ef44441f}.month-cell.ds-complete.is-today{background:#22c55e2e}.month-cell.ds-partial.is-today{background:#3b82f62e}.month-cell.ds-insufficient.is-today{background:#ef44442e}.month-cell-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:2px}.month-day-num{font-size:15px;font-weight:600;color:var(--text-muted);width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;line-height:1;cursor:pointer;transition:background var(--tr)}.month-day-num:hover{background:var(--bg-toggle)}.month-cell.is-today .month-day-num{background:var(--accent);color:#fff}.month-add-btn{width:20px;height:20px;border-radius:50%;border:none;background:transparent;color:var(--text-light);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--tr),color var(--tr),background var(--tr)}.month-cell:hover .month-add-btn{opacity:1}.month-add-btn:hover{background:var(--accent);color:#fff}.month-task-bar{display:flex;align-items:flex-start;gap:9px;padding:8px 12px;border-radius:var(--r-sm);font-size:15px;font-weight:500;cursor:pointer;transition:opacity var(--tr);word-break:break-word}.month-task-bar:hover{opacity:.8}.month-task-bar[data-status=done]{background:var(--bg-done);color:var(--t-done)}.month-task-bar[data-status=partially_done]{background:var(--bg-partial);color:var(--t-partial)}.month-task-bar[data-status=not_done]{background:var(--bg-not-done);color:var(--t-not-done);border:1px solid var(--border)}.month-task-bar[data-status=done_late]{background:var(--bg-late);color:var(--t-late)}.month-task-bar[data-status=cancelled]{background:var(--bg-cancelled);color:var(--t-cancelled);opacity:.7}.month-bar-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.month-task-bar[data-status=done] .month-bar-dot{background:var(--c-done)}.month-task-bar[data-status=partially_done] .month-bar-dot{background:var(--c-partial)}.month-task-bar[data-status=not_done] .month-bar-dot{background:var(--c-not-done)}.month-task-bar[data-status=done_late] .month-bar-dot{background:var(--c-late)}.month-task-bar[data-status=cancelled] .month-bar-dot{background:var(--c-cancelled)}.month-more{font-size:13px;color:var(--text-muted);padding:3px 12px;font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .2s ease}.modal-overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--bg-modal);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-width:520px;display:flex;flex-direction:column;transform:scale(.95) translateY(8px);transition:transform .2s ease,background var(--tr);max-height:calc(100vh - 48px);overflow:hidden}.modal-overlay.open .modal{transform:scale(1) translateY(0)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:22px 22px 0}.modal-heading{font-size:20px;font-weight:700;color:var(--text)}.modal-body{padding:20px 22px;display:flex;flex-direction:column;gap:18px;overflow-y:auto}.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 22px 20px;border-top:1px solid var(--border);gap:8px}.modal-footer-actions{display:flex;gap:8px}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-input,.form-textarea{padding:11px 14px;border-radius:var(--r);border:1.5px solid var(--border);background:var(--bg-input);color:var(--text);font-family:var(--font);font-size:16px;transition:border-color var(--tr),background var(--tr);outline:none;width:100%}.form-input:focus,.form-textarea:focus{border-color:var(--border-focus);background:var(--bg-modal)}.form-textarea{resize:vertical;min-height:72px}.form-input[type=date]{cursor:pointer}.status-selector{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.status-opt{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r);border:1.5px solid var(--border);background:var(--bg-input);cursor:pointer;font-family:var(--font);font-size:14px;font-weight:500;color:var(--text-muted);transition:border-color var(--tr),color var(--tr),background var(--tr)}.status-opt:hover{border-color:var(--accent);color:var(--text)}.status-opt.selected{border-color:var(--accent);background:var(--accent-light);color:var(--text)}.status-swatch{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-swatch.done{background:var(--c-done)}.status-swatch.partially_done{background:var(--c-partial)}.status-swatch.not_done{background:var(--c-not-done)}.status-swatch.done_late{background:var(--c-late)}.status-swatch.cancelled{background:var(--c-cancelled)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.login-card{background:var(--bg-modal);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:40px 36px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:8px}.login-logo{width:52px;height:52px;background:var(--accent);color:#fff;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.login-title{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.3px}.login-subtitle{font-size:14px;color:var(--text-muted);text-align:center;margin-bottom:8px}.login-form{width:100%;display:flex;flex-direction:column;gap:10px;margin-top:8px}.login-input{width:100%;font-size:16px}.login-input-error{border-color:var(--danger)!important}.login-error{font-size:13px;color:var(--danger);text-align:center}.login-btn{width:100%;justify-content:center;font-size:15px;padding:12px}.loading-state{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px;gap:8px}@media (max-width: 900px){.week-grid{grid-template-columns:repeat(7,minmax(110px,1fr))}}@media (max-width: 720px){.app-header{padding:0 12px;gap:8px}.header-nav{gap:2px}.current-period{min-width:120px;font-size:15px}}@media (max-width: 560px){.vl{display:none}.vs{display:inline}.view-btn{padding:5px 9px}.current-period{min-width:90px;font-size:14px}}@media (max-width: 640px){.app-title{display:none}.current-period{min-width:80px}.theme-btn-desktop,.theme-btn-mobile{display:none}.settings-btn-mobile{display:flex}.stats-btn-desktop,.today-btn,.new-habit-btn-desktop,.logout-btn{display:none}.week-pills{display:flex}.week-grid{grid-template-columns:1fr;overflow-x:hidden;border-top:none}.day-col{min-height:auto}.day-col.mobile-hidden{display:none}.day-col.mobile-visible{display:flex}.modal{max-width:100%;border-radius:var(--r-lg) var(--r-lg) 0 0}.modal-overlay{align-items:flex-end;padding:0}.modal-overlay.open .modal{transform:translateY(0)}.modal-overlay .modal{transform:translateY(20px)}.status-selector{grid-template-columns:repeat(2,1fr)}.month-weekdays{grid-template-columns:repeat(7,minmax(0,1fr))}.month-grid{grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:auto}.month-cell{padding:4px 2px;gap:2px;min-height:40px;overflow:hidden}.month-task-bar-hidden{display:none}.month-more-mobile{display:block;font-size:9px;color:var(--text-muted);padding:0 2px;font-weight:500}.month-cell-head{margin-bottom:0}.month-day-num{font-size:11px;width:22px;height:22px}.month-add-btn{display:none}.month-task-bar{font-size:0;padding:0;gap:0;border-radius:3px;height:6px}.month-bar-dot{width:100%;height:100%;border-radius:3px}.month-weekday{font-size:9px;padding:6px 2px;letter-spacing:0}}@media (max-width: 400px){.view-btn{padding:4px 6px;font-size:11px}.app-logo{width:28px;height:28px}}.habit-bar{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:var(--r);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:background var(--tr),border-color var(--tr),transform var(--tr),box-shadow var(--tr);box-shadow:var(--shadow-xs);-webkit-user-select:none;user-select:none}.habit-bar:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.habit-bar:active{transform:translateY(0)}.habit-bar.is-done{background:var(--bg-done);border-color:var(--c-done)}.habit-bar-emoji{font-size:18px;flex-shrink:0;line-height:1}.habit-bar-name{flex:1;font-size:14px;font-weight:500;color:var(--text)}.habit-bar.is-done .habit-bar-name{color:var(--t-done)}.habit-bar-value{font-size:13px;font-weight:600;color:var(--accent);background:var(--accent-light);padding:2px 8px;border-radius:var(--r-sm)}.habit-bar-edit-btn{flex-shrink:0;width:24px;height:24px;border-radius:var(--r-sm);border:none;background:transparent;color:var(--text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--tr),background var(--tr),color var(--tr)}.habit-bar:hover .habit-bar-edit-btn{opacity:1}.habit-bar-edit-btn:hover{background:var(--bg-toggle);color:var(--text)}.btn-sm{padding:6px 12px;font-size:13px}.delete-menu,.delete-confirm{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.delete-menu-label,.delete-confirm-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.delete-confirm-label{flex:1 1 100%;margin-bottom:2px}.habit-month-bar{display:flex;align-items:center;gap:5px;padding:2px 8px;border-radius:var(--r-sm);font-size:12px;font-weight:500;background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);overflow:hidden;white-space:nowrap;transition:opacity var(--tr)}.habit-month-bar:hover{opacity:.8}.habit-month-bar.is-done{background:var(--bg-done);border-color:var(--c-done);color:var(--t-done)}.habit-month-bar-emoji{flex-shrink:0;font-size:11px}.habit-month-bar-name{overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.habit-month-bar-val{flex-shrink:0;font-size:11px;color:var(--accent)}.habit-month-bar-hidden{display:none}.habit-month-dots{display:flex;flex-wrap:wrap;gap:4px;padding:2px 0}.habit-month-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:background var(--tr);flex-shrink:0}.habit-month-dot.is-done{background:var(--c-done)}.habit-dates-row{display:flex;gap:10px}.habit-dates-row .form-group{flex:1}@media (max-width: 420px){.habit-dates-row{flex-direction:column}}.habit-days{display:flex;gap:6px;flex-wrap:wrap}.habit-day-btn{width:38px;height:38px;border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--bg-input);color:var(--text-muted);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--tr),border-color var(--tr),color var(--tr)}.habit-day-btn.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.stats-table{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--r);overflow:hidden}.stats-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);font-size:14px}.stats-row:last-child{border-bottom:none}.stats-header{background:var(--bg-col);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:8px 16px}.stats-row:has(.stats-habit-dot){grid-template-columns:1fr auto auto auto}.stats-habit-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.stats-rate-badge{display:inline-block;padding:2px 10px;border-radius:var(--r-sm);font-size:13px;font-weight:600}.stats-row-clickable{cursor:pointer}.stats-row-clickable:hover{background:var(--bg-card-hover)}.stats-row-clickable:after{content:"›";position:absolute;right:12px;color:var(--text-light);font-size:18px}.stats-row{position:relative}.stats-detail-row{display:grid;grid-template-columns:1fr auto auto;gap:16px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border)}.stats-detail-row:last-child{border-bottom:none}.stats-entry-value-btn{background:var(--accent-light);color:var(--accent);border:none;border-radius:var(--r-sm);padding:3px 10px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);transition:background var(--tr),color var(--tr)}.stats-entry-value-btn:hover{background:var(--accent);color:#fff}.stats-entry-input{width:80px;padding:4px 8px;border-radius:var(--r-sm);border:1.5px solid var(--border-focus);background:var(--bg-input);color:var(--text);font-family:var(--font);font-size:14px;outline:none}@media (max-width: 640px){.habit-month-dot{width:8px;height:8px}.habit-month-dots{gap:3px}.habit-month-bar{font-size:0;padding:0;border-radius:3px;height:6px}.habit-month-bar-emoji,.habit-month-bar-name,.habit-month-bar-val{display:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.task-card{animation:fadeIn .15s ease forwards}
