@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Plus+Jakarta+Sans:wght@600;700&display=swap";:root{--space-0:0;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--color-bg-canvas:#e3edf5;--color-bg-canvas-mid:#ebf3f1;--color-bg-canvas-end:#f0f6f3;--color-surface:#fff;--color-surface-elevated:#f6fafb;--color-surface-muted:#e5f0ec;--color-tonal-blue:#e1ecf4;--color-tonal-blue-text:#2a5f73;--color-tonal-green:#dff2ea;--color-tonal-green-text:#2a6b52;--color-border:#c9d9de;--color-border-strong:#a8bcc4;--color-border-card:#a5bec68c;--color-text:#1a2e36;--color-text-secondary:#3d5660;--color-text-muted:#5f7580;--color-heading:#1e4a55;--color-accent:#3a7d8f;--color-accent-hover:#2f6878;--color-accent-muted:#3a7d8f29;--color-accent-subtle:#3a7d8f17;--color-active-pill-stroke:#3a7d8f47;--color-success:#2a6b52;--color-danger:#b42318;--color-danger-bg:#fef2f2;--color-info-bg:#e0eef6;--color-info-text:#2a5f73;--color-focus-ring:#3a7d8f6b;--focus-ring-width:3px;--focus-ring-offset:2px;--radius-sm:8px;--radius-md:10px;--radius-lg:12px;--radius-pill:9999px;--shadow-xs:0 1px 2px #142d370d;--shadow-sm:0 1px 3px #142d3712;--shadow-md:0 4px 14px #142d3717;--shadow-lg:0 10px 28px #142d371c;--shadow-card:0 2px 12px #19374112, 0 1px 3px #1937410a;--shadow-primary:0 2px 10px #2f687838;--color-overlay:#16303a73;--font-sans:"DM Sans", system-ui, -apple-system, sans-serif;--font-display:"Plus Jakarta Sans", var(--font-sans);--text-xs:clamp(.6875rem, .65rem + .2vw, .75rem);--text-sm:clamp(.8125rem, .78rem + .15vw, .875rem);--text-base:clamp(.9375rem, .9rem + .1vw, 1rem);--text-lg:clamp(1.0625rem, 1rem + .2vw, 1.125rem);--text-xl:clamp(1.25rem, 1.1rem + .5vw, 1.5rem);--text-2xl:clamp(1.35rem, 1.2rem + .6vw, 1.75rem);--leading-tight:1.25;--leading-snug:1.35;--leading-normal:1.5;--duration-fast:.15s;--duration-normal:.22s;--ease-out:cubic-bezier(.33, 1, .68, 1);--layout-max-width:880px;--layout-nav-max-width:1100px;--tap-min:44px;--z-dropdown:50;--z-sticky:100;--z-modal:200;--z-toast:300;--page-pad-x:var(--space-4);--page-pad-y:var(--space-5);--card-pad:var(--space-5)}@media (width<=768px){:root{--page-pad-x:var(--space-3);--page-pad-y:var(--space-4);--card-pad:var(--space-4)}}@media (width<=480px){:root{--page-pad-x:var(--space-3);--page-pad-y:var(--space-3);--card-pad:var(--space-4)}}@media (prefers-reduced-motion:reduce){:root{--duration-fast:.01ms;--duration-normal:.01ms}}:root{font-family:var(--font-sans);line-height:var(--leading-normal);color:var(--color-text);background-color:var(--color-bg-canvas);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400}*{box-sizing:border-box}body{background-color:var(--color-bg-canvas);background-image:linear-gradient(165deg, var(--color-bg-canvas) 0%, var(--color-bg-canvas-mid) 48%, var(--color-bg-canvas-end) 100%);background-attachment:fixed;min-width:320px;min-height:100vh;margin:0}#root{flex-direction:column;min-height:100vh;display:flex}a{color:var(--color-accent);font-weight:500;text-decoration:none}a:hover{color:var(--color-accent-hover);text-decoration:underline}button{font-family:var(--font-sans);cursor:pointer;border-radius:var(--radius-md);letter-spacing:.02em;transition:background-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);touch-action:manipulation;border:none;font-weight:600}button:disabled{cursor:not-allowed;opacity:.72}button:focus:not(:focus-visible){outline:none}button:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}input,select,textarea{font-family:var(--font-sans);font-size:1rem}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}h1,h2,h3{font-family:var(--font-display);color:var(--color-heading);margin:0;font-weight:600}.page{padding:var(--page-pad-y) var(--page-pad-x);padding-bottom:max(var(--page-pad-y), env(safe-area-inset-bottom));max-width:var(--layout-max-width);flex:1;width:100%;margin:0 auto}@media (width<=768px){.page-title{font-size:var(--text-xl);margin-bottom:var(--space-3)}}@media (width<=480px){.page-title{font-size:var(--text-lg);margin-bottom:var(--space-3)}}.page-title{font-family:var(--font-display);font-size:var(--text-2xl);margin-bottom:var(--space-4);letter-spacing:-.02em;font-weight:700;line-height:var(--leading-tight);color:var(--color-heading)}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--color-border-card);padding:var(--card-pad)}a.btn-primary,a.btn-secondary{justify-content:center;align-items:center;gap:var(--space-2);box-sizing:border-box;display:inline-flex;text-decoration:none!important}a.btn-primary:hover,a.btn-secondary:hover{text-decoration:none!important}.btn-primary{justify-content:center;align-items:center;gap:var(--space-2);background:linear-gradient(180deg, #45899c 0%, var(--color-accent) 100%);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);min-height:var(--tap-min);box-shadow:var(--shadow-primary);transition:background-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);display:inline-flex;color:#fff!important}.btn-primary:hover{background:var(--color-accent-hover);box-shadow:0 4px 14px #2f687852;color:#fff!important}.btn-primary:active{box-shadow:var(--shadow-xs);transform:translateY(1px)}@media (prefers-reduced-motion:reduce){.btn-primary:active{transform:none}}.btn-secondary{justify-content:center;align-items:center;gap:var(--space-2);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border-strong);padding:var(--space-2) var(--space-5);font-size:var(--text-sm);min-height:var(--tap-min);display:inline-flex}.btn-secondary:hover{background:var(--color-tonal-blue);border-color:var(--color-border-strong)}.btn-icon{min-width:var(--tap-min);min-height:var(--tap-min);border-radius:var(--radius-md);justify-content:center;align-items:center;padding:0;display:inline-flex}.form-group{margin-bottom:var(--space-3)}.form-group:last-child{margin-bottom:0}.form-group label{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-1);font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:16px}@media (width>=768px){.form-group input,.form-group select,.form-group textarea{font-size:var(--text-base)}}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 var(--focus-ring-width) var(--color-accent-muted);outline:none}.spinner{vertical-align:middle;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.spinner-ring{border-style:solid;border-color:var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:.65s linear infinite spinner-rotate;display:block}.spinner-sm .spinner-ring{border-width:2px;width:14px;height:14px}.spinner-md .spinner-ring{border-width:2px;width:20px;height:20px}.spinner-lg .spinner-ring{border-width:3px;width:28px;height:28px}.spinner-xl .spinner-ring{border-width:3px;width:40px;height:40px}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.btn-spinner-icon{margin-right:.35rem}button.btn-with-spinner{justify-content:center;align-items:center;gap:.35rem;display:inline-flex}.list-detail-loading-panel{color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2.5rem 1rem;font-size:.875rem;display:flex}.app-loader{background:var(--color-surface);z-index:1000;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:fixed;inset:0}.app-loader p{color:var(--color-text-muted);margin:0;font-size:.9375rem}.app-error{z-index:100;color:#b91c1c;background:#fef2f2;border-bottom:1px solid #fecaca;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;font-size:.9375rem;display:flex;position:sticky;top:0}.app-error p{flex:1;margin:0}.app-error-dismiss{color:#b91c1c;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1px solid #b91c1c;padding:.35rem .75rem;font-size:.875rem}.app-error-dismiss:hover{color:#fff;background:#b91c1c}.layout-header{z-index:var(--z-sticky);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding-top:env(safe-area-inset-top);position:sticky;top:0}.layout-nav{max-width:var(--layout-nav-max-width);padding:0 max(var(--space-3), env(safe-area-inset-left)) 0 max(var(--space-3), env(safe-area-inset-right));justify-content:space-between;align-items:center;gap:var(--space-2);min-height:52px;margin:0 auto;display:flex}.layout-links-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:none;flex:1;justify-content:flex-end;min-width:0;display:flex;overflow-x:auto}.layout-links-scroll::-webkit-scrollbar{height:0;display:none}.layout-logo{font-family:var(--font-display);font-weight:700;font-size:var(--text-xl);letter-spacing:-.02em;padding:var(--space-2) 0;transition:color var(--duration-fast) var(--ease-out);align-items:center;display:inline-flex;color:var(--color-heading)!important;text-decoration:none!important}.layout-logo:hover{color:var(--color-accent)!important;text-decoration:none!important}.layout-logo:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}.layout-menu-toggle{min-width:var(--tap-min);min-height:var(--tap-min);background:var(--color-surface-elevated);border:1px solid var(--color-border);color:var(--color-heading);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;margin:0 0 0 auto;padding:0;display:none}.layout-menu-toggle:hover{background:var(--color-tonal-blue);border-color:var(--color-border-strong)}.layout-menu-toggle:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}.layout-mobile-backdrop,.layout-mobile-panel{display:none}.layout-mobile-links{gap:var(--space-1);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.layout-mobile-links a{min-height:var(--tap-min);padding:0 var(--space-3);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-base);transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);align-items:center;font-weight:600;display:flex;text-decoration:none!important}.layout-mobile-links a:hover{background:var(--color-surface-elevated);color:var(--color-text);text-decoration:none!important}.layout-mobile-links a.active{color:var(--color-tonal-blue-text);background:linear-gradient(180deg, var(--color-tonal-blue) 0%, var(--color-tonal-green) 100%);box-shadow:inset 0 0 0 1px var(--color-active-pill-stroke)}.layout-mobile-sign-out{width:100%;min-height:var(--tap-min);padding:0 var(--space-3);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text-muted);font-weight:600;font-family:var(--font-sans);text-align:left;cursor:pointer;transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);background:0 0;border:none;align-items:center;margin:0;display:flex}.layout-mobile-sign-out:hover{color:var(--color-text);background:var(--color-tonal-blue)}.layout-mobile-sign-out:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}.layout-links{align-items:center;gap:.125rem;margin:0;padding:0;list-style:none;display:flex}.layout-links li{display:block}.layout-profile-menu{align-items:center;gap:var(--space-1);display:flex;position:relative}.layout-profile-caret{min-width:var(--tap-min);min-height:var(--tap-min);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;display:inline-flex}.layout-profile-caret:hover{background:var(--color-surface-elevated);border-color:var(--color-border);color:var(--color-text)}.layout-profile-submenu{min-width:180px;padding:var(--space-2);border-radius:var(--radius-lg);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-md);opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out), visibility var(--duration-normal) var(--ease-out);z-index:calc(var(--z-sticky) + 5);position:absolute;top:calc(100% - 6px);right:0;transform:translateY(-6px)}.layout-profile-submenu--open{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}.layout-profile-sign-out{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);justify-content:flex-start}.layout-mobile-profile-menu{gap:var(--space-1);flex-direction:column;width:100%;display:flex}.layout-mobile-profile-row{align-items:center;gap:var(--space-2);width:100%;display:flex}.layout-mobile-profile-row a{flex:1}.layout-mobile-profile-caret{border-radius:var(--radius-md);min-width:44px;min-height:44px;color:var(--color-text-muted);cursor:pointer;transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);background:0 0;border:1px solid #0000;justify-content:center;align-items:center;padding:0;display:inline-flex}.layout-mobile-profile-caret:hover{background:var(--color-surface-elevated);border-color:var(--color-border);color:var(--color-text)}.layout-mobile-profile-sign-out{width:calc(100% - var(--space-3));margin-left:var(--space-3);min-height:var(--tap-min);padding:0 var(--space-3);border-radius:var(--radius-md);background:var(--color-surface-elevated);border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-sans);cursor:pointer;transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);justify-content:flex-start;align-items:center;font-weight:600;display:flex}.layout-mobile-profile-sign-out:hover{background:var(--color-tonal-blue);border-color:var(--color-border-strong);color:var(--color-text)}.layout-links a{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-sm);transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);min-height:var(--tap-min);box-sizing:border-box;white-space:nowrap;align-items:center;font-weight:500;display:flex;text-decoration:none!important}.layout-links a:hover{color:var(--color-text);background:var(--color-surface-elevated);text-decoration:none!important}.layout-links a.active{color:var(--color-tonal-blue-text);background:linear-gradient(180deg, var(--color-tonal-blue) 0%, var(--color-tonal-green) 100%);box-shadow:inset 0 0 0 1px var(--color-active-pill-stroke);font-weight:600}.layout-links a:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}.layout-sign-out{min-height:var(--tap-min);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);background:0 0;border:none;align-items:center;margin:0;font-family:inherit;font-weight:500;display:flex}.layout-sign-out:hover{color:var(--color-text);background:var(--color-tonal-blue)}.layout-main{max-width:var(--layout-max-width);width:100%;padding:0 max(var(--space-3), env(safe-area-inset-left)) 0 max(var(--space-3), env(safe-area-inset-right));flex:1;min-width:0;margin:0 auto}@media (width<=768px){.layout-nav{min-height:56px;padding:0 var(--space-4)}.layout-logo{font-size:var(--text-lg)}.layout-menu-toggle{display:inline-flex}.layout-links-scroll{display:none}.layout-mobile-backdrop.layout-mobile-backdrop--visible{z-index:calc(var(--z-sticky) + 1);background:var(--color-overlay);-webkit-backdrop-filter:blur(3px);display:block;position:fixed;inset:0}.layout-mobile-panel{left:0;right:0;top:calc(56px + env(safe-area-inset-top));z-index:calc(var(--z-sticky) + 2);background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-md);padding:var(--space-2) var(--space-3) var(--space-4);-webkit-overflow-scrolling:touch;visibility:hidden;opacity:0;pointer-events:none;max-height:min(72vh,400px);transition:opacity var(--duration-normal) var(--ease-out), transform var(--duration-normal) var(--ease-out), visibility var(--duration-normal);display:block;position:fixed;overflow-y:auto;transform:translateY(-10px)}.layout-mobile-panel--open{visibility:visible;opacity:1;pointer-events:auto;transform:translateY(0)}}@media (width<=480px){.layout-nav{min-height:52px;padding:0 var(--space-3);gap:var(--space-2);flex-wrap:nowrap}.layout-main{padding:0 var(--space-3)}.layout-logo{font-size:var(--text-base);padding:var(--space-1) 0;flex-shrink:0}.layout-mobile-panel{top:calc(52px + env(safe-area-inset-top))}}.login-page{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:1.5rem;display:flex}.login-card{width:100%;max-width:400px;padding:1.75rem}.login-title{margin-bottom:.35rem;font-size:1.375rem}.login-subtitle{color:var(--color-text-muted);margin:0 0 1.25rem;font-size:.9375rem}.login-error{border-radius:var(--radius-sm);color:#b91c1c;background:#fef2f2;border:1px solid #fecaca;margin-bottom:1rem;padding:.65rem .75rem;font-size:.875rem}.login-mode-toggle{gap:.35rem;margin-bottom:1rem;display:flex}.login-mode-toggle button{background:var(--color-surface-elevated);color:var(--color-text-muted);border:1px solid var(--color-border);flex:1;padding:.45rem .65rem;font-size:.875rem}.login-mode-toggle button.active{background:linear-gradient(180deg, var(--color-tonal-blue) 0%, var(--color-tonal-green) 100%);color:var(--color-tonal-blue-text);border-color:var(--color-accent);box-shadow:inset 0 0 0 1px var(--color-active-pill-stroke)}.login-form{flex-direction:column;gap:.25rem;display:flex}.login-submit{width:100%;margin-top:.75rem;padding:.65rem 1rem}.login-hint{color:var(--color-text-muted);margin:1rem 0 0;font-size:.8125rem}.sortable-list-item{background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.5rem .75rem;transition:box-shadow .15s;display:flex}.sortable-list-item.dragging{box-shadow:var(--shadow-md);opacity:.95;z-index:1}.sortable-list-item-drag{cursor:grab;color:var(--color-text-muted);-webkit-user-select:none;user-select:none;padding:.25rem;font-size:1rem}.sortable-list-item-drag:active{cursor:grabbing}.sortable-list-item-color{border-radius:50%;flex-shrink:0;width:12px;height:12px}.sortable-list-item-text{color:var(--color-text);flex:1;font-size:.9375rem}.sortable-list-item-color-picker{align-items:center;gap:.25rem;display:flex}.color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:18px;height:18px;padding:0;transition:transform .1s}.color-dot:hover{transform:scale(1.15)}.color-dot.active{border-color:var(--color-text);box-shadow:0 0 0 1px var(--color-surface)}.sortable-list-item-remove{width:28px;height:28px;color:var(--color-text-muted);border-radius:var(--radius-sm);background:0 0;justify-content:center;align-items:center;padding:0;font-size:1.25rem;line-height:1;display:flex}.sortable-list-item-remove:hover{color:#b91c1c;background:#fef2f2}.create-list-form{padding:var(--space-6)}.create-list-options{gap:var(--space-2);flex-wrap:wrap;display:flex}.option-chip{padding:var(--space-2) var(--space-4);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-pill);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;transition:border-color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);align-items:center;font-weight:500;display:inline-flex}.option-chip:hover{border-color:var(--color-border-strong);background:var(--color-tonal-blue)}.option-chip input{opacity:0;pointer-events:none;position:absolute}.option-chip:has(input:checked){border-color:var(--color-accent);background:linear-gradient(180deg, var(--color-tonal-blue) 0%, var(--color-tonal-green) 100%);color:var(--color-tonal-blue-text);box-shadow:inset 0 0 0 1px var(--color-active-pill-stroke), var(--shadow-xs)}.create-list-add-item{gap:var(--space-2);margin-bottom:var(--space-4);display:flex}.create-list-add-item input{flex:1}.create-list-items{margin-top:var(--space-2)}.create-list-actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--color-border);display:flex}.create-list-share-hint{margin:var(--space-1) 0 0 0;font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-snug)}@media (width<=600px){.create-list-options{flex-direction:column}.option-chip{width:100%}.create-list-form{padding:var(--space-4)}}.list-progress{width:100%;margin-top:var(--space-2)}.list-progress-row{justify-content:space-between;align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-1);display:flex}.list-progress-label{font-size:var(--text-xs);color:var(--color-text-secondary);letter-spacing:.02em;font-weight:600}.list-progress-pct{font-size:var(--text-xs);color:var(--color-accent);font-variant-numeric:tabular-nums;font-weight:600}.list-progress-track{border-radius:var(--radius-pill);background:var(--color-surface-muted);border:1px solid var(--color-border);height:6px;overflow:hidden}.list-progress-fill{border-radius:var(--radius-pill);background:linear-gradient(90deg, var(--color-tonal-green) 0%, var(--color-accent) 100%);height:100%;transition:width var(--duration-normal) var(--ease-out)}@media (prefers-reduced-motion:reduce){.list-progress-fill{transition:none}}.list-progress--compact .list-progress-row{margin-bottom:var(--space-1)}.list-progress--compact .list-progress-label,.list-progress--compact .list-progress-pct{font-size:.6875rem}.list-progress--compact .list-progress-track{height:5px}.sortable-list-card{position:relative}.sortable-list-card.dragging{box-shadow:var(--shadow-lg);opacity:.95;z-index:1}.sortable-list-card-drag{top:var(--space-4);left:var(--space-3);cursor:grab;color:var(--color-text-muted);font-size:var(--text-base);padding:var(--space-1);-webkit-user-select:none;user-select:none;min-width:var(--tap-min);min-height:var(--tap-min);margin:calc(-1 * var(--space-2));border-radius:var(--radius-sm);z-index:2;transition:background var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;display:flex;position:absolute}.sortable-list-card-drag:hover{background:var(--color-surface-muted)}.sortable-list-card-drag:active{cursor:grabbing}.sortable-list-card .list-card-link{padding-left:calc(var(--space-4) + var(--space-10))}.lists-page-header{justify-content:space-between;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.lists-page-header .page-title{margin-bottom:0}.lists-page-header-actions{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.lists-reorder-btn{flex-shrink:0;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;padding:0;display:inline-flex}.lists-reorder-btn svg{display:block}.lists-filters{margin-bottom:var(--space-6)}.lists-filters-mobile-toolbar{display:none}.lists-filters-toolbar-btn{justify-content:center;align-items:center;gap:var(--space-2);min-width:0;min-height:var(--tap-min);padding:0 var(--space-3);font-family:var(--font-sans);font-size:var(--text-sm);letter-spacing:.02em;color:var(--color-text-secondary);background:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);flex:1;font-weight:600;display:inline-flex}.lists-filters-toolbar-btn:hover{background:var(--color-tonal-blue);border-color:var(--color-border-strong)}.lists-filters-toolbar-btn--active{color:var(--color-tonal-blue-text);background:linear-gradient(180deg, var(--color-tonal-blue) 0%, var(--color-tonal-green) 100%);border-color:var(--color-accent);box-shadow:inset 0 0 0 1px var(--color-active-pill-stroke)}.lists-filters-toolbar-dot{background:var(--color-accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.lists-filters-toolbar-btn:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:2px}.lists-filters-grid{gap:var(--space-4);grid-template-columns:1fr auto auto;align-items:end;display:grid}.lists-search{margin-bottom:0!important}@media (width<=768px){.lists-filters--narrow .lists-filters-mobile-toolbar{gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.lists-filters--narrow.lists-filters--hide-search .lists-search,.lists-filters--narrow.lists-filters--hide-filters .lists-filter-type,.lists-filters--narrow.lists-filters--hide-filters .lists-filter-privacy{display:none!important}.lists-filters-grid{gap:var(--space-3);grid-template-columns:1fr}}.lists-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(240px,1fr));display:grid}@media (width<=380px){.lists-grid{grid-template-columns:1fr}}.list-card.card{flex-direction:column;min-height:0;padding:0;display:flex}.list-card{border-radius:var(--radius-lg);border:1px solid var(--color-border-card);transition:box-shadow var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out), transform var(--duration-fast) var(--ease-out)}.list-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-strong);transform:translateY(-1px)}@media (prefers-reduced-motion:reduce){.list-card:hover{transform:none}}.list-card-link{gap:var(--space-2);min-width:0;padding:var(--space-4);color:inherit;border-radius:var(--radius-lg);flex-direction:column;flex:1;margin:0;display:flex;text-decoration:none!important}.list-card:not(:has(.list-card-actions)) .list-card-link{border-radius:var(--radius-lg)}.list-card:has(.list-card-actions) .list-card-link{border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding-bottom:var(--space-3)}.list-card-link:hover{color:inherit;text-decoration:none!important}.list-card-link:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:2px;z-index:1}.list-card-header{justify-content:space-between;align-items:flex-start;gap:var(--space-2);flex-wrap:wrap;display:flex}.list-card-title{font-size:var(--text-lg);color:var(--color-heading);margin:0;font-weight:600}.list-card-badges{gap:var(--space-1);flex-wrap:wrap;justify-content:flex-end;max-width:100%;display:flex}.badge{font-size:var(--text-xs);border-radius:var(--radius-sm);padding:.2rem .5rem;font-weight:500}.badge-type{background:var(--color-tonal-green);color:var(--color-tonal-green-text);border:1px solid #0000}.badge-privacy{background:var(--color-tonal-blue);color:var(--color-tonal-blue-text);border:1px solid #3a7d8f26}.list-card-meta{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--leading-snug);margin:0}.btn-sm{padding:.4rem .75rem;font-size:.8125rem}.lists-empty{text-align:center;color:var(--color-text-muted);padding:var(--space-8);grid-column:1/-1}.profile-nav{border-bottom:1px solid var(--color-border);-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:.125rem;margin-bottom:1rem;padding-bottom:.4rem;display:flex;overflow-x:auto}.profile-nav::-webkit-scrollbar{display:none}.profile-nav a{border-radius:var(--radius-sm);color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;padding:.45rem .75rem;font-size:.875rem;text-decoration:none!important}.profile-nav a:hover{color:var(--color-text);background:var(--color-surface-elevated);text-decoration:none!important}.profile-nav a.active{color:var(--color-tonal-blue-text);background:linear-gradient(180deg, var(--color-tonal-blue) 0%, var(--color-tonal-green) 100%);box-shadow:inset 0 0 0 1px var(--color-active-pill-stroke);font-weight:600}.profile-nav a:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}.profile-account{max-width:420px;padding:1.5rem}.profile-account-actions{align-items:center;gap:.75rem;margin-top:1rem;display:flex}.saved-msg{color:var(--color-accent-hover);font-size:.875rem;font-weight:500}.profile-account-email-readonly{background:var(--color-tonal-blue);color:var(--color-tonal-blue-text);cursor:default;border-style:dashed}.profile-account-email-hint{color:var(--color-text-muted);margin:.35rem 0 0;font-size:.8125rem}.profile-history{max-width:560px;padding:1.5rem}.profile-history-intro{color:var(--color-text-muted);margin-bottom:1rem;font-size:.9375rem}.profile-history-empty{color:var(--color-text-muted);font-size:.9375rem}.profile-history-list{margin:0;padding:0;list-style:none}.profile-history-item{border-bottom:1px solid var(--color-border);grid-template-columns:auto 1fr auto;align-items:center;gap:.75rem;padding:.6rem 0;font-size:.9375rem;display:grid}.profile-history-item:last-child{border-bottom:none}.profile-history-action{color:var(--color-accent-hover);min-width:5rem;font-weight:500}.profile-history-name{color:var(--color-text)}.profile-history-date{color:var(--color-text-muted);font-size:.8125rem}.profile-shared{flex-direction:column;gap:1.25rem;max-width:640px;padding:1.5rem;display:flex}.profile-shared-section{padding:1.25rem}.profile-shared-section-title{margin:0 0 .5rem;font-size:1.125rem}.profile-shared-invite-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.profile-shared-invite-item{background:var(--color-surface-elevated);border-radius:var(--radius-sm);border:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem;display:flex}.profile-shared-invite-main{flex-direction:column;gap:.2rem;display:flex}.profile-shared-invite-name{color:var(--color-text);font-weight:600}.profile-shared-invite-meta{color:var(--color-text-muted);font-size:.8125rem}.profile-shared-invite-actions{flex-wrap:wrap;gap:.5rem;display:flex}.profile-shared-link-list{margin:0;padding:0;list-style:none}.profile-shared-link-list li{border-bottom:1px solid var(--color-border);padding:.75rem 0}.profile-shared-link-list li:last-child{border-bottom:none}.profile-shared-link-item{display:block}.profile-shared-link-block{flex-direction:column;align-items:flex-start;gap:.35rem;max-width:100%;display:flex}.profile-shared-with-who{color:var(--color-text-muted);font-size:.8125rem;line-height:var(--leading-snug);margin:0}.profile-shared-progress{width:100%;margin-top:0!important}.profile-shared-link{color:var(--color-accent);font-weight:500;text-decoration:none}.profile-shared-link:hover{color:var(--color-accent-hover);text-decoration:underline}.profile-shared-link-meta{color:var(--color-text-muted);font-size:.8125rem}.profile-shared-list-name-link{color:inherit;text-decoration:none}.profile-shared-list-name-link:hover .profile-shared-list-name{color:var(--color-accent)}.profile-shared-subblock{margin-top:.75rem}.profile-shared-subheading{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin:0 0 .35rem;font-size:.75rem}.profile-shared .btn-sm{padding:.35rem .75rem;font-size:.8125rem}.profile-shared-intro{color:var(--color-text-muted);margin-bottom:1rem;font-size:.9375rem}.profile-shared-empty{color:var(--color-text-muted);font-size:.9375rem}.profile-shared-grid{flex-direction:column;gap:1rem;display:flex}.profile-shared-item{background:var(--color-surface-elevated);border-radius:var(--radius-sm);border:1px solid var(--color-border);padding:1rem}.profile-shared-list-name{margin:0 0 .35rem;font-size:1rem;font-weight:600}.profile-shared-item .profile-shared-progress{margin-bottom:var(--space-3)}.profile-shared-people{margin:0;padding:0;font-size:.9375rem;list-style:none}.profile-shared-people li{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.15rem;padding:.35rem 0;display:flex}.profile-shared-people li:last-child{border-bottom:none}.profile-shared-email{color:var(--color-text);font-weight:500}.profile-shared-date{color:var(--color-text-muted);font-size:.8125rem}.sortable-list-detail-item.dragging{box-shadow:var(--shadow-md);opacity:.96;z-index:var(--z-sticky)}.list-detail-item.task-row{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);min-height:var(--tap-min);background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border);border-left-width:3px;border-left-color:var(--task-accent,var(--color-border));transition:background var(--duration-normal) var(--ease-out), border-color var(--duration-normal) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out), opacity var(--duration-fast) var(--ease-out);display:flex}.list-detail-item.task-row:not(.dragging):hover{box-shadow:var(--shadow-xs);border-color:var(--color-border-strong)}.task-row--completed{background:var(--color-surface-muted)}.task-row--completed .list-detail-item-text{color:var(--color-text-muted)}.list-detail-item-drag{cursor:grab;color:var(--color-text-muted);font-size:var(--text-base);padding:var(--space-2);-webkit-user-select:none;user-select:none;min-width:var(--tap-min);min-height:var(--tap-min);margin:calc(-1 * var(--space-2));border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);flex-shrink:0;justify-content:center;align-items:center;margin-right:0;display:flex}.list-detail-item-drag:hover{background:var(--color-surface-muted);color:var(--color-text-secondary)}.list-detail-item-drag:active{cursor:grabbing}.list-detail-item-done{width:var(--tap-min);height:var(--tap-min);min-width:var(--tap-min);min-height:var(--tap-min);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-lg);color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);background:0 0;flex-shrink:0;justify-content:center;align-items:center;line-height:1;display:flex}.list-detail-item-done:hover{border-color:var(--color-accent);color:var(--color-accent)}.list-detail-item-done[aria-pressed=true]{background:var(--color-accent-muted);border-color:var(--color-accent);color:var(--color-accent-hover)}.list-detail-item-done[aria-pressed=true]:active{transform:scale(.96)}.list-detail-item-text-block{justify-content:center;align-items:flex-start;gap:var(--space-1);flex-direction:column;flex:1;min-width:0;display:flex}.list-detail-item-text{font-size:var(--text-base);color:var(--color-text);font-weight:500;line-height:var(--leading-snug)}.list-detail-item-text.completed{font-weight:400;text-decoration:line-through}.list-detail-item-completed-by{font-size:var(--text-xs);color:var(--color-text-muted);line-height:var(--leading-tight)}.task-row__actions{align-items:center;gap:var(--space-1);flex-shrink:0;display:flex}.list-detail-item-edit{width:var(--tap-min);height:var(--tap-min);min-width:var(--tap-min);min-height:var(--tap-min);color:var(--color-text-muted);border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.list-detail-item-edit:hover{background:var(--color-accent-subtle);color:var(--color-accent-hover)}.list-detail-item-delete{width:var(--tap-min);height:var(--tap-min);min-width:var(--tap-min);min-height:var(--tap-min);color:var(--color-text-muted);font-size:var(--text-xl);border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;line-height:1;display:flex}.list-detail-item-delete:hover{background:var(--color-danger-bg);color:var(--color-danger)}.list-detail-item-edit:focus-visible,.list-detail-item-delete:focus-visible,.list-detail-item-done:focus-visible,.list-detail-item-drag:focus-visible{outline:var(--focus-ring-width) solid var(--color-focus-ring);outline-offset:var(--focus-ring-offset)}.list-detail-loading{color:var(--color-text-muted);margin:2rem 0}.list-detail-header{margin-bottom:1rem}.list-detail-back{color:var(--color-text-muted);align-items:center;gap:.25rem;font-size:.9375rem;display:inline-flex;text-decoration:none!important}.list-detail-back:hover{color:var(--color-accent);text-decoration:none!important}.list-detail{padding:1rem 1.125rem}@media (width<=480px){.list-detail{padding:.875rem .75rem}}.list-detail-page .badge{font-size:var(--text-xs);border-radius:var(--radius-sm);padding:.2rem .5rem;font-weight:500}.list-detail-page .badge-type{background:var(--color-tonal-green);color:var(--color-tonal-green-text);border:1px solid #0000}.list-detail-page .badge-privacy{background:var(--color-tonal-blue);color:var(--color-tonal-blue-text);border:1px solid #3a7d8f26}.list-detail-items-syncing{opacity:.88;pointer-events:none}.list-detail-title-row{justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-border);display:flex}.list-detail-title{font-size:var(--text-xl);color:var(--color-heading);letter-spacing:-.02em;min-width:0;font-weight:700;line-height:var(--leading-tight);flex:1;margin:0}.list-detail-badges{gap:var(--space-1);flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;align-items:center;max-width:min(100%,14rem);display:flex}.list-detail-badges--readonly{align-self:center;max-width:none}.list-detail-options-btn{justify-content:center;align-items:center;gap:var(--space-2);flex-shrink:0;display:inline-flex}.list-detail-options-icon{display:none}.list-detail-options-label{display:inline}@media (width<=768px){.list-detail-options-btn{min-width:var(--tap-min);min-height:var(--tap-min);padding-left:var(--space-3);padding-right:var(--space-3)}.list-detail-options-label{display:none}.list-detail-options-icon{display:block}}.list-detail-progress-wrap{margin-top:0;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);top:calc(env(safe-area-inset-top) + 48px);z-index:2;background:var(--color-surface);position:sticky}.list-detail-items{padding-top:var(--space-1);margin-top:0}.list-detail-items h3{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;margin:0 0 .75rem;font-size:.875rem;font-weight:600}.list-detail-add{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.list-detail-add-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);flex:1;min-width:140px;padding:.5rem .75rem;font-size:.9375rem}.list-detail-add-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-muted);outline:none}.list-detail-add-btn{flex-shrink:0}.list-detail-items-empty{color:var(--color-text-muted);margin:0;font-size:.9375rem}.list-detail-items-list{gap:var(--space-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.list-detail-not-found{text-align:center;padding:2rem}.list-detail-not-found h2{margin-bottom:.5rem}.list-detail-not-found p{color:var(--color-text-muted);margin-bottom:1.25rem}.list-detail-back-link{display:inline-block;text-decoration:none!important}.list-detail-back-link:hover{text-decoration:none!important}.list-detail-share-modal-overlay{background:var(--color-overlay);-webkit-backdrop-filter:blur(6px);z-index:var(--z-modal);padding:var(--space-4);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.list-detail-share-modal{width:100%;max-width:420px;padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-card)}.list-detail-share-modal h3{margin:0 0 var(--space-3) 0;font-size:1.25rem}.list-detail-modal-badges{gap:var(--space-1);margin:0 0 var(--space-4) 0;flex-wrap:wrap;display:flex}.list-detail-share-modal-section-title{text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-muted);margin:0 0 var(--space-2) 0;font-size:.8125rem;font-weight:600}.list-detail-share-modal-desc{color:var(--color-text-muted);margin:0 0 1.25rem;font-size:.9375rem;line-height:1.4}.list-detail-share-modal-add{gap:.5rem;margin-bottom:1.25rem;display:flex}.list-detail-share-modal-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);flex:1;padding:.5rem .75rem;font-size:.9375rem}.list-detail-share-modal-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent-muted);outline:none}.list-detail-share-modal-list-wrap h4{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;margin:0 0 .5rem;font-size:.8125rem;font-weight:600}.list-detail-share-modal-collab-heading{margin-top:1rem}.list-detail-share-modal-empty{color:var(--color-text-muted);margin:0;padding:.5rem 0;font-size:.9375rem}.list-detail-share-modal-list{max-height:200px;margin:0;padding:0;list-style:none;overflow-y:auto}.list-detail-share-modal-item{background:var(--color-surface-elevated);border-radius:var(--radius-sm);border:1px solid var(--color-border);align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.5rem .75rem;display:flex}.list-detail-share-modal-email{flex:1;min-width:0;font-size:.9375rem;font-weight:500}.list-detail-share-modal-date{color:var(--color-text-muted);flex-shrink:0;font-size:.75rem}.list-detail-share-modal-remove{width:28px;height:28px;color:var(--color-text-muted);border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;line-height:1;transition:color .15s,background .15s;display:flex}.list-detail-share-modal-remove:hover{color:#b91c1c;background:#fef2f2}.list-detail-share-modal-actions{border-top:1px solid var(--color-border);margin-top:1.25rem;padding-top:1.25rem}.list-detail-edit-item-overlay{background:var(--color-overlay);-webkit-backdrop-filter:blur(6px);z-index:var(--z-modal);padding:var(--space-4);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.list-detail-edit-item-modal{width:100%;max-width:400px;padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-card)}.list-detail-edit-item-modal h3{margin:0 0 1rem;font-size:1.25rem}.list-detail-edit-item-modal .form-group{margin-bottom:1rem}.list-detail-edit-item-modal .form-group:last-of-type{margin-bottom:0}.list-detail-edit-item-colors{flex-wrap:wrap;gap:.35rem;margin-top:.35rem;display:flex}.list-detail-edit-item-color-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;padding:0;transition:transform .1s}.list-detail-edit-item-color-dot:hover{transform:scale(1.1)}.list-detail-edit-item-color-dot.active{border-color:var(--color-text);box-shadow:0 0 0 1px var(--color-surface)}.list-detail-edit-item-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.75rem;margin-top:1.25rem;padding-top:1.25rem;display:flex}
