:root{--text:#4b5563;--text-h:#111827;--bg:#f9fafb;--surface:#fff;--border:#e5e7eb;--accent:#6366f1;--accent-hover:#4f46e5;--accent-bg:#6366f11a;--danger:#ef4444;--danger-hover:#dc2626;--success:#22c55e;--warning:#f59e0b;--warning-hover:#d97706;--warning-bg:#f59e0b1a;--shadow:#0000001a 0 4px 6px -1px, #0000000d 0 2px 4px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/150% var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--text:#d1d5db;--text-h:#f3f4f6;--bg:#0f172a;--surface:#1f2937;--border:#374151;--accent:#818cf8;--accent-hover:#6366f1;--accent-bg:#818cf826;--danger:#f87171;--danger-hover:#ef4444;--success:#4ade80;--warning:#fbbf24;--warning-hover:#f59e0b;--warning-bg:#fbbf2426}}body{margin:0}#root{box-sizing:border-box;max-width:800px;min-height:100svh;margin:0 auto;padding:24px}h1,h2,h3{font-family:var(--heading);color:var(--text-h);margin:0;font-weight:600}h1{font-size:28px}h2{font-size:22px}h3{margin-bottom:12px;font-size:18px}button{font:inherit;cursor:pointer;border:none;border-radius:8px;padding:8px 14px;transition:background .2s,transform .1s}button:active{transform:translateY(1px)}input,select{font:inherit;border:1px solid var(--border);background:var(--surface);color:var(--text-h);border-radius:8px;outline:none;padding:8px 10px}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}label{color:var(--text-h);flex-direction:column;gap:6px;font-weight:500;display:flex}.app-loading{text-align:center;color:var(--text);padding:40px}.app-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.points-badge{background:var(--accent-bg);color:var(--accent);border-radius:999px;padding:8px 14px;font-size:14px;font-weight:700}.app-nav{background:var(--surface);box-shadow:var(--shadow);border-radius:12px;gap:8px;margin-bottom:24px;padding:6px;display:flex}.app-nav button{color:var(--text);background:0 0;flex:1 1 0;padding:10px;font-weight:500}.app-nav button.active{background:var(--accent);color:#fff}.app-main section{flex-direction:column;gap:16px;display:flex}.section-header{justify-content:space-between;align-items:center;display:flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--border);color:var(--text-h)}.btn-secondary:hover{background:#d1d5db}.btn-danger{color:var(--danger);border:1px solid var(--danger);background:0 0;padding:6px 12px;font-size:14px}.btn-danger:hover{background:#ef44441a}.task-form,.reward-form{background:var(--surface);box-shadow:var(--shadow);border-radius:12px;flex-direction:column;gap:14px;padding:20px;display:flex}.form-actions{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.day-selector{flex-wrap:wrap;gap:8px;display:flex}.day-selector button{background:var(--bg);border:1px solid var(--border);min-width:44px;color:var(--text);flex:calc(14% - 8px);padding:10px 6px;font-size:14px}.day-selector button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.empty{color:var(--text);opacity:.8;text-align:center;padding:24px}.task-list,.reward-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.task-item,.reward-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.task-info,.reward-info{flex-direction:column;gap:4px;min-width:0;display:flex}.task-title,.reward-title{color:var(--text-h);word-break:break-word;font-weight:600}.task-meta,.reward-meta{opacity:.85;font-size:13px}.task-item.completed .task-title{opacity:.6;text-decoration:line-through}.task-item.failed{border-color:var(--danger);background:#ef44440d}.task-item.skipped{border-color:var(--text);background:#6b72800d}.task-item.skipped .task-title{opacity:.7;font-style:italic}.task-item.failed .task-title{opacity:.8;font-style:italic}.task-skip-btn{color:var(--text);border:1px solid var(--border);background:0 0;border-radius:6px;flex-shrink:0;padding:4px 10px;font-size:13px}.task-skip-btn:hover{background:var(--bg)}.task-skip-btn.unskip{background:var(--text);color:#fff}.task-skip-btn.unskip:hover{background:var(--text-h)}.task-fail-btn{color:var(--danger);border:1px solid var(--danger);background:0 0;border-radius:6px;flex-shrink:0;padding:4px 10px;font-size:13px}.task-fail-btn:hover{background:#ef44441a}.task-fail-btn.unfail{background:var(--danger);color:#fff}.task-fail-btn.unfail:hover{background:var(--danger-hover)}.task-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.task-postpone-btn{color:var(--text);border:1px solid var(--border);background:0 0;border-radius:6px;padding:4px 10px;font-size:13px}.task-postpone-btn:hover{background:var(--bg)}.postpone-date-input{padding:4px 8px;font-size:13px}.task-item.postponed{border-color:var(--warning);background:var(--warning-bg)}.task-checkbox{cursor:pointer;flex-direction:row;flex:auto;align-items:center;gap:12px;display:flex}.task-checkbox input{width:22px;height:22px;accent-color:var(--accent);cursor:pointer}.task-points{background:var(--accent-bg);color:var(--accent);border-radius:999px;margin-left:auto;padding:4px 10px;font-size:12px;font-weight:700}.reward-desc{opacity:.9;font-size:14px}.reward-actions{flex-shrink:0;gap:8px;display:flex}.reward-item.unaffordable{opacity:.7}.auth-container{text-align:center;max-width:400px;margin:80px auto}.auth-form{background:var(--surface);box-shadow:var(--shadow);text-align:left;border-radius:16px;flex-direction:column;gap:16px;margin-top:24px;padding:28px;display:flex}.auth-form h2{text-align:center;margin-bottom:8px}.auth-error{color:var(--danger);text-align:center;background:#ef44441a;border-radius:8px;padding:10px 12px;font-size:14px}.auth-toggle{text-align:center;margin:0;font-size:14px}.link-button{color:var(--accent);background:0 0;padding:0;font-weight:600;text-decoration:underline}.link-button:hover{color:var(--accent-hover)}.header-actions{align-items:center;gap:12px;display:flex}@media (width<=640px){#root{padding:16px}.app-header,.section-header{flex-direction:column;align-items:flex-start;gap:10px}.task-item,.reward-item{flex-direction:column;align-items:flex-start}.reward-actions{justify-content:flex-end;width:100%}.day-selector button{flex:calc(25% - 8px)}.task-actions{justify-content:flex-end;width:100%}}.modal-backdrop{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);box-shadow:var(--shadow);border-radius:16px;width:100%;max-width:360px;padding:20px}.date-picker-modal{flex-direction:column;gap:16px;display:flex}.date-picker-header{justify-content:space-between;align-items:center;display:flex}.date-picker-month-name{color:var(--text-h);font-size:18px;font-weight:600}.date-picker-nav{gap:6px;display:flex}.date-picker-nav button{background:var(--bg);border:1px solid var(--border);color:var(--text-h);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:20px;line-height:1;display:flex}.date-picker-nav button:hover{background:var(--accent-bg);border-color:var(--accent)}.date-picker-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.date-picker-grid button{aspect-ratio:1;background:var(--bg);border:1px solid var(--border);color:var(--text-h);border-radius:8px;justify-content:center;align-items:center;padding:0;font-size:14px;display:flex}.date-picker-grid button:hover{background:var(--accent-bg);border-color:var(--accent)}.date-picker-grid button.selected{background:var(--accent);color:#fff;border-color:var(--accent)}.date-picker-footer{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.yearly-date-selector{flex-direction:column;gap:10px;display:flex}.yearly-date-chips{flex-wrap:wrap;gap:8px;display:flex}.yearly-date-chip{background:var(--accent-bg);color:var(--accent);border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:14px;font-weight:500;display:inline-flex}.yearly-date-chip button{color:inherit;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:16px;line-height:1;display:flex}.yearly-date-chip button:hover{background:#0000001a}.stats-section{flex-direction:column;gap:16px;display:flex}.stats-summary{background:var(--surface);box-shadow:var(--shadow);color:var(--text);border-radius:12px;padding:16px 20px;font-size:16px}.stats-summary strong{color:var(--accent);margin-right:4px;font-size:24px}.bar-chart{background:var(--surface);box-shadow:var(--shadow);border-radius:12px;justify-content:space-between;align-items:flex-end;gap:4px;height:240px;padding:20px 12px 12px;display:flex;overflow-x:auto}.bar-chart-column{flex-direction:column;flex:1 1 0;justify-content:flex-end;align-items:center;gap:6px;min-width:18px;height:100%;display:flex}.bar-chart-bar{background:var(--accent);border-radius:4px 4px 0 0;width:100%;max-width:20px;min-height:2px;transition:height .3s}.bar-chart-bar:hover{background:var(--accent-hover)}.bar-chart-label{color:var(--text);opacity:.8;font-size:10px}
