@import"https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;500;600;700;800&family=Fraunces:ital,opsz,wght@1,9..144,400;1,9..144,600;1,9..144,700&display=swap";:root{--bg: #fef6f0;--peach: #f9dfd1;--peach2: #f2c7b0;--mint: #d1ede5;--mint2: #a8dccf;--lav: #e5d6f5;--rose: #f5d6df;--text: #3d2c24;--text2: #7a6058;--border: #ebd9cf;--white: #fffcf9;--green: #3a8c6e;--green2: #5ab892;--danger: #d04060;--edit-col: #8855cc;--tab-h: 80px;--head-h: 72px;--blue: #8855cc;--red: #d04060;--label: #3d2c24;--label2: #7a6058;--label3: rgba(61,44,36,.35);--sep: #ebd9cf;--surface: #fffcf9;--gray3: #d4bfb5;--gray4: #e0cfc8;--gray5: #f0e4de;--sat: env(safe-area-inset-top, 44px);--sab: env(safe-area-inset-bottom, 34px);--bottom-safe: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html,body{height:100%;margin:0;padding:0;font-family:Nunito,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none;background-image:radial-gradient(ellipse at 10% 10%,rgba(249,223,209,.7) 0%,transparent 50%),radial-gradient(ellipse at 90% 80%,rgba(209,237,229,.6) 0%,transparent 50%);background-attachment:fixed}#root{display:flex;flex-direction:column;height:var(--app-height, 100dvh)}.rotate-msg{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:9999;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text2);font-size:15px}@media (orientation: landscape){.rotate-msg{display:flex}}.app-shell{display:flex;flex-direction:column;height:var(--app-height, 100dvh);overflow:hidden}.header{flex-shrink:0;height:calc(var(--sat) + var(--head-h));padding-top:var(--sat);padding-left:20px;padding-right:20px;background:#fffcf9e0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;flex-direction:column}.header-title-row{display:flex;align-items:center;gap:7px}.header-title{font-family:Fraunces,serif;font-style:italic;font-size:27px;font-weight:700;color:var(--text);letter-spacing:-.5px;line-height:1}.cart-anim{font-size:22px;display:inline-block;animation:cartRide 1.8s ease-in-out infinite}@keyframes cartRide{0%{transform:translate(0) rotate(-3deg)}25%{transform:translate(4px) rotate(2deg) translateY(-1px)}50%{transform:translate(7px) rotate(-1deg)}75%{transform:translate(3px) rotate(2deg) translateY(-1px)}to{transform:translate(0) rotate(-3deg)}}.clock-anim{font-size:18px;display:inline-block}.header-subtitle{font-size:11px;font-weight:500;color:var(--text2);letter-spacing:.5px;margin-top:2px}.header-right{display:flex;align-items:center;gap:8px}.icon-btn{width:40px;height:40px;border-radius:14px;border:1.5px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all .2s;box-shadow:0 2px 8px #3d2c240f}.icon-btn:active{transform:scale(.92);background:var(--peach)}.count-badge{background:linear-gradient(135deg,var(--green),var(--green2));color:#fff;font-size:11px;font-weight:700;min-width:22px;height:22px;border-radius:11px;padding:0 7px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #3a8c6e66;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-family:Nunito,sans-serif}.count-badge.zero{background:#ccc;box-shadow:none}.scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:16px 0 110px}.scroll-area::-webkit-scrollbar{display:none}.section-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);padding:0 20px 10px;font-family:Nunito,sans-serif}.sep-row{display:flex;align-items:center;gap:10px;padding:12px 20px 10px}.sep-line{flex:1;height:1.5px;background:var(--border);border-radius:2px}.sep-text{font-size:11px;font-weight:700;color:var(--text2);white-space:nowrap}.empty-state{text-align:center;padding:60px 40px;animation:fadeUp .5s ease}.empty-icon{font-size:52px;margin-bottom:12px;display:block;animation:float 3s ease-in-out infinite}.empty-title{font-family:Fraunces,serif;font-style:italic;font-size:20px;color:var(--text);margin-bottom:8px}.empty-sub{font-size:14px;color:var(--text2);font-weight:400;line-height:1.5}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.item-wrapper{position:relative;margin:0 14px 9px;border-radius:18px;overflow:hidden}.swipe-actions{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:18px;display:flex;pointer-events:none}.swipe-action-left{flex:1;background:linear-gradient(135deg,var(--edit-col),#aa77ee);display:flex;align-items:center;padding-left:18px;border-radius:18px 0 0 18px;gap:8px}.swipe-action-right{flex:1;background:linear-gradient(135deg,#ee4466,var(--danger));display:flex;align-items:center;justify-content:flex-end;padding-right:18px;border-radius:0 18px 18px 0;gap:8px}.swipe-action-icon{color:#fff;font-size:22px;opacity:0;transform:scale(.5);transition:all .22s cubic-bezier(.34,1.56,.64,1)}.swipe-action-icon.visible{opacity:1;transform:scale(1)}.swipe-label{color:#fff;font-size:12px;font-weight:700;opacity:0;transition:opacity .2s}.swipe-label.visible{opacity:1}.item-card{background:var(--white);border:1.5px solid var(--border);border-radius:18px;display:flex;align-items:center;gap:12px;padding:12px 14px;box-shadow:0 2px 10px #3d2c240f;position:relative;z-index:1;will-change:transform;user-select:none;-webkit-user-select:none;animation:popIn .35s cubic-bezier(.34,1.56,.64,1);touch-action:pan-y}.item-card:not(.swiping){transition:transform .32s cubic-bezier(.34,1.2,.64,1)}@keyframes popIn{0%{opacity:0;transform:scale(.88) translateY(-8px)}70%{transform:scale(1.03) translateY(2px)}to{opacity:1;transform:scale(1) translateY(0)}}.item-wrapper.removing .item-card{animation:removeAnim .3s cubic-bezier(.4,0,.2,1) forwards}.item-wrapper.removing{animation:collapseH .3s .18s cubic-bezier(.4,0,.2,1) forwards;overflow:hidden}@keyframes removeAnim{to{opacity:0;transform:scale(.82) translate(28px)}}@keyframes collapseH{to{max-height:0;margin-bottom:0}}.item-wrapper.done .item-card{background:var(--mint);border-color:#b5ddd1}.item-wrapper.done .item-name{text-decoration:line-through;text-decoration-color:var(--mint2);color:var(--text2);font-weight:400}.item-wrapper.done .item-photo-placeholder{background:var(--mint);border-color:var(--mint2)}.item-photo{width:46px;height:46px;border-radius:13px;object-fit:cover;border:1.5px solid var(--border);flex-shrink:0;cursor:pointer}.item-photo-placeholder{width:46px;height:46px;border-radius:13px;background:var(--peach);border:1.5px dashed var(--peach2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.check-circle{width:28px;height:28px;border-radius:50%;border:2.5px solid var(--border);background:#fff;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.check-circle:active{transform:scale(.82)}.check-circle.checked{background:linear-gradient(135deg,var(--green),var(--green2));border-color:transparent;box-shadow:0 3px 12px #3a8c6e66;transform:scale(1.08)}.check-circle .tick{color:#fff;font-size:14px;font-weight:800;opacity:0;transform:scale(0) rotate(-30deg);transition:all .22s cubic-bezier(.34,1.56,.64,1)}.check-circle.checked .tick{opacity:1;transform:scale(1) rotate(0)}.item-info{flex:1;min-width:0}.item-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .2s}.item-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:2px;align-items:center}.item-qty{font-size:12px;color:var(--text2);font-weight:600}.item-notes{font-size:11px;color:var(--text2);font-weight:400;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.swipe-hint-label{font-size:11px;color:var(--text2);text-align:center;padding:0 0 10px;opacity:.65;font-weight:500}.tab-bar{flex-shrink:0;height:calc(var(--tab-h) + var(--sab));padding-bottom:var(--sab);background:#fffcf9ed;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1.5px solid var(--border);display:flex;align-items:flex-start;padding-top:6px;z-index:50}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;padding:8px 4px 4px;transition:all .2s}.tab-item:active{transform:scale(.88)}.tab-icon-wrap{width:34px;height:34px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;transition:all .28s cubic-bezier(.34,1.56,.64,1)}.tab-item.active .tab-icon-wrap{background:linear-gradient(135deg,var(--peach),var(--rose));box-shadow:0 3px 12px #c0506038;transform:scale(1.1) translateY(-2px)}.tab-label{font-size:10px;font-weight:700;letter-spacing:.3px;color:var(--text2);transition:color .2s}.tab-item.active .tab-label{color:var(--danger)}.fab{position:fixed;right:20px;bottom:calc(var(--tab-h) + var(--sab) + 16px);width:56px;height:56px;border-radius:20px;background:linear-gradient(135deg,var(--green),var(--green2));border:none;color:#fff;font-size:30px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px #3a8c6e73;transition:all .22s cubic-bezier(.34,1.56,.64,1);z-index:50;line-height:1}.fab:active{transform:scale(.86) rotate(18deg)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3d2c245c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:200;display:flex;align-items:flex-end;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-sheet{background:var(--white);border-radius:28px 28px 0 0;width:100%;padding:12px 20px 44px;animation:slideUp .38s cubic-bezier(.34,1.2,.64,1);max-height:92dvh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{width:38px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 16px}.modal-title{font-family:Fraunces,serif;font-style:italic;font-size:22px;font-weight:600;color:var(--text);text-align:center;margin-bottom:20px}.photo-picker{display:flex;align-items:center;gap:14px;margin-bottom:18px}.photo-preview-box{width:68px;height:68px;border-radius:18px;border:2px solid var(--border);background:var(--peach);display:flex;align-items:center;justify-content:center;font-size:30px;flex-shrink:0;overflow:hidden}.photo-preview-box img{width:100%;height:100%;object-fit:cover}.photo-controls{display:flex;flex-direction:column;gap:8px;flex:1}.photo-btn-row{display:flex;gap:8px;align-items:center}.photo-btn{flex:1;background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:8px 10px;font-family:Nunito,sans-serif;font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:all .15s;white-space:nowrap}.photo-btn:active{background:var(--peach);border-color:var(--peach2);transform:scale(.96)}.photo-del-btn{width:36px;height:36px;flex-shrink:0;background:#d0406014;border:1.5px solid rgba(208,64,96,.25);border-radius:12px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.photo-del-btn:active{background:#d040602e;transform:scale(.9)}.photo-note{font-size:11px;color:var(--text2);font-style:italic;font-weight:400}.form-group{margin-bottom:14px}.form-label{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text2);margin-bottom:6px;display:block}.form-label .opt{font-weight:400;letter-spacing:0;text-transform:none;font-style:italic;color:var(--border);font-size:10px;margin-left:4px}.form-input{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:12px 16px;font-family:Nunito,sans-serif;font-size:16px;font-weight:500;color:var(--text);outline:none;transition:all .2s;-moz-appearance:none;appearance:none;-webkit-appearance:none}.form-input:focus{border-color:var(--green);background:var(--mint);box-shadow:0 0 0 3px #3a8c6e1f}textarea.form-input{resize:none;min-height:68px;line-height:1.5;font-size:14px}.form-row{display:flex;gap:10px}.form-row .form-group{flex:1}input[type=date].form-input,input[type=time].form-input{color:var(--text);font-size:15px}.datetime-card{background:var(--bg);border:1.5px solid var(--border);border-radius:16px;padding:14px 16px;margin-bottom:14px}.datetime-title{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--text2);margin-bottom:12px;display:block}.datetime-fields{display:flex;gap:10px;margin-bottom:10px}.datetime-fields .form-group{flex:1;margin-bottom:0}.datetime-fields .form-label{font-size:10px}.no-schedule-row{display:flex;align-items:center;gap:10px}.no-schedule-label{font-size:13px;font-weight:500;color:var(--text2)}.toggle-switch{width:44px;height:26px;background:var(--border);border-radius:13px;position:relative;cursor:pointer;transition:background .25s;flex-shrink:0;border:none}.toggle-switch.on{background:linear-gradient(135deg,var(--green),var(--green2))}.toggle-knob{width:20px;height:20px;background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;transition:transform .25s cubic-bezier(.34,1.56,.64,1);box-shadow:0 1px 4px #0003}.toggle-switch.on .toggle-knob{transform:translate(18px)}.save-btn{width:100%;background:linear-gradient(135deg,var(--green),var(--green2));color:#fff;border:none;border-radius:16px;padding:15px;font-family:Nunito,sans-serif;font-size:16px;font-weight:700;cursor:pointer;margin-top:6px;box-shadow:0 5px 20px #3a8c6e59;transition:all .2s}.save-btn:active{transform:scale(.97);box-shadow:0 2px 10px #3a8c6e40}.save-btn:disabled{opacity:.45;cursor:default}.save-btn:disabled:active{transform:none}.settings-row{display:flex;align-items:center;gap:14px;background:var(--bg);border:1.5px solid var(--border);border-radius:16px;padding:14px 16px;margin-bottom:14px}.settings-avatar{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--peach),var(--rose));display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.settings-name{font-size:16px;font-weight:700;color:var(--text)}.settings-detail{font-size:12px;color:var(--text2);margin-top:2px}.settings-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:13px 16px;margin-bottom:8px;cursor:pointer;transition:all .15s}.settings-item:active{background:var(--peach)}.settings-item-left{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:600;color:var(--text)}.settings-item-icon{font-size:20px}.settings-item-arrow{color:var(--text2);font-size:16px}.danger-btn{width:100%;background:#d0406014;color:var(--danger);border:1.5px solid rgba(208,64,96,.22);border-radius:14px;padding:13px;font-family:Nunito,sans-serif;font-size:15px;font-weight:700;cursor:pointer;margin-top:8px;transition:all .2s}.danger-btn:active{background:#d0406029}.task-wrapper{position:relative;margin:0 14px 9px;border-radius:18px;overflow:hidden}.task-swipe-left{position:absolute;top:0;left:0;bottom:0;width:55%;background:linear-gradient(135deg,var(--edit-col),#aa77ee);border-radius:18px 0 0 18px;display:flex;align-items:center;padding-left:20px;gap:8px;pointer-events:none}.task-swipe-right{position:absolute;top:0;right:0;bottom:0;width:55%;background:linear-gradient(135deg,#ee4466,var(--danger));border-radius:0 18px 18px 0;display:flex;align-items:center;justify-content:flex-end;padding-right:20px;gap:8px;pointer-events:none}.sw-icon{color:#fff;font-size:22px;opacity:0;transform:scale(.5);transition:all .22s cubic-bezier(.34,1.56,.64,1)}.sw-icon.v{opacity:1;transform:scale(1)}.sw-lbl{color:#fff;font-size:12px;font-weight:700;opacity:0;transition:opacity .2s}.sw-lbl.v{opacity:1}.task-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.p-high{background:#e84060;box-shadow:0 0 0 3px #e840602e}.p-mid{background:#f0a030;box-shadow:0 0 0 3px #f0a0302e}.p-low{background:var(--green);box-shadow:0 0 0 3px #3a8c6e2e}.task-info{flex:1;min-width:0}.task-name{font-size:15px;font-weight:600;color:var(--text)}.task-sub{font-size:12px;color:var(--text2);margin-top:2px;font-weight:400}.task-dt{font-size:11px;font-weight:700;color:var(--edit-col);background:var(--lav);border-radius:8px;padding:2px 8px;margin-top:5px;display:inline-block}.task-check{width:28px;height:28px;border-radius:50%;border:2.5px solid var(--border);background:#fff;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;font-weight:800;color:transparent;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.task-check:active{transform:scale(.82)}.task-check.chk{background:linear-gradient(135deg,var(--green),var(--green2));border-color:transparent;box-shadow:0 3px 12px #3a8c6e59;color:#fff}.task-wrapper.done .item-card{background:var(--mint);border-color:#b5ddd1}.task-wrapper.done .task-name{text-decoration:line-through;text-decoration-color:var(--mint2);color:var(--text2);font-weight:400}.confetti-piece{position:fixed;pointer-events:none;z-index:999;font-size:18px;animation:confettiFall .9s ease-out forwards}@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0) scale(1)}to{opacity:0;transform:translateY(70px) rotate(220deg) scale(.4)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.action-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3d2c2452;z-index:400;display:flex;flex-direction:column;justify-content:flex-end;padding:8px;padding-bottom:calc(8px + var(--sab));animation:fadeIn .2s}.action-sheet{background:#fffcf9f5;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-radius:22px;overflow:hidden;margin-bottom:8px;border:1.5px solid var(--border);animation:slideUp .25s cubic-bezier(.32,.72,0,1)}.action-sheet-title{padding:14px 16px 10px;text-align:center;border-bottom:1.5px solid var(--border)}.action-sheet-title p{margin:4px 0 0;font-size:13px;color:var(--text2)}.action-sheet-title strong{font-size:13px;font-weight:700}.action-sheet-btn{display:block;width:100%;padding:16px;background:none;border:none;font-size:18px;font-family:Nunito,sans-serif;font-weight:600;cursor:pointer;text-align:center;transition:background .12s}.action-sheet-btn:active{background:var(--peach)}.action-sheet-btn+.action-sheet-btn{border-top:1.5px solid var(--border)}.action-sheet-btn.danger{color:var(--danger)}.action-sheet-cancel{background:#fffcf9f5;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-radius:22px;overflow:hidden;border:1.5px solid var(--border)}.action-sheet-cancel button{display:block;width:100%;padding:18px;background:none;border:none;font-size:18px;font-weight:700;font-family:Nunito,sans-serif;color:var(--text);cursor:pointer}.photo-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f0804eb;z-index:300;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.photo-overlay img{max-width:100%;max-height:100%;object-fit:contain;touch-action:none;border-radius:12px}.photo-close{position:absolute;top:calc(var(--sat) + 8px);right:16px;width:34px;height:34px;border-radius:50%;background:#fffcf933;border:none;color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--green2);border-radius:50%;animation:spin .7s linear infinite;margin:40px auto;display:block}@keyframes spin{to{transform:rotate(360deg)}}.login-wrap{height:var(--app-height, 100dvh);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 28px;background:var(--bg);background-image:radial-gradient(ellipse at 15% 15%,rgba(249,223,209,.7) 0%,transparent 50%),radial-gradient(ellipse at 85% 80%,rgba(209,237,229,.6) 0%,transparent 50%)}
