:root{--color-bg: #FFF4E0;--color-surface: #FFFFFF;--color-primary: #FF3366;--color-secondary: #88D317;--color-accent: #FFD700;--color-tertiary: #7B68EE;--color-text: #1A1A2E;--color-border: #1A1A2E;--color-muted: #6B6B6B;--color-error: #E74C3C;--color-danger: var(--color-error);--color-success: var(--color-secondary);--color-shopping-bg: #F5F0FF;--color-overlay: rgba(26, 26, 46, .5);--color-on-accent: var(--color-text);--shadow-sm: 2px 2px 0px var(--color-border);--shadow-md: 4px 4px 0px var(--color-border);--shadow-lg: 6px 6px 0px var(--color-border);--shadow-primary: 4px 4px 0px color-mix(in srgb, var(--color-primary) 70%, black);--shadow-primary-lg: 6px 6px 0px color-mix(in srgb, var(--color-primary) 70%, black);--shadow-secondary: 4px 4px 0px color-mix(in srgb, var(--color-secondary) 70%, black);--shadow-secondary-lg: 6px 6px 0px color-mix(in srgb, var(--color-secondary) 70%, black);--shadow-accent: 4px 4px 0px color-mix(in srgb, var(--color-accent) 70%, black);--shadow-accent-lg: 6px 6px 0px color-mix(in srgb, var(--color-accent) 70%, black);--border-thin: 1.5px solid var(--color-border);--border: 2px solid var(--color-border);--border-thick: 3px solid var(--color-border);--radius: 4px;--font-display: "Space Grotesk", sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--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;--space-12: 3rem;--transition: .15s ease-out;--transition-mode: .3s ease-out}[data-theme=dark]{--color-bg: #1A1A2E;--color-surface: #272740;--color-primary: #FF4477;--color-secondary: #88D317;--color-accent: #FFD700;--color-tertiary: #8B7BF0;--color-text: #F0F0F5;--color-border: #7A7A98;--color-muted: #9999B0;--color-error: #FF5555;--color-danger: var(--color-error);--color-success: var(--color-secondary);--color-shopping-bg: #1E1C30;--color-overlay: rgba(0, 0, 0, .7);--color-on-accent: #1A1A2E;--shadow-sm: 2px 2px 0px rgba(0, 0, 0, .5);--shadow-md: 4px 4px 0px rgba(0, 0, 0, .5);--shadow-lg: 6px 6px 0px rgba(0, 0, 0, .5);--shadow-primary: 4px 4px 0px rgba(0, 0, 0, .5);--shadow-primary-lg: 6px 6px 0px rgba(0, 0, 0, .5);--shadow-secondary: 4px 4px 0px rgba(0, 0, 0, .5);--shadow-secondary-lg: 6px 6px 0px rgba(0, 0, 0, .5);--shadow-accent: 4px 4px 0px rgba(0, 0, 0, .5);--shadow-accent-lg: 6px 6px 0px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;background-color:var(--color-bg);overflow-x:clip;min-height:calc(100% + env(safe-area-inset-top,0px))}html.app--shopping{--color-bg: var(--color-shopping-bg)}body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.5;color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--transition-mode);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:contain;overflow-x:clip}body:before{content:"";position:fixed;top:0;left:0;right:0;height:env(safe-area-inset-top,0px);background:var(--color-primary);z-index:51;pointer-events:none;transition:background var(--transition-mode)}body.app--shopping:before{background:var(--color-tertiary)}body:after{content:"";position:fixed;bottom:0;left:0;right:0;height:env(safe-area-inset-bottom,0px);background:var(--color-bg);z-index:51;pointer-events:none;transition:background var(--transition-mode)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.2}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}button,input,textarea,select{font:inherit;color:inherit}input,textarea,select{font-size:max(16px,1em)}a{color:var(--color-primary);text-decoration:none}.halftone{position:relative;overflow:hidden}.halftone:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle,var(--color-border) 1px,transparent 1px);background-size:8px 8px;opacity:.08;pointer-events:none}@media(prefers-reduced-motion:no-preference){.halftone:before{animation:halftone-pulse 4s ease-in-out infinite}}@keyframes halftone-pulse{0%,to{opacity:.08}50%{opacity:.12}}.halftone-dense:before{background-size:6px 6px;opacity:.12}.app{min-height:100dvh;display:flex;flex-direction:column;transition:background-color var(--transition-mode)}body.app--shopping{--color-bg: var(--color-shopping-bg)}.app--shopping{--color-bg: var(--color-shopping-bg);--shadow-sm: 2px 2px 0px color-mix(in srgb, var(--color-tertiary) 20%, transparent);--shadow-md: 4px 4px 0px color-mix(in srgb, var(--color-tertiary) 20%, transparent);--shadow-lg: 6px 6px 0px color-mix(in srgb, var(--color-tertiary) 25%, transparent);background-color:var(--color-bg)}.app-main{--main-pad: var(--space-6);flex:1;padding:var(--main-pad);padding-bottom:calc(var(--main-pad) + env(safe-area-inset-bottom,0px));max-width:960px;width:100%;margin:0 auto}.mono{font-family:var(--font-mono)}.display{font-family:var(--font-display)}.text-muted{color:var(--color-muted)}.text-center{text-align:center}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-primary) 40%,var(--color-bg));border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:1px 1px 0 var(--color-border)}::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--color-primary) 60%,var(--color-bg))}*{scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--color-primary) 40%,var(--color-bg)) var(--color-bg)}.app__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;gap:var(--space-4);-webkit-user-select:none;user-select:none}.app__loading-cart{position:relative;width:120px;height:100px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}.app__loading-items{display:flex;gap:var(--space-2);margin-bottom:var(--space-1)}.app__loading-item{font-size:1.6rem;display:inline-block}.app__loading-basket{font-size:2.8rem;line-height:1}.app__loading-text{font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:var(--color-text);letter-spacing:-.01em}@media(prefers-reduced-motion:no-preference){.app__loading-item{animation:item-drop 1.8s ease-in-out infinite}.app__loading-item--1{animation-delay:0s}.app__loading-item--2{animation-delay:.25s}.app__loading-item--3{animation-delay:.5s}.app__loading-basket{animation:cart-wobble 1.8s ease-in-out infinite;animation-delay:.4s}.app__loading-text{animation:text-pulse 1.8s ease-in-out infinite}}@keyframes item-drop{0%,to{transform:translateY(0);opacity:1}15%{transform:translateY(-18px) scale(1.15);opacity:1}30%{transform:translateY(2px) scale(.95);opacity:1}45%{transform:translateY(0) scale(1);opacity:1}}@keyframes cart-wobble{0%,to{transform:rotate(0)}20%{transform:rotate(0)}35%{transform:rotate(-4deg)}50%{transform:rotate(3deg)}65%{transform:rotate(-1deg)}75%{transform:rotate(0)}}@keyframes text-pulse{0%,to{opacity:1}50%{opacity:.5}}@media(max-width:640px){.app-main{--main-pad: var(--space-3);padding:var(--main-pad);padding-bottom:calc(var(--main-pad) + env(safe-area-inset-bottom,0px))}}.toast-container{position:fixed;bottom:calc(var(--space-6) + var(--keyboard-offset, 0px));left:50%;transform:translate(-50%);z-index:1100;display:flex;flex-direction:column;align-items:stretch;gap:var(--space-2);pointer-events:none;width:calc(100% - var(--space-8));max-width:520px}.toast{text-align:left;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);min-height:48px;background:var(--color-text);color:var(--color-bg);border-radius:var(--radius);border:var(--border-thick);box-shadow:var(--shadow-md);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;pointer-events:auto;animation:toast-in .2s ease-out;width:100%;cursor:pointer;-webkit-user-select:none;user-select:none;transition:box-shadow var(--transition),transform var(--transition)}.toast:hover{box-shadow:var(--shadow-lg);transform:translate(-1px,-1px)}.toast:active{box-shadow:none;transform:translate(1px,1px)}.toast--leaving{animation:toast-out .15s ease-in forwards}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(12px) scale(.95)}}.toast__message{flex:1;min-width:0;line-height:1.4}.toast__actions{display:flex;gap:var(--space-2);flex-shrink:0}.toast__action{background:none;border:1.5px solid var(--color-bg);border-radius:var(--radius);color:var(--color-bg);min-height:44px;padding:var(--space-1) var(--space-3);font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;cursor:pointer;white-space:nowrap;transition:background var(--transition),color var(--transition),border-color var(--transition)}.toast__action:hover{background:var(--color-bg);color:var(--color-text)}.toast__action--primary{background:var(--color-accent);color:var(--color-on-accent);border-color:var(--color-accent)}.toast__action--primary:hover{background:var(--color-bg);color:var(--color-text)}.toast__close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:1.5px solid color-mix(in srgb,var(--color-bg) 30%,transparent);border-radius:var(--radius);color:var(--color-bg);cursor:pointer;opacity:.6;transition:opacity var(--transition),border-color var(--transition)}.toast__close:hover{opacity:1;border-color:var(--color-bg)}@media(max-width:640px){.toast-container{bottom:calc(var(--space-4) + var(--keyboard-offset, 0px));width:calc(100% - var(--space-6))}}.help-icon{flex-shrink:0;min-width:80px;display:flex;align-items:center;justify-content:center}.help-icon--compact{width:48px}.help-icon__add-row{width:100%;display:flex;align-items:center;gap:3px}.help-icon__add-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;height:22px;padding:0 5px;background:var(--color-primary);color:#fff;border:2px solid var(--color-border);border-radius:var(--radius);font-family:var(--font-display);font-size:10px;font-weight:700;line-height:1;box-shadow:1px 1px color-mix(in srgb,var(--color-primary) 70%,black)}.help-icon__input{flex:1;min-width:0;height:22px;padding:0 6px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:1px 1px 0 var(--color-border);font-family:var(--font-body);font-size:8px;color:var(--color-muted);white-space:nowrap;overflow:hidden;display:flex;align-items:center}.help-icon__input-text{color:var(--color-muted);line-height:1}.help-icon__input-typed{color:var(--color-text);font-weight:600;line-height:1}.help-icon__input-ghost{color:var(--color-muted);opacity:.5;line-height:1}.help-icon__swipe-arrow{margin-left:auto;font-size:10px;font-weight:700;color:var(--color-muted);line-height:1}.help-icon__row{width:100%;display:flex;align-items:center;gap:3px;height:26px;padding:0 4px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:1px 1px 0 var(--color-border)}.help-icon__row-checkbox{width:14px;height:14px;flex-shrink:0;border:2px solid var(--color-border);border-radius:2px;background:var(--color-surface)}.help-icon__dot{width:8px;height:8px;border-radius:50%;border:2px solid var(--color-border);flex-shrink:0}.help-icon__row-name{font-family:var(--font-display);font-size:9px;font-weight:600;line-height:1;flex:1}.help-icon__row-qty{font-family:var(--font-mono);font-size:7px;font-weight:800;line-height:1;padding:2px 4px;border:2px solid var(--color-border);border-radius:2px;background:var(--color-accent);color:var(--color-on-accent);flex-shrink:0}.help-icon__store-trigger{display:flex;align-items:center;justify-content:center;gap:3px;min-width:28px;min-height:28px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text)}.help-icon__store-trigger--active{padding:0 5px;background:color-mix(in srgb,var(--color-tertiary) 12%,var(--color-surface))}.help-icon__store-name{font-family:var(--font-display);font-size:8px;font-weight:600;white-space:nowrap;line-height:1}.help-icon__store-trigger svg{flex-shrink:0}.help-icon__toggle-row{display:flex;align-items:center;gap:4px;color:var(--color-tertiary)}.help-icon__toggle-track{display:inline-flex;align-items:center;width:22px;height:12px;border-radius:6px;background:var(--color-border);border:1px solid var(--color-text);padding:1px}.help-icon__toggle-track--on{background:var(--color-tertiary)}.help-icon__toggle-thumb{display:block;width:8px;height:8px;border-radius:50%;background:var(--color-surface);border:1px solid var(--color-text)}.help-icon__toggle-track--on .help-icon__toggle-thumb{transform:translate(9px)}.help-icon__mode{display:flex;align-items:center;gap:3px}.help-icon__mode-edit{width:22px;height:22px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);display:flex;align-items:center;justify-content:center;color:var(--color-muted)}.help-icon__mode-arrow{font-size:9px;color:var(--color-muted);line-height:1}.help-icon__mode-shop{width:22px;height:22px;border:2px solid var(--color-border);border-radius:3px;background:var(--color-secondary);display:flex;align-items:center;justify-content:center}.help-icon__checkmark{font-size:11px;font-weight:700;color:var(--color-text);line-height:1}.help-icon__aisle{display:flex;flex-direction:column;gap:3px;width:100%;padding:4px 6px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:1px 1px 0 var(--color-border)}.help-icon__aisle-item{display:flex;align-items:center;gap:4px}.help-icon__aisle-dot{width:6px;height:6px;border-radius:50%;border:var(--border-thin);flex-shrink:0}.help-icon__aisle-line{height:3px;flex:1;border-radius:1px;background:var(--color-border);opacity:.2}.help-icon__aisle-line--short{flex:.6}.help-icon__btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:1px 1px 0 var(--color-border);color:var(--color-text)}.help-icon__variant{font-family:var(--font-mono);font-size:8px;font-weight:800;line-height:1;padding:2px 6px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-accent);color:var(--color-on-accent);box-shadow:1px 1px 0 var(--color-border)}.help-icon__clear-fab{display:flex;align-items:center;justify-content:center;gap:3px;min-width:28px;min-height:28px;padding:0 6px;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-primary);color:#fff;box-shadow:1px 1px color-mix(in srgb,var(--color-primary) 70%,black)}.help-icon__clear-fab-count{font-family:var(--font-mono);font-size:8px;font-weight:800;line-height:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-display);font-weight:600;border:var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn--sm{padding:var(--space-1) var(--space-3);font-size:var(--text-sm)}.btn--md{padding:var(--space-2) var(--space-5);font-size:var(--text-base)}.btn--lg{padding:var(--space-3) var(--space-8);font-size:var(--text-lg)}.btn--primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn--primary:hover:not(:disabled){box-shadow:var(--shadow-primary-lg);transform:translate(-2px,-2px)}.btn--primary:active:not(:disabled){box-shadow:none;transform:translate(4px,4px)}.btn--secondary{background:var(--color-secondary);color:var(--color-text);box-shadow:var(--shadow-secondary)}.btn--secondary:hover:not(:disabled){box-shadow:var(--shadow-secondary-lg);transform:translate(-2px,-2px)}.btn--secondary:active:not(:disabled){box-shadow:none;transform:translate(4px,4px)}.btn--accent{background:var(--color-accent);color:var(--color-on-accent);box-shadow:var(--shadow-accent)}.btn--accent:hover:not(:disabled){box-shadow:var(--shadow-accent-lg);transform:translate(-2px,-2px)}.btn--accent:active:not(:disabled){box-shadow:none;transform:translate(4px,4px)}.btn--ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--color-text)}.btn--ghost:hover:not(:disabled){background:color-mix(in srgb,var(--color-text) 8%,transparent)}.btn--ghost:active:not(:disabled){background:color-mix(in srgb,var(--color-text) 15%,transparent);transform:translate(1px,1px)}.btn--outline{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-md)}.btn--outline:hover:not(:disabled){box-shadow:var(--shadow-lg);transform:translate(-2px,-2px)}.btn--outline:active:not(:disabled){box-shadow:none;transform:translate(4px,4px)}.btn--danger{background:var(--color-surface);color:var(--color-error);border-color:var(--color-error);box-shadow:var(--shadow-md)}.btn--danger:hover:not(:disabled){background:var(--color-error);color:#fff;transform:translate(-2px,-2px);box-shadow:var(--shadow-lg)}.btn--danger:active:not(:disabled){box-shadow:none;transform:translate(4px,4px)}.btn:disabled{opacity:.5;cursor:not-allowed}.legal-page{min-height:100dvh;background:var(--color-bg);display:flex;flex-direction:column}.legal-page__header{position:sticky;top:0;z-index:50;background:var(--color-bg);border-bottom:var(--border);padding:var(--space-3) var(--space-6)}.legal-page__back{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-surface);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);color:var(--color-text);cursor:pointer;transition:var(--transition)}.legal-page__back:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-md)}.legal-page__back:active{transform:translate(1px,1px);box-shadow:none}.legal-page__back-arrow{font-size:var(--text-base);line-height:1}.legal-page__content{max-width:640px;width:100%;margin:0 auto;padding:var(--space-8) var(--space-6) var(--space-12)}.legal-page__title{font-family:var(--font-display);font-weight:700;font-size:var(--text-3xl);color:var(--color-text);margin-bottom:var(--space-2)}.legal-page__updated{font-size:var(--text-sm);color:var(--color-muted);margin-bottom:var(--space-8)}.legal-page__section{margin-bottom:var(--space-8)}.legal-page__section-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:var(--border)}.legal-page__section p{font-size:var(--text-base);color:var(--color-text);line-height:1.6;margin-bottom:var(--space-3)}.legal-page__section p:last-child{margin-bottom:0}.legal-page__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.legal-page__list li{font-size:var(--text-base);color:var(--color-text);line-height:1.6;padding-left:var(--space-4);position:relative}.legal-page__list li:before{content:"–";position:absolute;left:0;color:var(--color-primary);font-weight:700}.legal-page__section code{font-family:var(--font-mono);font-size:var(--text-sm);background:color-mix(in srgb,var(--color-border) 10%,var(--color-surface));border:var(--border-thin);border-radius:var(--radius);padding:.1em .4em}@media(max-width:640px){.legal-page__content{padding:var(--space-6) var(--space-4) var(--space-10)}.legal-page__title{font-size:var(--text-2xl)}}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-6);text-align:center;position:relative}.login-screen__brand{margin-bottom:var(--space-8)}.login-screen__logo{font-family:var(--font-display);font-weight:700;font-size:3rem;color:var(--color-text);margin-bottom:var(--space-2)}.login-screen__tagline{font-size:var(--text-lg);color:var(--color-muted)}.login-screen__card{background:var(--color-surface);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:var(--space-8);width:100%;max-width:360px}.login-screen__error{color:var(--color-error);font-size:var(--text-sm);margin-top:var(--space-3);padding:var(--space-2) var(--space-3);background:color-mix(in srgb,var(--color-error) 10%,var(--color-surface));border-radius:var(--radius);border:1px solid var(--color-error)}.login-screen__inapp-warning{text-align:left}.login-screen__inapp-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);margin-bottom:var(--space-3)}.login-screen__inapp-text{font-size:var(--text-sm);color:var(--color-muted);line-height:1.5;margin-bottom:var(--space-4)}.login-screen__inapp-text strong{color:var(--color-text)}.login-screen__features{list-style:none;padding:0;margin:var(--space-8) 0 0;width:100%;max-width:360px;display:flex;flex-direction:column;gap:var(--space-3)}.login-screen__feature{display:flex;align-items:center;gap:var(--space-4);background:var(--color-surface);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:var(--space-4);text-align:left}.login-screen__feature-emoji{font-size:1.75rem;line-height:1;flex-shrink:0;width:2.5rem;text-align:center}.login-screen__feature-text{display:flex;flex-direction:column;gap:var(--space-1)}.login-screen__feature-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-base);color:var(--color-text)}.login-screen__feature-desc{font-size:var(--text-sm);color:var(--color-muted);line-height:1.4}.login-screen__footer{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-8);padding-bottom:var(--space-4)}.login-screen__footer-link{background:none;border:none;padding:0;font-size:var(--text-sm);color:var(--color-muted);cursor:pointer;text-decoration:underline;text-underline-offset:3px;font-family:var(--font-body);transition:color var(--transition)}.login-screen__footer-link:hover{color:var(--color-text)}.login-screen__footer-sep{color:var(--color-muted);font-size:var(--text-sm);-webkit-user-select:none;user-select:none}@media(max-width:640px){.login-screen__logo{font-size:2.5rem}.login-screen__card{padding:var(--space-6)}}.suggestion-dropdown__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition);min-height:48px;border-bottom:1px solid color-mix(in srgb,var(--color-border) 15%,transparent)}.suggestion-dropdown__group:last-child>.suggestion-dropdown__item{border-bottom:none}.suggestion-dropdown__group:last-child>.suggestion-dropdown__variants{border-bottom:none}.suggestion-dropdown__item:hover,.suggestion-dropdown__item--active{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.suggestion-dropdown__name{flex:1;font-weight:500}.suggestion-dropdown__highlight{font-weight:700;color:var(--color-primary)}.suggestion-dropdown__category{font-size:var(--text-xs);color:var(--color-muted);font-family:var(--font-display);padding:2px var(--space-2);border:1px solid color-mix(in srgb,var(--color-border) 30%,transparent);border-radius:var(--radius)}.suggestion-dropdown__existing{font-size:var(--text-xs);color:var(--color-muted);font-style:italic}.suggestion-dropdown__item--freetext{border:2px dashed color-mix(in srgb,var(--color-primary) 40%,transparent);background:color-mix(in srgb,var(--color-accent) 12%,var(--color-surface));border-bottom:2px dashed color-mix(in srgb,var(--color-primary) 40%,transparent)}.suggestion-dropdown__freetext-icon{font-weight:700;font-size:var(--text-lg);color:var(--color-primary);line-height:1;flex-shrink:0}.suggestion-dropdown__variants{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2) var(--space-4) var(--space-3);border-bottom:1px solid color-mix(in srgb,var(--color-border) 15%,transparent);background:color-mix(in srgb,var(--color-accent) 8%,var(--color-surface))}.suggestion-dropdown__variant-chip{display:inline-flex;align-items:center;padding:var(--space-2) var(--space-3);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;white-space:nowrap;transition:all var(--transition);color:var(--color-text);min-height:36px;box-shadow:1px 1px 0 var(--color-border)}.suggestion-dropdown__variant-chip:hover{background:var(--color-accent);color:var(--color-on-accent);border-color:var(--color-text);box-shadow:2px 2px 0 var(--color-border);transform:translate(-1px,-1px)}.suggestion-dropdown__variant-chip:active{box-shadow:none;transform:translate(1px,1px)}.suggestion-dropdown__variant-chip--matched{background:var(--color-accent);color:var(--color-on-accent);border-color:var(--color-text);font-weight:700;box-shadow:2px 2px 0 var(--color-text)}[data-theme=dark] .suggestion-dropdown__item,[data-theme=dark] .suggestion-dropdown__variants{border-bottom-color:color-mix(in srgb,var(--color-border) 50%,transparent)}[data-theme=dark] .suggestion-dropdown__category{border-color:color-mix(in srgb,var(--color-border) 60%,transparent)}.add-item{position:relative}.add-item__form{display:flex;gap:var(--space-2)}.add-item__input-wrapper{flex:1;position:relative;background:var(--color-surface);border-radius:var(--radius)}.add-item__input{width:100%;padding:var(--space-3) var(--space-4);border:var(--border);border-radius:var(--radius);background:var(--color-surface);font-family:var(--font-body);font-size:var(--text-base);box-shadow:var(--shadow-sm);transition:all var(--transition);position:relative;z-index:1;background:transparent}.add-item__ghost{position:absolute;top:0;left:0;right:0;bottom:0;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-base);pointer-events:none;white-space:nowrap;overflow:hidden;z-index:0;border:2px solid transparent}.add-item__ghost-typed{visibility:hidden}.add-item__ghost-completion{color:var(--color-muted);opacity:.6}.add-item__input--dropdown-open{border-bottom-left-radius:0;border-bottom-right-radius:0}.add-item__input:focus{outline:none;box-shadow:var(--shadow-md);border-color:var(--color-primary)}.add-item__input::placeholder{color:var(--color-muted)}.add-item__submit{flex-shrink:0}.add-item__mic{position:absolute;right:var(--space-2);top:50%;transform:translateY(-50%);z-index:2;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius);background:transparent;cursor:pointer;color:var(--color-muted);transition:color var(--transition)}.add-item__mic:hover{color:var(--color-text)}.add-item__input--has-mic{padding-right:calc(var(--space-2) + 36px)}.add-item__mic--active{color:var(--color-primary)}@media(prefers-reduced-motion:no-preference){.add-item__mic--active{animation:mic-pulse 1.2s ease-in-out infinite}}@keyframes mic-pulse{0%,to{opacity:1}50%{opacity:.4}}.add-item__dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:0;background:var(--color-surface);border:var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-md);overflow:hidden;animation:additem-dropdown-in .15s ease-out}@keyframes additem-dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.add-item__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.add-item__recent{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:var(--space-1);background:var(--color-surface);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:var(--space-2) var(--space-3);animation:additem-dropdown-in .15s ease-out}.add-item__recent-label{font-size:var(--text-xs);color:var(--color-muted);font-family:var(--font-display);display:block;margin-bottom:var(--space-1)}.add-item__recent-chips{display:flex;flex-wrap:wrap;gap:var(--space-1)}.add-item__recent-chip{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-family:var(--font-display);font-size:var(--text-sm);font-weight:500;border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:1px 1px 0 var(--color-border);cursor:pointer;white-space:nowrap;transition:all var(--transition);color:var(--color-text);min-height:44px}.add-item__recent-chip:hover{background:var(--color-accent);color:var(--color-on-accent);box-shadow:2px 2px 0 var(--color-border);transform:translate(-1px,-1px)}.add-item__recent-chip:active{box-shadow:none;transform:translate(1px,1px)}.add-item__recent-chip--suggested{border-style:dashed}.add-item__cancel{display:none}@media(max-width:640px){.add-item__dropdown,.add-item__recent{max-height:var(--add-item-dropdown-max-height, 50vh);overflow-y:auto;overscroll-behavior:contain;width:calc(100vw - 2 * var(--space-3))}}.item-row-wrapper{display:flex;flex-direction:column;position:relative}.item-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all var(--transition);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:56px;position:relative;z-index:1;touch-action:manipulation}.item-row:hover{box-shadow:var(--shadow-md);transform:translate(-1px,-1px)}.item-row:active{box-shadow:none;transform:translate(1px,1px)}.item-row--checked{opacity:.5;background:color-mix(in srgb,var(--color-bg) 50%,var(--color-surface));transition:opacity .2s ease-out,background .2s ease-out}.item-row--checked .item-row__name{color:var(--color-muted)}.item-row__checkbox{width:28px;height:28px;flex-shrink:0;border:var(--border);border-radius:4px;background:var(--color-surface);display:flex;align-items:center;justify-content:center;transition:all var(--transition);position:relative;cursor:pointer}.item-row__checkbox:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px}.app--shopping .item-row__checkbox{width:36px;height:36px;transition:all .2s ease-out}.app--shopping .item-row__checkbox:after{top:-4px;right:-4px;bottom:-4px;left:-4px}.item-row--checked .item-row__checkbox{background:var(--color-secondary)}.item-row__checkmark{display:none;font-size:var(--text-sm);font-weight:700}.item-row--checked .item-row__checkmark{display:block}@media(prefers-reduced-motion:no-preference){.item-row--checked{animation:check-pop .2s cubic-bezier(.34,1.56,.64,1),shadow-flash .4s ease-out}.item-row--checked .item-row__checkmark{animation:checkmark-spring .3s cubic-bezier(.34,1.56,.64,1)}.item-row-wrapper{animation:item-rubber-band .3s cubic-bezier(.34,1.56,.64,1)}.item-row-wrapper--removing{animation:item-exit .6s ease-out forwards;pointer-events:none}}.item-row-wrapper--removing{pointer-events:none}@keyframes item-exit{0%{opacity:1;transform:translate(0);max-height:100px}50%{opacity:1;transform:translate(0);max-height:100px}75%{opacity:0;transform:translate(50px);max-height:100px}to{opacity:0;transform:translate(50px);max-height:0;margin-bottom:calc(-1 * var(--space-2))}}@keyframes check-pop{0%{transform:scale(1)}40%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes checkmark-spring{0%{transform:scale(0)}60%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes shadow-flash{0%{box-shadow:var(--shadow-sm)}30%{box-shadow:2px 2px 0 var(--color-secondary)}to{box-shadow:var(--shadow-sm)}}.app--shopping .item-row--checked .item-row__checkbox{animation:shopping-check-bounce .3s cubic-bezier(.34,1.56,.64,1)}@keyframes shopping-check-bounce{0%{transform:scale(1)}40%{transform:scale(1.25)}70%{transform:scale(.95)}to{transform:scale(1)}}@keyframes item-rubber-band{0%{opacity:0;transform:translate(-20px) scale(.97);box-shadow:none}60%{opacity:1;transform:translate(4px) scale(1.005);box-shadow:none}80%{transform:translate(-1px) scale(1);box-shadow:none}to{transform:translate(0) scale(1);box-shadow:var(--shadow-sm)}}.item-row__content{flex:1;min-width:0}.item-row__name{font-family:var(--font-display);font-weight:700;font-size:var(--text-base);overflow-x:auto;overflow-y:hidden;white-space:nowrap;display:flex;align-items:center;gap:var(--space-2);scrollbar-width:none;padding:4px 0;margin:-4px 0;max-width:100%;overscroll-behavior-x:contain}.item-row__name::-webkit-scrollbar{display:none}.item-row__name--fade-right{mask-image:linear-gradient(to right,black calc(100% - 32px),transparent);-webkit-mask-image:linear-gradient(to right,black calc(100% - 32px),transparent)}.item-row__name--fade-left{mask-image:linear-gradient(to left,black calc(100% - 32px),transparent);-webkit-mask-image:linear-gradient(to left,black calc(100% - 32px),transparent)}.item-row__name--fade-both{mask-image:linear-gradient(to right,transparent,black 32px,black calc(100% - 32px),transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 32px,black calc(100% - 32px),transparent)}.item-row__name--editable{cursor:text}.item-row__variant-badge.item-row__variant-badge--empty{background:transparent;border:1.5px dashed var(--color-muted);box-shadow:none;color:var(--color-muted);font-weight:500;font-size:var(--text-sm)}.item-row__variant-badge.item-row__variant-badge--empty:hover{border-style:solid;border-color:var(--color-border);background:color-mix(in srgb,var(--color-accent) 30%,transparent);box-shadow:2px 2px 0 var(--color-border);color:var(--color-text)}.item-row__variant-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;border:var(--border-thin);border-radius:var(--radius);background:color-mix(in srgb,var(--color-accent) 35%,transparent);box-shadow:none;cursor:pointer;transition:all var(--transition);white-space:nowrap;color:var(--color-text)}.item-row__variant-badge:hover{background:color-mix(in srgb,var(--color-accent) 55%,transparent);transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--color-border)}.item-row__variant-badge:active{box-shadow:none;transform:translate(1px,1px)}.item-row__variant-badge--readonly,.item-row__variant-badge--readonly:hover,.item-row__variant-badge--readonly:active{cursor:default;background:color-mix(in srgb,var(--color-accent) 20%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);box-shadow:none;color:var(--color-text);font-weight:500;transform:none}.item-row__category-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.item-row__amount{flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;padding:var(--space-1) var(--space-3);border:var(--border-thin);border-radius:var(--radius);background:color-mix(in srgb,var(--color-accent) 35%,transparent);box-shadow:none;white-space:nowrap;min-width:44px;text-align:center;cursor:default;color:var(--color-text)}.item-row__amount--editable{cursor:pointer;transition:all var(--transition)}.item-row__amount--editable:hover{background:color-mix(in srgb,var(--color-accent) 55%,transparent);transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--color-border)}.item-row__amount--editable:active{transform:translate(1px,1px);box-shadow:none}.item-row__amount--empty{background:transparent;border:1.5px dashed var(--color-muted);box-shadow:none;min-width:44px}.item-row__amount--empty.item-row__amount--editable:hover{border-style:solid;border-color:var(--color-border);background:color-mix(in srgb,var(--color-accent) 30%,transparent);box-shadow:2px 2px 0 var(--color-border)}.item-row__amount--readonly{background:color-mix(in srgb,var(--color-accent) 20%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);box-shadow:none}.item-row__category-dot--editable{cursor:pointer;transition:all var(--transition);width:16px;height:16px;border:2px solid var(--color-border);position:relative}.item-row__category-dot--editable:after{content:"";position:absolute;top:-14px;right:-14px;bottom:-14px;left:-14px}.item-row__category-dot--editable:hover{transform:scale(1.3);box-shadow:0 0 0 2px var(--color-surface),0 0 0 4px var(--color-border);transition:transform .1s ease-out,box-shadow .1s ease-out}.item-row__category-dot--editable:active{transform:scale(.9)}@media(max-width:640px){.item-row{gap:var(--space-2);padding:var(--space-2) var(--space-3);min-height:48px}.item-row:hover{box-shadow:var(--shadow-sm);transform:none}.item-row__variant-badge:hover,.item-row__amount--editable:hover,.item-row__category-dot--editable:hover{transform:none;box-shadow:none}.item-row:active{transform:translate(1px,1px)}}.modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--color-overlay);display:flex;align-items:flex-end;justify-content:center;overscroll-behavior:contain;touch-action:none;padding-top:calc(var(--space-6) + env(safe-area-inset-top,0px))}.modal{background:var(--color-bg);border:var(--border-thick);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;width:100%;max-height:100%;animation:modal-slide-up .2s cubic-bezier(.32,.72,0,1)}@keyframes modal-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4) var(--space-2);flex-shrink:0}.modal__title{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em}.modal__header-actions{display:flex;align-items:center;gap:var(--space-1)}.modal__close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:none;color:var(--color-muted);cursor:pointer;border-radius:var(--radius);transition:color var(--transition);margin:calc(-1 * var(--space-2)) calc(-1 * var(--space-2)) 0 0}.modal__close:hover{color:var(--color-text)}.modal__body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;padding:0 var(--space-4)}.modal__footer{flex-shrink:0;padding:var(--space-3) var(--space-4);padding-bottom:calc(var(--space-3) + env(safe-area-inset-bottom,0px))}:root:has(input:focus,textarea:focus,[contenteditable]:focus) .modal__footer{padding-bottom:var(--space-3)}.modal__done-btn{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-size:var(--text-base);font-weight:700;color:var(--color-text);background:var(--color-surface);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition)}.modal__done-btn:active{box-shadow:none;transform:translate(1px,1px)}@media(min-width:641px){.modal__backdrop{align-items:center}.modal{max-width:420px;max-height:80dvh;border:var(--border-thick);border-radius:var(--radius);animation:modal-fade-in .2s ease-out}@keyframes modal-fade-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}}@media(prefers-reduced-motion:no-preference){.chip-selector-wrapper{animation:chip-selector-slide-down .2s ease-out}}@keyframes chip-selector-slide-down{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.chip-selector{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:color-mix(in srgb,var(--color-accent) 10%,var(--color-surface));border:var(--border);border-top:none;border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius);box-shadow:var(--shadow-sm);overflow-x:auto;touch-action:pan-x;overscroll-behavior-x:contain;scrollbar-width:none}.chip-selector::-webkit-scrollbar{display:none}.chip-selector__label{font-size:var(--text-xs);color:var(--color-muted);white-space:nowrap;flex-shrink:0}.chip-selector__chips{display:flex;gap:var(--space-1);flex-wrap:nowrap}.chip-selector__chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;border:2px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);box-shadow:1px 1px 0 var(--color-border);cursor:pointer;white-space:nowrap;transition:all var(--transition);min-height:44px}.chip-selector__chip--selected{background:var(--color-secondary);border-color:var(--color-text);border-width:2px;box-shadow:2px 2px 0 var(--color-border)}.chip-selector__chip:hover{background:var(--color-accent);color:var(--color-on-accent);box-shadow:2px 2px 0 var(--color-border);transform:translate(-1px,-1px)}.chip-selector__chip:active{box-shadow:none;transform:translate(1px,1px)}.chip-selector__chip--add{background:transparent;border-style:dashed;font-size:var(--text-sm);font-weight:700;min-width:32px}.chip-selector__chip--add:hover{background:var(--color-accent);color:var(--color-on-accent);border-style:solid}.chip-selector__chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chip-selector__input{padding:var(--space-2) var(--space-3);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;border:var(--border);border-radius:var(--radius);background:var(--color-surface);min-width:80px;max-width:120px}.chip-selector__input:focus{outline:none;box-shadow:var(--shadow-sm)}.chip-selector__dismiss{flex-shrink:0;width:44px;height:44px;border:none;background:none;cursor:pointer;font-size:var(--text-xs);color:var(--color-muted);display:flex;align-items:center;justify-content:center;transition:color var(--transition)}.chip-selector__dismiss:hover{color:var(--color-text)}@media(max-width:640px){.chip-selector{flex-wrap:wrap;overflow-x:visible}.chip-selector__label{flex-basis:100%}.chip-selector__chips{flex-wrap:wrap}}.edit-item-modal{display:flex;flex-direction:column;gap:var(--space-4);padding-bottom:var(--space-4)}.edit-item-modal__section{display:flex;flex-direction:column;gap:var(--space-2)}.edit-item-modal__label{font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em}.edit-item-modal__input{width:100%;min-height:44px;padding:var(--space-2) var(--space-3);font-family:var(--font-display);font-size:var(--text-base);font-weight:600;border:var(--border);border-radius:var(--radius);background:var(--color-surface);box-shadow:var(--shadow-sm);color:var(--color-text)}.edit-item-modal__input:focus{outline:none;box-shadow:3px 3px 0 var(--color-primary)}.edit-item-modal__name-suggestions{background:var(--color-surface);border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.edit-item-modal__name-suggestions .suggestion-dropdown__item{min-height:44px;padding:var(--space-2) var(--space-3)}.edit-item-modal__qty-row{display:flex;gap:var(--space-2);align-items:center}.edit-item-modal__qty-input{width:64px;min-height:44px;padding:var(--space-2) var(--space-3);font-family:var(--font-mono);font-size:var(--text-base);font-weight:600;border:var(--border);border-radius:var(--radius);background:var(--color-surface);box-shadow:var(--shadow-sm);color:var(--color-text);text-align:center;flex-shrink:0}.edit-item-modal__qty-input:focus{outline:none;box-shadow:3px 3px 0 var(--color-primary)}.edit-item-modal__unit-chips{display:flex;gap:var(--space-1);flex-wrap:wrap;flex:1}.edit-item-modal__unit-chip{padding:var(--space-1) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;border:var(--border-thin);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:all var(--transition);color:var(--color-text);min-height:44px}.edit-item-modal__unit-chip:active{transform:translate(1px,1px);box-shadow:none}.edit-item-modal__unit-chip--selected{background:var(--color-secondary);box-shadow:var(--shadow-sm)}.edit-item-modal__category-trigger{display:flex;align-items:center;gap:var(--space-2);min-height:44px;padding:var(--space-2) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;border:var(--border);border-radius:var(--radius);background:var(--color-surface);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition);color:var(--color-text);width:fit-content}.edit-item-modal__category-trigger:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-md)}.edit-item-modal__category-trigger:active{transform:translate(1px,1px);box-shadow:none}.edit-item-modal__category-dot{width:12px;height:12px;border-radius:50%;border:1.5px solid var(--color-border);flex-shrink:0}.edit-item-modal__category-chevron{margin-left:var(--space-1);color:var(--color-muted)}.edit-item-modal__category-grid{display:flex;flex-wrap:wrap;gap:var(--space-2)}.edit-item-modal__category-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;border:var(--border-thin);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:all var(--transition);color:var(--color-text);min-height:44px}.edit-item-modal__category-chip:active{transform:translate(1px,1px);box-shadow:none}.edit-item-modal__category-chip--selected{border-width:2px;box-shadow:var(--shadow-sm);background:color-mix(in srgb,var(--color-accent) 25%,var(--color-surface))}.edit-item-modal__category-chip-dot{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--color-border);flex-shrink:0}.edit-item-modal__chips-wrap .chip-selector-wrapper{margin:0;animation:none}.edit-item-modal__chips-wrap .chip-selector{background:transparent;border:none;box-shadow:none;padding:var(--space-1);border-radius:0;overflow:visible;touch-action:auto}.edit-item-modal__chips-wrap .chip-selector__label{display:none}.edit-item-modal__chips-wrap .chip-selector__chips{flex-wrap:wrap}.edit-item-modal__chips-wrap .chip-selector__dismiss{display:none}.edit-item-modal__delete-btn{display:flex;align-items:center;justify-content:center;width:100%;min-height:44px;margin-top:var(--space-2);padding:var(--space-2);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;color:var(--color-muted);background:none;border:none;cursor:pointer;transition:color var(--transition)}.edit-item-modal__delete-btn:hover{color:var(--color-error)}.category-group{margin-bottom:var(--space-4)}.category-group+.category-group:before{content:"";display:block;width:100%;margin-bottom:var(--space-2);border-bottom:2px dashed var(--color-border)}.category-group__header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);-webkit-user-select:none;user-select:none;border-radius:var(--radius);position:sticky;top:0;z-index:10;background:var(--color-bg)}.category-group__color-bar{width:4px;height:20px;border-radius:2px;flex-shrink:0}.category-group__name{font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;flex:1}.category-group__count{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted)}.category-group__items{display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-2)}.ghost-item-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:transparent;border:1px dashed var(--color-border);border-radius:var(--radius);opacity:.65;min-height:56px;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;transition:opacity .2s ease,transform .2s ease,border .2s ease,background .2s ease}.ghost-item-row:hover{opacity:.8}.ghost-item-row--dismissing{opacity:0;transform:translate(-100%);transition:opacity .25s ease,transform .25s ease}.ghost-item-row__add-btn{width:28px;height:28px;flex-shrink:0;border:1.5px solid var(--color-secondary);border-radius:4px;background:color-mix(in srgb,var(--color-secondary) 15%,transparent);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-secondary);transition:all var(--transition);touch-action:manipulation}.ghost-item-row__add-btn:hover{background:color-mix(in srgb,var(--color-secondary) 30%,transparent);transform:translate(-1px,-1px);box-shadow:2px 2px color-mix(in srgb,var(--color-secondary) 50%,black)}.ghost-item-row__add-btn:active{transform:translate(1px,1px);box-shadow:none}.ghost-item-row__category-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;border:2px solid var(--color-border)}.ghost-item-row__content{flex:1;min-width:0}.ghost-item-row__name{font-family:var(--font-display);font-weight:700;font-size:var(--text-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:var(--space-2);color:var(--color-muted)}.ghost-item-row__variant{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-family:var(--font-body);font-size:var(--text-sm);font-weight:500;border:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);border-radius:var(--radius);background:color-mix(in srgb,var(--color-accent) 20%,transparent);white-space:nowrap;color:var(--color-muted)}.ghost-item-row__amount{flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-sm);font-weight:600;padding:var(--space-1) var(--space-3);border:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);border-radius:var(--radius);background:color-mix(in srgb,var(--color-accent) 20%,transparent);white-space:nowrap;min-width:44px;text-align:center;color:var(--color-muted)}@media(max-width:640px){.ghost-item-row{gap:var(--space-2);padding:var(--space-2) var(--space-3);min-height:48px}.ghost-item-row__add-btn:hover{transform:none;box-shadow:none}}.duplicate-group{position:relative;margin-top:var(--space-2);margin-bottom:var(--space-2)}.duplicate-group__items{display:flex;flex-direction:column;gap:2px}.duplicate-group__items>:first-child .item-row{border-bottom-left-radius:0;border-bottom-right-radius:0}.duplicate-group__items>:last-child .item-row{border-top-left-radius:0;border-top-right-radius:0;border-top:1px dashed var(--color-border)}.duplicate-group__items>:not(:first-child):not(:last-child) .item-row{border-radius:0;border-top:1px dashed var(--color-border)}.duplicate-group__merge-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-1);width:fit-content;margin:0 auto;padding:var(--space-1) var(--space-3);min-height:36px;font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;color:var(--color-text);background:color-mix(in srgb,var(--color-accent) 40%,var(--color-surface));border:2px solid var(--color-text);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition)}.duplicate-group__merge-btn:hover{background:var(--color-accent);color:var(--color-on-accent);box-shadow:var(--shadow-md);transform:translate(-1px,-1px)}.duplicate-group__merge-btn:active{box-shadow:none;transform:translate(1px,1px)}.duplicate-group__merge-btn:disabled{cursor:default;opacity:.7}.duplicate-group__merge-icon{flex-shrink:0}@media(prefers-reduced-motion:no-preference){.duplicate-group--merging .duplicate-group__items>:not(:first-child){animation:merge-collapse .3s ease-out forwards}.duplicate-group--merging .duplicate-group__items>:first-child .item-row{animation:merge-highlight .4s ease-out}}@keyframes merge-collapse{0%{transform:translateY(0);opacity:1;max-height:80px}to{transform:translateY(-100%);opacity:0;max-height:0;padding:0;margin:0;overflow:hidden}}@keyframes merge-highlight{0%{box-shadow:var(--shadow-sm)}40%{box-shadow:0 0 0 3px var(--color-accent)}to{box-shadow:var(--shadow-sm)}}.toggle{display:inline-flex;align-items:center;gap:var(--space-2);flex-shrink:0}.toggle__track{display:inline-flex;align-items:center;width:32px;height:18px;border-radius:9px;background:var(--color-border);border:1.5px solid var(--color-text);padding:2px;flex-shrink:0;transition:background var(--transition)}.toggle__track--on{background:var(--color-tertiary)}.toggle__thumb{display:block;width:12px;height:12px;border-radius:50%;background:var(--color-surface);border:1.5px solid var(--color-text);transition:transform var(--transition)}.toggle__track--on .toggle__thumb{transform:translate(12px)}.toggle__label{font-size:var(--text-xs);color:var(--color-muted);min-width:3.5em}.store-selector{position:relative}.store-selector__trigger{display:flex;align-items:center;justify-content:center;gap:var(--space-1);min-width:44px;min-height:44px;border:var(--border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;color:var(--color-text);transition:all var(--transition)}.store-selector__trigger:hover{box-shadow:var(--shadow-sm);transform:translate(-1px,-1px)}.store-selector__trigger:active{box-shadow:none;transform:translate(1px,1px)}.store-selector__trigger--active{background:color-mix(in srgb,var(--color-tertiary) 12%,var(--color-surface));padding:0 var(--space-2)}.store-selector__trigger--auto:not(.store-selector__trigger--active){border-color:var(--color-tertiary);color:var(--color-tertiary)}.store-selector__trigger--locating{border-color:var(--color-tertiary);color:var(--color-tertiary);animation:locating-breathe 1s ease-in-out infinite alternate;box-shadow:none;z-index:50}.store-selector__trigger--locating:hover,.store-selector__trigger--locating:active{transform:none}.store-selector__trigger--locating:before,.store-selector__trigger--locating:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:2.5px solid var(--color-tertiary);border-radius:var(--radius);opacity:0;pointer-events:none;animation:sonar-ring 2s cubic-bezier(.2,.8,.4,1) infinite;will-change:transform,opacity}.store-selector__trigger--locating:after{animation-delay:.7s}@keyframes sonar-ring{0%{transform:scale(1);opacity:.9}to{transform:scale(1.8);opacity:0}}@keyframes locating-breathe{0%{transform:scale(1)}to{transform:scale(1.04)}}.store-selector__trigger--found{animation:found-bounce .6s cubic-bezier(.17,.67,.83,.67)}@keyframes found-bounce{0%{transform:translate(0);box-shadow:none}35%{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--color-tertiary)}55%{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--color-tertiary)}to{transform:translate(0);box-shadow:var(--shadow-sm)}}.store-selector__name{font-family:var(--font-display);font-size:var(--text-xs);font-weight:600;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.store-selector__dropdown{position:fixed;min-width:220px;max-width:min(340px,calc(100vw - var(--space-4) * 2));max-height:70vh;overflow-y:auto;background:var(--color-surface);border:var(--border-thick);box-shadow:var(--shadow-md);border-radius:var(--radius);z-index:100;animation:store-popover-in .15s ease-out}@keyframes store-popover-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.store-selector__header{padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);border-bottom:var(--border)}.store-selector__option{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);cursor:pointer;transition:background var(--transition);font-size:var(--text-sm);min-height:44px}.store-selector__option:hover,.store-selector__option--focused{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.store-selector__option--selected{background:color-mix(in srgb,var(--color-primary) 6%,transparent);font-weight:600}.store-selector__option--suggested{background:color-mix(in srgb,var(--color-tertiary) 8%,transparent)}.store-selector__option--stop{color:var(--color-danger);font-weight:600}.store-selector__option--stop .store-selector__option-label{display:flex;align-items:center;gap:var(--space-2)}.store-selector__option--stop:hover,.store-selector__option--stop.store-selector__option--focused{background:color-mix(in srgb,var(--color-danger) 10%,transparent)}.store-selector__option--add{font-style:italic;color:var(--color-primary);font-weight:600}.store-selector__option-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.store-selector__check{color:var(--color-primary);font-weight:700;font-size:var(--text-base);flex-shrink:0;margin-left:var(--space-2)}.store-selector__nearby-badge{flex-shrink:0;margin-left:var(--space-2);padding:1px var(--space-2);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--color-tertiary);border:1.5px solid var(--color-tertiary);border-radius:var(--radius);white-space:nowrap}.store-selector__trigger--has-suggestion{position:relative}.store-selector__trigger--has-suggestion:not(.store-selector__trigger--locating):after{content:"";position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--color-tertiary);border:1.5px solid var(--color-surface)}.store-selector__divider{height:1px;background:var(--color-border);margin:0}.store-selector__option--toggle{gap:var(--space-3)}.store-selector__option--toggle .store-selector__option-label{display:flex;align-items:center;gap:var(--space-2);flex:0 1 auto}.store-selector__option-pin{flex-shrink:0;color:var(--color-muted)}.store-selector__option--toggle.store-selector__option--selected .store-selector__option-pin{color:var(--color-tertiary)}.store-selector__section-header{padding:var(--space-1) var(--space-4) var(--space-1);font-family:var(--font-display);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted)}.store-selector__hide-btn{display:none;align-items:center;justify-content:center;min-width:44px;min-height:44px;border:none;background:none;color:var(--color-muted);cursor:pointer;flex-shrink:0;margin-left:var(--space-1);border-radius:var(--radius);padding:0;transition:color var(--transition),background var(--transition)}.store-selector__option:hover .store-selector__hide-btn{display:flex}@media(hover:none){.store-selector__hide-btn{display:flex;opacity:.5}.store-selector__option:active .store-selector__hide-btn{opacity:1}}.store-selector__hide-btn:hover{color:var(--color-danger);background:color-mix(in srgb,var(--color-danger) 10%,transparent)}.app--shopping .store-selector__dropdown{background:var(--color-shopping-bg);border-color:var(--color-tertiary);box-shadow:4px 4px color-mix(in srgb,var(--color-tertiary) 40%,black);color:var(--color-text)}.app--shopping .store-selector__header{color:color-mix(in srgb,var(--color-tertiary) 80%,black);border-bottom-color:color-mix(in srgb,var(--color-tertiary) 30%,transparent)}.app--shopping .store-selector__section-header{color:color-mix(in srgb,var(--color-tertiary) 80%,black)}.app--shopping .store-selector__option:hover,.app--shopping .store-selector__option--focused{background:color-mix(in srgb,var(--color-tertiary) 15%,transparent)}.app--shopping .store-selector__option--selected,.app--shopping .store-selector__option--suggested{background:color-mix(in srgb,var(--color-tertiary) 12%,transparent)}.app--shopping .store-selector__option--add,.app--shopping .store-selector__check{color:var(--color-tertiary)}.app--shopping .store-selector__nearby-badge{color:#fff;background:var(--color-tertiary)}.app--shopping .toggle__track{border-color:color-mix(in srgb,var(--color-tertiary) 60%,black)}.app--shopping .store-selector__option--stop:hover,.app--shopping .store-selector__option--stop.store-selector__option--focused{background:color-mix(in srgb,var(--color-danger) 12%,transparent)}.app--shopping .toggle__thumb{border-color:color-mix(in srgb,var(--color-tertiary) 60%,black)}.list-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:var(--space-2) 0;position:relative;z-index:2}.list-header__left{display:flex;align-items:center;gap:var(--space-2);min-width:0;flex:1}.list-header__drawer-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:var(--border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;color:var(--color-text);flex-shrink:0;transition:all var(--transition)}.list-header__drawer-btn:hover{box-shadow:var(--shadow-sm);transform:translate(-1px,-1px)}.list-header__drawer-btn:active{box-shadow:none;transform:translate(1px,1px)}.list-header__name{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);border:none;background:transparent;padding:var(--space-1) var(--space-2);border-radius:var(--radius);transition:all var(--transition);min-width:0;margin:0;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-header__name--editable{cursor:pointer}.list-header__name--editable:hover{background:color-mix(in srgb,var(--color-text) 5%,transparent)}.list-header__rename-input{font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);line-height:1.2;padding:var(--space-1) var(--space-2);border:var(--border);border-radius:var(--radius);background:var(--color-surface);min-width:0;flex:1;box-shadow:var(--shadow-sm)}.list-header__rename-input:focus{outline:none;box-shadow:var(--shadow-md)}.list-header__stats{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-muted);white-space:nowrap;flex-shrink:0}.list-header__status{display:flex;align-items:center;flex-shrink:0;color:var(--color-muted)}.list-header__status--offline{color:var(--color-error)}.list-header__status--syncing{color:var(--color-text);opacity:.5}@media(prefers-reduced-motion:no-preference){.list-header__status--syncing svg{animation:spin 1.2s cubic-bezier(.4,0,.6,1) infinite}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.list-header__status--synced{color:var(--color-secondary)}@media(prefers-reduced-motion:no-preference){.list-header__status--synced{animation:sync-success-pop 1.8s ease-out forwards}}@keyframes sync-success-pop{0%{opacity:0;transform:scale(.6)}15%{opacity:1;transform:scale(1.1)}25%{transform:scale(1)}70%{opacity:1}to{opacity:0}}.list-header__actions{display:flex;gap:var(--space-1);flex-shrink:0}.list-header__action-btn{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border:var(--border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;color:var(--color-text);transition:all var(--transition)}.list-header__action-btn:hover{box-shadow:var(--shadow-sm);transform:translate(-1px,-1px)}.list-header__action-btn:active{box-shadow:none;transform:translate(1px,1px)}.list-header .store-selector__trigger{min-width:44px;min-height:44px}.app--shopping .app__sticky{background:var(--color-tertiary);border-bottom-color:var(--color-text);transition:background-color .2s ease-out}.app--shopping .list-header,.app--shopping .list-header__name{color:#fff}.app--shopping .list-header__stats{color:#ffffffb3}.app--shopping .list-header__drawer-btn{background:#ffffff26;border-color:#ffffff4d;color:#fff}.app--shopping .list-header__drawer-btn:hover{background:#ffffff40}.app--shopping .list-header__action-btn{background:#ffffff26;border-color:#ffffff4d;color:#fff}.app--shopping .list-header__action-btn:hover{background:#ffffff40}.app--shopping .list-header__status{color:#ffffffb3}.app--shopping .store-selector__trigger{background:#ffffff26;border-color:#ffffff4d;color:#fff}.app--shopping .store-selector__trigger:hover{background:#ffffff40}.app--shopping .app__sticky--bordered{border-bottom-color:var(--color-text)}.app__sticky--scrolled .list-header__rename-input,.app__sticky--scrolled .list-header__action-btn:not(.list-header__category-btn),.app__sticky--scrolled .store-selector__name{display:none}.list-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);z-index:1000;animation:list-drawer-overlay-in .2s ease-out}@keyframes list-drawer-overlay-in{0%{opacity:0}to{opacity:1}}.list-drawer{position:absolute;top:0;left:0;bottom:0;width:320px;max-width:85vw;background:var(--color-surface);border-right:var(--border-thick);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:list-drawer-slide-in .25s ease-out}@keyframes list-drawer-slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.list-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:var(--border)}.list-drawer__title{font-family:var(--font-display);font-weight:700;font-size:var(--text-xl);margin:0}.list-drawer__close{background:none;border:none;cursor:pointer;font-size:var(--text-xl);padding:var(--space-1);line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.list-drawer__list{flex:1;overflow-y:auto;padding:var(--space-2) 0}@keyframes list-drawer-item-in{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.list-drawer__item{display:flex;align-items:center;padding:var(--space-2) var(--space-4);gap:var(--space-2);transition:background var(--transition);animation:list-drawer-item-in .2s ease-out both}@media(prefers-reduced-motion:reduce){.list-drawer__item{animation:none}}.list-drawer__item:hover{background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.list-drawer__item--active{background:color-mix(in srgb,var(--color-primary) 12%,transparent);border-left:4px solid var(--color-primary);padding-left:calc(var(--space-4) - 4px)}.list-drawer__item--active .list-drawer__item-name{font-weight:700}.list-drawer__item--shared{border-left:2px solid transparent}.list-drawer__item--shared .list-drawer__dot{border-style:dashed}.list-drawer__dot{width:10px;height:10px;border:2px solid var(--color-border);border-radius:2px;flex-shrink:0;transition:all var(--transition)}.list-drawer__dot--active{box-shadow:var(--shadow-sm);transform:scale(1.2)}.list-drawer__item-main{flex:1;min-width:0;cursor:pointer;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0}.list-drawer__item-name{font-family:var(--font-display);font-weight:600;font-size:var(--text-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-drawer__item-meta{flex-shrink:0}.list-drawer__member-count{font-size:var(--text-xs);color:var(--color-muted);font-family:var(--font-mono)}.list-drawer__edit-input{flex:1;font-family:var(--font-display);font-weight:600;font-size:var(--text-base);padding:var(--space-1) var(--space-2);border:var(--border);border-radius:var(--radius);background:var(--color-bg);min-width:0}.list-drawer__edit-input:focus{outline:none;box-shadow:var(--shadow-sm)}.list-drawer__item-actions{display:flex;gap:var(--space-1);flex-shrink:0;align-items:center}.list-drawer__icon-btn{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border:var(--border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;color:var(--color-text);transition:all var(--transition)}.list-drawer__icon-btn:hover{box-shadow:var(--shadow-sm);transform:translate(-1px,-1px)}.list-drawer__icon-btn:active{box-shadow:none;transform:translate(1px,1px)}.list-drawer__icon-btn--danger{color:var(--color-error);border-color:var(--color-error)}.list-drawer__icon-btn--danger:hover{background:color-mix(in srgb,var(--color-error) 10%,transparent)}.list-drawer__confirm{display:flex;align-items:center;gap:var(--space-1)}.list-drawer__confirm-text{font-size:var(--text-xs);font-weight:600;color:var(--color-error);white-space:nowrap}.list-drawer__confirm-btn{font-size:var(--text-xs);font-weight:700;padding:var(--space-1) var(--space-2);min-height:44px;border:var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}.list-drawer__confirm-btn--yes{background:var(--color-error);color:#fff;border-color:var(--color-error)}.list-drawer__confirm-btn--no{background:var(--color-surface);color:var(--color-text)}.list-drawer__footer{padding:var(--space-4);border-top:var(--border)}.list-drawer__profile{padding:var(--space-3) var(--space-4);border-top:var(--border-thick);display:flex;flex-direction:column;gap:var(--space-3)}.list-drawer__profile-info{min-width:0}.list-drawer__profile-actions{display:flex;align-items:center;gap:var(--space-3)}.list-drawer__profile-name{font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-drawer__profile-email{font-size:var(--text-xs);color:var(--color-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-drawer__theme-btn,.list-drawer__push-btn,.list-drawer__settings-btn,.list-drawer__help-btn{width:36px;height:36px;border-radius:var(--radius);box-shadow:var(--shadow-sm);color:var(--color-text);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition)}.list-drawer__theme-btn:hover,.list-drawer__push-btn:hover,.list-drawer__settings-btn:hover,.list-drawer__help-btn:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-md)}.list-drawer__theme-btn:active,.list-drawer__push-btn:active,.list-drawer__settings-btn:active,.list-drawer__help-btn:active{transform:translate(1px,1px);box-shadow:none}.list-drawer__theme-btn{background:var(--color-surface);border:var(--border-thick)}.list-drawer__theme-btn--dark{background:var(--color-tertiary);color:#fff}.list-drawer__push-btn{background:var(--color-surface);border:var(--border-thick)}.list-drawer__push-btn--active{background:var(--color-secondary);color:var(--color-surface);border:var(--border-thick)}.list-drawer__settings-btn{background:var(--color-surface);border:var(--border-thick)}.list-drawer__help-btn{background:var(--color-accent);border:var(--border);font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);color:var(--color-on-accent)}.list-drawer__sign-out{font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);padding:var(--space-2) var(--space-3);border:var(--border-thick);border-radius:var(--radius);background:var(--color-surface);color:var(--color-primary);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all var(--transition);box-shadow:var(--shadow-sm)}.list-drawer__sign-out:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-md)}.list-drawer__sign-out:active{transform:translate(1px,1px);box-shadow:none}.list-drawer__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);text-align:center}.list-drawer__empty-icon{font-size:2.5rem;margin-bottom:var(--space-3)}.list-drawer__empty-text{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-muted);margin:0;line-height:1.5}.base-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);padding-top:calc(var(--space-4) + env(safe-area-inset-top,0px));animation:base-dialog-overlay-in .15s ease-out}.base-dialog-overlay--keyboard{bottom:var(--keyboard-offset, 0px)}@keyframes base-dialog-overlay-in{0%{opacity:0}to{opacity:1}}.base-dialog{background:var(--color-surface);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:var(--space-6);width:100%;max-width:400px;max-height:90%;overflow-y:auto;animation:base-dialog-in .2s ease-out}@keyframes base-dialog-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.base-dialog__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.base-dialog__title{font-family:var(--font-display);font-weight:700;font-size:var(--text-xl)}.base-dialog__close{background:none;border:none;cursor:pointer;font-size:var(--text-xl);padding:var(--space-1);line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.base-dialog__close:hover{opacity:.7}.base-dialog__close:active{transform:scale(.9)}@media(max-width:640px){.base-dialog-overlay{padding:var(--space-3);padding-top:calc(var(--space-3) + env(safe-area-inset-top,0px))}.base-dialog{max-height:calc(100% - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px))}}.share-dialog__link-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.share-dialog__link-input{flex:1;padding:var(--space-2) var(--space-3);border:var(--border);border-radius:var(--radius);background:var(--color-bg);font-family:var(--font-mono);font-size:var(--text-sm)}.share-dialog__qr{display:flex;justify-content:center;margin-bottom:var(--space-4)}.share-dialog__qr canvas{border:var(--border);border-radius:var(--radius);padding:var(--space-2);background:#fff}.share-dialog__actions{display:flex;gap:var(--space-2);justify-content:center}.share-dialog__leave{margin-top:var(--space-4);padding-top:var(--space-4);border-top:var(--border);display:flex;justify-content:center}.copy-move-dialog__body{font-size:var(--text-base);line-height:1.5;margin:0 0 var(--space-5);color:var(--color-text)}.copy-move-dialog__actions{display:flex;gap:var(--space-3);justify-content:center;margin-bottom:var(--space-3)}.copy-move-dialog__cancel{display:block;margin:0 auto;background:none;border:none;cursor:pointer;color:var(--color-muted);font-size:var(--text-sm);padding:var(--space-2);text-decoration:underline}.copy-move-dialog__cancel:hover{color:var(--color-text)}.location-dialog__body{display:flex;flex-direction:column;gap:var(--space-4)}.location-dialog__text{font-size:var(--text-sm);color:var(--color-muted);line-height:1.5}.location-dialog__input{padding:var(--space-2) var(--space-3);border:var(--border);border-radius:var(--radius);background:var(--color-bg);font-family:var(--font-body);font-size:var(--text-base)}.location-dialog__input:focus{outline:none;box-shadow:var(--shadow-sm)}.location-dialog__status{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:600;flex-wrap:wrap}.location-dialog__status--loading{color:var(--color-primary)}.location-dialog__status--done{color:var(--color-success)}.location-dialog__status--error{color:var(--color-danger);line-height:1.4}.location-dialog__retry{background:none;border:none;color:var(--color-primary);font-weight:700;font-size:var(--text-sm);cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;margin-left:var(--space-1)}.location-dialog__retry:active{opacity:.7}.location-dialog__spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--color-primary);border-top-color:transparent;border-radius:50%;animation:location-spin .6s linear infinite}@keyframes location-spin{to{transform:rotate(360deg)}}.location-dialog__actions{display:flex;gap:var(--space-2);justify-content:center}.clear-checked__body{display:flex;flex-direction:column;gap:var(--space-4)}.clear-checked__text{font-size:var(--text-sm);color:var(--color-muted);line-height:1.5}.clear-checked__actions{display:flex;gap:var(--space-2);justify-content:center}.shopping-confirm__body{display:flex;flex-direction:column;gap:var(--space-4)}.shopping-confirm__text{font-size:var(--text-sm);color:var(--color-muted);line-height:1.5}.shopping-confirm__stores{border:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.shopping-confirm__legend{font-weight:700;font-size:var(--text-sm);margin-bottom:var(--space-1)}.shopping-confirm__option{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--text-sm);padding:var(--space-1) 0}.shopping-confirm__store-name{-webkit-user-select:none;user-select:none}.shopping-confirm__actions{display:flex;gap:var(--space-2);justify-content:center}.help-dialog.base-dialog{max-width:420px;overscroll-behavior:contain}.help-dialog__content{margin-bottom:var(--space-4)}.help-dialog__intro{margin-bottom:var(--space-4);padding-bottom:var(--space-4);position:relative}.help-dialog__intro:after{content:"";position:absolute;bottom:0;left:0;right:0;border-bottom:2px dashed var(--color-border)}.help-dialog__intro p{font-size:var(--text-sm);color:var(--color-muted);line-height:1.5;margin:0}.help-dialog__intro p+p{margin-top:var(--space-2)}.help-dialog__section--spaced{margin-top:var(--space-3);padding-top:var(--space-3)}.help-dialog__section--spaced:before{content:"";display:block;width:100%;margin-bottom:var(--space-3);border-bottom:2px dashed var(--color-border)}.help-dialog__section-heading{font-family:var(--font-display);font-weight:700;font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);margin-bottom:var(--space-3)}.help-dialog__items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-4)}.help-dialog__item{display:flex;align-items:flex-start;gap:var(--space-3)}.help-dialog__item-body{display:flex;flex-direction:column;gap:var(--space-1);flex:1;min-width:0}.help-dialog__item-title{font-family:var(--font-display);font-weight:700;font-size:var(--text-sm)}.help-dialog__item-desc{font-size:var(--text-sm);color:var(--color-muted);line-height:1.4}.help-dialog__footer{padding-top:var(--space-4);display:flex;justify-content:center;gap:var(--space-3);position:relative}.help-dialog__footer:before{content:"";position:absolute;top:0;left:0;right:0;border-bottom:2px dashed var(--color-border)}.help-dialog__reset-btn{background:var(--color-surface);border:var(--border);border-radius:var(--radius);padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-text);cursor:pointer;min-height:44px;box-shadow:var(--shadow-sm);transition:all var(--transition)}.help-dialog__reset-btn:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-md)}.help-dialog__reset-btn:active{transform:translate(1px,1px);box-shadow:none}.help-dialog__ok-btn{background:var(--color-primary);color:#fff;border:var(--border-thick);border-radius:var(--radius);padding:var(--space-2) var(--space-6);font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;cursor:pointer;min-height:44px;box-shadow:var(--shadow-sm);transition:all var(--transition)}.help-dialog__ok-btn:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-md)}.help-dialog__ok-btn:active{transform:translate(1px,1px);box-shadow:none}.nudge-tip{position:fixed;top:calc(var(--space-3) + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);z-index:900;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-accent);color:var(--color-on-accent);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:var(--text-sm);max-width:calc(100% - var(--space-6));width:420px;cursor:pointer;animation:nudge-tip-in .3s ease-out}.nudge-tip--leaving{animation:nudge-tip-out .2s ease-in forwards}@keyframes nudge-tip-in{0%{opacity:0;transform:translate(-50%) translateY(-100%)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes nudge-tip-out{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-100%)}}.nudge-tip__icon{flex-shrink:0;display:flex;align-items:center;transform:scale(.55);transform-origin:center;margin:calc(var(--space-3) * -1)}.nudge-tip__message{flex:1;font-family:var(--font-display);font-weight:600;line-height:1.3}.nudge-tip__help-btn{flex-shrink:0;background:none;border:none;padding:var(--space-1) var(--space-2);font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;color:var(--color-on-accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px;white-space:nowrap}.nudge-tip__close-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;background:none;border:none;font-size:var(--text-lg);font-weight:700;color:color-mix(in srgb,var(--color-on-accent) 60%,transparent);cursor:pointer;border-radius:var(--radius);transition:color var(--transition);margin:calc(var(--space-2) * -1)}.nudge-tip__close-btn:hover{color:var(--color-on-accent)}.data-mgmt{max-width:440px}.data-mgmt__section{margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1.5px solid var(--color-border)}.data-mgmt__section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.data-mgmt__heading{font-family:var(--font-display);font-weight:700;font-size:var(--text-base);margin:0 0 var(--space-3) 0;display:flex;align-items:center;gap:var(--space-2)}.data-mgmt__count{font-size:var(--text-sm);font-weight:500;color:var(--color-muted);background:var(--color-bg);border:var(--border);border-radius:999px;padding:0 var(--space-2);min-width:24px;text-align:center}.data-mgmt__sub-heading{font-size:var(--text-sm);font-weight:600;color:var(--color-muted);margin:var(--space-3) 0 var(--space-2) 0;display:flex;align-items:center;gap:var(--space-2)}.data-mgmt__description{font-size:var(--text-sm);color:var(--color-muted);margin:0 0 var(--space-3) 0;line-height:1.5}.data-mgmt__search{width:100%;padding:var(--space-2) var(--space-3);border:var(--border);border-radius:var(--radius);font-size:var(--text-sm);margin-bottom:var(--space-3);background:var(--color-bg)}.data-mgmt__search:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-alpha)}.data-mgmt__list{max-height:240px;overflow-y:auto;margin-bottom:var(--space-3);border:var(--border);border-radius:var(--radius)}.data-mgmt__item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-bottom:1.5px solid var(--color-border)}.data-mgmt__item:last-child{border-bottom:none}.data-mgmt__item-name{flex:1;font-size:var(--text-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-mgmt__item-category{font-size:var(--text-xs);color:var(--color-muted);background:var(--color-bg);border:var(--border);border-radius:var(--radius);padding:1px var(--space-2);white-space:nowrap;flex-shrink:0}.data-mgmt__item-delete{background:none;border:none;cursor:pointer;padding:var(--space-1);color:var(--color-muted);display:flex;align-items:center;justify-content:center;min-width:28px;min-height:28px;border-radius:var(--radius);flex-shrink:0;transition:color var(--transition)}.data-mgmt__item-delete:hover{color:var(--color-danger)}.data-mgmt__empty{font-size:var(--text-sm);color:var(--color-muted);font-style:italic;margin:0 0 var(--space-3) 0}.data-mgmt__confirm-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);flex-wrap:wrap}.data-mgmt__version{font-size:var(--text-sm);color:var(--color-muted);margin:0 0 var(--space-3) 0;font-family:var(--font-mono)}.data-mgmt__section--danger{border:2px solid var(--color-danger);border-radius:var(--radius);padding:var(--space-4);margin-bottom:var(--space-5);box-shadow:var(--shadow-sm)}.data-mgmt__section--danger:last-child{margin-bottom:0}.data-mgmt__heading--danger{color:var(--color-danger)}.data-mgmt__delete-confirm{display:flex;flex-direction:column;gap:var(--space-3)}.data-mgmt__delete-label{font-size:var(--text-sm);color:var(--color-text)}.data-mgmt__delete-input{margin-bottom:0}.notif-settings{max-width:400px}.notif-settings__section{margin-bottom:var(--space-5);padding-bottom:var(--space-4);border-bottom:1.5px solid var(--color-border)}.notif-settings__section--last{margin-bottom:0;padding-bottom:0;border-bottom:none}.notif-settings__heading{font-family:var(--font-display);font-weight:700;font-size:var(--text-base);margin:0 0 var(--space-3) 0}.notif-settings__status-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg);border:var(--border);border-radius:var(--radius)}.notif-settings__status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:2px solid currentColor}.notif-settings__status-dot--active{background:var(--color-success);border-color:var(--color-success)}.notif-settings__status-dot--denied{background:var(--color-danger);border-color:var(--color-danger)}.notif-settings__status-dot--inactive{background:var(--color-muted);border-color:var(--color-muted)}.notif-settings__status-label{font-size:var(--text-sm);font-weight:500}.notif-settings__action{margin-top:var(--space-2)}.notif-settings__description{font-size:var(--text-sm);color:var(--color-muted);margin:0 0 var(--space-3) 0;line-height:1.5}.notif-settings__confirm-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);flex-wrap:wrap}.notif-settings__mute-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.notif-settings__mute-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--color-bg);border:var(--border);border-radius:var(--radius)}.notif-settings__mute-name{font-size:var(--text-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.notif-settings__button-row{display:flex;gap:var(--space-2);flex-wrap:wrap}.notif-settings__mute-toggle{display:flex;align-items:center;background:none;border:none;padding:var(--space-1);cursor:pointer;flex-shrink:0;border-radius:var(--radius)}.notif-settings__mute-toggle .toggle__track--on{background:var(--color-success)}.note-dialog__body{display:flex;flex-direction:column;gap:var(--space-2)}.note-dialog__textarea{width:100%;min-height:200px;padding:var(--space-3);font-family:var(--font-body);font-size:var(--text-base);line-height:1.5;border:var(--border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);resize:vertical;outline:none;transition:border-color var(--transition);box-sizing:border-box}.note-dialog__textarea:focus{border-color:var(--color-primary)}.note-dialog__textarea::placeholder{color:var(--color-muted)}.note-dialog__hint{font-size:var(--text-xs);color:var(--color-muted);text-align:right;margin:0}.app--initial,.app--initial *{animation-duration:0s!important;transition-duration:0s!important}.app__sticky{position:sticky;top:calc(-1*env(safe-area-inset-top,0px));z-index:50;background:var(--color-bg);border-bottom:2px solid transparent;transition:border-color var(--transition);padding:calc(var(--space-2) + env(safe-area-inset-top,0px)) 0 var(--space-3)}.scroll-locked .app__sticky{transform:translateY(var(--scroll-lock-offset, 0px))}.app__sticky-inner{max-width:960px;margin:0 auto;padding:0 var(--space-6)}@media(max-width:640px){.app__sticky-inner{padding:0 var(--space-3)}}.app__sticky--bordered{border-bottom-color:var(--color-border)}.app__sticky--scrolled{padding-bottom:var(--space-1)}.app__sticky--scrolled .header__collapsible{display:none}.app__offline-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--color-accent);color:var(--color-on-accent);font-family:var(--font-display);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-bottom:var(--border)}.app__list{display:flex;flex-direction:column;gap:var(--space-2);padding-bottom:88px}.app__empty{display:flex;justify-content:center;padding:var(--space-8) var(--space-4)}.app__empty-card{background:var(--color-surface);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:var(--space-6);width:100%;max-width:360px;text-align:center}.app__empty-heading{font-family:var(--font-display);font-weight:700;font-size:var(--text-2xl);color:var(--color-text);margin:0 0 var(--space-2)}.app__empty-text{font-family:var(--font-display);font-size:var(--text-sm);color:var(--color-muted);margin:0 0 var(--space-4)}.app__starter-chips{display:flex;flex-wrap:wrap;gap:var(--space-2);justify-content:center}.app__starter-chip{display:inline-flex;align-items:center;min-height:44px;padding:var(--space-2) var(--space-4);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;border:var(--border);border-radius:var(--radius);background:var(--color-surface);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition);color:var(--color-text)}.app__starter-chip:hover{box-shadow:var(--shadow-md);transform:translate(-1px,-1px);background:var(--color-accent);color:var(--color-on-accent)}.app__starter-chip:active{box-shadow:none;transform:translate(1px,1px)}.app__empty-footer{margin-top:var(--space-5);padding-top:var(--space-4);border-top:var(--border)}.app__empty-help{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;color:var(--color-muted);background:none;border:none;padding:var(--space-2) var(--space-4);min-height:44px;cursor:pointer;transition:color var(--transition)}.app__empty-help:hover{color:var(--color-text)}.app__clear-fab{position:fixed;bottom:calc(var(--space-6) + env(safe-area-inset-bottom,0px));right:var(--space-4);z-index:40;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);min-height:56px;background:var(--color-primary);color:#fff;border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-primary);cursor:pointer;font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;transition:transform var(--transition),box-shadow var(--transition)}.app__clear-fab:hover{box-shadow:var(--shadow-primary-lg);transform:translate(-2px,-2px)}.app__clear-fab:active{box-shadow:none;transform:translate(2px,2px)}.app__clear-fab:disabled{opacity:.4;pointer-events:none}.app__note-fab{position:fixed;bottom:calc(var(--space-6) + env(safe-area-inset-bottom,0px));left:var(--space-4);z-index:40;display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-accent);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-accent);cursor:pointer;color:var(--color-on-accent);transition:transform var(--transition),box-shadow var(--transition)}.app__note-fab--unread{animation:note-wobble 3s ease-in-out infinite}.app__note-fab:hover{box-shadow:var(--shadow-accent-lg);transform:translate(-2px,-2px)}.app__note-fab:active{box-shadow:none;transform:translate(2px,2px)}.app__note-fab-dot{position:absolute;top:-3px;right:-3px;width:10px;height:10px;background:var(--color-primary);border:2px solid var(--color-surface);border-radius:50%}.app__note-fab-dot--unread{width:14px;height:14px;top:-5px;right:-5px;background:var(--color-error, #e53e3e);border-width:2px}@keyframes note-wobble{0%,85%,to{transform:rotate(0)}88%{transform:rotate(-8deg)}91%{transform:rotate(8deg)}94%{transform:rotate(-6deg)}97%{transform:rotate(4deg)}}.app__clear-fab-count{font-family:var(--font-mono);font-size:var(--text-xs);background:var(--color-surface);color:var(--color-text);min-width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:99px;border:1.5px solid var(--color-text);padding:0 var(--space-1);font-weight:700}.app__checked-section{margin-top:var(--space-6)}.app__checked-toggle{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-3);color:var(--color-muted);font-size:var(--text-sm);font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:none;border:none;cursor:pointer;transition:color var(--transition)}.app__checked-toggle:hover{color:var(--color-text)}.app__checked-chevron{font-size:var(--text-xs);transition:transform var(--transition)}.app__checked-chevron--collapsed{transform:rotate(-90deg)}.app__checked-list{display:flex;flex-direction:column;gap:var(--space-2)}@media(prefers-reduced-motion:no-preference){.app__checked-list--clearing .app__checked-item-wrapper{animation:item-clear-sweep .25s ease-in forwards;animation-delay:calc(var(--clear-index) * 40ms)}}@keyframes item-clear-sweep{0%{transform:translate(0) scale(1) rotate(0);opacity:1;box-shadow:var(--shadow-sm)}to{transform:translate(80px) scale(.9) rotate(4deg);opacity:0;box-shadow:none}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-4);background:var(--color-bg)}.error-boundary__card{text-align:center;padding:var(--space-6);background:var(--color-surface);border:var(--border-thick);border-radius:var(--radius);box-shadow:var(--shadow-md);max-width:400px}.error-boundary__title{font-size:1.5rem;margin:0 0 var(--space-3);color:var(--color-text)}.error-boundary__message{margin:0 0 var(--space-4);color:var(--color-muted)}.error-boundary__button{padding:var(--space-2) var(--space-4);font-size:1rem;font-weight:700;background:var(--color-primary);color:#fff;border:var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;transition:var(--transition)}.error-boundary__button:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-md)}.error-boundary__button:active{transform:translate(1px,1px);box-shadow:none}
