*,:before,:after{-webkit-tap-highlight-color:transparent}html,body{overscroll-behavior-y:none}html{background:var(--paper)}button,[role=button],a{touch-action:manipulation;-webkit-user-select:none;user-select:none}@media (hover:none) and (pointer:coarse){input,textarea,select{font-size:16px}}html,body,#app{height:100%}html,body{font-family:var(--font-sans);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;font-feature-settings:"ss01", "ss02";margin:0}#app{background:var(--paper);justify-content:center;align-items:stretch;min-height:100vh;display:flex}@media (min-width:1024px){html,body{background:var(--paper-backdrop)}#app{background:linear-gradient(180deg, var(--paper-backdrop-light) 0%, var(--paper-backdrop-dark) 100%)}}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none}input,textarea,select{font:inherit;color:inherit}input:focus,textarea:focus,select:focus,button:focus{outline:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}.phone{width:100%;max-width:100%;min-height:100vh;background:var(--paper);min-height:100dvh;color:var(--ink);isolation:isolate;box-shadow:none;padding-top:env(safe-area-inset-top,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);flex-direction:column;font-size:16px;line-height:1.4;display:flex;position:relative;overflow:hidden}@media (min-width:1024px){.phone{max-width:1040px;min-height:calc(100vh - 56px);border-radius:32px;min-height:calc(100dvh - 56px);margin:28px 0;box-shadow:0 0 0 1px #1c1a150f,0 30px 80px -30px #1c1a1573}}@media (min-width:1440px){.phone{max-width:1240px}}.phone:before{content:"";pointer-events:none;mix-blend-mode:multiply;opacity:.8;z-index:0;background-image:radial-gradient(1px 1px at 20% 30%,#1c1a150a 50%,#0000 51%),radial-gradient(1px 1px at 60% 70%,#1c1a1508 50%,#0000 51%),radial-gradient(1px 1px at 80% 20%,#1c1a1509 50%,#0000 51%),radial-gradient(1px 1px at 30% 80%,#1c1a1506 50%,#0000 51%);background-size:140px 140px,90px 90px,180px 180px,110px 110px;position:absolute;inset:0}.phone>*{z-index:1;position:relative}.phone-scroll{padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;scroll-behavior:smooth;flex-direction:column;flex:1;display:flex;position:relative;overflow-y:auto}.scroll-top-fab{bottom:calc(20px + env(safe-area-inset-bottom,0px));aspect-ratio:1;background:color-mix(in oklab, var(--paper-card) 85%, transparent);-webkit-backdrop-filter:saturate(180%)blur(18px);border:1px solid var(--line);width:56px;height:56px;color:var(--ink);box-shadow:var(--shadow-pop,0 10px 24px #00000024);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s var(--spring), transform .32s var(--spring-bounce), border-color .16s var(--spring), background .16s var(--spring);z-index:20;border-radius:50%;justify-content:center;align-self:flex-end;align-items:center;margin-top:auto;margin-right:20px;padding:0;display:inline-flex;position:sticky;transform:translateY(12px)scale(.85)}.scroll-top-fab.visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.scroll-top-fab:hover{border-color:var(--accent);color:var(--accent-ink)}.scroll-top-fab:active{transition:transform 90ms var(--spring);transform:translateY(0)scale(.92)}.scroll-top-fab svg{width:22px;height:22px;transform:rotate(90deg)}.phone-scroll::-webkit-scrollbar{width:6px}.phone-scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px}.topbar{justify-content:space-between;align-items:center;gap:10px;padding:14px 20px 4px;display:flex}@media (min-width:640px){.topbar{padding:18px 28px 6px}}@media (min-width:1024px){.topbar{padding:22px 40px 8px}}.topbar.compact-top{gap:8px;padding:12px 16px 6px 10px}.topbar.compact-top .back-chev{width:36px;height:36px;color:var(--ink-2);transition:background .16s ease, transform .22s var(--spring);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.topbar.compact-top .back-chev:hover{background:var(--paper-2)}.topbar.compact-top .back-chev:active{transition:transform 80ms var(--spring);transform:scale(.88)}.topbar.compact-top .title-inline{flex:1;align-items:baseline;gap:10px;min-width:0;display:flex;overflow:hidden}.topbar.compact-top .title-inline h1{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--ink);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:26px;font-weight:400;line-height:1.1;overflow:hidden}.topbar .back{color:var(--ink-3);align-items:center;gap:6px;padding:8px 8px 8px 0;font-size:14px;font-weight:500;display:inline-flex}.topbar .back:hover{color:var(--ink)}.icon-btn{width:40px;height:40px;color:var(--ink-2);transition:background .16s ease, color .16s ease, transform .22s var(--spring);border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{background:var(--paper-2)}.icon-btn:active{background:var(--paper-3);transition:transform 80ms var(--spring);transform:scale(.9)}.icon-btn.sm{width:32px;height:32px}.header{padding:4px 24px 12px}@media (min-width:640px){.header{padding:8px 28px 18px}}@media (min-width:1024px){.header{padding:14px 40px 22px}}.header .eyebrow{color:var(--ink-3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2px;font-size:12px;font-weight:500}.header h1{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--ink);margin:0 0 6px;font-size:34px;font-weight:400;line-height:1}@media (min-width:1024px){.header h1{font-size:44px}.header .eyebrow{font-size:13px}}.header .sub{color:var(--ink-3);flex-wrap:wrap;align-items:center;gap:8px;font-size:13.5px;display:flex}.pill{background:var(--paper-2);color:var(--ink-2);border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:12.5px;font-weight:500;display:inline-flex}button.pill,.pill.pill-btn{cursor:pointer;border:none;transition:background .14s,color .14s,transform .14s}button.pill:hover,.pill.pill-btn:hover{background:var(--paper-3);color:var(--ink)}button.pill:active,.pill.pill-btn:active{transform:scale(.97)}.searchwrap{z-index:30;padding:4px 16px 8px;position:relative}.search{background:var(--paper-card);border:1px solid var(--line);border-radius:14px;align-items:center;gap:10px;padding:12px 14px;transition:border-color .16s,box-shadow .16s;display:flex}.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.search>svg{color:var(--ink-4);flex-shrink:0}.search input{color:var(--ink);background:0 0;border:none;flex:1;min-width:0;font-size:16px}.search input::placeholder{color:var(--ink-4)}.search .add-btn{background:var(--accent);color:#fff;opacity:0;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;transition:transform .18s cubic-bezier(.2,.9,.3,1.2),opacity .16s;display:inline-flex;transform:scale(.92)}.search .add-btn.visible{opacity:1;transform:scale(1)}.search .add-btn:hover{filter:brightness(1.05)}.search-conflict{color:var(--accent-ink);margin:0;padding:6px 14px 10px;font-size:12px}.searchbox{background:var(--paper-card);border:1px solid var(--line);border-radius:14px;transition:border-color .16s,box-shadow .16s,border-radius .14s;position:relative}.searchbox:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.searchbox.open{border-radius:14px 14px 0 0}.searchbox .search{background:0 0;border:none;border-radius:0;padding:12px 14px}.searchbox .search:focus-within{box-shadow:none;border-color:#0000}.ac{background:var(--paper-card);border:1px solid var(--line);box-shadow:var(--shadow-pop);z-index:40;border-top:none;border-radius:0 0 14px 14px;flex-direction:column;max-height:340px;animation:.14s acPop;display:flex;position:absolute;top:100%;left:-1px;right:-1px;overflow:hidden}.searchbox:focus-within .ac{border-color:var(--accent)}@keyframes acPop{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ac-scroll{overscroll-behavior:contain;overflow-y:auto}.ac-scroll::-webkit-scrollbar{width:6px}.ac-scroll::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px}.ac-item{cursor:pointer;color:var(--ink-2);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:10px 14px;font-size:14.5px;transition:background .14s;display:flex}.ac-item:hover,.ac-item.active{background:var(--paper-2);color:var(--ink)}.ac-item.done{color:var(--ink-4)}.ac-item.done .ac-label{text-decoration:line-through;-webkit-text-decoration-color:var(--ink-4);text-decoration-color:var(--ink-4)}.ac-item .cat-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.ac-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.ac-qty{color:var(--ink-4);flex-shrink:0;font-size:13px;font-weight:500}.ac-empty{color:var(--ink-3);text-align:center;padding:16px 14px;font-size:13.5px}.toolbar{color:var(--ink-3);justify-content:space-between;align-items:center;gap:8px;padding:0 20px 10px;font-size:13px;display:flex}.chip{color:var(--ink-2);min-width:104px;height:28px;transition:background .14s ease, transform .22s var(--spring);background:0 0;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:4px;padding:5px 10px;font-size:13px;font-weight:500;display:inline-flex}.chip:hover{background:var(--paper-2)}.chip:active{transition:transform 80ms var(--spring);transform:scale(.94)}.chip.active{background:var(--ink);color:var(--paper)}.seg{background:var(--paper-2);border-radius:999px;gap:2px;padding:3px;display:inline-flex}.seg button{color:var(--ink-3);border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:500}.seg button.active{background:var(--paper-card);color:var(--ink);box-shadow:0 1px 3px #0000000d}.listwrap{scroll-behavior:smooth;padding:0 20px 28px}.listwrap--lists{padding-top:8px}@media (min-width:640px){.listwrap{padding:0 28px 32px}.listwrap--lists{padding-top:10px}}@media (min-width:1024px){.listwrap{padding:0 40px 44px}.listwrap--lists{padding-top:14px}}.section-label{color:var(--ink-3);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:8px;padding:10px 6px 6px;font-size:11px;font-weight:700;display:flex}button.section-label.section-label-btn{cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;letter-spacing:.12em;text-transform:uppercase;background:0 0;border:0;border-radius:6px;transition:background .14s,color .14s}button.section-label.section-label-btn:hover{color:var(--ink);background:color-mix(in oklab, var(--ink) 5%, transparent)}.section-chevron{color:var(--ink-4);transition:transform .18s var(--spring);margin-left:auto;display:inline-flex;transform:rotate(-90deg)}.section-chevron.open{transform:rotate(0)}.section-label .count{color:var(--ink-4);letter-spacing:.02em;text-transform:none;font-size:11.5px;font-weight:500}.section-label .cat-dot{border-radius:2px;width:8px;height:8px}.item-list{position:relative}.itemfx-move{transition:transform .22s var(--spring)}.itemfx-enter-active{transition:transform .34s var(--spring-bounce), opacity .22s ease}.itemfx-leave-active{transition:transform .26s var(--spring), opacity .2s ease, max-height .26s var(--spring), margin .26s var(--spring);overflow:hidden}.itemfx-enter-from{opacity:0;max-height:0;margin-bottom:0;transform:translateY(-6px)scale(.98)}.itemfx-enter-to,.itemfx-leave-from{max-height:80px}.itemfx-leave-to{opacity:0;max-height:0;margin-bottom:0;transform:translate(40px)}.row{border-radius:var(--radius);margin-bottom:6px;position:relative;overflow:hidden}.row.removing{opacity:0;pointer-events:none;transition:transform .26s var(--spring-bounce), opacity .22s ease;transform:translate(110%)}.row .item{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius);transition:background .12s ease, border-color .12s ease, opacity .12s ease, transform .18s var(--spring);will-change:transform;align-items:center;gap:10px;min-height:48px;padding:8px 10px;display:flex;position:relative}.row .item:hover{border-color:var(--line-2)}.row .label:active{transition:transform 80ms var(--spring);transform:scale(.985)}.row.done .item{border-color:var(--line);opacity:.75;background:#faf4e4}.row .label{color:var(--ink);flex:1;align-items:baseline;gap:8px;min-width:0;font-size:14.5px;line-height:1.3;display:flex}.row .label>span:first-child{text-overflow:ellipsis;white-space:nowrap;min-width:0;position:relative;overflow:hidden}.row .label .qty{color:var(--ink-4);flex-shrink:0;font-size:13px;font-weight:500}.row.done .label{color:var(--ink-4);position:relative}.row.done .label>span:first-child:after{content:"";background:var(--ink-4);pointer-events:none;height:1px;position:absolute;top:50%;left:0;right:0;transform:translateY(-.5px)}.row .cat-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.row .food-tile{background:var(--tint-1,#00000008);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:opacity .18s;display:inline-flex}.row.done .food-tile{opacity:.5}.check{border:1.5px solid var(--line-2);width:24px;height:24px;transition:background-color .12s ease, border-color .12s ease, transform .16s var(--spring-bounce);background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;position:relative}.check:hover{border-color:var(--ink-3)}.check:active{transition:transform 80ms var(--spring);transform:scale(.88)}.check.checked{transform:scale(1)}.check.checked:active{transform:scale(.9)}.check.checked{background:var(--accent);border-color:var(--accent)}.check svg{color:#fff;stroke-dasharray:20;stroke-dashoffset:20px;width:14px;height:14px;transition:stroke-dashoffset .14s}.check.checked svg{stroke-dashoffset:0}.burst{pointer-events:none;position:absolute;inset:0}.burst span{background:var(--ink-4);opacity:0;border-radius:50%;width:4px;height:4px;position:absolute;top:50%;left:50%}.check.checked .burst span{animation:.52s ease-out forwards burst}.check.checked .burst span:first-child{--tx:-18px;--ty:-14px;background:var(--ink-3)}.check.checked .burst span:nth-child(2){--tx:16px;--ty:-18px;background:var(--ink-4)}.check.checked .burst span:nth-child(3){--tx:-20px;--ty:14px;background:var(--ink-3)}.check.checked .burst span:nth-child(4){--tx:18px;--ty:16px;background:var(--ink-4)}.check.checked .burst span:nth-child(5){--tx:0;--ty:-22px;background:var(--ink-3)}@keyframes burst{0%{opacity:1;transform:translate(-50%,-50%)scale(.3)}70%{opacity:1}to{transform:translate(calc(-50% + var(--tx)), calc(-50% + var(--ty))) scale(.6);opacity:0}}.done-card{background:linear-gradient(180deg, var(--paper-card) 0%, #faf4e4 100%);border:1px solid var(--line);border-radius:var(--radius-lg);text-align:center;margin:24px 8px;padding:28px 22px 24px;animation:.5s cubic-bezier(.2,.9,.3,1.2) fadeup;position:relative;overflow:hidden}@keyframes fadeup{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.done-card .mark{background:var(--accent-soft);width:60px;height:60px;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;margin-bottom:14px;display:inline-flex}.done-card h3{font-family:var(--font-serif);color:var(--ink);margin:0 0 6px;font-size:28px;font-weight:400}.done-card p{color:var(--ink-3);margin:0;font-size:14px}@media (min-width:900px){.listwrap{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));align-items:start;gap:14px;display:grid}.listwrap>.list-card-add,.listwrap>form.list-card,.listwrap>.empty{grid-column:1/-1}.listwrap>.swipe-card{margin-bottom:0}}.list-card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius-lg);width:100%;color:inherit;text-align:left;margin-bottom:12px;padding:18px 18px 16px;text-decoration:none;transition:transform .18s,border-color .18s,box-shadow .18s;display:block;position:relative;overflow:hidden}.list-card:hover{box-shadow:var(--shadow-card);border-color:var(--line-2);transform:translateY(-1px)}.list-card .title{font-family:var(--font-serif);color:var(--ink);margin:0 0 2px;font-size:26px;font-weight:400;line-height:1.05}.list-card .meta{color:var(--ink-3);margin-bottom:12px;font-size:13px}.list-card .pips{gap:4px;margin-bottom:10px;display:flex}.list-card .pip{background:var(--paper-3);border-radius:3px;flex:1;height:5px;transition:background .22s}.list-card .pip.done{background:var(--accent)}.list-card .footer{color:var(--ink-3);justify-content:space-between;align-items:center;gap:10px;font-size:12.5px;display:flex}.list-card-actions{align-items:center;gap:2px;display:inline-flex}.list-card-add{border:1.5px dashed var(--line-2);color:var(--ink-3);width:100%;font-family:var(--font-sans);border-radius:var(--radius-lg);background:0 0;justify-content:center;align-items:center;gap:8px;margin-bottom:12px;padding:20px 18px;font-size:15px;font-weight:500;transition:border-color .16s,color .16s,background .16s;display:flex}.list-card-add:hover{border-color:var(--ink-3);color:var(--ink);background:var(--paper-card)}.list-card-inline-edit{align-items:center;gap:8px;display:flex}.swipe-card{border-radius:var(--radius-lg);isolation:isolate;background:0 0;margin-bottom:12px;position:relative;overflow:hidden}.swipe-card .swipe-surface{cursor:pointer;touch-action:pan-y;transform:translate3d(var(--surface-offset,0px), 0, 0);z-index:1;margin-bottom:0;transition:transform .32s cubic-bezier(.22,1,.36,1),border-color .18s,box-shadow .18s;position:relative}.swipe-card.is-dragging .swipe-surface{transition:none}.swipe-card .swipe-surface:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.swipe-card.is-open .swipe-surface{border-color:var(--line-2)}.swipe-card .swipe-actions{width:var(--swipe-panel-w,224px);pointer-events:none;z-index:2;transform:translate3d(var(--actions-offset,100%), 0, 0);will-change:transform;align-items:stretch;gap:2px;padding:2px 8px 2px 2px;transition:transform .36s cubic-bezier(.22,1,.36,1);display:flex;position:absolute;top:6px;bottom:6px;right:0}.swipe-card .swipe-actions:before{content:"";background:var(--paper-2);border-radius:calc(var(--radius-lg) - 6px);z-index:-1;position:absolute;inset:0 8px 0 0;box-shadow:0 1px 2px #1c1a150d,0 4px 14px #1c1a1514}.swipe-card.is-dragging .swipe-actions{transition:none}.swipe-card.is-open .swipe-actions{pointer-events:auto}.swipe-card .swipe-action{min-width:0;color:var(--ink-2);border-radius:calc(var(--radius-lg) - 8px);cursor:pointer;background:0 0;border:0;flex:1 1 0;justify-content:center;align-items:center;margin:0;padding:0;transition:background .14s,color .14s,filter .14s;display:inline-flex}.swipe-card .swipe-action:hover{background:var(--paper-3);color:var(--ink)}.swipe-card .swipe-action:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.swipe-card .swipe-action-danger{background:var(--ink);color:var(--paper)}.swipe-card .swipe-action-danger:hover{background:var(--ink);color:var(--paper);filter:brightness(1.12)}.swipe-card-body{align-items:center;gap:10px;display:flex}.swipe-card-text{flex:1;min-width:0}.swipe-card-text .title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.swipe-card-text .meta{margin-bottom:0}.swipe-card-hint{width:18px;color:var(--ink-4);opacity:calc(1 - var(--swipe-reveal,0));flex:none;justify-content:center;align-items:center;transition:opacity .2s;display:flex}.swipe-card-hint .swipe-grip{opacity:.35;background:currentColor;border-radius:2px;width:3px;height:28px;display:inline-block}@media (hover:hover) and (pointer:fine){.swipe-card:not(.is-editing):hover{box-shadow:var(--shadow-card)}.swipe-card:not(.is-editing):hover .swipe-actions{pointer-events:auto;transform:translate(0,0)!important}.swipe-card:not(.is-editing):hover .swipe-card-hint{opacity:0}}@media (prefers-reduced-motion:reduce){.swipe-card .swipe-surface,.swipe-card .swipe-actions,.swipe-card .swipe-action{transition-duration:0s!important}}.rule-group{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius-lg);margin-bottom:16px;overflow:hidden}.rule-group h4{font-family:var(--font-sans);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin:0;padding:14px 18px 8px;font-size:11px;font-weight:700}.rule{border-top:1px solid var(--line);align-items:center;gap:12px;padding:14px 18px;display:flex}.rule:first-of-type,.rule-group h4+.rule{border-top:none}.rule .rule-body{flex:1;min-width:0}.rule .rule-title{color:var(--ink);font-size:15px;font-weight:500}.rule .rule-desc{color:var(--ink-3);margin-top:2px;font-size:13px}.rule-config{border-top:1px solid var(--line);background:#f6f1e673;gap:10px;padding:4px 18px 16px;display:grid}.switch{background:var(--paper-3);cursor:pointer;border:none;border-radius:999px;flex-shrink:0;width:42px;height:24px;padding:0;transition:background .2s;position:relative}.switch i{background:#fff;border-radius:999px;width:20px;height:20px;transition:left .22s cubic-bezier(.2,.9,.3,1.2);position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0000001f}.switch.on{background:var(--accent)}.switch.on i{left:20px}.auth-shell{background:var(--paper);isolation:isolate;flex-direction:column;justify-content:center;width:100%;max-width:440px;min-height:100vh;margin:0 auto;padding:40px 28px 48px;display:flex;position:relative}.auth-shell:before{content:"";pointer-events:none;mix-blend-mode:multiply;opacity:.8;z-index:0;background-image:radial-gradient(1px 1px at 20% 30%,#1c1a150a 50%,#0000 51%),radial-gradient(1px 1px at 60% 70%,#1c1a1508 50%,#0000 51%),radial-gradient(1px 1px at 80% 20%,#1c1a1509 50%,#0000 51%);background-size:140px 140px,90px 90px,180px 180px;position:absolute;inset:0}.auth-shell>*{z-index:1;position:relative}.auth-wordmark{font-family:var(--font-serif);letter-spacing:-.015em;color:var(--ink);margin:0 0 6px;font-size:40px;line-height:1}.auth-tagline{color:var(--ink-3);margin:0 0 32px;font-size:14px}.card{background:var(--paper-card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-card)}.btn{font-family:var(--font-sans);letter-spacing:.01em;border-radius:12px;justify-content:center;align-items:center;gap:6px;min-height:40px;padding:10px 14px;font-size:14px;font-weight:600;line-height:1;transition:background .14s,color .14s,transform .14s,box-shadow .14s,border-color .14s;display:inline-flex}.btn[disabled]{opacity:.55;cursor:not-allowed}.btn.btn-primary{background:var(--accent);color:#fff}.btn.btn-primary:hover:not([disabled]){filter:brightness(1.05)}.btn.btn-secondary{background:var(--paper-card);color:var(--ink);border:1px solid var(--line-2)}.btn.btn-secondary:hover:not([disabled]){background:var(--paper-2)}.btn.btn-danger{background:var(--ink);color:var(--paper)}.btn.btn-danger:hover:not([disabled]){filter:brightness(1.08)}.btn.btn-ghost{color:var(--ink-3);background:0 0}.btn.btn-ghost:hover:not([disabled]){color:var(--ink);background:var(--paper-2)}.btn.btn-sm{border-radius:10px;min-height:32px;padding:6px 10px;font-size:12.5px}.btn.btn-block{width:100%}.input{background:var(--paper-card);border:1px solid var(--line);width:100%;color:var(--ink);border-radius:12px;padding:12px 14px;font-family:inherit;font-size:16px;transition:border-color .16s,box-shadow .16s}.input::placeholder{color:var(--ink-4)}.input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);outline:none}.input.input-invalid{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}select.input{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b6759' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.badge{background:var(--paper-2);color:var(--ink-2);border-radius:999px;align-items:center;gap:6px;padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-brand,.badge-danger{background:var(--accent-soft);color:var(--accent-ink)}.modal-overlay{-webkit-backdrop-filter:blur(3px);z-index:60;background:#1c1a156b;justify-content:center;align-items:center;padding:24px 20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);isolation:isolate;width:100%;max-width:380px;max-height:min(88vh,640px);margin:auto;animation:.22s cubic-bezier(.2,.9,.3,1.2) modalRise;position:relative;overflow-y:auto}.modal-card:before{content:"";pointer-events:none;mix-blend-mode:multiply;opacity:.8;z-index:0;border-radius:inherit;background-image:radial-gradient(1px 1px at 20% 30%,#1c1a150a 50%,#0000 51%),radial-gradient(1px 1px at 60% 70%,#1c1a1508 50%,#0000 51%);background-size:140px 140px,90px 90px;position:absolute;inset:0}.modal-card>*{z-index:1;position:relative}.modal-card.sm{max-width:340px}.modal-card.lg{max-width:440px}.fullscreen-overlay{background:var(--paper);z-index:50;isolation:isolate;flex-direction:column;animation:.22s cubic-bezier(.2,.9,.3,1.2) fsSlide;display:flex;position:absolute;inset:0;overflow:hidden}.fullscreen-overlay:before{content:"";pointer-events:none;mix-blend-mode:multiply;opacity:.8;z-index:0;background-image:radial-gradient(1px 1px at 20% 30%,#1c1a150a 50%,#0000 51%),radial-gradient(1px 1px at 60% 70%,#1c1a1508 50%,#0000 51%),radial-gradient(1px 1px at 80% 20%,#1c1a1509 50%,#0000 51%);background-size:140px 140px,90px 90px,180px 180px;position:absolute;inset:0}.fullscreen-overlay>*{z-index:1;position:relative}@keyframes fsSlide{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}.fullscreen-body{flex-direction:column;flex:1;gap:14px;padding:8px 20px 16px;display:flex;overflow-y:auto}.fullscreen-hero{text-align:center;padding:16px 16px 8px}.fullscreen-hero .mark{background:var(--accent-soft);width:80px;height:80px;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.fullscreen-hero h2{font-family:var(--font-serif);color:var(--ink);letter-spacing:-.01em;margin:0 0 8px;font-size:30px;font-weight:400;line-height:1.1}.fullscreen-hero p{color:var(--ink-3);max-width:280px;margin:0 auto;font-size:14.5px;line-height:1.5}.fullscreen-footer{padding:12px 20px calc(18px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line);background:var(--paper);gap:8px;display:flex}.fullscreen-footer .btn{flex:1}.detail-hero{text-align:left;border-bottom:1px solid var(--line);padding:14px 24px 18px}.detail-hero .eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px;font-size:11px;font-weight:700}.detail-hero h2{font-family:var(--font-serif);color:var(--ink);letter-spacing:-.01em;word-break:break-word;margin:0 0 10px;font-size:32px;font-weight:400;line-height:1.08}.detail-meta{color:var(--ink-3);flex-wrap:wrap;align-items:center;gap:8px;font-size:13.5px;display:flex}.detail-meta .cat-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.detail-list{flex-direction:column;display:flex}.detail-row{border-top:1px solid var(--line);flex-direction:column;gap:6px;padding:14px 24px;display:flex}.detail-row:first-child{border-top:none}.detail-row-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:700}.detail-row-value{color:var(--ink);white-space:pre-wrap;word-break:break-word;font-size:15px;line-height:1.5}.detail-row-value.muted{color:var(--ink-4);font-style:italic}.edit-form{flex-direction:column;flex:1;display:flex;overflow-y:auto}.ghost-input,.ghost-textarea{width:100%;color:var(--ink);border:none;border-bottom:1px dashed var(--line-2);background:0 0;border-radius:0;padding:6px 0;font-family:inherit;font-size:15px;line-height:1.5;transition:border-color .16s,border-bottom-style .16s}.ghost-input:hover,.ghost-textarea:hover{border-bottom-color:var(--ink-3)}.ghost-input:focus,.ghost-textarea:focus{border-bottom:1px solid var(--accent);box-shadow:none;outline:none}.ghost-input::-moz-placeholder{color:var(--ink-4)}.ghost-textarea::-moz-placeholder{color:var(--ink-4)}.ghost-input::placeholder,.ghost-textarea::placeholder{color:var(--ink-4)}.ghost-textarea{resize:vertical;min-height:80px;padding:6px 0 8px}.picker{background:var(--paper-2);border:1px solid var(--line-2);cursor:pointer;color:var(--ink);border-radius:999px;align-items:center;gap:8px;min-height:38px;padding:8px 14px 8px 12px;font-size:14px;font-weight:500;transition:border-color .16s,background .16s,box-shadow .16s;display:inline-flex;position:relative}.picker:hover{background:var(--paper-card);border-color:var(--ink-4)}.picker:focus-within{border-color:var(--accent);background:var(--paper-card);box-shadow:0 0 0 3px var(--accent-soft)}.picker>.cat-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.picker>select{appearance:none;font:inherit;color:inherit;cursor:pointer;background-color:#0000;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%233b382f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-position:right 0 center;background-repeat:no-repeat;border:none;min-width:0;padding:0 20px 0 0;font-weight:500}.picker>select:focus{outline:none}.picker.picker-block{width:100%;display:flex}.picker.picker-block>select{flex:1}.picker.picker-sm{flex-shrink:0;min-height:34px;padding:6px 14px 6px 12px;font-size:13.5px}.ghost-serif-input{width:100%;font-family:var(--font-serif);letter-spacing:-.01em;color:var(--ink);border:none;border-bottom:1px dashed var(--line-2);background:0 0;border-radius:0;margin:0;padding:4px 0;font-size:32px;font-weight:400;line-height:1.08;transition:border-color .18s,border-bottom-style .18s}.ghost-serif-input:hover{border-bottom-color:var(--ink-3)}.ghost-serif-input:focus{border-bottom:1px solid var(--accent);outline:none}.ghost-serif-input::placeholder{color:var(--ink-4);font-style:italic}.detail-hero.editing{padding-bottom:20px}.detail-row.editing{padding-top:14px;padding-bottom:14px;transition:background .16s}.detail-row.editing:focus-within{background:var(--paper-2)}.detail-row.editing:focus-within .detail-row-label{color:var(--accent-ink)}.qty-row{align-items:center;gap:14px;display:flex}.qty-row .ghost-input{flex:1;min-width:0}.modal-head-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.modal-head-row>div{flex:1;min-width:0}.modal-head-row .modal-subtitle{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.cat-appearance-btn{border:1px solid var(--line);cursor:pointer;background:var(--paper-2);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;transition:transform .14s,border-color .16s,box-shadow .16s;display:inline-flex}.cat-appearance-btn:hover{border-color:var(--ink-4);transform:scale(1.05)}.cat-appearance-btn:active{transform:scale(.96)}.appearance-section{flex-direction:column;gap:10px;display:flex}.appearance-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:700}.swatch-row{grid-template-columns:repeat(5,1fr);gap:10px;display:grid}.swatch{aspect-ratio:1;cursor:pointer;border:2px solid #0000;border-radius:999px;padding:0;transition:transform .16s,border-color .16s,box-shadow .16s;box-shadow:inset 0 0 0 1px #1c1a150f}.swatch:hover{transform:scale(1.08)}.swatch.on{border-color:var(--ink);box-shadow:0 0 0 2px var(--paper), inset 0 0 0 1px #1c1a150f;transform:scale(1.08)}.icon-grid{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.icon-cell{aspect-ratio:1;background:var(--paper-card);border:1px solid var(--line);color:var(--ink-2);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;padding:0;transition:background .16s,color .16s,border-color .16s,transform .14s;display:inline-flex}.icon-cell:hover{background:var(--paper-2);border-color:var(--ink-4)}.icon-cell.on{transform:scale(1.06);box-shadow:0 4px 12px -6px #1c1a1540}.modal-detail-notes{flex-direction:column;gap:6px;display:flex}.modal-detail-notes p{color:var(--ink-2);white-space:pre-wrap;word-break:break-word;margin:0;font-size:14px;line-height:1.55}.modal-detail-notes .muted{color:var(--ink-4);font-style:italic}@keyframes modalRise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:22px 22px 6px}.modal-title{font-family:var(--font-serif);color:var(--ink);margin:0;font-size:26px;font-weight:400;line-height:1.1}.modal-subtitle{color:var(--ink-3);margin-top:4px;font-size:13px}.modal-body{flex-direction:column;gap:14px;padding:14px 22px 18px;display:flex}.modal-footer{justify-content:flex-end;gap:8px;padding:0 22px 22px;display:flex}.toast{left:50%;bottom:calc(24px + env(safe-area-inset-bottom,0px));z-index:50;pointer-events:none;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:400px;display:flex;position:fixed;transform:translate(-50%)}.toast-item{background:var(--ink);color:var(--paper);box-shadow:var(--shadow-pop);pointer-events:auto;border-radius:14px;align-items:center;gap:12px;padding:12px 14px;font-size:14px;display:flex}.toast-item.success .toast-dot{background:var(--accent-warm)}.toast-item.error .toast-dot{background:#ff6b5a}.toast-item.info .toast-dot{background:var(--ink-4)}.toast-dot{border-radius:999px;flex-shrink:0;width:8px;height:8px}.toast-item span{flex:1}.divider{background:var(--line);height:1px;margin:14px 0}.stack{flex-direction:column;display:flex}.row-layout{align-items:center;display:flex}.muted{color:var(--ink-3)}.muted-2{color:var(--ink-4)}.serif{font-family:var(--font-serif);letter-spacing:-.01em;font-weight:400}.sr{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.form-field{display:block}.form-field-label{letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin:0 0 6px 2px;font-size:12px;font-weight:600;display:block}.form-field-hint{color:var(--ink-4);margin:6px 2px 0;font-size:12px}.form-field-error{color:var(--accent-ink);margin:6px 2px 0;font-size:12px}.page-header{justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 24px 10px;display:flex}.page-header h1{font-family:var(--font-serif);margin:0 0 4px;font-size:32px;font-weight:400;line-height:1}.page-header .sub{color:var(--ink-3);font-size:13px}.avatars{display:inline-flex}.avatar{background:var(--paper-2);border:2px solid var(--paper-card);width:22px;height:22px;color:var(--ink-3);border-radius:999px;justify-content:center;align-items:center;margin-left:-6px;font-size:10px;font-weight:600;display:inline-flex}.avatar:first-child{margin-left:0}.empty{text-align:center;color:var(--ink-3);padding:48px 20px}.empty .empty-icon{background:var(--paper-2);width:56px;height:56px;color:var(--ink-4);border-radius:999px;justify-content:center;align-items:center;margin-bottom:14px;display:inline-flex}.empty h3{font-family:var(--font-serif);color:var(--ink);margin:0 0 6px;font-size:24px;font-weight:400}.empty p{margin:0;font-size:14px}.checkbox{appearance:none;border:1.5px solid var(--line-2);background:var(--paper-card);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:all .16s;display:inline-flex;position:relative}.checkbox:checked{background:var(--accent);border-color:var(--accent)}.checkbox:checked:after{content:"";border:2px solid #fff;border-width:0 2px 2px 0;width:6px;height:11px;position:absolute;top:1px;left:5px;transform:rotate(45deg)}*,:before,:after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--font-sans);font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.collapse{visibility:collapse}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.translate-y-0{--tw-translate-y:0px;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-2{--tw-translate-y:.5rem;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow{--tw-shadow:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)}.outline{outline-style:solid}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-100{transition-duration:.1s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}
