:root{--bg:#f9f5f0;--surface:#fffdfa;--surface-sunk:#f1eae1;--ink:#2b2b2b;--ink-soft:#6b6459;--primary:#556b4a;--primary-dark:#45583c;--primary-tint:#e6ece1;--accent:#d97533;--accent-dark:#bf5f22;--success:#a8d5ba;--success-deep:#3f7a57;--danger:#b4452f;--line:#e4dccf;--shadow:0 18px 40px -24px rgba(85,107,74,0.45);--radius:16px;--radius-sm:10px;--font-display:var(--font-sora),"Sora",system-ui,sans-serif;--font-body:var(--font-inter),"Inter",system-ui,sans-serif}*{box-sizing:border-box}body,html{margin:0;padding:0}body{background-color:var(--bg);background-image:radial-gradient(circle at 12% 8%,rgba(168,213,186,.18),transparent 38%),radial-gradient(circle at 92% 0,rgba(217,117,51,.1),transparent 32%);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.55;min-height:100vh;-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.05;margin:0}a{color:var(--primary);font-weight:600}button{cursor:pointer}button,input{font-family:inherit}.auth-shell{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}.auth-aside{background:linear-gradient(155deg,var(--primary) 0,var(--primary-dark) 100%);color:#f4f0e8;padding:clamp(2rem,5vw,4.5rem);display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.auth-aside:after{content:"";position:absolute;inset:auto -30% -40% auto;width:70%;aspect-ratio:1;border-radius:50%;background:rgba(217,117,51,.28);filter:blur(8px)}.auth-aside__eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.32em;font-size:.72rem;font-weight:600;opacity:.85}.auth-aside__title{font-size:clamp(2.2rem,4vw,3.4rem);max-width:14ch;margin-top:1.5rem}.auth-aside__lede{max-width:34ch;opacity:.9;font-size:1.05rem;position:relative;z-index:1}.auth-aside__sign{color:rgba(244,240,232,.72);font-size:.92rem;position:relative;z-index:1}.auth-main{display:flex;align-items:center;justify-content:center;padding:clamp(1.5rem,5vw,4rem)}.auth-card{width:100%;max-width:380px}.auth-card h1{font-size:2rem}.auth-card__sub{color:var(--ink-soft);margin:.6rem 0 2rem}.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}.field label{font-size:.82rem;font-weight:600;letter-spacing:.01em;color:var(--ink-soft)}.field input{border:1.5px solid var(--line);border-radius:var(--radius-sm);padding:.8rem .9rem;font-size:1rem;background:var(--surface);color:var(--ink);transition:border-color .18s ease,box-shadow .18s ease}.field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-tint)}.btn{border:none;border-radius:var(--radius-sm);font-weight:600;font-size:1rem;padding:.8rem 1.2rem;transition:transform .15s ease,background-color .18s ease,box-shadow .18s ease}.btn:disabled{opacity:.6;cursor:progress}.btn-primary{background:var(--primary);color:#f7f4ee;width:100%;box-shadow:0 10px 24px -14px rgba(85,107,74,.8)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover:not(:disabled){background:var(--accent-dark)}.btn-ghost{background:transparent;color:var(--ink-soft);border:1.5px solid var(--line)}.btn-ghost:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.btn-danger{background:transparent;color:var(--danger);border:1.5px solid rgba(180,69,47,.3)}.btn-danger:hover:not(:disabled){background:rgba(180,69,47,.08)}.auth-switch{margin-top:1.6rem;color:var(--ink-soft);font-size:.92rem;text-align:center}.form-error{background:rgba(180,69,47,.08);border:1px solid rgba(180,69,47,.25);color:var(--danger);border-radius:var(--radius-sm);padding:.7rem .9rem;font-size:.88rem;margin-bottom:1.1rem}.topbar{justify-content:space-between;gap:1rem;padding:1.4rem clamp(1.2rem,5vw,3.5rem);border-bottom:1px solid var(--line);background:rgba(255,253,250,.75);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:-webkit-sticky;position:sticky;top:0;z-index:10}.brand,.topbar{display:flex;align-items:center}.brand{gap:.7rem;font-family:var(--font-display);font-weight:700;letter-spacing:-.01em}.brand__mark{width:34px;height:34px;border-radius:10px;background:var(--primary);color:#f7f4ee;display:grid;place-items:center;font-size:1.1rem}.topbar__user{display:flex;align-items:center;gap:.9rem;color:var(--ink-soft);font-size:.9rem}.topbar__user strong{color:var(--ink)}.page{max-width:880px;margin:0 auto;padding:clamp(1.5rem,4vw,3rem) clamp(1.2rem,5vw,2rem) 4rem}.page__head{margin-bottom:2rem}.page__eyebrow{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.28em;font-size:.72rem;font-weight:600;color:var(--accent)}.page__title{font-size:clamp(1.9rem,4vw,2.6rem);margin-top:.5rem}.page__subtitle{color:var(--ink-soft);margin-top:.6rem;max-width:48ch}.add-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow);margin-bottom:2rem}.add-form{display:grid;grid-template-columns:1fr 110px auto;grid-gap:.7rem;gap:.7rem;align-items:end}.list-toolbar{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.list-toolbar__count{color:var(--ink-soft);font-size:.9rem}.list{flex-direction:column;gap:.7rem;list-style:none;margin:0;padding:0}.item,.list{display:flex}.item{align-items:center;gap:.9rem;background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--radius);padding:.9rem 1rem;transition:opacity .25s ease,border-color .25s ease,background .25s ease;animation:rise-in .4s cubic-bezier(.22,1,.36,1) both}.item.is-purchased{opacity:.62;border-left-color:var(--success-deep);background:var(--surface-sunk)}.item__check{width:26px;height:26px;border-radius:50%;border:2px solid var(--primary);background:transparent;display:grid;place-items:center;flex-shrink:0;color:transparent;transition:background .18s ease,color .18s ease,border-color .18s ease;font-size:.8rem}.item.is-purchased .item__check{background:var(--success-deep);border-color:var(--success-deep);color:#fff}.item__body{flex:1 1;min-width:0}.item__name{font-weight:600;font-size:1.02rem;word-break:break-word}.item.is-purchased .item__name{text-decoration:line-through;color:var(--ink-soft)}.item__meta{font-size:.82rem;color:var(--ink-soft)}.item__qty{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.15rem .55rem;border-radius:999px;background:var(--primary-tint);color:var(--primary-dark);font-weight:600;font-size:.85rem}.item__actions{display:flex;gap:.4rem;flex-shrink:0}.icon-btn{border:1px solid var(--line);background:var(--surface);border-radius:8px;padding:.4rem .7rem;font-size:.82rem;font-weight:600;color:var(--ink-soft);transition:border-color .15s ease,color .15s ease,background .15s ease}.icon-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.icon-btn.is-danger:hover:not(:disabled){border-color:var(--danger);color:var(--danger)}.icon-btn:disabled{opacity:.5;cursor:progress}.item-edit{display:grid;grid-template-columns:1fr 100px auto auto;grid-gap:.5rem;gap:.5rem;width:100%;align-items:center}.item-edit input{border:1.5px solid var(--line);border-radius:8px;padding:.55rem .7rem;font-size:.95rem;background:var(--surface)}.item-edit input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint)}.empty{text-align:center;padding:3rem 1.5rem;border:1.5px dashed var(--line);border-radius:var(--radius);color:var(--ink-soft);background:rgba(255,253,250,.5)}.empty__title{font-family:var(--font-display);font-weight:700;color:var(--ink);margin-bottom:.4rem;font-size:1.2rem}.banner-error{background:rgba(180,69,47,.08);border:1px solid rgba(180,69,47,.25);color:var(--danger);border-radius:var(--radius-sm);padding:.7rem .9rem;font-size:.9rem;margin-bottom:1.2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.banner-error button{background:none;border:none;color:var(--danger);font-weight:700;font-size:1.1rem;line-height:1}.skeleton{height:64px;border-radius:var(--radius);background:linear-gradient(90deg,var(--surface-sunk) 25%,#efe7da 37%,var(--surface-sunk) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite}.muted{color:var(--ink-soft)}.modal-overlay{position:fixed;inset:0;background:rgba(43,43,43,.45);display:grid;place-items:center;padding:1.2rem;z-index:50;animation:fade-in .18s ease both}.modal{background:var(--surface);border-radius:var(--radius);padding:1.7rem;width:100%;max-width:400px;box-shadow:0 30px 60px -20px rgba(43,43,43,.5);animation:rise-in .25s cubic-bezier(.22,1,.36,1) both}.modal h2{font-size:1.3rem;margin-bottom:.6rem}.modal p{color:var(--ink-soft);margin:0 0 1.5rem}.modal__actions{display:flex;gap:.7rem;justify-content:flex-end}.modal__actions .btn{width:auto;padding:.65rem 1.1rem}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}@media (max-width:720px){.auth-shell{grid-template-columns:1fr}.auth-aside{display:none}.add-form{grid-template-columns:1fr}.add-form .btn{width:100%}.item-edit{grid-template-columns:1fr 1fr}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}@font-face{font-family:Sora;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/1d4eaed977255102-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Sora;font-style:normal;font-weight:100 800;font-display:swap;src:url(/_next/static/media/f3f7e95f2dbc4fe4-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Sora Fallback;src:local("Arial");ascent-override:85.29%;descent-override:25.50%;line-gap-override:0.00%;size-adjust:113.73%}.__className_ce197d{font-family:Sora,Sora Fallback;font-style:normal}.__variable_ce197d{--font-sora:"Sora","Sora Fallback"}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Inter Fallback;src:local("Arial");ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.00%;size-adjust:107.12%}.__className_f367f3{font-family:Inter,Inter Fallback;font-style:normal}.__variable_f367f3{--font-inter:"Inter","Inter Fallback"}