@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_fe4d0f8a-module__6kuHYW__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_fe4d0f8a-module__6kuHYW__variable{--font-inter:"Inter", "Inter Fallback"}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--bg:#f2f2f7;--card:#fff;--card-hover:#fafafa;--separator:#3c3c431a;--text-primary:#1c1c1e;--text-secondary:#8e8e93;--text-tertiary:#aeaeb2;--accent:#007aff;--accent-bg:#007aff14;--success:#34c759;--success-bg:#34c7591a;--joris-bg:#fdf0ef;--joris-text:#b5342b;--joris-ring:#e8756e;--dylan-bg:#eeedf9;--dylan-text:#4748a8;--dylan-ring:#8485d6;--daan-bg:#e8f5ed;--daan-text:#287a48;--daan-ring:#5fba82;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--shadow-card:0 0 0 .5px #0000000a, 0 1px 3px #0000000a, 0 4px 12px #00000008;--shadow-elevated:0 0 0 .5px #0000000f, 0 4px 16px #00000014, 0 8px 32px #0000000a;--ease-out:cubic-bezier(.25, 1, .5, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s}@media (prefers-color-scheme:dark){:root{--bg:#000;--card:#1c1c1e;--card-hover:#252527;--separator:#ffffff14;--text-primary:#f5f5f7;--text-secondary:#98989d;--text-tertiary:#636366;--accent-bg:#007aff26;--success-bg:#34c75926;--joris-bg:#b5342b26;--joris-text:#f08a83;--joris-ring:#c94040;--dylan-bg:#4748a826;--dylan-text:#a8a9e0;--dylan-ring:#6d6ed0;--daan-bg:#287a4826;--daan-text:#7fd49e;--daan-ring:#4aaf6e;--shadow-card:0 0 0 .5px #ffffff0f, 0 1px 3px #0000004d;--shadow-elevated:0 0 0 .5px #ffffff14, 0 8px 32px #0006}}html{font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg);color:var(--text-primary)}body{background:var(--bg);min-height:100dvh;overflow-x:hidden}#app{max-width:520px;padding:0 16px 80px;padding-top:env(safe-area-inset-top,0);margin:0 auto}.app-header{text-align:center;padding:48px 4px 8px}.app-icon{border-radius:var(--radius-lg);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:28px;display:flex;box-shadow:0 4px 16px #667eea4d}.app-header-hero{justify-content:center;align-items:center;gap:16px;margin-bottom:20px;display:flex}.header-img{object-fit:cover;width:70px;height:70px;box-shadow:var(--shadow-card);border-radius:10%;flex-shrink:0}.header-img-left{transform:rotate(-10deg)}.header-img-right{transform:rotate(10deg)}.app-title{letter-spacing:-.5px;color:var(--text-primary);font-size:28px;font-weight:700;line-height:1.15}.app-subtitle{color:var(--text-secondary);margin-top:4px;font-size:15px;font-weight:400}.person-row{justify-content:center;gap:8px;margin-top:20px;display:flex}.person-chip{cursor:pointer;transition:all var(--duration-normal) var(--ease-out);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;border-radius:100px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;display:flex}.person-chip:active{transform:scale(.95)}.person-chip.active{box-shadow:var(--shadow-card);border-color:currentColor}.person-chip .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.person-chip[data-person=Joris]{background:var(--joris-bg);color:var(--joris-text)}.person-chip[data-person=Joris] .dot{background:var(--joris-ring)}.person-chip[data-person=Dylan]{background:var(--dylan-bg);color:var(--dylan-text)}.person-chip[data-person=Dylan] .dot{background:var(--dylan-ring)}.person-chip[data-person=Daan]{background:var(--daan-bg);color:var(--daan-text)}.person-chip[data-person=Daan] .dot{background:var(--daan-ring)}.week-nav{z-index:100;background:linear-gradient(to bottom, var(--bg) 80%, transparent);margin:12px -16px 0;padding:16px;position:sticky;top:0}.week-nav-inner{-webkit-backdrop-filter:blur(24px)saturate(180%);backdrop-filter:blur(24px)saturate(180%);border-radius:var(--radius-xl);background:#ffffffd9;border:1px solid #ffffff80;justify-content:space-between;align-items:center;padding:14px 10px;display:flex;box-shadow:0 8px 32px #0000000a,0 1px 2px #00000005}@media (prefers-color-scheme:dark){.week-nav-inner{background:#1c1c1eb3;border:1px solid #ffffff14;box-shadow:0 8px 32px #0003}}.week-nav-btn{background:var(--bg);width:44px;height:44px;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;display:flex;box-shadow:0 2px 8px #0000000a}@media (prefers-color-scheme:dark){.week-nav-btn{background:#2c2c2e}}.week-nav-btn:hover{background:var(--accent-bg);color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.week-nav-btn:active{background:var(--accent-bg);transform:scale(.92)}.week-nav-btn svg{width:22px;height:22px}.week-info{text-align:center;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;display:flex}.week-label{color:var(--text-primary);letter-spacing:-.4px;font-size:18px;font-weight:700}.week-date{color:var(--text-secondary);font-size:13px;font-weight:500}.week-current-badge{background:var(--accent-bg);color:var(--accent);text-transform:uppercase;letter-spacing:.8px;border-radius:100px;align-items:center;gap:4px;margin-top:6px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.week-current-badge:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.progress-section{margin:16px 4px 0}.progress-bar-container{align-items:center;gap:12px;display:flex}.progress-bar-track{background:var(--separator);border-radius:100px;flex:1;height:4px;overflow:hidden}.progress-bar-fill{background:var(--success);height:100%;transition:width var(--duration-slow) var(--ease-spring);border-radius:100px;min-width:0}.progress-label{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:500}.progress-complete{color:var(--success)}.section{margin-top:28px}.section-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;padding:0 4px;font-size:13px;font-weight:600}.task-group{background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.task-item{transition:all var(--duration-normal) var(--ease-out);cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;padding:14px 16px;display:flex;position:relative}.task-item:not(:last-child):after{content:"";background:var(--separator);height:.5px;position:absolute;bottom:0;left:52px;right:16px}.task-item:active{background:var(--card-hover)}.task-item.completed{opacity:.5}.task-item.dimmed{opacity:.35}.task-check{border:2px solid var(--text-tertiary);width:24px;height:24px;transition:all var(--duration-normal) var(--ease-spring);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.task-check svg{stroke:#fff;stroke-width:2.5px;stroke-linecap:round;stroke-linejoin:round;fill:none;opacity:0;width:14px;height:14px;transition:all var(--duration-normal) var(--ease-spring);transform:scale(0)}.task-item.completed .task-check{background:var(--success);border-color:var(--success);transform:scale(1)}.task-item.completed .task-check svg{opacity:1;transform:scale(1)}@keyframes checkBounce{0%{transform:scale(.7)}50%{transform:scale(1.15)}to{transform:scale(1)}}.task-item.just-completed .task-check{animation:checkBounce .4s var(--ease-spring)}.task-content{flex:1;min-width:0}.task-icon{text-align:center;flex-shrink:0;width:28px;font-size:20px}.task-name{color:var(--text-primary);letter-spacing:-.2px;font-size:16px;font-weight:500;line-height:1.3}.task-subtitle{color:var(--text-tertiary);margin-top:1px;font-size:13px;font-weight:400}.task-meta{align-items:center;gap:8px;margin-top:3px;display:flex}.frequency-badge{color:var(--text-tertiary);background:color-mix(in srgb, var(--text-tertiary) 8%, transparent);letter-spacing:.1px;border-radius:100px;padding:1px 7px;font-size:11px;font-weight:500}.person-badge{transition:all var(--duration-normal) var(--ease-out);border-radius:100px;flex-shrink:0;align-items:center;gap:4px;padding:4px 10px;font-size:13px;font-weight:600;display:inline-flex}.person-badge[data-person=Joris]{background:var(--joris-bg);color:var(--joris-text)}.person-badge[data-person=Dylan]{background:var(--dylan-bg);color:var(--dylan-text)}.person-badge[data-person=Daan]{background:var(--daan-bg);color:var(--daan-text)}.empty-state{text-align:center;padding:40px 20px}.empty-state-icon{margin-bottom:12px;font-size:40px}.empty-state-title{color:var(--text-primary);font-size:17px;font-weight:600}.empty-state-subtitle{color:var(--text-secondary);margin-top:4px;font-size:15px}.all-done{text-align:center;background:var(--card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);margin-top:28px;padding:32px 20px 24px}.all-done-icon{margin-bottom:12px;font-size:44px;animation:3s ease-in-out infinite celebrateFloat}@keyframes celebrateFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.all-done-title{color:var(--text-primary);letter-spacing:-.3px;font-size:20px;font-weight:700}.all-done-subtitle{color:var(--text-secondary);margin-top:4px;font-size:15px}.content-area{transition:opacity var(--duration-fast) ease}.content-area.sliding{opacity:0}.today-btn{background:var(--accent);color:#fff;font-family:var(--font);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);-webkit-tap-highlight-color:transparent;border:none;border-radius:100px;margin:12px auto 0;padding:6px 16px;font-size:13px;font-weight:600;display:none}.today-btn.visible{display:block}.today-btn:hover{box-shadow:0 2px 12px #007aff4d}.today-btn:active{transform:scale(.95)}.scroll-fade{background:linear-gradient(to top, var(--bg), transparent);pointer-events:none;z-index:50;height:60px;position:fixed;bottom:0;left:0;right:0}@media (max-width:400px){#app{padding:0 12px 60px}.app-title{font-size:20px}.app-header-hero{gap:12px}.header-img{width:70px;height:70px}.week-nav{margin:8px -12px 0;padding-left:12px;padding-right:12px}.task-item{gap:10px;padding:12px 14px}.person-chip{padding:5px 11px;font-size:12px}}@keyframes shimmer{to{background-position:-200%}}.skeleton{background:linear-gradient(90deg, var(--separator) 25%, color-mix(in srgb, var(--separator) 50%, transparent) 50%, var(--separator) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}.overdue-dot{background:#ff3b30;border-radius:50%;flex-shrink:0;width:6px;height:6px;animation:2s ease-in-out infinite pulse}
