@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-font-weight:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:"DM Sans", sans-serif;--font-serif:"Fraunces", serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-bold:700;--radius-sm:.25rem;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);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}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.top-4{top:calc(var(--spacing) * 4)}.right-4{right:calc(var(--spacing) * 4)}.z-50{z-index:50}.m-0{margin:0}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.mt-6{margin-top:calc(var(--spacing) * 6)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.table{display:table}.w-full{width:100%}.items-center{align-items:center}.justify-end{justify-content:flex-end}.gap-2{gap:calc(var(--spacing) * 2)}.border{border-style:var(--tw-border-style);border-width:1px}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.px-4{padding-inline:calc(var(--spacing) * 4)}.py-3{padding-block:calc(var(--spacing) * 3)}.font-serif{font-family:var(--font-serif)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.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,)}}:root{--bark:#3d2b1f;--leaf:#5f7f4f;--sun:#e8a020;--clay:#b5673f;--bg:#f5f0e8;--surface:#fffaf2;--cream:#fff6df;--line:#ded4c7;--text:#2b211a;--text-muted:#685c50;--shadow:0 12px 30px #3d2b1f1f;--shadow-lg:0 18px 50px #3d2b1f29;--radius:16px;--radius-sm:10px}*{box-sizing:border-box}html{background:var(--bg);min-height:100%}body{background:var(--bg);min-height:100vh;color:var(--text);margin:0;font-family:DM Sans,sans-serif}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}.app{min-height:100vh;padding-left:220px}.app-main{width:min(1120px,100%);margin:0 auto;padding:32px}.sidebar-nav{z-index:30;background:var(--bark);color:#fff;flex-direction:column;width:220px;display:flex;position:fixed;inset:0 auto 0 0}.sidebar-logo{color:#fff;padding:22px 18px;font-family:Fraunces,serif;font-size:1.45rem;font-weight:700}.sidebar-items{flex-direction:column;flex:1;gap:6px;padding:8px 12px;display:flex}.sidebar-section{color:#ffffff8c;letter-spacing:.08em;text-transform:uppercase;margin:14px 8px 6px;font-size:.72rem;font-weight:700}.sideitem{border-radius:var(--radius-sm);color:#ffffffd1;align-items:center;gap:10px;min-height:44px;padding:0 12px;font-weight:700;display:flex}.sideitem.active{background:var(--sun);color:var(--bark)}.sidebar-footer{color:#ffffffb8;border-top:1px solid #ffffff1f;padding:16px;font-size:.9rem}.mobile-topbar{z-index:40;background:var(--bark);color:#fff;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:none;position:fixed;inset:0 0 auto}.bottom-nav{z-index:40;background:var(--bark);color:#ffffffbd;grid-template-columns:repeat(4,1fr);height:56px;display:none;position:fixed;inset:auto 0 0}.bottom-nav a,.bottom-nav button{min-height:56px;color:inherit;background:0 0;border:0;justify-content:center;align-items:center;display:inline-flex}.bottom-nav .active{color:var(--sun)}.nav-drawer{z-index:50;background:var(--bark);color:#fff;width:min(300px,86vw);padding:18px;transition:transform .18s;position:fixed;inset:0 0 0 auto;transform:translate(100%)}.nav-drawer.open{transform:translate(0)}.drawer-scrim{z-index:45;background:#2b211a5c;border:0;position:fixed;inset:0}.card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.btn{border-radius:var(--radius-sm);background:var(--bark);color:#fff;cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:0 16px;font-weight:700;display:inline-flex}.btn.secondary{border-color:var(--line);background:var(--surface);color:var(--text)}.btn.sun{background:var(--sun);color:var(--bark)}.badge{background:var(--cream);min-height:28px;color:var(--bark);border-radius:999px;align-items:center;padding:0 10px;font-size:.85rem;font-weight:700;display:inline-flex}.input-label{color:var(--text-muted);gap:6px;font-size:.9rem;font-weight:700;display:grid}.input{border:1px solid var(--line);border-radius:var(--radius-sm);width:100%;min-height:46px;color:var(--text);background:#fff;padding:0 12px}.modal{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);width:min(460px,100vw - 32px);box-shadow:var(--shadow-lg)}.fab-btn{z-index:41;background:var(--bark);color:#fff;width:52px;height:52px;box-shadow:var(--shadow-lg);border:0;border-radius:999px;justify-content:center;align-items:center;display:none;position:fixed;bottom:72px;right:18px}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-title{margin:0;font-family:Fraunces,serif;font-size:clamp(2rem,4vw,3.4rem);line-height:1}.muted{color:var(--text-muted)}.dashboard-grid{grid-template-columns:minmax(0,1.4fr) minmax(280px,.6fr);gap:18px;display:grid}.shopping-list{gap:10px;padding:16px;display:grid}.shopping-item{border-bottom:1px solid var(--line);grid-template-columns:24px minmax(0,1fr) auto;align-items:center;gap:12px;min-height:52px;display:grid}.shopping-item:last-child{border-bottom:0}.auth-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{width:min(430px,100%);padding:24px}.toast{z-index:70;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);box-shadow:var(--shadow-lg);padding:12px 14px;font-weight:700;position:fixed;top:18px;right:18px}.shop-hero{align-items:center}.hero-actions,.toolbar-actions{flex-wrap:wrap;gap:8px;display:flex}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:18px;display:grid}.workspace-grid{grid-template-columns:280px minmax(0,1fr) 280px;align-items:start;gap:18px;display:grid}.left-rail,.right-rail{gap:16px;display:grid}.panel{padding:16px}.panel-title{margin:0;font-family:Fraunces,serif;font-size:1.75rem;line-height:1.05}.section-title{color:var(--bark);align-items:center;gap:8px;margin-bottom:12px;font-weight:800;display:flex}.compact-form,.item-form{gap:10px;display:grid}.two-col{grid-template-columns:1fr .72fr;gap:8px;display:grid}.list-stack,.template-list,.items-list{gap:8px;margin-top:14px;display:grid}.list-chip{border:1px solid var(--line);border-radius:var(--radius-sm);width:100%;min-height:54px;color:var(--text);text-align:left;cursor:pointer;background:#fff;padding:9px 10px;display:grid}.list-chip.active{border-color:var(--sun);background:var(--cream)}.list-chip span{text-overflow:ellipsis;white-space:nowrap;font-weight:800;overflow:hidden}.list-chip small{color:var(--text-muted)}.template-row{border-bottom:1px solid var(--line);grid-template-columns:minmax(0,1fr) 44px;align-items:center;gap:10px;padding-bottom:10px;display:grid}.template-row:last-child{border-bottom:0;padding-bottom:0}.list-panel{min-width:0}.list-toolbar{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px;display:flex}.list-toolbar .muted{flex-wrap:wrap;align-items:center;gap:5px;display:inline-flex}.item-form{grid-template-columns:minmax(180px,1fr) 86px 92px 130px 86px 100px auto;align-items:center;margin-bottom:14px}.item-name-input{min-width:0}.filter-bar{grid-template-columns:minmax(180px,1fr) 130px 150px 140px;gap:8px;margin-bottom:12px;display:grid}.search-field{border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;align-items:center;gap:8px;min-height:46px;padding:0 12px;display:flex}.search-field input{width:100%;min-width:0;color:var(--text);background:0 0;border:0;outline:0}.bulk-bar{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--cream);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:8px;display:flex}.bulk-bar span{margin-right:auto;font-weight:800}.item-row{border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff;grid-template-columns:22px 34px minmax(0,1fr) auto 44px 44px;align-items:center;gap:10px;min-height:64px;padding:9px;display:grid}.item-row.taken{background:var(--leaf)}@supports (color:color-mix(in lab, red, red)){.item-row.taken{background:color-mix(in srgb, var(--leaf) 10%, white)}}.item-row.taken .item-copy{opacity:.68;text-decoration:line-through}.taken-toggle,.icon-btn{width:44px;min-width:44px;height:44px;padding:0}.taken-toggle{border:2px solid var(--leaf);color:var(--leaf);cursor:pointer;background:#fff;border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.item-copy{min-width:0;display:grid}.item-copy strong,.item-copy span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.item-copy span{color:var(--text-muted);font-size:.92rem}.price-pill{background:var(--cream);color:var(--bark);border-radius:999px;padding:6px 9px;font-weight:800}.empty-state{border:1px dashed var(--line);border-radius:var(--radius-sm);min-height:140px;color:var(--text-muted);text-align:center;place-items:center;gap:8px;display:grid}.suggestion-group{gap:8px;margin-bottom:14px;display:grid}.suggestion-pills{flex-wrap:wrap;gap:7px;display:flex}.suggestion-pills .badge{cursor:pointer;border:0}.budget-meter{background:var(--line);border-radius:999px;height:12px;overflow:hidden}.budget-meter span{border-radius:inherit;background:var(--leaf);height:100%;display:block}.qr-placeholder{width:118px;height:118px;box-shadow:inset 0 0 0 1px var(--line);background:#fff;border:8px solid #fff;grid-template-columns:repeat(5,1fr);gap:4px;display:grid}.qr-placeholder span{background:var(--cream)}.qr-placeholder span.dark{background:var(--bark)}@media (prefers-color-scheme:dark){:root{--bg:#201914;--surface:#30251e;--cream:#473425;--line:#5a493e;--text:#fff6e8;--text-muted:#d8c4ad;--shadow:0 12px 30px #00000047;--shadow-lg:0 18px 50px #0000005c}.input,.search-field,.list-chip,.item-row,.taken-toggle,.qr-placeholder{background:#251d18}.item-row.taken{background:var(--leaf)}@supports (color:color-mix(in lab, red, red)){.item-row.taken{background:color-mix(in srgb, var(--leaf) 18%, #251d18)}}}@media (max-width:1180px){.workspace-grid{grid-template-columns:250px minmax(0,1fr)}.right-rail{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr))}.item-form,.filter-bar{grid-template-columns:repeat(2,minmax(0,1fr))}.item-name-input,.search-field{grid-column:1/-1}}.rail-qr{justify-content:center;padding:16px 0 12px;display:flex}.share-backdrop{z-index:60;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#2b211a80;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.share-modal{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);width:min(380px,100vw - 32px);box-shadow:var(--shadow-lg);grid-template-columns:minmax(0,1fr);gap:14px;padding:20px;display:grid;overflow:hidden}.share-modal-header{justify-content:space-between;align-items:center;font-size:1.05rem;display:flex}.share-qr{border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--bark);background:#fff;justify-content:center;align-items:center;padding:16px;display:flex;overflow:hidden}.share-qr-inner{aspect-ratio:1;width:200px;max-width:100%;overflow:hidden}.share-qr-inner svg{display:block;width:100%!important;height:100%!important}.share-hint{text-align:center;margin:0;font-size:.9rem}.share-link-row{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg);align-items:center;gap:8px;padding:8px 10px;display:flex}.share-url-text{text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted);flex:1;font-size:.82rem;overflow:hidden}.mobile-stats-strip,.mobile-list-strip,.mobile-share-btn,.mobile-suggestion-strip{display:none}@media (max-width:767px){.app{padding:56px 0 72px}.app-main{padding:14px 12px}.sidebar-nav{display:none}.mobile-topbar,.bottom-nav{display:flex}.bottom-nav{display:grid}.fab-btn{display:inline-flex}.toast{inset:66px 12px auto}.shop-hero,.stats-grid{display:none}.mobile-share-btn{min-height:38px;padding:0 10px;font-size:.9rem;display:inline-flex}.strip-actions{flex-direction:row;flex-shrink:0;align-items:center;gap:6px;margin-left:auto;display:flex}.list-menu-wrap{position:relative}.list-menu-dropdown{z-index:50;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:160px;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.list-menu-dropdown button{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:12px 16px;font-size:.95rem;display:block}.list-menu-dropdown button:hover{background:var(--cream)}.list-menu-dropdown button.danger{color:#c0392b}.new-list-chip{color:var(--text-muted);border-style:dashed;padding:0 14px}.mobile-stats-strip{color:var(--text-muted);align-items:center;gap:10px;margin-bottom:4px;padding:8px 2px 4px;font-size:.95rem;display:flex}.mobile-stats-strip strong{color:var(--text);font-size:1rem}.strip-dot{background:var(--line);border-radius:50%;flex-shrink:0;width:4px;height:4px}.mobile-list-strip{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:8px;margin-bottom:4px;padding-bottom:14px;display:flex;overflow-x:auto}.mobile-list-strip::-webkit-scrollbar{display:none}.mobile-list-chip{scroll-snap-align:start;border:2px solid var(--line);background:var(--surface);min-height:52px;color:var(--text);cursor:pointer;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:8px;padding:0 16px;font-size:1rem;font-weight:700;display:flex}.mobile-list-chip.active{border-color:var(--sun);background:var(--cream)}.mlc-name{text-overflow:ellipsis;max-width:160px;overflow:hidden}.mlc-count{background:var(--line);min-width:24px;height:24px;color:var(--text-muted);border-radius:999px;justify-content:center;align-items:center;padding:0 6px;font-size:.8rem;font-weight:800;display:inline-flex}.mobile-list-chip.active .mlc-count{background:var(--sun);color:var(--bark)}.workspace-grid{grid-template-columns:1fr}.left-rail,.right-rail,.list-toolbar{display:none}.item-form{gap:8px;margin-bottom:12px;display:flex}.item-form select,.item-form input:not(#item-name){display:none}.item-form button[type=submit]{flex-shrink:0;min-width:80px}.filter-bar{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.filter-bar select:not(:first-of-type){display:none}.item-row{grid-template-columns:52px minmax(0,1fr) auto;gap:8px;min-height:56px;padding:6px 8px 6px 2px}.item-row input[type=checkbox]{display:none}.taken-toggle{border-width:2px;place-self:center;width:44px;min-width:44px;height:44px}.item-copy strong{font-size:1rem;font-weight:800}.item-copy span{font-size:.82rem}.price-pill{align-self:center;padding:3px 7px;font-size:.85rem}.item-row .icon-btn{display:none}.mobile-tappable{cursor:pointer;-webkit-tap-highlight-color:transparent}.mobile-suggestion-strip{scrollbar-width:none;gap:6px;margin-bottom:8px;padding-bottom:4px;display:flex;overflow-x:auto}.mobile-suggestion-strip::-webkit-scrollbar{display:none}.suggestion-chip{border:1px solid var(--line);background:var(--surface);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:999px;flex-shrink:0;padding:5px 12px;font-size:.85rem}.bottom-sheet{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);width:min(420px,100vw - 24px);box-shadow:var(--shadow-lg);grid-template-columns:minmax(0,1fr);gap:10px;padding:20px;display:grid;overflow:hidden}.sheet-delete-btn{color:#c0392b;border-color:#c0392b33}.mobile-suggestion-strip{display:flex}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
