:root{--color-text:#1a1a1a;--color-text-muted:#666;--color-border:#d9d9d9;--color-border-hover:hsl(from var(--color-border) h s calc(l - 20));--color-background:#f5f5f5;--color-background-hover:hsl(from var(--color-background) h s calc(l - 3));--color-white:#fff;--color-neutral:#fafafa;--color-primary:#4cae4f;--color-primary-hover:hsl(from var(--color-primary) h s calc(l - 20));--color-success:#4cae4f;--color-warning:#f90;--color-danger:#f44034;--color-critical:#212121;--color-bronze:#ffc105;--color-transparent:transparent;--color-backdrop:#00000059;--color-shadow:#00000026;--color-shadow-darker:#0000004d;--z-index-focus:1;--z-index-backdrop:9;--z-index-overlay:10;--z-index-update-prompt:100;background:var(--color-background);color:var(--color-text);font-family:system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:var(--color-background);margin:0}#app{max-width:1200px;min-height:100vh;margin:0 auto;padding:16px}@media (max-width:768px){#app{padding:2px}header{gap:4px;margin-bottom:4px}h1{font-size:.95rem}header label{gap:4px;font-size:.85rem}header label input[type=number]{width:60px;padding:4px 6px;font-size:.85rem}button{padding:4px 8px;font-size:.85rem}.section{border-width:1px;border-radius:4px;padding:2px}}header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}button{appearance:none;border:1px solid var(--color-border);background:var(--color-white);cursor:pointer;border-radius:6px;padding:8px 12px;transition:border-color .15s}button:disabled{opacity:.5;cursor:default}button:hover:not(:disabled){border-color:var(--color-border-hover)}button.primary{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);font-weight:500}button.primary:hover{border-color:var(--color-primary-hover)}input,select,textarea{border:1px solid var(--color-border);width:100%;font:inherit;border-radius:6px;padding:8px}h1{margin:0;font-size:1.5rem}header label{white-space:nowrap;align-items:center;gap:8px;display:flex}header label input[type=number]{width:80px}.section{background:var(--color-white);border:1px solid var(--color-border);border-radius:10px;padding:12px}.note-backdrop.svelte-xskfn5{background:var(--color-backdrop);z-index:var(--z-index-overlay);cursor:pointer;border:none;justify-content:center;align-items:flex-end;width:100%;height:100%;padding:10px;display:flex;position:fixed;inset:0}.note-backdrop.svelte-xskfn5:focus{outline:none}.note-dialog.svelte-xskfn5{background:var(--color-white);width:min(480px,100%);box-shadow:0 10px 30px var(--color-shadow);cursor:default;border-radius:12px 12px 10px 10px;flex-direction:column;gap:8px;padding:12px;display:flex}.note-dialog.svelte-xskfn5 header:where(.svelte-xskfn5){justify-content:space-between;align-items:center;display:flex}.note-actions.svelte-xskfn5{justify-content:flex-end;gap:8px;display:flex}.year-grid.svelte-4laz5u{border-collapse:separate;border-spacing:2px;table-layout:fixed;width:100%;overflow-x:auto}.day-header.svelte-4laz5u{background:var(--color-transparent);width:40px;padding:4px 2px}.month-header.svelte-4laz5u{text-align:center;color:var(--color-text-muted);width:calc(8.33333% - 3.33333px);padding:4px 2px;font-size:.85rem;font-weight:600}.day-label.svelte-4laz5u{text-align:right;color:var(--color-text-muted);width:40px;padding:4px 6px 4px 2px;font-size:.75rem;font-weight:400}.day-cell.svelte-4laz5u{padding:0;position:relative}.day-cell.svelte-4laz5u:after{content:"";padding-bottom:100%;display:block}.day-cell.empty.svelte-4laz5u{background:var(--color-transparent)}.day.svelte-4laz5u{border:1px solid var(--color-border);background:var(--color-background);text-align:center;vertical-align:middle;-webkit-user-select:none;user-select:none;touch-action:manipulation;cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:100%;height:100%;padding:0;font-size:1.2rem;display:flex;position:absolute;top:0;left:0}.day.svelte-4laz5u>span:where(.svelte-4laz5u){justify-content:center;align-items:center;display:flex}.day.svelte-4laz5u:focus{z-index:var(--z-index-focus);outline-offset:-2px}.day.has-category.svelte-4laz5u{color:var(--color-white);border-color:var(--color-transparent)}.note-badge.svelte-4laz5u{width:6px;height:6px;box-shadow:0 1px 2px var(--color-shadow-darker);background:#ffffffe6;border-radius:50%;position:absolute;top:2px;right:2px}.day.svelte-4laz5u:not(.has-category) .note-badge:where(.svelte-4laz5u){background:var(--color-primary)}@media (max-width:768px){.year-grid.svelte-4laz5u{border-spacing:1px;overflow-x:hidden}.day-header.svelte-4laz5u{width:24px}.month-header.svelte-4laz5u{width:calc(8.33333% - 2px);padding:1px;font-size:.55rem;font-weight:500}.day-label.svelte-4laz5u{width:24px;padding:1px 2px 1px 0;font-size:.5rem}.day.svelte-4laz5u{border-radius:1px;font-size:.6rem}.note-badge.svelte-4laz5u{width:3px;height:3px;box-shadow:0 0 1px var(--color-shadow-darker);top:1px;right:1px}}.stat-section.svelte-1cpfk6k{background:var(--color-white);border:1px solid var(--color-border);border-radius:10px;padding:12px}.stat-section.svelte-1cpfk6k h2{color:var(--color-text);margin:0 0 16px;font-size:1.25rem;font-weight:600}.no-data.svelte-1cpfk6k{color:var(--color-text-muted);margin:8px 0;font-style:italic}.category-stats.svelte-1cpfk6k{color:var(--color-text);font-size:.95rem}.percentage.svelte-1cpfk6k{color:var(--color-text-muted);font-size:.9rem}@media (max-width:768px){.stat-section.svelte-1cpfk6k{padding:12px}.stat-section.svelte-1cpfk6k h2{margin-bottom:12px;font-size:1rem}.category-stats.svelte-1cpfk6k{font-size:.85rem}}.tug-of-war.svelte-1cpfk6k{flex-direction:column;gap:12px;display:flex}.tug-sides.svelte-1cpfk6k{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px;display:flex}.tug-side.svelte-1cpfk6k{flex-direction:column;flex:1;gap:4px;display:flex}.tug-side.water-side.svelte-1cpfk6k{align-items:flex-start}.tug-side.alcohol-side.svelte-1cpfk6k{align-items:flex-end}.tug-label.svelte-1cpfk6k{color:var(--color-text);font-size:1rem;font-weight:600}.tug-bar.svelte-1cpfk6k{width:100%;height:40px;box-shadow:0 2px 8px var(--color-shadow);border-radius:8px;display:flex;overflow:hidden}.water-portion.svelte-1cpfk6k{background:var(--color-success);height:100%}.alcohol-portion.svelte-1cpfk6k{background:linear-gradient(90deg,#f90,#f44034,#212121);height:100%}.stat-section.svelte-cwzvf3{background:var(--color-white);border:1px solid var(--color-border);border-radius:10px;padding:12px}.stat-section.svelte-cwzvf3 h2{color:var(--color-text);margin:0 0 16px;font-size:1.25rem;font-weight:600}.no-data.svelte-cwzvf3{color:var(--color-text-muted);margin:8px 0;font-style:italic}.category-stats.svelte-cwzvf3{color:var(--color-text);font-size:.95rem}.percentage.svelte-cwzvf3{color:var(--color-text-muted);font-size:.9rem}@media (max-width:768px){.stat-section.svelte-cwzvf3{padding:12px}.stat-section.svelte-cwzvf3 h2{margin-bottom:12px;font-size:1rem}.category-stats.svelte-cwzvf3{font-size:.85rem}}.category-list.svelte-cwzvf3{flex-direction:column;gap:16px;display:flex}.category-item.svelte-cwzvf3{flex-direction:column;gap:6px;display:flex}.category-header.svelte-cwzvf3{justify-content:space-between;align-items:center;display:flex}.category-label.svelte-cwzvf3{align-items:center;gap:8px;font-size:1.5rem;display:flex}.progress-bar.svelte-cwzvf3{background:var(--color-background);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-fill.svelte-cwzvf3{border-radius:4px;height:100%}.total-info.svelte-cwzvf3{border-top:1px solid var(--color-border);color:var(--color-text-muted);text-align:right;margin-top:16px;padding-top:16px;font-size:.9rem}@media (max-width:768px){.category-label.svelte-cwzvf3{font-size:1.2rem}}.stat-section.svelte-muhydt{background:var(--color-white);border:1px solid var(--color-border);border-radius:10px;padding:12px}.stat-section.svelte-muhydt h2{color:var(--color-text);margin:0 0 16px;font-size:1.25rem;font-weight:600}.no-data.svelte-muhydt{color:var(--color-text-muted);margin:8px 0;font-style:italic}@media (max-width:768px){.stat-section.svelte-muhydt{padding:12px}.stat-section.svelte-muhydt h2{margin-bottom:12px;font-size:1rem}}.streak-info.svelte-muhydt{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.streak-card.svelte-muhydt{border:2px solid var(--color-border);background:var(--color-background);border-radius:8px;padding:16px}.streak-card.longest.svelte-muhydt{border-color:var(--color-success)}.streak-card.current.svelte-muhydt{border-color:var(--color-warning)}.streak-title.svelte-muhydt{color:var(--color-text-muted);text-transform:uppercase;margin-bottom:8px;font-size:.85rem;font-weight:500}.streak-value.svelte-muhydt{color:var(--color-text);margin-bottom:4px;font-size:2rem;font-weight:700}.streak-dates.svelte-muhydt{color:var(--color-text-muted);font-size:.85rem}@media (max-width:768px){.streak-value.svelte-muhydt{font-size:1.5rem}.streak-info.svelte-muhydt{grid-template-columns:1fr;gap:12px}.streak-card.svelte-muhydt{padding:12px}}.stat-section.svelte-sberht{background:var(--color-white);border:1px solid var(--color-border);border-radius:10px;padding:12px}.stat-section.svelte-sberht h2{color:var(--color-text);margin:0 0 16px;font-size:1.25rem;font-weight:600}.no-data.svelte-sberht{color:var(--color-text-muted);margin:8px 0;font-style:italic}.percentage.svelte-sberht{color:var(--color-text-muted);font-size:.9rem}@media (max-width:768px){.stat-section.svelte-sberht{padding:12px}.stat-section.svelte-sberht h2{margin-bottom:12px;font-size:1rem}}.weekday-ranking.svelte-sberht{flex-direction:column;gap:12px;display:flex}.weekday-item.svelte-sberht{border:1px solid var(--color-border);background:var(--color-background);border-radius:8px;align-items:flex-start;gap:12px;padding:12px;display:flex}.weekday-rank.svelte-sberht{color:var(--color-text-muted);text-align:center;min-width:40px;font-size:1.25rem;font-weight:700}.weekday-item.svelte-sberht:first-child .weekday-rank:where(.svelte-sberht){color:var(--color-danger);font-size:1.5rem}.weekday-item.svelte-sberht:nth-child(2) .weekday-rank:where(.svelte-sberht){color:var(--color-warning)}.weekday-item.svelte-sberht:nth-child(3) .weekday-rank:where(.svelte-sberht){color:var(--color-bronze)}.weekday-content.svelte-sberht{flex-direction:column;flex:1;gap:4px;display:flex}.weekday-header.svelte-sberht{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.weekday-name.svelte-sberht{color:var(--color-text);font-size:1rem;font-weight:600}.weekday-stats.svelte-sberht{color:var(--color-text);font-size:.9rem}.weekday-details.svelte-sberht{color:var(--color-text-muted);font-size:.85rem}.statistics.svelte-ofqa5g{flex-direction:column;gap:24px;display:flex}@media (max-width:768px){.statistics.svelte-ofqa5g{gap:12px}}.backdrop.svelte-1gn5923{z-index:var(--z-index-backdrop);background:var(--color-backdrop);position:fixed;inset:0}.sync-dialog.svelte-1gn5923{z-index:var(--z-index-overlay);background:var(--color-white);border:1px solid var(--color-border);box-shadow:0 8px 24px var(--color-shadow-darker);border-radius:10px;width:min(400px,100vw - 32px);max-height:calc(100vh - 32px);margin:0;padding:0;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}.sync-dialog.svelte-1gn5923 header:where(.svelte-1gn5923){justify-content:space-between;align-items:center;gap:8px;margin:0;padding:16px 20px 12px;display:flex}.sync-dialog.svelte-1gn5923 h2:where(.svelte-1gn5923){margin:0;font-size:1.1rem}.close-btn.svelte-1gn5923{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:4px 8px;font-size:1.4rem;line-height:1}.close-btn.svelte-1gn5923:hover{color:var(--color-text)}.dialog-body.svelte-1gn5923{flex-direction:column;gap:12px;padding:0 20px 20px;display:flex}label.svelte-1gn5923{color:var(--color-text-muted);flex-direction:column;gap:4px;font-size:.9rem;display:flex}.info.svelte-1gn5923{margin:0;font-size:.95rem}.muted.svelte-1gn5923{color:var(--color-text-muted);margin:0;font-size:.85rem}code.svelte-1gn5923{background:var(--color-background);border-radius:3px;padding:2px 4px;font-size:.8rem}.error.svelte-1gn5923{color:var(--color-danger);margin:0;font-size:.85rem}.success.svelte-1gn5923{color:var(--color-success);margin:0;font-size:.85rem}.user-info.svelte-1gn5923{word-break:break-all;margin:0;font-size:.9rem}.sync-status.svelte-1gn5923{background:var(--color-background);color:var(--color-text-muted);border-radius:8px;align-items:center;gap:8px;padding:10px 12px;font-size:.85rem;display:flex}.sync-status.syncing.svelte-1gn5923{background:hsl(from var(--color-warning) h s l / .1);color:var(--color-warning)}.sync-status.synced.svelte-1gn5923{background:hsl(from var(--color-success) h s l / .1);color:var(--color-success)}.sync-status.sync-error.svelte-1gn5923{background:hsl(from var(--color-danger) h s l / .1);color:var(--color-danger)}.spinner.svelte-1gn5923{border:2px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.6s linear infinite svelte-1gn5923-spin}@keyframes svelte-1gn5923-spin{to{transform:rotate(360deg)}}.check.svelte-1gn5923,.cross.svelte-1gn5923{flex-shrink:0;font-size:1rem;font-weight:700}.dot.svelte-1gn5923{background:currentColor;border-radius:50%;flex-shrink:0;width:8px;height:8px}.sync-actions.svelte-1gn5923{gap:8px;display:flex}.sync-actions.svelte-1gn5923 button:where(.svelte-1gn5923){flex:1}hr.svelte-1gn5923{border:none;border-top:1px solid var(--color-border);margin:4px 0}.secondary.svelte-1gn5923{background:var(--color-background);border:1px solid var(--color-border);cursor:pointer;border-radius:6px;padding:8px 16px;font-size:.9rem}.secondary.svelte-1gn5923:hover{background:var(--color-border)}.logout.svelte-1gn5923{color:var(--color-danger);cursor:pointer;text-align:left;background:0 0;border:none;padding:8px 0;font-size:.9rem}.logout.svelte-1gn5923:hover{text-decoration:underline}.backdrop.svelte-1a002vt{z-index:var(--z-index-backdrop);background:0 0;position:fixed;inset:0}.sync-dropdown.svelte-1a002vt{display:inline-block;position:relative}.sync-dropdown.svelte-1a002vt summary:where(.svelte-1a002vt){cursor:pointer;border:1px solid var(--color-border);background:var(--color-white);-webkit-user-select:none;user-select:none;box-sizing:border-box;border-radius:6px;align-items:center;height:40px;padding:8px 10px;font-size:1.2rem;list-style:none;transition:border-color .15s;display:flex}.sync-dropdown.svelte-1a002vt summary:where(.svelte-1a002vt)::-webkit-details-marker{display:none}.sync-dropdown.svelte-1a002vt summary:where(.svelte-1a002vt):hover{border-color:var(--color-border-hover)}.sync-menu.svelte-1a002vt{background:var(--color-white);border:1px solid var(--color-border);box-shadow:0 4px 12px var(--color-shadow);min-width:180px;z-index:var(--z-index-overlay);border-radius:6px;flex-direction:column;margin-top:4px;display:flex;position:absolute;top:100%;right:0;overflow:hidden}.sync-menu.svelte-1a002vt button:where(.svelte-1a002vt){text-align:left;background:var(--color-white);white-space:nowrap;border:none;border-radius:0;align-items:center;min-height:40px;padding:12px 16px;transition:background .15s;display:flex}.sync-menu.svelte-1a002vt button:where(.svelte-1a002vt):hover{background:var(--color-background-hover)}.sync-menu.svelte-1a002vt button:where(.svelte-1a002vt)+button:where(.svelte-1a002vt){border-top:1px solid var(--color-border)}.sync-tick.svelte-1a002vt{color:var(--color-success);margin-left:6px;font-weight:700}@media (max-width:768px){.sync-dropdown.svelte-1a002vt summary:where(.svelte-1a002vt){border-radius:4px;padding:4px 6px;font-size:1rem}.sync-menu.svelte-1a002vt{border-radius:4px;min-width:140px;margin-top:2px}.sync-menu.svelte-1a002vt button:where(.svelte-1a002vt){min-height:40px;padding:10px 12px;font-size:.85rem}}.update-prompt.svelte-1ou6uno{z-index:var(--z-index-update-prompt);animation:.3s ease-out svelte-1ou6uno-slideIn;position:fixed;bottom:20px;right:20px}@keyframes svelte-1ou6uno-slideIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.update-content.svelte-1ou6uno{background:#fff;border:1px solid #e0e0e0;border-radius:8px;min-width:300px;max-width:400px;padding:16px;box-shadow:0 4px 12px #00000026}.update-message.svelte-1ou6uno{margin-bottom:12px}.update-message.svelte-1ou6uno strong:where(.svelte-1ou6uno){color:var(--color-text);margin-bottom:4px;font-size:16px;display:block}.update-message.svelte-1ou6uno p:where(.svelte-1ou6uno){color:var(--color-text-muted);margin:0;font-size:14px}.update-actions.svelte-1ou6uno{justify-content:flex-end;gap:8px;display:flex}@media (max-width:480px){.update-prompt.svelte-1ou6uno{bottom:10px;left:10px;right:10px}.update-content.svelte-1ou6uno{min-width:100%}}header.svelte-1n46o8q{align-items:center;gap:8px;display:flex}h1.svelte-1n46o8q{align-items:center;gap:4px;display:inline-flex}.favicon.svelte-1n46o8q{width:1.5rem;height:1.5rem}.year-editable.svelte-1n46o8q{cursor:text;border-radius:4px;padding:2px 4px;transition:background-color .2s}.year-editable.svelte-1n46o8q:hover,.year-editable.svelte-1n46o8q:focus{background-color:var(--color-background)}.view-buttons.svelte-1n46o8q{border:1px solid var(--color-border);background:var(--color-background);border-radius:6px;gap:4px;height:40px;margin-inline-start:auto;padding:2px;display:flex}.view-buttons.svelte-1n46o8q button:where(.svelte-1n46o8q){background:0 0;border:none;border-radius:4px;height:34px;padding:6px 12px;font-size:.9rem}.view-buttons.svelte-1n46o8q button[aria-selected=true]:where(.svelte-1n46o8q){background:var(--color-white);border:1px solid var(--color-border)}.view-buttons.svelte-1n46o8q button[aria-selected=false]:where(.svelte-1n46o8q):hover{background:hsl(from var(--color-white) h s l / .8)}@media (max-width:768px){.view-buttons.svelte-1n46o8q button:where(.svelte-1n46o8q){padding:4px 8px;font-size:.8rem}}
