:root{--bg:#fafaf8;--bg-card:#fff;--bg-alt:#f3f2ee;--bg-accent:#e8f5e3;--accent:#3b8c5c;--accent-light:#5cb87a;--accent-dim:#e8f5e3;--text:#1a1a1a;--text-2:#6b6b6b;--text-3:#9ca3af;--border:#e8e6e1;--border-light:#f0ede8;--danger:#dc4a4a;--checked:#b8b8b0;--shadow:0 1px 3px #0000000f;--shadow-md:0 4px 12px #00000014;--radius-sm:8px;--radius:12px;--radius-lg:16px;--shadow-sm:0 1px 2px #0000000a;--shadow-lg:0 8px 24px #0000001f;--font-title:"Nunito", sans-serif;--font-body:"DM Sans", sans-serif}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px;overflow-x:hidden}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}button{cursor:pointer;font-family:inherit;font-size:inherit;color:inherit;background:0 0;border:none}input,select,textarea{font-family:inherit;font-size:inherit}a{color:var(--accent);text-decoration:none}img{max-width:100%;display:block}.layout{flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.layout-content{flex:1;padding:16px 24px 100px}.bottom-nav{background:var(--bg-card);border-top:1px solid var(--border-light);width:100%;max-width:480px;padding:8px 0;padding-bottom:max(8px, env(safe-area-inset-bottom));z-index:100;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-nav-item{color:var(--text-3);flex-direction:column;flex:1;align-items:center;gap:2px;min-height:44px;padding:8px 0;transition:color .18s;display:flex}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-icon{font-size:22px;line-height:1}.bottom-nav-label{font-size:11px;font-weight:600;font-family:var(--font-title)}.page-center{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100dvh;display:flex}.page-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.page-header-left{align-items:center;gap:12px;display:flex}.page-title{font-family:var(--font-title);color:var(--text);font-size:24px;font-weight:800}.page-emoji{font-size:32px;line-height:1}.page-back{margin-bottom:12px}.btn-back{color:var(--accent);align-items:center;min-height:44px;padding:8px 0;font-size:14px;font-weight:600;display:flex}.badge{background:var(--accent-dim);color:var(--accent);font-size:13px;font-weight:700;font-family:var(--font-title);border-radius:20px;padding:2px 10px}.badge-members,.badge-count{color:var(--text-2);font-size:13px}.loading-spinner-container{justify-content:center;align-items:center;padding:32px;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;display:flex}.empty-state-emoji{margin-bottom:8px;font-size:48px}.empty-state-title{font-family:var(--font-title);color:var(--text);font-size:18px;font-weight:700}.empty-state-desc{color:var(--text-2);max-width:260px;font-size:14px}.empty-state-action{margin-top:16px}.btn-primary{background:var(--accent);color:#fff;font-family:var(--font-title);border-radius:var(--radius);min-height:44px;padding:12px 24px;font-size:15px;font-weight:700;transition:background .18s,transform .1s}.btn-primary:hover{background:var(--accent-light)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-full{width:100%}.btn-secondary{background:var(--bg-alt);color:var(--text);font-family:var(--font-title);border-radius:var(--radius);min-height:44px;padding:12px 24px;font-size:15px;font-weight:700;transition:background .18s}.btn-secondary:hover{background:var(--border)}.btn-signout{width:100%;color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius);background:0 0;min-height:44px;margin-top:24px;padding:14px;font-size:15px;font-weight:600;transition:background .18s}.btn-signout:hover{background:#fef2f2}.login-page{flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:32px 24px;display:flex}.login-content{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.login-logo{margin-bottom:8px;font-size:64px}.login-title{font-family:var(--font-title);color:var(--text);font-size:28px;font-weight:800}.login-tagline{color:var(--text-2);max-width:280px;margin-bottom:24px;font-size:15px}.btn-google{background:var(--bg-card);color:var(--text);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);align-items:center;gap:12px;min-height:48px;padding:14px 28px;font-size:15px;font-weight:600;transition:box-shadow .18s,transform .1s;display:flex}.btn-google:hover{box-shadow:var(--shadow-md)}.btn-google:active{transform:scale(.97)}.login-footer{color:var(--text-3);padding-bottom:24px;font-size:13px}.groups-list{flex-direction:column;gap:8px;display:flex}.group-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);text-align:left;width:100%;box-shadow:var(--shadow);align-items:center;gap:14px;min-height:44px;padding:16px;transition:box-shadow .18s,transform .1s;display:flex}.group-card:hover{box-shadow:var(--shadow-md)}.group-card:active{transform:scale(.98)}.group-card-new{border-style:dashed;border-color:var(--border);box-shadow:none;background:0 0}.group-card-new .group-card-emoji{color:var(--text-3);font-size:24px}.group-card-new .group-card-name{color:var(--text-2)}.group-card-emoji{flex-shrink:0;font-size:32px;line-height:1}.group-card-info{flex:1;min-width:0}.group-card-name{font-family:var(--font-title);color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:16px;font-weight:700;overflow:hidden}.group-card-meta{color:var(--text-2);margin-top:2px;font-size:13px}.group-card-time{color:var(--text-3);flex-shrink:0;font-size:12px}.lists-list{flex-direction:column;gap:8px;display:flex}.list-card-wrapper{position:relative}.list-card-actions{z-index:5;position:absolute;top:12px;right:12px}.list-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);text-align:left;width:100%;box-shadow:var(--shadow);align-items:flex-start;gap:14px;min-height:44px;padding:16px 44px 16px 16px;transition:box-shadow .18s,transform .1s;display:flex}.list-card:hover{box-shadow:var(--shadow-md)}.list-card:active{transform:scale(.98)}.list-card-emoji{flex-shrink:0;margin-top:2px;font-size:28px;line-height:1}.list-card-info{flex:1;min-width:0}.list-card-name{font-family:var(--font-title);color:var(--text);font-size:15px;font-weight:700}.list-card-meta{color:var(--text-2);margin-top:2px;font-size:13px}.list-card-time{color:var(--text-3);flex-shrink:0;font-size:12px}.progress-bar{background:var(--bg-alt);border-radius:3px;height:6px;margin-top:8px;overflow:hidden}.progress-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.invite-banner{background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--radius);text-align:left;align-items:center;gap:12px;width:100%;min-height:44px;margin-bottom:20px;padding:14px 16px;transition:transform .1s;display:flex}.invite-banner:active{transform:scale(.98)}.invite-banner-icon{font-size:20px}.invite-banner-text{color:var(--accent);flex:1;font-size:14px;font-weight:600}.invite-banner-arrow{color:var(--accent);font-weight:700}.fab{background:var(--accent);color:#fff;z-index:50;border-radius:26px;justify-content:center;align-items:center;width:52px;height:52px;font-size:28px;font-weight:300;transition:transform .18s,box-shadow .18s;display:flex;position:fixed;bottom:90px;right:calc(50% - 210px);box-shadow:0 4px 16px #3b8c5c59}@media (width<=480px){.fab{right:20px}}.fab:hover{transform:scale(1.05);box-shadow:0 6px 20px #3b8c5c73}.fab:active{transform:scale(.95)}.modal-overlay{z-index:200;background:#0006;justify-content:center;align-items:flex-end;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:24px 20px;padding-bottom:max(24px, env(safe-area-inset-bottom));width:100%;max-width:480px;max-height:80dvh;animation:.25s slideUp;overflow-y:auto}.modal-title{font-family:var(--font-title);margin-bottom:20px;font-size:20px;font-weight:800}.modal-actions{gap:12px;margin-top:20px;display:flex}.modal-actions .btn-secondary,.modal-actions .btn-primary{flex:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.form-group{margin-bottom:16px}.form-label{color:var(--text-2);font-size:13px;font-weight:600;font-family:var(--font-title);margin-bottom:6px;display:block}.form-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);width:100%;color:var(--text);outline:none;min-height:44px;padding:12px 14px;font-size:15px;transition:border-color .18s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-3)}.form-row{gap:12px;display:flex}.form-group-half{flex:1}.emoji-grid{grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:8px;display:grid}.emoji-option{border-radius:var(--radius);border:2px solid var(--border-light);justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;transition:border-color .18s,transform .1s;display:flex}.emoji-option.selected{border-color:var(--accent);background:var(--accent-dim)}.emoji-option:active{transform:scale(.9)}.category-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}.category-option{border-radius:var(--radius);border:2px solid var(--border-light);align-items:center;gap:8px;min-height:44px;padding:12px;transition:border-color .18s,background .18s;display:flex}.category-option.selected{border-color:var(--accent);background:var(--accent-dim)}.category-option:active{transform:scale(.97)}.category-option-emoji{font-size:20px}.category-option-name{color:var(--text);font-size:13px;font-weight:600}.quick-add{gap:8px;margin-bottom:12px;display:flex}.quick-add-input{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);outline:none;flex:1;min-height:44px;padding:12px 14px;font-size:15px}.quick-add-input:focus{border-color:var(--accent)}.quick-add-input::placeholder{color:var(--text-3)}.quick-add-btn{border-radius:var(--radius);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:24px;transition:background .18s;display:flex}.quick-add-btn:disabled{opacity:.5}.quick-add-btn:hover:not(:disabled){background:var(--accent-light)}.btn-add-full{text-align:center;width:100%;color:var(--accent);background:var(--accent-dim);border-radius:var(--radius);min-height:44px;margin-bottom:20px;padding:10px;font-size:14px;font-weight:600;transition:background .18s;display:block}.btn-add-full:hover{background:var(--bg-accent)}.items-list{flex-direction:column;gap:16px;display:flex}.items-category{flex-direction:column;gap:4px;display:flex}.items-category-header{color:var(--text-2);font-size:13px;font-weight:700;font-family:var(--font-title);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;padding:4px 0;display:flex}.item-row{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);align-items:center;gap:12px;min-height:44px;padding:12px;transition:opacity .3s,transform .18s;display:flex;position:relative}.item-row.item-checked{opacity:.6}.item-checkbox{border:2px solid var(--border);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;transition:all .18s;display:flex}.item-checkbox.checked{background:var(--accent);border-color:var(--accent)}.item-info{flex:1;min-width:0}.item-name{color:var(--text);font-size:15px;font-weight:500;transition:color .18s;display:block}.item-name-checked{color:var(--checked);text-decoration:line-through}.item-meta{color:var(--text-3);margin-top:2px;font-size:12px;display:block}.item-actions{flex-shrink:0;position:relative}.item-menu-btn{width:32px;height:32px;color:var(--text-3);border-radius:8px;justify-content:center;align-items:center;font-size:18px;transition:background .18s;display:flex}.item-menu-btn:hover{background:var(--bg-alt)}.item-menu{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:10;min-width:140px;padding:4px;animation:.15s fadeIn;position:absolute;top:100%;right:0}.item-menu-option{border-radius:8px;align-items:center;gap:8px;width:100%;min-height:44px;padding:10px 12px;font-size:14px;transition:background .18s;display:flex}.item-menu-option:hover{background:var(--bg-alt)}.item-menu-option.danger{color:var(--danger)}.add-item-form{flex-direction:column;display:flex}.invite-page{flex-direction:column;gap:24px;display:flex}.invite-hero{text-align:center;padding:24px 0}.invite-hero-icon{margin-bottom:12px;font-size:48px;display:block}.invite-hero-title{font-family:var(--font-title);font-size:22px;font-weight:800}.invite-hero-desc{color:var(--text-2);margin-top:6px;font-size:14px}.invite-link-box{background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:14px}.invite-link-code{color:var(--text);word-break:break-all;font-size:13px;font-family:var(--font-body)}.invite-actions{gap:12px;display:flex}.btn-whatsapp{color:#fff;border-radius:var(--radius);font-size:15px;font-weight:700;font-family:var(--font-title);background:#25d366;flex:1;min-height:44px;padding:14px;transition:opacity .18s}.btn-whatsapp:hover{opacity:.9}.btn-copy{background:var(--bg-alt);color:var(--text);border-radius:var(--radius);font-size:15px;font-weight:700;font-family:var(--font-title);border:1px solid var(--border);flex:1;min-height:44px;padding:14px;transition:background .18s}.btn-copy:hover{background:var(--border-light)}.invite-members{margin-top:8px}.invite-members-title{font-family:var(--font-title);margin-bottom:12px;font-size:16px;font-weight:700}.invite-members-list{flex-direction:column;gap:8px;display:flex}.member-row{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);align-items:center;gap:12px;padding:10px;display:flex}.member-avatar{background:var(--accent-dim);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.member-avatar-img{object-fit:cover;width:100%;height:100%}.member-avatar-fallback{font-family:var(--font-title);color:var(--accent);font-size:16px;font-weight:700}.member-info{flex-direction:column;flex:1;display:flex}.member-name{font-size:14px;font-weight:600}.member-role{color:var(--text-3);font-size:12px}.join-status-text{color:var(--text-2);margin-top:8px;font-size:15px}.join-result{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:24px;display:flex}.join-result-emoji{font-size:56px}.join-result-title{font-family:var(--font-title);font-size:20px;font-weight:700}.profile-page{flex-direction:column;padding-bottom:24px;display:flex}.profile-header{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:24px 0;display:flex}.profile-avatar{background:var(--accent-dim);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:4px;display:flex;overflow:hidden}.profile-avatar-img{object-fit:cover;width:100%;height:100%}.profile-avatar-fallback{font-family:var(--font-title);color:var(--accent);font-size:32px;font-weight:800}.profile-name{font-family:var(--font-title);font-size:22px;font-weight:800}.profile-email{color:var(--text-2);font-size:14px}.profile-section{margin-top:16px}.profile-section-title{font-family:var(--font-title);color:var(--text);margin-bottom:12px;font-size:16px;font-weight:700}.profile-empty{color:var(--text-3);text-align:center;padding:16px;font-size:14px}.profile-groups{flex-direction:column;gap:6px;display:flex}.profile-group-item{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);text-align:left;align-items:center;gap:10px;width:100%;min-height:44px;padding:12px;font-size:14px;font-weight:500;transition:background .18s;display:flex}.profile-group-item:hover{background:var(--bg-alt)}.profile-group-members{color:var(--text-3);margin-left:auto;font-size:13px}.profile-footer{text-align:center;color:var(--text-3);margin-top:40px;padding-bottom:16px;font-size:13px}.toast-container{z-index:300;pointer-events:none;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:440px;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%)}.toast{border-radius:var(--radius);font-size:14px;font-weight:600;font-family:var(--font-title);box-shadow:var(--shadow-md);pointer-events:auto;align-items:center;gap:8px;padding:12px 16px;animation:.25s toastIn,.25s 2.5s forwards toastOut;display:flex}.toast-success{background:var(--accent-dim);color:var(--accent)}.toast-error{color:var(--danger);background:#fdecec}.toast-info{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.toast-icon{font-size:16px;font-weight:700}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}.product-search{margin-bottom:16px;position:relative}.search-results{background:var(--bg-card);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-md);z-index:50;max-height:280px;animation:.15s fadeIn;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-result-item{text-align:left;border-bottom:1px solid var(--border-light);align-items:center;gap:10px;width:100%;min-height:44px;padding:12px 14px;transition:background .15s;display:flex}.search-result-item:last-child{border-bottom:none}.search-result-item:hover,.search-result-item.selected{background:var(--accent-dim)}.search-result-emoji{text-align:center;flex-shrink:0;width:28px;font-size:20px}.search-result-name{color:var(--text);flex:1;font-size:14px;font-weight:500}.search-result-meta{color:var(--text-3);flex-shrink:0;font-size:12px}.search-result-custom{color:var(--accent)}.search-result-custom .search-result-name{color:var(--accent);font-weight:600}.skeleton{background:linear-gradient(90deg, var(--bg-alt) 25%, var(--border-light) 50%, var(--bg-alt) 75%);border-radius:var(--radius);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.item-row.item-recent{background:var(--bg-alt)}.item-row.item-recent .item-meta{color:var(--checked)}.item-swipe-container{border-radius:var(--radius);position:relative}.item-swipe-bg-check{background:var(--accent);border-radius:var(--radius);color:#fff;z-index:0;align-items:center;width:100%;padding-left:24px;font-size:22px;font-weight:700;display:flex;position:absolute;top:0;bottom:0;left:0}.item-swipe-bg-delete{background:var(--danger);border-radius:0 var(--radius) var(--radius) 0;z-index:0;justify-content:center;align-items:center;width:80px;display:flex;position:absolute;top:0;bottom:0;right:0}.item-delete-confirm{color:#fff;width:100%;height:100%;font-size:14px;font-weight:700;font-family:var(--font-title);justify-content:center;align-items:center;display:flex}.item-row.item-row-swipeable{z-index:1;will-change:transform;position:relative}.completed-section{margin-top:8px}.completed-header{width:100%;color:var(--text-2);font-size:14px;font-weight:600;font-family:var(--font-title);background:var(--bg-alt);border-radius:var(--radius);justify-content:space-between;align-items:center;min-height:44px;padding:12px 16px;transition:background .18s;display:flex}.completed-header:hover{background:var(--border)}.completed-chevron{font-size:14px}.completed-list{flex-direction:column;gap:2px;margin-top:4px;display:flex}.completed-item{border-radius:var(--radius);text-align:left;align-items:center;gap:10px;width:100%;min-height:44px;padding:10px 12px;transition:background .18s;display:flex}.completed-item:hover{background:var(--bg-alt)}.completed-item-emoji{text-align:center;flex-shrink:0;width:24px;font-size:18px}.completed-item-name{color:var(--checked);flex:1;font-size:14px;text-decoration:line-through}.completed-item-meta{color:var(--text-3);flex-shrink:0;font-size:12px}.search-result-reuse{background:var(--accent-dim)}.search-result-reuse .search-result-meta{color:var(--accent);font-weight:600}.group-code-box{background:var(--bg-accent);border-radius:var(--radius);margin-bottom:20px;padding:16px 20px}.group-code-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.group-code-text{font-family:var(--font-title);letter-spacing:.15em;color:var(--accent);font-size:26px;font-weight:800}.btn-copy-small{font-size:13px;font-weight:700;font-family:var(--font-title);color:var(--accent);background:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius);flex-shrink:0;min-height:36px;padding:8px 16px;transition:background .18s}.btn-copy-small:hover{background:var(--accent-dim)}.group-code-hint{color:var(--text-2);margin-top:8px;font-size:13px}.join-code-input{text-align:center;font-family:var(--font-title);letter-spacing:.2em;text-transform:uppercase;font-size:24px;font-weight:800}.join-code-input::placeholder{letter-spacing:.1em;font-size:16px;font-weight:500}.group-actions{border-top:1px solid var(--border-light);flex-direction:column;gap:8px;margin-top:32px;padding-top:16px;display:flex}.btn-danger-outline{width:100%;font-size:14px;font-weight:600;font-family:var(--font-title);color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius);background:0 0;min-height:44px;padding:12px;transition:background .18s}.btn-danger-outline:hover{background:#fef2f2}.btn-danger-text{width:100%;color:var(--danger);background:0 0;min-height:40px;padding:10px;font-size:13px;font-weight:600;transition:opacity .18s}.btn-danger-text:hover{opacity:.7}.btn-danger{background:var(--danger);color:#fff;font-family:var(--font-title);border-radius:var(--radius);flex:1;min-height:44px;padding:12px 24px;font-size:15px;font-weight:700;transition:opacity .18s}.btn-danger:hover{opacity:.9}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.modal-desc{color:var(--text-2);margin-bottom:8px;font-size:14px;line-height:1.5}.modal-warning{color:var(--danger);background:#fef2f2;border-radius:8px;margin-top:8px;padding:10px 12px;font-size:13px;line-height:1.4}button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-secondary:active,.btn-signout:active,.btn-copy:active,.btn-copy-small:active,.btn-whatsapp:active,.btn-danger-outline:active{transform:scale(.97)}.item-menu-option:active{background:var(--border)}.completed-header:active{transform:scale(.98)}.group-card:hover,.list-card:hover{transform:translateY(-2px)}.group-card:active,.list-card:active{transform:scale(.98)translateY(0)}.item-checkbox.checked{animation:.3s cubic-bezier(.34,1.56,.64,1) checkBounce}@keyframes checkBounce{0%{transform:scale(.8)}50%{transform:scale(1.15)}to{transform:scale(1)}}.modal{animation:.3s cubic-bezier(.16,1,.3,1) slideUp}.modal-overlay{-webkit-backdrop-filter:blur(2px)}.bottom-nav-item{position:relative}.bottom-nav-item:after{content:"";background:var(--accent);border-radius:1.5px;width:0;height:3px;transition:width .25s;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.bottom-nav-item.active:after{width:20px}.empty-state{position:relative;overflow:hidden}.empty-state:before{content:"";background:radial-gradient(circle, var(--accent-dim) 0%, transparent 70%);opacity:.4;z-index:0;pointer-events:none;border-radius:50%;width:200px;height:200px;position:absolute;top:-60px;right:-60px}.empty-state>*{z-index:1;position:relative}.empty-state-emoji{animation:2.5s ease-in-out infinite emojiBounce;display:inline-block}@keyframes emojiBounce{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-6px)scale(1.05)}}.skeleton-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);align-items:center;gap:14px;margin-bottom:8px;padding:16px;display:flex}.skeleton-circle{border-radius:var(--radius);background:linear-gradient(90deg, var(--bg-alt) 25%, var(--border-light) 50%, var(--bg-alt) 75%);background-size:200% 100%;flex-shrink:0;width:28px;height:28px;animation:1.5s infinite shimmer}.skeleton-lines{flex-direction:column;flex:1;gap:8px;display:flex}.skeleton-line{background:linear-gradient(90deg, var(--bg-alt) 25%, var(--border-light) 50%, var(--bg-alt) 75%);background-size:200% 100%;border-radius:4px;height:14px;animation:1.5s infinite shimmer}.skeleton-line-short{width:40%;height:10px}.skeleton-line-medium{width:65%}.skeleton-line-long{width:85%}.form-input:disabled{background:var(--bg-alt);color:var(--text-3);cursor:not-allowed;opacity:.6}@keyframes swipeHint{0%,to{transform:translate(0)}30%{transform:translate(-16px)}60%{transform:translate(0)}}.item-swipe-container:first-child .item-row-swipeable{animation:2s 1.5s swipeHint}.search-result-item{border-left:3px solid #0000}.search-result-item.selected{border-left-color:var(--accent)}.fab{transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s}.fab:active{transform:scale(.88);box-shadow:0 2px 8px #3b8c5c40}.completed-list{animation:.25s completedExpand}@keyframes completedExpand{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.progress-bar-fill.complete{background:linear-gradient(90deg, var(--accent), var(--accent-light));box-shadow:0 0 8px #3b8c5c4d}.toast-success{animation:.25s toastIn,.25s 2.5s forwards toastSuccessOut}.toast-error{animation:.25s toastIn,.3s 2.5s forwards toastErrorOut}@keyframes toastSuccessOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)scale(.95)}}@keyframes toastErrorOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translate(100px)}}.profile-group-item{transition:background .18s,transform .1s}.profile-group-item:hover{transform:translate(2px)}.profile-group-item:active{transform:scale(.98)}.btn-google svg{transition:transform .25s}.btn-google:hover svg{transform:scale(1.15)rotate(5deg)}.group-card-new:hover{border-color:var(--accent);background:var(--accent-dim)}.group-card-new .group-card-emoji{transition:transform .25s}.group-card-new:hover .group-card-emoji{transform:scale(1.2)rotate(90deg)}.form-label{color:var(--text);font-weight:700}@media (width>=540px){html{background:var(--bg-alt)}.layout{box-shadow:0 0 0 1px var(--border-light), 0 8px 32px #0000000f;background:var(--bg);border-radius:32px;min-height:calc(100dvh - 64px);margin:32px auto}.bottom-nav{border-radius:0 0 32px 32px;bottom:32px}.fab{bottom:122px}.login-page{max-width:480px;box-shadow:0 0 0 1px var(--border-light), 0 8px 32px #0000000f;background:var(--bg);border-radius:32px;min-height:calc(100dvh - 64px);margin:32px auto}}
