@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg:#111009;--surface:#fff6ea0f;--surface-2:#fff6ea1a;--surface-hover:#fff6ea14;--border:#fff6ea1a;--border-mid:#fff6ea12;--text:#f2ede8;--text-2:#8c8078;--text-3:#4e4743;--accent:#c4704f;--accent-2:#d4845f;--accent-dim:#c4704f2e;--accent-ring:#c4704f4d;--sage:#7aa87f;--sage-dim:#7aa87f26;--radius:14px;--radius-sm:10px;--radius-xs:7px;--shadow:0 8px 32px #00000059, 0 2px 8px #0003;--shadow-sm:0 2px 8px #00000040;--glass-shine:inset 0 1px 0 #fff6ea14;--font-ui:"Inter", system-ui, -apple-system, sans-serif;--header-h:64px}html[data-theme=light]{--bg:#fdfaf5;--surface:#f3ede299;--surface-2:#ede5d88c;--surface-hover:#ede5d866;--border:#d2c6b680;--border-mid:#d2c6b64d;--text:#1c1917;--text-2:#78706c;--text-3:#b0a49e;--accent:#c4704f;--accent-2:#d4845f;--accent-dim:#c4704f1a;--accent-ring:#c4704f33;--sage:#6b8f71;--sage-dim:#6b8f711f;--shadow:0 4px 24px #1c19170f, 0 1px 4px #1c19170a;--shadow-sm:0 1px 4px #1c19170d;--glass-shine:inset 0 1px 0 #ffffff80}html[data-theme=light] body:before{background:radial-gradient(55% 45% at 15% 10%,#c4704f12 0%,#0000 65%),radial-gradient(45% 55% at 85% 85%,#6b8f710d 0%,#0000 60%),radial-gradient(35% 40% at 70% 20%,#c4704f0a 0%,#0000 55%)}html[data-theme=light] .app-header,html[data-theme=light] .app-nav{background:#fdfaf5b3}html[data-theme=light] .add-bar{background:#fdfaf5eb;box-shadow:inset 0 1px #1c191714,inset 0 6px 20px #1c19170f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;overflow-x:hidden}body{background:var(--bg);color:var(--text);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;max-width:100vw;height:100%;font-size:16px;line-height:1.5;position:relative;overflow:hidden}#root{flex-direction:column;height:100%;display:flex}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(55% 45% at 15% 10%,#c4704f1f 0%,#0000 65%),radial-gradient(45% 55% at 85% 85%,#6b8f7114 0%,#0000 60%),radial-gradient(35% 40% at 70% 20%,#c4704f0f 0%,#0000 55%);position:fixed;inset:0}#root{z-index:1;flex-direction:column;min-height:100svh;display:flex;position:relative}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:inherit}.app-loading{min-height:100svh;color:var(--text-3);justify-content:center;align-items:center;font-size:2rem;animation:1.6s ease-in-out infinite pulse;display:flex}@keyframes pulse{0%,to{opacity:.3;transform:scale(.96)}50%{opacity:.8;transform:scale(1.04)}}.auth-page{justify-content:center;align-items:center;min-height:100svh;padding:24px 16px;display:flex}.auth-grain{display:none}.auth-card{border:1px solid var(--border);width:100%;max-width:400px;box-shadow:var(--shadow), var(--glass-shine);-webkit-backdrop-filter:blur(28px);background:#fff6ea0d;border-radius:24px;padding:44px 40px}.auth-brand{text-align:center;margin-bottom:36px}.auth-logo{color:var(--accent);margin-bottom:12px;font-size:1.75rem;display:block}.auth-title{letter-spacing:-.03em;color:var(--text);font-size:1.75rem;font-weight:700;line-height:1.15}.auth-tagline{color:var(--text-2);margin-top:6px;font-size:.9375rem}.auth-tabs{border-radius:var(--radius-sm);border:1px solid var(--border-mid);background:#fff6ea0f;gap:4px;margin-bottom:24px;padding:4px;display:flex}.auth-tab{border-radius:var(--radius-xs);color:var(--text-2);flex:1;min-height:44px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s}.auth-tab.active{color:var(--text);box-shadow:var(--glass-shine);background:#fff6ea1a;font-weight:600}.auth-tab:hover:not(.active){color:var(--text)}.auth-form{flex-direction:column;gap:16px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text-2);font-size:13.5px;font-weight:500}.field input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);-webkit-backdrop-filter:blur(8px);background:#fff6ea12;outline:none;min-height:48px;padding:12px 14px;font-size:15px;transition:border-color .15s,box-shadow .15s}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.field input::placeholder{color:var(--text-3)}.field-hint{color:var(--text-3);font-size:13px;line-height:1.45}.form-error{color:#e8967a;border-radius:var(--radius-sm);background:#c4704f1a;border:1px solid #c4704f4d;padding:10px 14px;font-size:13.5px}.btn-google{width:100%;color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm), var(--glass-shine);-webkit-backdrop-filter:blur(8px);background:#fff6ea12;justify-content:center;align-items:center;gap:10px;min-height:50px;padding:13px 20px;font-size:15px;font-weight:500;transition:background .15s,border-color .15s;display:flex}.btn-google:hover:not(:disabled){background:#fff6ea1f;border-color:#fff6ea2e}.btn-google:active:not(:disabled){transform:scale(.985)}.btn-google:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-radius:var(--radius-sm);letter-spacing:-.01em;width:100%;min-height:50px;padding:13px 20px;font-size:15px;font-weight:600;transition:background .15s,transform .1s;box-shadow:0 4px 16px #c4704f4d}.btn-primary:hover:not(:disabled){background:var(--accent-2)}.btn-primary:active:not(:disabled){transform:scale(.985)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.app-shell{flex-direction:column;flex:1;width:100%;max-width:min(680px,100vw);height:100%;margin:0 auto;display:flex;overflow:hidden}.app-header{border-bottom:1px solid var(--border-mid);z-index:10;-webkit-backdrop-filter:blur(24px);padding-top:env(safe-area-inset-top);background:#11100999;position:sticky;top:0;box-shadow:0 1px #fff6ea0d}.app-header-inner{height:var(--header-h);justify-content:space-between;align-items:center;gap:12px;padding:0 24px;display:flex}.app-brand{flex-shrink:0;align-items:center;gap:10px;display:flex}.app-logo-wrap{flex-shrink:0;justify-content:center;align-items:center;display:flex}.app-logo-wrap img{display:block}.app-name{color:var(--text);letter-spacing:-.025em;font-size:1.0625rem;font-weight:700}.app-home-name{color:var(--text-2);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xs);white-space:nowrap;text-overflow:ellipsis;-webkit-backdrop-filter:blur(8px);max-width:160px;box-shadow:var(--glass-shine);padding:5px 12px;font-size:13px;font-weight:500;overflow:hidden}.app-header-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.app-header-divider{background:var(--border);flex-shrink:0;width:1px;height:20px;margin:0 2px}.invite-btn,.signout-btn,.theme-btn{border-radius:var(--radius-xs);width:38px;height:38px;color:var(--text-3);justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.invite-btn:hover,.signout-btn:hover,.theme-btn:hover{background:var(--surface-2);color:var(--text-2)}.invite-banner{border-top:1px solid var(--border-mid);-webkit-backdrop-filter:blur(12px);background:#fff6ea0d;padding:16px 24px 18px;animation:.15s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.invite-label{color:var(--text-2);margin-bottom:10px;font-size:13px;font-weight:500}.invite-code-row{align-items:center;gap:14px;display:flex}.invite-code{letter-spacing:.18em;color:var(--accent);font-size:1.75rem;font-weight:700}.invite-copy{background:var(--accent);color:#fff;border-radius:var(--radius-xs);min-height:36px;padding:8px 18px;font-size:13.5px;font-weight:600;transition:background .15s;box-shadow:0 2px 10px #c4704f40}.invite-copy:hover:not(:disabled){background:var(--accent-2)}.invite-copy--done{background:var(--sage);cursor:default}.app-nav{border-bottom:1px solid var(--border-mid);-webkit-backdrop-filter:blur(16px);background:#11100980;padding:0 16px;display:flex}.nav-link{height:48px;color:var(--text-3);white-space:nowrap;letter-spacing:-.01em;border-bottom:2px solid #0000;align-items:center;gap:7px;padding:0 12px;font-size:14.5px;font-weight:500;text-decoration:none;transition:color .15s,border-color .15s;display:flex;position:relative;top:1px}.nav-link:hover{color:var(--text-2)}.nav-link.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.app-main{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden auto}.list-page{flex-direction:column;min-height:100%;display:flex}.list-header{padding:28px 24px 16px}.list-title{letter-spacing:-.04em;color:var(--text);font-size:1.875rem;font-weight:700;line-height:1.1}.list-subtitle{color:var(--text-2);margin-top:5px;font-size:.9375rem}.items-list{flex-direction:column;flex:1;gap:6px;padding:4px 24px 20px;display:flex}.item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);-webkit-backdrop-filter:blur(16px);box-shadow:var(--shadow-sm), var(--glass-shine);align-items:center;gap:12px;margin-bottom:6px;padding:14px 16px 14px 10px;transition:opacity .2s;animation:.18s itemIn;display:flex}@keyframes itemIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.item--checked{opacity:.35;border-color:var(--border-mid);box-shadow:none;background:0 0}.item-drag-handle{width:32px;height:44px;color:var(--text-3);cursor:grab;touch-action:none;flex-shrink:0;justify-content:center;align-items:center;margin-left:-4px;display:flex}.item-drag-handle:active{cursor:grabbing}.item-drag-handle:hover{color:var(--text-2)}.item-placeholder{border:1.5px dashed var(--text-3);opacity:.5;background:0 0;border-radius:12px;height:52px;margin-bottom:4px}.droppable-zone{border-radius:10px;transition:background .15s,box-shadow .15s}.droppable-zone--over{background:#fff6ea0d;box-shadow:inset 0 0 0 1.5px #fff6ea26}.item-check{color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;margin:-10px -8px -10px -4px;display:flex}.item-check-inner{border:1.5px solid var(--text-3);pointer-events:none;border-radius:6px;justify-content:center;align-items:center;width:22px;height:22px;transition:background .15s,border-color .15s;display:flex}.item-check:hover .item-check-inner{border-color:var(--accent)}.item-check.checked .item-check-inner{background:var(--accent);border-color:var(--accent)}.item-emoji{flex-shrink:0;font-size:1.1rem}.item-body{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.item-name{color:var(--text);letter-spacing:-.01em;font-size:15.5px;font-weight:500;line-height:1.3}.item--checked .item-name{color:var(--text-3);font-weight:400;text-decoration:line-through}.item-qty{color:var(--text-2);font-size:13px}.item-by{white-space:nowrap;text-overflow:ellipsis;border-radius:20px;align-self:flex-start;max-width:140px;padding:2px 7px;font-size:11.5px;font-weight:500;overflow:hidden}.item-by--mine{background:var(--accent-dim);color:var(--accent)}.item-by--theirs{background:var(--sage-dim);color:var(--sage)}.item-delete{width:36px;height:36px;color:var(--text-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-right:-8px;transition:color .15s;display:flex}.item-delete:hover{color:var(--accent)}.item-edit-btn{width:30px;height:30px;color:var(--text-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-right:2px;transition:color .15s,background .12s;display:flex}.item-edit-btn:hover{color:var(--accent);background:var(--accent-dim)}.section-drop-hint{border:1.5px dashed var(--border);border-radius:var(--radius-sm);min-height:48px;color:var(--text-3);letter-spacing:.02em;justify-content:center;align-items:center;font-size:12.5px;font-weight:500;transition:border-color .15s,background .15s,color .15s;display:flex}.section-drop-hint--over{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.item--editing{background:var(--surface-2);border-color:var(--accent-ring)!important;padding:10px 14px!important}.item-edit-inner{flex-direction:column;gap:8px;width:100%;display:flex}.item-edit-picker{grid-template-columns:repeat(8,1fr);gap:4px;animation:.15s fadeSlideIn;display:grid}.item-edit-row{align-items:center;gap:6px;display:flex}.item-edit-inputs{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.item-edit-emoji-btn{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:1.1rem;transition:background .12s,transform .1s;display:flex}.item-edit-emoji-btn:hover{background:var(--surface-2)}.item-edit-emoji-btn--open{background:var(--accent-dim);border-color:var(--accent-ring);transform:scale(1.06)}.item-edit-input{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;outline:none;flex:1;min-width:0;padding:7px 10px;font-size:14px;transition:border-color .15s}.item-edit-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-ring)}.item-edit-qty{text-align:center;flex:none;width:56px}.item-edit-note{color:var(--text-2);font-size:13px}.item-edit-note::placeholder{color:var(--text-3)}.item-edit-save{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s,opacity .15s;display:flex}.item-edit-save:hover:not(:disabled){background:var(--accent-2)}.item-edit-save:disabled{opacity:.35;cursor:not-allowed}.item-edit-cancel{background:var(--surface);border:1px solid var(--border);width:32px;height:32px;color:var(--text-2);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.item-edit-cancel:hover{background:var(--surface-2);color:var(--text)}.item-edit-cats{flex-wrap:wrap;gap:5px;display:flex}.item-edit-cats .cat-pill{min-height:28px;padding:4px 11px;font-size:12.5px}.item-edit-actions{justify-content:flex-end;gap:6px;display:flex}.checked-divider{color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:center;margin:12px 0 4px;padding:0 2px;font-size:12px;font-weight:500;display:flex}.clear-btn{color:var(--accent);text-transform:none;letter-spacing:0;align-items:center;min-height:44px;padding:6px 0;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.clear-btn:hover{opacity:.65}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:64px 24px;display:flex}.empty-icon{background:var(--surface);border:1px solid var(--border);width:72px;height:72px;color:var(--text-3);-webkit-backdrop-filter:blur(12px);box-shadow:var(--glass-shine);border-radius:20px;justify-content:center;align-items:center;margin-bottom:8px;display:flex}.empty-title{color:var(--text);letter-spacing:-.02em;font-size:1.125rem;font-weight:600}.empty-body{color:var(--text-2);font-size:14.5px}.list-header-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.list-filter{flex-wrap:wrap;align-items:center;gap:6px;padding-top:12px;display:flex}.filter-pill{color:var(--text-2);background:var(--surface);border:1px solid var(--border);white-space:nowrap;cursor:pointer;border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500;transition:all .12s}.filter-pill:hover{background:var(--surface-2);color:var(--text)}.filter-pill--active{background:var(--accent-dim);border-color:var(--accent-ring);color:var(--accent);font-weight:600}.sections-btn{color:var(--text-2);background:var(--surface);border:1px solid var(--border);white-space:nowrap;-webkit-backdrop-filter:blur(8px);border-radius:20px;flex-shrink:0;align-items:center;gap:5px;margin-top:6px;padding:7px 13px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:flex}.sections-btn:hover{color:var(--text);background:var(--surface-2)}.sections-btn--active{background:var(--accent-dim);border-color:var(--accent-ring);color:var(--accent)}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:flex-end;animation:.2s backdropIn;display:flex;position:fixed;inset:0}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:var(--bg);border:1px solid var(--border);width:100%;max-width:680px;max-height:80svh;box-shadow:0 -8px 40px #0000004d, var(--glass-shine);-webkit-backdrop-filter:blur(24px);border-bottom:none;border-radius:24px 24px 0 0;flex-direction:column;animation:.25s cubic-bezier(.32,.72,0,1) sheetUp;display:flex}@keyframes sheetUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-drag-handle{background:var(--border);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.modal-header{border-bottom:1px solid var(--border-mid);flex-shrink:0;padding:20px 24px 16px;position:relative}.modal-title{color:var(--text);letter-spacing:-.025em;font-size:1.125rem;font-weight:700}.modal-subtitle{color:var(--text-2);margin-top:2px;font-size:13.5px}.modal-close{background:var(--surface-2);width:32px;height:32px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;top:18px;right:20px}.modal-close:hover{background:var(--surface-2);color:var(--text)}.modal-body{flex:1;padding:8px 0;overflow-y:auto}.modal-empty{text-align:center;color:var(--text-3);padding:32px 24px;font-size:14px;line-height:1.8}.sections-list{flex-direction:column;gap:4px;padding:0 16px;list-style:none;display:flex}.section-item{border-radius:var(--radius-sm);overflow:hidden}.section-item-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(12px);box-shadow:var(--glass-shine);align-items:center;gap:10px;padding:12px 14px;display:flex}.section-drag-btn{width:32px;height:32px;color:var(--text-3);cursor:grab;border-radius:var(--radius-xs);touch-action:none;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.section-drag-btn:active{cursor:grabbing}.section-drag-btn:hover{color:var(--text-2);background:var(--surface-2)}.section-item-name{color:var(--text);flex:1;font-size:15px;font-weight:500}.section-item-actions{gap:4px;display:flex}.section-icon-btn{border-radius:var(--radius-xs);width:34px;height:34px;color:var(--text-3);justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.section-icon-btn:hover{background:var(--surface-2);color:var(--text-2)}.section-icon-btn--delete:hover{background:var(--accent-dim);color:var(--accent)}.section-item-edit{background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius-sm);box-shadow:0 0 0 3px var(--accent-ring);align-items:center;gap:8px;padding:10px 14px;display:flex}.section-edit-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:15px;font-weight:500}.section-item-confirm{background:var(--accent-dim);border:1px solid var(--accent-ring);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:10px 14px;display:flex}.section-confirm-text{flex-direction:column;flex:1;gap:2px;display:flex}.section-confirm-name{color:var(--text);opacity:.6;font-size:14px;font-weight:500;text-decoration:line-through}.section-confirm-hint{color:var(--text-2);font-size:12px}.section-action-btn{border-radius:var(--radius-xs);white-space:nowrap;min-height:34px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s}.section-action-save{background:var(--accent);color:#fff}.section-action-save:hover{background:var(--accent-2)}.section-action-cancel{color:var(--text-2)}.section-action-cancel:hover{background:var(--surface-2)}.section-action-delete{background:var(--accent);color:#fff}.section-action-delete:hover{background:var(--accent-2)}.modal-footer{border-top:1px solid var(--border-mid);padding:16px;padding-bottom:max(16px, env(safe-area-inset-bottom));flex-shrink:0}.section-add-form{gap:8px;display:flex}.section-add-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);-webkit-backdrop-filter:blur(8px);outline:none;flex:1;min-height:46px;padding:11px 14px;font-size:15px;transition:border-color .15s,box-shadow .15s}.section-add-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.section-add-input::placeholder{color:var(--text-3)}.section-add-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);white-space:nowrap;align-items:center;gap:6px;min-height:46px;padding:11px 18px;font-size:14px;font-weight:600;transition:background .15s,opacity .15s;display:flex;box-shadow:0 4px 14px #c4704f4d}.section-add-btn:hover:not(:disabled){background:var(--accent-2)}.section-add-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.section-group{flex-direction:column;gap:6px;margin-bottom:6px;display:flex}.section-header{letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);padding:6px 4px 2px;font-size:11.5px;font-weight:600}.section-header--btn{cursor:pointer;text-align:left;letter-spacing:.07em;text-transform:uppercase;width:100%;color:var(--text-3);-webkit-tap-highlight-color:transparent;background:0 0;border:none;align-items:center;gap:5px;padding:6px 4px 2px;font-family:inherit;font-size:11.5px;font-weight:600;display:flex}.section-header--btn:hover{color:var(--text-2)}.section-chevron{opacity:.7;flex-shrink:0;transition:transform .2s}.section-chevron--collapsed{transform:rotate(-90deg)}.section-count{letter-spacing:0;text-transform:none;background:var(--border);color:var(--text-3);border-radius:8px;margin-left:2px;padding:1px 6px;font-size:10px;font-weight:700;line-height:1.5}.section-header--other{color:var(--border)}.cat-pills{flex-wrap:wrap;gap:6px;padding-bottom:10px;animation:.15s fadeSlideIn;display:flex}.cat-pill{background:var(--surface);border:1px solid var(--border);color:var(--text-2);white-space:nowrap;border-radius:20px;align-items:center;min-height:32px;padding:5px 13px;font-size:13px;font-weight:500;transition:all .12s;display:flex}.cat-pill:hover{background:var(--surface-2);color:var(--text)}.cat-pill--selected{background:var(--accent-dim);border-color:var(--accent-ring);color:var(--accent);font-weight:600}.add-bar{padding:10px 14px;padding-bottom:max(8px, env(safe-area-inset-bottom));z-index:5;-webkit-backdrop-filter:blur(24px);background:#111009b3;border-radius:22px 22px 0 0;position:sticky;bottom:0;box-shadow:inset 0 1px #ffffff14,inset 0 6px 20px #0000001f}.emoji-picker-row{border-bottom:1px solid var(--border);grid-template-columns:repeat(8,minmax(0,1fr));gap:4px;margin-bottom:12px;padding:12px 0 14px;animation:.15s fadeSlideIn;display:grid}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.add-bar-form{align-items:flex-end;gap:8px;display:flex}.add-bar-field{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;flex:1;align-items:center;min-width:0;min-height:46px;transition:border-color .15s,box-shadow .15s,background .15s;display:flex}html[data-theme=light] .add-bar-field{background:#ffffffb3;border-color:#d2c6b6b3}.add-bar-field:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.add-bar-inputs{flex-direction:column;flex:1;justify-content:center;align-self:stretch;min-width:0;display:flex}.add-bar-emoji-btn{cursor:pointer;background:0 0;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;margin:5px 2px 5px 5px;font-size:1.15rem;line-height:1;transition:background .12s,transform .1s;display:flex}.add-bar-emoji-btn:hover{background:var(--surface-2)}.add-bar-emoji-btn--open{background:var(--accent-dim);transform:scale(1.06)}.add-bar-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:12px 10px 12px 8px;font-size:16px}.add-bar-input::placeholder{color:var(--text-3)}.add-bar-qty{width:50px;color:var(--text-2);text-align:center;background:0 0;border:none;outline:none;flex-shrink:0;padding:12px 12px 12px 4px;font-size:16px}.add-bar-qty::placeholder{color:var(--text-3)}.add-bar-note{color:var(--text);background:0 0;border:none;outline:none;padding:2px 10px 10px 8px;font-size:16px;animation:.15s fadeSlideIn}.add-bar-note::placeholder{color:var(--text-3)}.add-bar-submit{background:var(--accent);color:#fff;letter-spacing:.01em;white-space:nowrap;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;height:46px;padding:0 16px;font-size:15px;font-weight:600;transition:background .15s,box-shadow .15s,transform .1s;display:flex;box-shadow:0 4px 14px #c4704f47}.add-bar-submit:hover:not(:disabled){background:var(--accent-2);box-shadow:0 6px 20px #c4704f61}.add-bar-submit:active:not(:disabled){transform:scale(.97)}.add-bar-submit:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.emoji-btn{border-radius:var(--radius-xs);background:var(--surface);border:1px solid var(--border);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:7px 2px 5px;transition:all .12s;display:flex}.emoji-btn-icon{font-size:1.3rem;line-height:1}.emoji-btn-label{color:var(--text-3);letter-spacing:.01em;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:8.5px;font-weight:500;line-height:1;overflow:hidden}.emoji-btn:hover{background:var(--surface-2);transform:scale(1.04)}.emoji-btn.selected{border-color:var(--accent);background:var(--accent-dim);transform:scale(1.06)}.emoji-btn.selected .emoji-btn-label{color:var(--accent)}.plans-list{flex-direction:column;flex:1;gap:10px;padding:12px 20px 120px;display:flex;overflow-y:auto}.plan-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s,box-shadow .15s;overflow:hidden}.plan-card--expanded{box-shadow:var(--shadow-sm), var(--glass-shine);border-color:#fff6ea24}.plan-card-header{text-align:left;align-items:center;gap:12px;width:100%;padding:14px 16px;transition:background .12s;display:flex}.plan-card-header:hover{background:var(--surface-hover)}.plan-card-emoji{flex-shrink:0;font-size:1.625rem;line-height:1}.plan-card-info{flex:1;min-width:0}.plan-card-title-row{align-items:center;gap:8px;min-width:0;margin-bottom:8px;display:flex}.plan-card-title{color:var(--text);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:600;overflow:hidden}.plan-deadline{white-space:nowrap;border-radius:99px;flex-shrink:0;padding:2px 8px;font-size:11px;font-weight:500}.plan-deadline--ok{background:var(--sage-dim);color:var(--sage)}.plan-deadline--soon{color:#c89a30;background:#e0a83c1f}.plan-deadline--overdue{background:var(--accent-dim);color:var(--accent)}html[data-theme=light] .plan-deadline--soon{color:#a07820;background:#b4821e1a}.plan-deadline--sm{padding:1px 6px;font-size:10px}.plan-progress-bar{background:var(--surface-2);border-radius:99px;height:5px;margin-bottom:8px;overflow:hidden}.plan-progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:99px;height:100%;transition:width .5s}.plan-card-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.plan-pct{color:var(--accent);font-size:12px;font-weight:700}.plan-type-badge{color:var(--text-3);font-size:11.5px}.plan-amount-badge{color:var(--text-2);font-size:11.5px}.plan-chevron{color:var(--text-3);flex-shrink:0;transition:transform .2s}.plan-chevron--open{transform:rotate(180deg)}.plan-card-body{border-top:1px solid var(--border-mid);flex-direction:column;gap:16px;padding:14px 16px 18px;display:flex}.plan-card-actions{justify-content:flex-end;gap:8px;display:flex}.plan-action-btn{color:var(--text-2);border-radius:var(--radius-xs);background:var(--surface-2);border:1px solid var(--border);padding:5px 12px;font-size:12px;font-weight:500;transition:all .12s}.plan-action-btn:hover{color:var(--text);background:var(--surface-hover)}.plan-action-btn--danger:hover{color:var(--accent);border-color:var(--accent-ring)}.plan-subtasks{flex-direction:column;display:flex}.plan-subtasks-empty{color:var(--text-3);padding:6px 4px 10px;font-size:13px}.plan-subtask{border-radius:var(--radius-sm);align-items:center;gap:10px;padding:7px 6px;transition:background .1s;display:flex}.plan-subtask:hover{background:var(--surface-hover)}.plan-subtask--done .plan-subtask-title{color:var(--text-3);text-decoration:line-through}.plan-subtask--editing{background:var(--surface-2)!important}.plan-subtask-check{border:1.5px solid var(--border);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:all .12s;display:flex}.plan-subtask-check:hover:not(.plan-subtask-check--placeholder){border-color:var(--accent)}.plan-subtask-check.checked{background:var(--accent);border-color:var(--accent)}.plan-subtask-check--placeholder{cursor:default;pointer-events:none;border-color:#0000}.plan-subtask-check-inner{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.plan-subtask-title{color:var(--text);flex:1;min-width:0;font-size:14px}.plan-subtask-edit-input{border:none;border-bottom:1.5px solid var(--accent);color:var(--text);background:0 0;outline:none;flex:1;min-width:0;padding:2px 0;font-family:inherit;font-size:14px}.plan-add-subtask{border-top:1px solid var(--border-mid);align-items:center;gap:8px;margin-top:4px;padding:6px;display:flex}.plan-add-subtask-input{border:none;border-bottom:1px solid var(--border);color:var(--text);background:0 0;outline:none;flex:1;min-width:0;padding:4px 0;font-family:inherit;font-size:14px}.plan-add-subtask-input::placeholder{color:var(--text-3)}.plan-add-subtask-input:focus{border-bottom-color:var(--accent)}.plan-add-subtask-date{color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-xs);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;outline:none;flex-shrink:0;padding:4px 7px;font-family:inherit;font-size:12px}html[data-theme=light] .plan-add-subtask-date{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}.plan-add-subtask-date:focus{border-color:var(--accent)}.plan-add-subtask-btn{color:var(--accent);border-radius:var(--radius-xs);background:var(--accent-dim);border:1px solid var(--accent-ring);flex-shrink:0;padding:5px 12px;font-size:13px;font-weight:500;transition:all .12s}.plan-add-subtask-btn:disabled{opacity:.4;cursor:not-allowed}.plan-add-subtask-btn:not(:disabled):hover{background:#c4704f42}.plan-monetary{background:var(--surface-2);border:1px solid var(--border-mid);border-radius:var(--radius-sm);flex-direction:column;gap:10px;padding:14px 16px;display:flex}.plan-monetary-label{color:var(--text-2);font-size:12.5px;font-weight:500}.plan-monetary-goal{color:var(--text-3);font-weight:400}.plan-monetary-row{align-items:center;gap:8px;display:flex}.plan-monetary-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;outline:none;flex:1;padding:9px 12px;font-family:inherit;font-size:1.125rem;font-weight:600}html[data-theme=light] .plan-monetary-input{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}.plan-monetary-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.plan-monetary-save{color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-ring);border-radius:var(--radius-sm);flex-shrink:0;padding:9px 16px;font-size:13px;font-weight:500;transition:all .12s}.plan-monetary-save:disabled{opacity:.4}.plan-monetary-save:not(:disabled):hover{background:#c4704f42}.plan-monetary-bar{background:var(--border);border-radius:99px;height:4px;overflow:hidden}.plan-monetary-fill{background:linear-gradient(90deg, var(--sage), #9bc99e);border-radius:99px;height:100%;transition:width .5s}.plan-modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:200;background:#0000008c;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.plan-modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:min(680px,100vw);padding:24px 20px;padding-bottom:calc(28px + env(safe-area-inset-bottom));max-height:88svh;box-shadow:var(--shadow), var(--glass-shine);border-top:1px solid #fff6ea1f;overflow-y:auto}html[data-theme=light] .plan-modal{background:var(--bg);border-top-color:#d2c6b666}.plan-modal-header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.plan-modal-title{letter-spacing:-.025em;color:var(--text);font-size:1.0625rem;font-weight:700}.plan-modal-close{background:var(--surface-2);border:1px solid var(--border);width:28px;height:28px;color:var(--text-2);border-radius:50%;justify-content:center;align-items:center;transition:all .12s;display:flex}.plan-modal-close:hover{color:var(--text);background:var(--surface-hover)}.plan-modal-form{flex-direction:column;gap:14px;display:flex}.plan-modal-title-row{align-items:center;gap:10px;display:flex}.plan-modal-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);outline:none;flex:1;width:100%;min-height:46px;padding:11px 14px;font-family:inherit;font-size:15px}.plan-modal-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.plan-modal-input::placeholder{color:var(--text-3)}.plan-modal-section-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:-4px;font-size:11.5px;font-weight:600}.plan-modal-optional{text-transform:none;letter-spacing:0;font-size:11.5px;font-weight:400}.plan-type-pills{gap:8px;display:flex}.plan-type-pill{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);color:var(--text-2);flex:1;padding:9px 8px;font-size:13px;font-weight:500;transition:all .12s}.plan-type-pill:hover{color:var(--text);background:var(--surface-hover)}.plan-type-pill--active{background:var(--accent-dim);border-color:var(--accent-ring);color:var(--accent);font-weight:600}.plan-modal-date{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;outline:none;width:100%;min-height:46px;padding:11px 14px;font-family:inherit;font-size:15px}html[data-theme=light] .plan-modal-date{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}.plan-modal-date:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}.plan-emoji-grid{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:2px;padding:10px;display:grid}.todo-plan-badge{color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent-ring);white-space:nowrap;border-radius:4px;flex-shrink:0;padding:1px 6px;font-size:10.5px;font-weight:500}.cal-header-btns{align-items:center;gap:8px;display:flex}.cal-disconnect-btn{color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:5px 10px;font-size:12px;font-weight:500;transition:color .15s,border-color .15s}.cal-disconnect-btn:hover{color:#e57373;border-color:#e57373}.cal-body{padding:0 16px 32px}.cal-setup-banner{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;padding:16px}.cal-setup-title{margin:0 0 6px;font-weight:600}.cal-setup-body{color:var(--text-muted);margin:4px 0;font-size:13px}.cal-setup-code{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);word-break:break-all;color:var(--accent);margin-top:6px;padding:8px 12px;font-size:12px;display:block}.cal-error{border-radius:var(--radius-sm);color:#e57373;background:#e573731a;border:1px solid #e5737359;margin-bottom:16px;padding:10px 14px;font-size:13px}.cal-nav{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cal-nav-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex}.cal-nav-btn:hover{color:var(--text);background:var(--surface-hover)}.cal-nav-label{font-size:15px;font-weight:600}.cal-legend{color:var(--text-muted);gap:14px;margin-bottom:10px;font-size:12px;display:flex}.cal-legend-item{align-items:center;gap:5px;display:flex}.cal-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.cal-dot--mine{background:var(--accent)}.cal-dot--partner{background:var(--sage,#81b29a)}.cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:16px;display:grid}.cal-day-header{color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.03em;padding:4px 0;font-size:11px;font-weight:600}.cal-day{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:1.5px solid #0000;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:0;transition:background .12s,border-color .12s;display:flex}.cal-day:hover{background:var(--surface-hover)}.cal-day--pad{cursor:default;pointer-events:none}.cal-day--today .cal-day-num{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex}.cal-day--selected{background:var(--accent-dim);border-color:var(--accent-ring)}.cal-day-num{font-size:13px;line-height:1}.cal-day-dots{align-items:center;gap:2px;min-height:7px;display:flex}.cal-detail{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.cal-detail-header{color:var(--text-muted);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;padding:12px 16px 10px;font-size:13px;font-weight:600}.cal-detail-empty{color:var(--text-muted);margin:0;padding:16px;font-size:13px}.cal-event{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:10px 16px;display:flex}.cal-event:last-child{border-bottom:none}.cal-event-body{flex-direction:column;gap:2px;min-width:0;display:flex}.cal-event-title{font-size:14px;font-weight:500;line-height:1.3}.cal-event-meta{color:var(--text-muted);font-size:12px}.cal-event-owner{color:var(--sage,#81b29a)}@keyframes cal-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cal-spin{animation:1s linear infinite cal-spin}
