:root{--bg:#f5f4f1;--surface:#fff;--surface-2:#efede9;--sidebar-bg:#1e1b18;--sidebar-text:#a8a39c;--sidebar-text-hover:#d6d1ca;--sidebar-text-active:#f5f4f1;--sidebar-item-active:#e85d262e;--sidebar-border:#ffffff12;--text:#1a1714;--text-2:#6b6560;--text-muted:#9e9890;--control-idle:#7e7770;--control-danger-idle:#8d746e;--accent:#e85d26;--accent-hover:#d04e1a;--accent-dim:#e85d261a;--accent-dim-2:#e85d262e;--danger:#ef4444;--danger-dim:#ef44441a;--border:#e8e5e0;--border-strong:#d4d0c9;--shadow-sm:0 1px 3px #00000012, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 4px #0000000a;--font-display:"Cormorant Garamond", Georgia, serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--t:.15s cubic-bezier(.4, 0, .2, 1);--r-sm:5px;--r:8px;--r-lg:12px;--r-xl:18px;--r-full:9999px;--topbar-bg:#1e1b18;--topbar-text:#ffffffeb;--topbar-text-muted:#ffffff73;--topbar-border:#ffffff14;--topbar-btn-hover:#ffffff17;--topbar-menu-bg:#2a2622;--topbar-menu-border:#ffffff1a;--topbar-menu-hover:#ffffff12;--topbar-menu-danger:#ef444426}*,:before,:after{box-sizing:border-box}html{max-width:100vw;overflow-x:hidden}button,input,textarea{-webkit-tap-highlight-color:transparent;touch-action:manipulation}body{background:var(--bg);max-width:100vw;color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;margin:0;font-size:14px;line-height:1.6;overflow-x:hidden}.app-root{height:100dvh;height:-webkit-fill-available;display:flex}.app-content{background:var(--bg);flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.app-main{padding:32px 44px;padding-bottom:max(80px, env(safe-area-inset-bottom,80px));-webkit-overflow-scrolling:touch;flex:1;width:100%;max-width:700px;scroll-padding-bottom:80px;overflow-y:auto}.mobile-topbar,.topbar-actions{display:none}.list-actions-desktop{display:contents}.sidebar{background:var(--sidebar-bg);border-right:none;flex-direction:column;flex-shrink:0;width:248px;height:100dvh;display:flex}.sidebar-brand{font-family:var(--font-display);letter-spacing:-.01em;color:var(--sidebar-text-active);-webkit-user-select:none;user-select:none;padding:24px 20px 8px;font-size:20px;font-weight:700}.sidebar-section-label{letter-spacing:.12em;text-transform:uppercase;color:#ffffff40;margin-bottom:2px;padding:10px 20px 6px;font-size:10px}.sidebar-section-label--compact{margin:0;padding:0;line-height:1}.sidebar-list{flex:1;padding:2px 10px;overflow-y:auto}.sidebar-list-tools{justify-content:space-between;align-items:center;gap:10px;padding:12px 10px 7px 20px;display:flex}.sidebar-sort{flex:0 148px;position:relative}.sidebar-sort:after{content:"";pointer-events:none;border-bottom:1.5px solid #ffffff61;border-right:1.5px solid #ffffff61;width:6px;height:6px;position:absolute;top:50%;right:9px;transform:translateY(-65%)rotate(45deg)}.sidebar-sort-select{appearance:none;border-radius:var(--r-sm);width:100%;height:28px;color:var(--sidebar-text-hover);font-family:var(--font-body);cursor:pointer;transition:color var(--t), border-color var(--t), background var(--t);background:#ffffff0b;border:1px solid #ffffff17;outline:none;padding:0 24px 0 9px;font-size:12px;font-weight:500;line-height:1}.sidebar-sort-select:hover{color:var(--sidebar-text-active);background:#fff1;border-color:#ffffff29}.sidebar-sort-select:focus{background:#e85d261a;border-color:#e85d26a6}.sidebar-sort-select option{color:var(--text);background:var(--surface)}.sidebar-item{text-align:left;border-radius:var(--r);width:100%;color:var(--sidebar-text);cursor:pointer;font-size:13.5px;font-family:var(--font-body);transition:color var(--t), background var(--t);white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;align-items:center;gap:8px;margin-bottom:1px;padding:9px 12px;font-weight:400;display:flex;overflow:hidden}.sidebar-item:hover{color:var(--sidebar-text-hover);background:#ffffff0f}.sidebar-item.active{color:var(--sidebar-text-active);background:var(--sidebar-item-active);font-weight:500}.sidebar-invites{border-bottom:1px solid var(--sidebar-border);margin-bottom:4px;padding:4px 10px 8px}.invite-row{padding:6px 4px}.invite-info{flex-direction:column;gap:1px;margin-bottom:6px;display:flex}.invite-name{color:var(--sidebar-text-active);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.invite-owner{color:var(--sidebar-text);font-size:11px}.invite-actions{gap:6px;display:flex}.invite-btn{border-radius:var(--r-sm);cursor:pointer;font-size:12px;font-family:var(--font-body);transition:opacity var(--t);color:var(--sidebar-text);background:0 0;border:1px solid #ffffff26;padding:5px 12px}.invite-btn:hover{opacity:.75}.invite-btn--accept{color:var(--accent);background:#e85d2614;border-color:#e85d2666}.invite-btn--decline{color:var(--sidebar-text)}.sidebar-shared-badge{color:#ffffff40;flex-shrink:0;margin-left:auto;font-size:10px}.sidebar-new{border-top:1px solid var(--sidebar-border);padding:10px}.sidebar-new-input{border-radius:var(--r-sm);width:100%;font-size:13px;font-family:var(--font-body);color:var(--sidebar-text-active);transition:border-color var(--t);background:#ffffff12;border:1px solid #ffffff1a;outline:none;padding:8px 12px}.sidebar-new-input:focus{border-color:#e85d2680}.sidebar-new-input::placeholder{color:#ffffff40}.sidebar-new-btn{width:100%;color:var(--sidebar-text);font-size:13px;font-family:var(--font-body);cursor:pointer;text-align:left;border-radius:var(--r-sm);transition:color var(--t), background var(--t);background:0 0;border:none;padding:9px 12px}.sidebar-new-btn:hover{color:var(--sidebar-text-active);background:#ffffff0f}.sidebar-footer{padding:10px 10px 16px;padding-bottom:max(16px, env(safe-area-inset-bottom,16px));border-top:1px solid var(--sidebar-border);flex-direction:column;gap:1px;display:flex}.sidebar-footer-btn{text-align:left;cursor:pointer;font-size:12.5px;font-family:var(--font-body);color:var(--sidebar-text);border-radius:var(--r-sm);transition:color var(--t), background var(--t);background:0 0;border:none;padding:7px 12px}.sidebar-footer-btn:hover{color:var(--sidebar-text-hover);background:#ffffff0f}.sidebar-new-form{flex-direction:column;gap:6px;display:flex}.list-type-toggle{gap:4px;display:flex}.list-type-btn{font-size:12px;font-family:var(--font-body);border-radius:var(--r-sm);color:var(--sidebar-text);cursor:pointer;transition:all var(--t);background:0 0;border:1px solid #ffffff1f;flex:1;padding:6px 8px}.list-type-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.sidebar-shopping-badge{opacity:.8;flex-shrink:0;margin-left:2px;font-size:13px}.list-header{z-index:20;background:var(--bg);border-bottom:1px solid var(--border);align-items:center;gap:10px;margin:-32px -44px 28px;padding:12px 44px;display:flex;position:sticky;top:0}.list-title-wrap{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.list-title{min-width:0;font-family:var(--font-display);letter-spacing:-.02em;cursor:text;color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:32px;font-weight:600;line-height:1.15;overflow:hidden}.list-title-edit{border:1px solid var(--border-strong);border-radius:var(--r-sm);cursor:pointer;width:30px;height:30px;color:var(--text-muted);transition:color var(--t), border-color var(--t), background var(--t);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;line-height:1;display:inline-flex}.list-title-edit:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.list-title-input{font-family:var(--font-display);border:none;border-bottom:2px solid var(--accent);color:var(--text);letter-spacing:-.02em;background:0 0;outline:none;flex:1;padding:0;font-size:32px;font-weight:600}.list-header-btn{border:1px solid var(--border-strong);border-radius:var(--r-sm);cursor:pointer;font-size:12px;font-family:var(--font-body);color:var(--text-muted);transition:color var(--t), border-color var(--t), background var(--t);background:0 0;flex-shrink:0;padding:5px 12px;font-weight:500}.list-header-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.list-header-undo{flex-shrink:0;gap:2px;display:flex}.list-header-undo-btn{border:1px solid var(--border-strong);border-radius:var(--r-sm);cursor:pointer;color:var(--text-muted);transition:color var(--t), border-color var(--t), background var(--t);background:0 0;padding:5px 9px;font-size:14px;line-height:1}.list-header-undo-btn:hover:not(:disabled){color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.list-header-undo-btn:disabled{opacity:.3;cursor:default}.list-header-confirm-text{color:var(--text-2);white-space:nowrap;font-size:13px}.list-header-btn--danger{color:var(--danger);border-color:var(--danger)}.list-header-btn--danger:hover{background:var(--danger-dim);color:var(--danger);border-color:var(--danger)}.list-header-delete{cursor:pointer;color:var(--border-strong);border-radius:var(--r-sm);transition:color var(--t), background var(--t);background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:22px;line-height:1}.list-header-delete:hover{color:var(--danger);background:var(--danger-dim)}.item-row{transition:opacity var(--t);border-radius:var(--r-sm);outline:none;flex-wrap:wrap;align-items:center;gap:10px;padding:4px 0;display:flex}.item-row.is-dragging{opacity:.4}.item-row.is-done{opacity:.55}.drag-handle{cursor:grab;color:var(--border-strong);touch-action:none;opacity:0;transition:opacity var(--t);background:0 0;border:none;flex-shrink:0;width:14px;padding:0;font-size:12px;line-height:1}.drag-handle:active{cursor:grabbing}.item-row:hover .drag-handle{opacity:1}.item-checkbox{appearance:none;border:1.5px solid var(--control-idle);cursor:pointer;width:18px;height:18px;transition:background var(--t), border-color var(--t), transform 80ms ease;background:0 0;border-radius:50%;flex-shrink:0;margin:0;position:relative}.item-checkbox:hover{border-color:var(--accent);transform:scale(1.08)}.item-checkbox:checked{background:var(--accent);border-color:var(--accent)}.item-checkbox:checked:after{content:"";border:2px solid #fff;border-top:none;border-left:none;width:5px;height:9px;position:absolute;top:1.5px;left:4px;transform:rotate(45deg)}.item-text{font-size:14.5px;font-family:var(--font-body);letter-spacing:0;word-break:break-word;cursor:pointer;color:var(--text);flex:1;line-height:1.55}.item-text.done{color:var(--text-muted);text-decoration:line-through;-webkit-text-decoration-color:var(--border-strong);text-decoration-color:var(--border-strong)}.item-text:hover{color:var(--accent)}.item-edit-input{border:none;border-bottom:1.5px solid var(--accent);font-size:14.5px;font-family:var(--font-body);color:var(--text);background:0 0;outline:none;flex:1;padding:0}.item-row-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.item-more-btn,.item-delete-btn{cursor:pointer;border-radius:var(--r-sm);width:30px;height:30px;transition:color var(--t), background var(--t), opacity var(--t);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;line-height:1;display:inline-flex}.item-more-btn{color:var(--control-idle);visibility:hidden;font-size:18px}.item-more-btn:hover{color:var(--accent);background:var(--accent-dim)}.item-delete-btn{color:var(--control-danger-idle);visibility:hidden;font-size:18px}.item-delete-btn:hover{color:var(--danger);background:var(--danger-dim)}.item-row:hover .item-more-btn,.item-row.is-menu-open .item-more-btn,.item-row:hover .item-delete-btn{visibility:visible}.item-row.is-menu-open{background:var(--accent-dim)}.item-menu{flex-wrap:wrap;flex-basis:100%;gap:6px;padding:4px 0 4px 28px;display:flex}.item-action-btn{border:1px solid var(--border-strong);border-radius:var(--r-sm);font-size:12px;font-family:var(--font-body);color:var(--text-2);cursor:pointer;transition:color var(--t), border-color var(--t), background var(--t);background:0 0;padding:6px 14px;font-weight:500}.item-action-btn:active{opacity:.7}.item-action-btn--add{color:var(--accent);border-color:var(--accent)}.item-action-btn--add:hover{background:var(--accent-dim)}.add-gap{align-items:center;height:8px;display:flex;position:relative}.add-gap:after{content:"";background:var(--accent);opacity:0;height:1px;transition:opacity var(--t);position:absolute;top:50%;left:28px;right:0}.add-gap:hover:after{opacity:.3}.add-gap-btn{background:var(--accent);color:#fff;cursor:pointer;text-align:center;opacity:0;width:20px;height:20px;transition:opacity var(--t);z-index:1;border:none;border-radius:50%;flex-shrink:0;padding:0;font-size:14px;line-height:20px;position:absolute;left:0}.add-gap:hover .add-gap-btn{opacity:1}.add-input-row{align-items:center;gap:10px;padding:6px 0;display:flex}.add-input-bullet{color:var(--accent);flex-shrink:0;font-size:18px;line-height:1}.add-input-field{border:none;border-bottom:1.5px solid var(--border-strong);font-size:14.5px;font-family:var(--font-body);color:var(--text);transition:border-color var(--t);background:0 0;outline:none;flex:1;padding:2px 0}.add-input-field:focus{border-bottom-color:var(--accent)}.add-input-field::placeholder{color:var(--text-muted)}.add-input-scan-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px 4px;font-size:16px;line-height:1}.add-input-scan-btn:hover{color:var(--text)}.add-input-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px 6px;font-size:20px;line-height:1}.add-input-close-btn:hover{color:var(--text)}.login-page{background:var(--bg);justify-content:center;align-items:center;height:100vh;display:flex}.login-card{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);width:360px;max-width:calc(100vw - 32px);box-shadow:var(--shadow-md);padding:48px 44px 44px}.login-title{font-family:var(--font-display);letter-spacing:-.02em;color:var(--text);margin:0 0 4px;font-size:36px;font-weight:700}.login-subtitle{color:var(--text-muted);font-size:13px;font-family:var(--font-body);margin:0 0 32px}.login-label{margin-bottom:20px;display:block}.login-label-text{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:500;display:block}.login-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);width:100%;font-size:15px;font-family:var(--font-body);color:var(--text);transition:border-color var(--t);outline:none;padding:10px 12px;display:block}.login-input:focus{border-color:var(--accent);background:var(--surface)}.login-error{color:var(--danger);margin:0 0 16px;font-size:13px}.login-btn{background:var(--accent);color:#fff;border-radius:var(--r);width:100%;font-size:14px;font-family:var(--font-body);letter-spacing:.02em;cursor:pointer;transition:background var(--t), opacity var(--t);border:none;margin-top:8px;padding:13px 0;font-weight:600}.login-btn:disabled{opacity:.55;cursor:default}.login-btn:not(:disabled):hover{background:var(--accent-hover)}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#14120f8c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);width:440px;max-width:90vw;max-height:82vh;box-shadow:var(--shadow-md);padding:28px 32px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-family:var(--font-display);color:var(--text);margin:0;font-size:20px;font-weight:600}.modal-title em{color:var(--accent);font-style:italic}.modal-close{cursor:pointer;color:var(--text-muted);border-radius:var(--r-sm);transition:color var(--t), background var(--t);background:0 0;border:none;padding:4px;font-size:22px;line-height:1}.modal-close:hover{color:var(--text);background:var(--surface-2)}.modal-empty{color:var(--text-muted);margin:0 0 16px;font-size:13px;font-style:italic}.share-owner-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;margin-bottom:8px;padding:10px 0;display:flex}.share-owner-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;font-size:12px}.share-owner-name{color:var(--text);font-size:14px;font-weight:500}.share-list{margin:0 0 16px;padding:0;list-style:none}.share-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.share-user-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.share-username{font-size:14px;font-family:var(--font-body);color:var(--text);font-weight:500}.share-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.share-status-pending{color:var(--text-muted);margin-left:auto;margin-right:8px;font-size:11px}.share-remove-btn{color:var(--danger);cursor:pointer;font-size:12px;font-family:var(--font-body);border-radius:var(--r-sm);transition:background var(--t);background:0 0;border:none;padding:4px 8px;font-weight:500}.share-remove-btn:hover{background:var(--danger-dim)}.modal-input-row{gap:8px;display:flex}.modal-input{border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface-2);font-family:var(--font-body);color:var(--text);transition:border-color var(--t);outline:none;flex:1;padding:9px 12px;font-size:14px}.modal-input:focus{border-color:var(--accent);background:var(--surface)}.modal-submit-btn{background:var(--accent);color:#fff;border-radius:var(--r-sm);font-family:var(--font-body);cursor:pointer;transition:background var(--t);border:none;padding:9px 18px;font-size:13px;font-weight:600}.modal-submit-btn:hover{background:var(--accent-hover)}.modal-error{color:var(--danger);margin:6px 0 0;font-size:12px}.admin-panel{width:580px}.admin-table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--font-body);margin-bottom:24px}.admin-table thead tr{border-bottom:2px solid var(--border-strong)}.admin-table th{text-align:left;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);padding:6px 8px;font-size:11px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border);color:var(--text);padding:9px 8px}.admin-table-actions{text-align:right}.admin-email-cell{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:12px;overflow:hidden}.admin-inline-group{align-items:center;gap:4px;display:inline-flex}.admin-inline-input{font-size:12px;font-family:var(--font-body);border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface-2);color:var(--text);outline:none;padding:5px 8px}.admin-inline-input:focus{border-color:var(--accent)}.admin-btn{font-size:12px;font-family:var(--font-body);border:1px solid var(--border-strong);border-radius:var(--r-sm);background:var(--surface);color:var(--text);cursor:pointer;transition:border-color var(--t), color var(--t), background var(--t);padding:5px 12px;font-weight:500}.admin-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.admin-btn--cancel{color:var(--text-muted)}.admin-btn--danger{color:var(--danger);border-color:var(--border)}.admin-btn--danger:hover{background:var(--danger-dim);border-color:var(--danger);color:var(--danger)}.admin-section-title{font-family:var(--font-display);color:var(--text);margin:0 0 12px;font-size:16px;font-weight:600}.admin-create-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-create-row .modal-input{flex:1;min-width:120px}.admin-checkbox-label{font-size:13px;font-family:var(--font-body);color:var(--text);white-space:nowrap;align-items:center;gap:6px;display:flex}.list-document{flex-direction:column;display:flex}.items-section{position:relative}.section-title-row{padding:4px 0 2px}.section-title{color:var(--text-muted);cursor:text;font-size:16px;font-weight:600;font-family:var(--font-body);margin:0}.section-title-input{border:none;border-bottom:1.5px solid var(--accent);width:100%;color:var(--text);font-size:13px;font-weight:600;font-family:var(--font-body);background:0 0;outline:none;padding:2px 0}.text-section{margin:8px 0;position:relative}.section-menu-row{align-items:center;gap:6px;min-height:24px;margin-bottom:4px;display:flex}.section-menu-toggle{background:var(--surface-2);border:1px solid var(--border);cursor:pointer;color:var(--text-2);letter-spacing:2px;border-radius:var(--r-sm);transition:color var(--t), background var(--t), border-color var(--t);flex-shrink:0;padding:3px 8px;font-size:14px;line-height:1}.section-menu-toggle:hover,.section-menu-toggle.is-open{color:var(--text-1);background:var(--surface-3);border-color:var(--border-strong)}.section-menu-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.text-section-input{width:100%;font-size:16px;font-family:var(--font-display);color:var(--text);resize:none;letter-spacing:-.01em;transition:border-color var(--t);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;padding:4px 0;font-weight:600;line-height:1.5;overflow:visible}.text-section-input:focus{border-color:var(--accent)}.text-section-input::placeholder{color:var(--text-muted);font-weight:400;font-family:var(--font-body);font-size:14px}.text-section-actions{align-items:center;gap:6px;margin-top:4px;display:flex}.section-action-btn{border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;font-size:11px;font-family:var(--font-body);color:var(--text-muted);transition:color var(--t), border-color var(--t), background var(--t);background:0 0;padding:3px 10px;font-weight:500}.section-action-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.section-action-btn--delete:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-dim)}.section-gap{opacity:.35;transition:opacity var(--t);align-items:center;gap:8px;padding:10px 0;display:flex}.section-gap:hover,.section-gap:focus-within,.section-gap:active{opacity:1}.section-gap-line{background:var(--border-strong);pointer-events:none;flex:1;height:1px}.section-gap-icon{width:22px;height:22px;color:var(--text-muted);font-size:12px;font-family:var(--font-body);cursor:pointer;transition:color var(--t), border-color var(--t), background var(--t);background:0 0;border:1px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;line-height:1;display:inline-flex}.section-gap-icon:hover,.section-gap-icon:focus-visible{color:var(--accent);border-color:var(--accent);background:var(--accent-dim);outline:none}.undo-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;padding:10px 14px;font-size:13px;display:flex}.undo-bar-text{color:var(--text-2);font-weight:500}.undo-bar-btn{border:1px solid var(--border-strong);border-radius:var(--r-sm);color:var(--text);cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font-body);transition:border-color var(--t), color var(--t), background var(--t);background:0 0;padding:4px 12px}.undo-bar-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.mode-bar{padding:10px 44px;padding-bottom:max(10px, env(safe-area-inset-bottom,10px));background:var(--bg);z-index:10;border-top:1px solid var(--border);gap:6px;display:flex;position:fixed;bottom:0;left:248px;right:0}.mode-bar-btn{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);color:var(--text-muted);cursor:pointer;font-family:var(--font-body);transition:color var(--t), border-color var(--t), background var(--t);flex:1;padding:9px 12px;font-size:13px;font-weight:500}.mode-bar-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.mode-bar-btn--current{color:var(--text);border-color:var(--border-strong);background:var(--surface);box-shadow:var(--shadow-sm)}.mode-bar-btn--highlight{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);animation:1.5s ease-in-out 2 mode-bar-pulse}.mode-bar-btn--active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}@keyframes mode-bar-pulse{0%,to{opacity:1}50%{opacity:.5}}.add-item-visible-btn{width:100%;color:var(--control-idle);font-size:14px;font-family:var(--font-body);cursor:pointer;text-align:left;transition:color var(--t), border-color var(--t);background:0 0;border:none;align-items:center;gap:8px;margin-top:4px;padding:10px 0;display:flex}.add-item-visible-btn:hover{color:var(--accent);border-color:var(--accent)}.add-item-visible-icon{border:1.5px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:15px;line-height:1;display:flex}@media (width<=640px){.add-item-visible-btn{border-top-width:1.5px;padding:14px 0;font-size:16px}.add-item-visible-icon{width:26px;height:26px;font-size:18px}}.empty-state{text-align:center;color:var(--text-muted);padding:64px 0}.empty-state p{margin:0 0 4px;font-size:14px;line-height:1.6}.import-toast{background:var(--text);color:var(--bg);font-family:var(--font-body);border-radius:var(--r-full);pointer-events:none;box-shadow:var(--shadow-md);padding:10px 22px;font-size:13px;font-weight:500;animation:.15s toast-in;position:fixed;bottom:32px;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@media (hover:none){.item-more-btn{visibility:visible;opacity:.5}.item-delete-btn{visibility:visible;opacity:.3}.drag-handle{opacity:.55;touch-action:none;padding:4px 5px;font-size:16px}.add-gap{height:10px}.add-gap-btn{display:none}}@media (width<=900px){.sidebar{width:216px}.mode-bar{padding:10px 28px;left:216px}.app-main{padding:24px 28px;padding-bottom:max(80px, env(safe-area-inset-bottom,80px))}.list-title,.list-title-input{font-size:28px}}@media (width<=640px){.sidebar{width:82vw;max-width:310px;height:100dvh;z-index:200;height:-webkit-fill-available;box-shadow:none;padding-top:env(safe-area-inset-top,0px);transition:transform .22s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.is-open{transform:translate(0);box-shadow:6px 0 32px #00000040}.sidebar-backdrop{z-index:199;background:#14120f80;position:fixed;inset:0}.sidebar-item{padding:12px 16px;font-size:15px}.sidebar-new-btn{padding:10px 12px;font-size:15px}.sidebar-footer-btn{padding:9px 12px;font-size:14px}.mobile-topbar{padding:0 12px 0 16px;padding-top:env(safe-area-inset-top,0px);height:calc(52px + env(safe-area-inset-top,0px));background:var(--topbar-bg);box-shadow:0 1px 0 var(--topbar-border);flex-shrink:0;align-items:center;gap:8px;display:flex}.mobile-menu-btn{cursor:pointer;width:40px;height:40px;color:var(--topbar-text-muted);border-radius:var(--r-sm);transition:color var(--t), background var(--t);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:22px;line-height:1;display:flex}.mobile-menu-btn:active{background:var(--topbar-btn-hover);color:var(--topbar-text)}.mobile-topbar-title{font-family:var(--font-body);color:var(--topbar-text);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:16px;font-weight:600;overflow:hidden}.mobile-topbar-title-input{border:1px solid var(--topbar-menu-border);border-radius:var(--r-sm);min-width:0;height:34px;color:var(--topbar-text);font-family:var(--font-body);background:#ffffff14;outline:none;flex:1;padding:0 10px;font-size:16px;font-weight:600}.mobile-title-edit{width:32px;height:36px;font-size:15px}.mobile-paste-btn{border-radius:var(--r-sm);color:#ffffffbf;font-size:12px;font-family:var(--font-body);cursor:pointer;transition:background var(--t);background:#ffffff1a;border:1px solid #ffffff26;flex-shrink:0;padding:6px 12px;font-weight:500}.mobile-paste-btn:active{background:#ffffff2e}.paste-btn-desktop{display:none}.topbar-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.list-actions-desktop{display:none}.topbar-icon-btn{cursor:pointer;width:36px;height:36px;color:var(--topbar-text-muted);border-radius:var(--r-sm);transition:color var(--t), background var(--t);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:17px;display:flex}.topbar-icon-btn:disabled{opacity:.25;cursor:default}.topbar-icon-btn:not(:disabled):active{background:var(--topbar-btn-hover);color:var(--topbar-text)}.topbar-overflow-btn{letter-spacing:1px;font-size:20px}.topbar-menu-wrap{position:relative}.topbar-menu{background:var(--topbar-menu-bg);border:1px solid var(--topbar-menu-border);border-radius:var(--r);z-index:200;min-width:190px;padding:4px 0;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #00000059}.topbar-menu-item{width:100%;font-family:var(--font-body);color:var(--topbar-text);cursor:pointer;text-align:left;transition:background var(--t);background:0 0;border:none;align-items:center;gap:8px;padding:11px 16px;font-size:14px;display:flex}.topbar-menu-item:active{background:var(--topbar-menu-hover)}.topbar-menu-item--danger{color:var(--danger)}.topbar-menu-item--danger:active{background:var(--topbar-menu-danger)}.topbar-menu-divider{background:var(--topbar-menu-border);height:1px;margin:4px 0}.topbar-menu-confirm{color:var(--topbar-text-muted);padding:10px 16px 6px;font-size:12px;line-height:1.4;display:block}.app-main{padding:16px;padding-bottom:max(90px, calc(56px + env(safe-area-inset-bottom,0px) + var(--keyboard-inset,0px)));max-width:100%;scroll-padding-bottom:max(120px, calc(80px + var(--keyboard-inset,0px)))}.mode-bar{padding:8px 16px;padding-bottom:max(8px, env(safe-area-inset-bottom,8px));left:0}.list-header{display:none}.list-header-btn{padding:6px 10px;font-size:11px}.item-row{gap:1px;padding:5px 0}.item-checkbox{width:22px;height:22px}.item-checkbox:checked:after{width:7px;height:11px;top:2px;left:5px}.item-text{font-size:16px}.item-row-actions{gap:8px;margin-left:4px}.item-more-btn{visibility:visible;opacity:.72;width:38px;height:38px;font-size:22px}.item-delete-btn{visibility:visible;opacity:.55;width:38px;height:38px;font-size:22px}.add-gap{height:14px}.add-gap-btn{display:none}.add-input-field{padding:6px 0;font-size:16px}.add-input-bullet{font-size:20px}.section-gap{opacity:.15;padding:12px 0}.section-gap-line{background:var(--control-idle)}.section-gap-icon{width:34px;height:34px;color:var(--control-idle);font-size:15px;font-weight:500}.text-section{scroll-margin-bottom:max(160px, calc(96px + var(--keyboard-inset,0px)))}.text-section-input{scroll-margin-bottom:max(180px, calc(120px + var(--keyboard-inset,0px)))}input,textarea,select{font-size:16px!important}.modal-panel{border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:100%;max-height:88dvh;padding:24px 20px;padding-bottom:max(24px, env(safe-area-inset-bottom,24px));border-bottom:none;margin:auto 0 0}.modal-overlay{align-items:flex-end}.admin-panel{width:100%}.login-card{border-radius:var(--r-lg);width:100%;max-width:400px;box-shadow:none;background:0 0;border:none;padding:40px 28px}.mode-bar{position:fixed}}.shopping-list{padding:0}.shopping-add-wrap{border-bottom:1px solid var(--border);padding:12px 16px 14px;position:relative}.shopping-add-input{width:100%;font-size:14px;font-family:var(--font-body);color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);box-sizing:border-box;transition:border-color var(--t);outline:none;padding:9px 12px}.shopping-add-input:focus{border-color:var(--accent)}.shopping-add-row{align-items:stretch;gap:6px;display:flex}.shopping-add-row .shopping-add-input{flex:1}.shopping-add-btn{border:1px solid var(--accent);background:var(--accent);color:#fff;border-radius:var(--r-sm);cursor:pointer;width:42px;transition:background var(--t);flex-shrink:0;justify-content:center;align-items:center;font-size:22px;font-weight:300;display:flex}.shopping-add-btn:disabled{opacity:.35;cursor:default}.shopping-add-btn:not(:disabled):hover{background:var(--accent-hover)}.scan-btn{border:1px solid var(--border);border-radius:var(--r-sm);width:42px;color:var(--text-muted);cursor:pointer;transition:color var(--t), border-color var(--t), background var(--t);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.scan-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.scan-status{color:var(--accent);font-size:12px;font-family:var(--font-body);border-bottom:1px solid var(--border);padding:6px 16px}.dup-warning{color:#c8760a;font-size:12px;font-family:var(--font-body);background:#c8760a14;border-bottom:1px solid #c8760a33;padding:8px 16px}.skaupat-order-bar{border-bottom:1px solid var(--border);padding:8px 16px}.csv-export-btn{border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-family:var(--font-body);cursor:pointer;transition:border-color var(--t), color var(--t);background:0 0;width:100%;padding:6px 14px;font-size:13px}.csv-export-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.csv-export-btn:disabled{opacity:.4;cursor:default}.scanner-overlay{z-index:100;background:#000000e0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.scanner-panel{border-radius:var(--r-sm);background:#000;width:min(380px,100vw);position:relative;overflow:hidden}.scanner-close{z-index:10;color:#fff;cursor:pointer;background:#00000080;border:1px solid #ffffff40;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex;position:absolute;top:10px;right:10px}.scanner-viewport{aspect-ratio:4/3;background:#111;width:100%;position:relative;overflow:hidden}.scanner-video{object-fit:cover;width:100%;height:100%}.scanner-crosshair{pointer-events:none;border:2px solid #ffffffb3;position:absolute;inset:20%;box-shadow:0 0 0 9999px #00000059}.scanner-hint{color:#fffc;font-size:13px;font-family:var(--font-body);text-align:center;margin:0;padding:12px 16px}.scanner-error{color:#fffc;font-size:13px;font-family:var(--font-body);text-align:center;padding:24px 20px;line-height:1.6}.product-dropdown{background:var(--surface);border:1px solid var(--border-strong);border-radius:0 0 var(--r-sm) var(--r-sm);z-index:20;max-height:240px;box-shadow:var(--shadow-md);border-top:none;position:absolute;top:100%;left:16px;right:16px;overflow-y:auto}.product-option{text-align:left;width:100%;font-size:13px;font-family:var(--font-body);color:var(--text);border:none;border-bottom:1px solid var(--border);cursor:pointer;background:0 0;padding:9px 14px;display:block}.product-option:last-child{border-bottom:none}.product-option:hover{background:var(--surface-2)}.shopping-item-row{border-bottom:1px solid var(--border);transition:opacity var(--t);align-items:center;gap:10px;padding:11px 16px;display:flex}.shopping-item-row.is-done{opacity:.42}.shopping-item-row.is-dragging{opacity:.5;background:var(--surface-2);z-index:10}.shopping-item-text{font-size:14px;font-family:var(--font-body);color:var(--text);flex:1}.shopping-item-text.done{color:var(--text-muted);text-decoration:line-through}.item-ean{color:var(--text-muted);font-size:10px;font-family:var(--font-mono);letter-spacing:.04em;margin-top:1px;display:block}.quantity-control{flex-shrink:0;align-items:center;gap:2px;display:flex}.qty-btn{border:1px solid var(--border-strong);border-radius:var(--r-sm);cursor:pointer;width:28px;height:28px;color:var(--text);font-size:16px;font-family:var(--font-body);transition:border-color var(--t), color var(--t);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.qty-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.qty-btn:disabled{opacity:.25;cursor:default}.qty-value{text-align:center;min-width:28px;font-size:14px;font-family:var(--font-body);color:var(--text);font-weight:500}.shopping-done-divider{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:10px;font-family:var(--font-body);padding:6px 16px;font-weight:600}.shopping-empty{color:var(--text-muted);text-align:center;padding:28px 16px;font-size:13px}
