*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth;font-size:16px}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}:root{--color-border:#e2dbd2;--color-bg:#f0ece5}body{color:#1e2028;background-color:#f0ece5;min-height:100dvh;font-family:DM Sans,system-ui,sans-serif;font-size:1rem;line-height:1.7}h1,h2,h3,h4,h5,h6{color:#c0503a;font-family:Playfair Display,georgia,serif;font-weight:700;line-height:1.2}h1{font-size:2.25rem}h2{font-size:1.75rem}h3{font-size:1.375rem}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:.875rem}p{color:#4a4e5a;margin-bottom:1rem}p:last-child{margin-bottom:0}a{color:#c0503a;text-decoration:none;transition:color .15s}a:hover{color:#a8422e}ul,ol{margin-bottom:1rem;padding-left:1.5rem}ul:last-child,ol:last-child{margin-bottom:0}li{color:#4a4e5a;margin-bottom:.25rem}li:last-child{margin-bottom:0}section{margin-bottom:3rem}section:last-child{margin-bottom:0}input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],textarea{color:#1e2028;background:#fff;border:1px solid #e2dbd2;border-radius:8px;outline:none;width:100%;padding:.5rem .75rem;font-family:DM Sans,system-ui,sans-serif;font-size:1rem;transition:border-color .15s,box-shadow .15s}input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=search]::placeholder,input[type=number]::placeholder,textarea::placeholder{color:#8892a4}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=search]:focus,input[type=number]:focus,textarea:focus{border-color:#c0503a;box-shadow:0 0 0 3px #f5e8e5}:root{--mobile-nav-h:64px}app-shell{display:block}.shell{min-height:100vh;display:flex}.sidebar{display:none}@media (width>=769px){.sidebar{background:#2b2d33;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;width:72px;height:100vh;padding:20px 0;display:flex;position:sticky;top:0}}.sidebar-brand{color:#fff;margin-bottom:24px;font-family:Playfair Display,georgia,serif;font-size:20px;font-weight:700;line-height:1}.sidebar-brand span{color:#c0503a}.nav-item{cursor:pointer;color:#ffffff73;background:0 0;border:none;border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{color:#fff;background:#ffffff1f}.nav-item.active:before{content:"";background:#c0503a;border-radius:0 4px 4px 0;width:4px;height:24px;position:absolute;left:-12px}.sidebar-spacer{flex:1}.page-main{min-width:0;padding-top:var(--mobile-nav-h);flex:1}@media (width>=769px){.page-main{padding-top:0}}.shell-slot{flex:1;min-width:0}.top-bar{opacity:0;flex-direction:column;gap:8px;margin-block:20px;padding:16px 16px 0;animation:.4s forwards shell-fade-in;display:flex}@media (width>=480px){.top-bar{flex-direction:row;justify-content:space-between;align-items:center;padding:20px 20px 0}}@media (width>=769px){.top-bar{padding:24px 32px 0}}@media (width>=1025px){.top-bar{padding:24px 40px 0}}.top-bar h1{color:#1e2028;letter-spacing:-.3px;font-family:Playfair Display,georgia,serif;font-size:1.125rem;font-weight:600}@media (width>=769px){.top-bar h1{font-size:1.375rem}}.top-actions{align-items:center;gap:12px;display:flex}.weather-pill{color:#4a4e5a;background:#fff;border:1px solid #e2dbd2;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:500;display:flex}@media (width>=480px){.weather-pill{padding:8px 16px;font-size:.875rem}}@keyframes shell-fade-in{to{opacity:1}}.mobile-nav{padding:calc(8px + env(safe-area-inset-top)) 16px 8px;z-index:200;background:#2b2d33;display:block;position:fixed;top:0;left:0;right:0}@media (width>=769px){.mobile-nav{display:none}}.mobile-nav-inner{justify-content:space-around;display:flex}.mob-nav-item{color:#fff6;cursor:pointer;background:0 0;border:none;border-radius:8px;flex-direction:column;align-items:center;gap:3px;padding:6px 8px;font-size:10px;font-weight:600;text-decoration:none;display:flex}.mob-nav-item.active{color:#fff}.mob-nav-item .m-icon{font-size:20px}.hidden{display:none!important}.splash{z-index:50;background:#f0ece5;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash-spinner{border:3px solid var(--color-border);border-top-color:#5c6bc0;border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.container{max-width:640px;margin:0 auto;padding:1.5rem 1rem 2rem}.add-card{border:1.5px solid var(--color-border);background:#fff;border-radius:14px;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;padding:1.1rem 1rem;animation:.3s both fade-up;display:flex;box-shadow:0 1px 4px #00000012}.add-row{gap:.5rem;display:flex}.input-main{border:1.5px solid var(--color-border);color:#1e2028;background:#f0ece5;border-radius:9px;outline:none;flex:1;min-width:0;padding:.75rem .9rem;font-family:DM Sans,system-ui,sans-serif;font-size:1rem;transition:border-color .2s,box-shadow .2s}.input-main:focus{background:#fff;border-color:#5c6bc0;box-shadow:0 0 0 3px #5c6bc01f}.input-qty{border:1.5px solid var(--color-border);color:#1e2028;text-align:center;background:#f0ece5;border-radius:9px;outline:none;flex:0 0 70px;padding:.75rem .6rem;font-family:DM Sans,system-ui,sans-serif;font-size:.875rem;transition:border-color .2s}.input-qty:focus{background:#fff;border-color:#5c6bc0}.btn-add{color:#fff;cursor:pointer;background:#5c6bc0;border:none;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.375rem;line-height:1;transition:background .2s,transform .2s;display:flex}.btn-add:hover{background:#5c6bc0;transform:scale(1.05)}.btn-add:active{transform:scale(.97)}.add-row-who{align-items:center;gap:.6rem;display:flex}.who-label{color:#8892a4;white-space:nowrap;font-size:.75rem}.who-select{border:1.5px solid var(--color-border);color:#1e2028;cursor:pointer;background:#f0ece5;border-radius:8px;outline:none;flex:1;padding:.25rem .75rem;font-family:DM Sans,system-ui,sans-serif;font-size:.875rem;transition:border-color .2s}.who-select:focus{border-color:#5c6bc0}.sync-status{border-radius:999px;align-items:center;gap:.35rem;margin-bottom:.75rem;padding:.25rem .6rem;font-size:.75rem;font-weight:500;transition:background .2s,color .2s;display:inline-flex}.sync-status__dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.sync-status--connecting{color:#8892a4;background:#0000000d}.sync-status--connecting .sync-status__dot{background:#8892a4;animation:1.4s ease-in-out infinite pulse}.sync-status--live{color:#166534;background:#22c55e1a}.sync-status--live .sync-status__dot{background:#22c55e}.sync-status--error{color:#c0392b;background:#c0392b14}.sync-status--error .sync-status__dot{background:#c0392b}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.state-msg{text-align:center;color:#8892a4;padding:2rem 0;font-size:.875rem}.item-list{flex-direction:column;gap:.45rem;list-style:none;display:flex}.item{border:1.5px solid var(--color-border);background:#fff;border-radius:11px;align-items:center;gap:.75rem;padding:.8rem .9rem;transition:opacity .2s,transform .2s;animation:.25s both item-in;display:flex}@keyframes item-in{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.item.removing{opacity:0;pointer-events:none;animation:none;transform:translate(10px)}.item-check{appearance:none;border:2px solid var(--color-border);cursor:pointer;border-radius:50%;flex-shrink:0;width:22px;height:22px;transition:border-color .2s,background .2s;position:relative}.item-check:hover{border-color:#5c6bc0}.item-check:checked{background:#5c6bc0;border-color:#5c6bc0}.item-check:checked:after{content:"";border-bottom:2px solid #fff;border-left:2px solid #fff;width:10px;height:6px;position:absolute;top:4px;left:4px;transform:rotate(-45deg)}.item-body{flex:1;min-width:0}.item-name{color:#1e2028;white-space:nowrap;text-overflow:ellipsis;font-size:1rem;font-weight:400;transition:color .2s;overflow:hidden}.item-sub{flex-wrap:wrap;gap:.5rem;margin-top:.25rem;display:flex}.item-qty{color:#5c6bc0;background:#e8eaf6;border-radius:999px;padding:.1rem .45rem;font-size:.75rem;font-weight:500}.item-who{color:#8892a4;font-size:.75rem}.item-delete{color:#8892a4;cursor:pointer;opacity:.25;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:.25rem .3rem;font-size:1.125rem;line-height:1;transition:color .2s,background .2s,opacity .2s}.item:hover .item-delete{opacity:1}.item-delete:hover{color:#c0392b;background:#fdecea}.checked-list .item{opacity:.6;background:#f0ece5}.checked-list .item-name{color:#8892a4;text-decoration:line-through}.checked-list .item-delete{opacity:1}.section-divider{color:#8892a4;letter-spacing:.05em;text-transform:uppercase;align-items:center;gap:.75rem;margin:1.25rem 0 .75rem;font-size:.75rem;font-weight:500;display:flex}.section-divider:before,.section-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.btn-clear-done{color:#8892a4;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:4px;flex-shrink:0;padding:.1rem .3rem;font-family:DM Sans,system-ui,sans-serif;font-size:.75rem;font-weight:500;transition:color .2s}.btn-clear-done:hover{color:#c0392b}#app{animation:.3s both fade-up}@keyframes fade-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (hover:none){.item-delete{opacity:1}}@media (width<=480px){.input-qty{flex-basis:58px}}
