:root{--bg: #f4f1ec;--surface: #ffffff;--surface-2: #faf8f5;--text: #1a1a1a;--text-muted: #6b6560;--accent: #2d6a4f;--accent-hover: #1b4332;--accent-light: #d8f3dc;--border: #e5dfd6;--danger: #c1121f;--warn: #e09f3e;--ok: #2d6a4f;--radius: 12px;--shadow: 0 2px 12px rgba(26, 26, 26, .06);--font: "DM Sans", system-ui, sans-serif;--font-display: "DM Serif Display", Georgia, serif}*,*:before,*:after{box-sizing:border-box}html{font-size:16px}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.5;min-height:100vh}#app{max-width:960px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:2rem}.header__brand{display:flex;align-items:center;gap:.875rem}.header__icon{font-size:2.25rem;line-height:1}.header h1{font-family:var(--font-display);font-size:1.75rem;font-weight:400;margin:0;letter-spacing:-.02em}.header__subtitle{margin:.125rem 0 0;color:var(--text-muted);font-size:.875rem}.header__sync{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.8125rem;width:100%;order:3}.sync-status[data-status=ok]{color:var(--ok)}.sync-status[data-status=error]{color:var(--danger)}.sync-status[data-status=syncing]{color:var(--warn)}.sync-account{color:var(--text-muted);max-width:12rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn--small{padding:.25rem .5rem;font-size:.75rem}.header__actions{display:flex;gap:.625rem;flex-wrap:wrap}.btn{font-family:inherit;font-size:.875rem;font-weight:600;padding:.625rem 1.125rem;border-radius:999px;border:none;cursor:pointer;transition:background .15s,opacity .15s,transform .1s}.btn:active:not(:disabled){transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--secondary{background:var(--surface);color:var(--accent);border:1.5px solid var(--accent)}.btn--secondary:hover:not(:disabled){background:var(--accent-light)}.btn--ghost{background:transparent;color:var(--text-muted);padding:.375rem .75rem}.btn--ghost:hover:not(:disabled){color:var(--text)}.btn--danger:hover:not(:disabled){color:var(--danger)}.layout{display:flex;flex-direction:column;gap:1.25rem}.panel{background:var(--surface);border-radius:var(--radius);padding:1.25rem 1.5rem;box-shadow:var(--shadow);border:1px solid var(--border)}.panel h2{font-size:1rem;font-weight:600;margin:0 0 1rem}.lists-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.backup-toolbar{margin-top:.75rem;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.backup-toolbar__status{margin:0;width:100%}.panel--admin{border-color:#c9b8a8;background:linear-gradient(180deg,#fff,#faf6f1)}.admin__intro{margin:-.5rem 0 1rem}.admin-stores-list{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.5rem}.admin-store-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.625rem .75rem;background:var(--surface-2);border:1px solid var(--border);border-radius:8px}.admin-store-row__icon{width:3rem;font-family:inherit;font-size:1rem;text-align:center;padding:.375rem;border:1px solid var(--border);border-radius:6px}.admin-store-row__label{flex:1;min-width:160px;font-family:inherit;font-size:.875rem;padding:.375rem .5rem;border:1px solid var(--border);border-radius:6px}.admin-store-row__default.is-active{color:var(--accent);font-weight:600}.admin-add-store{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.admin-add-store__icon{width:3rem;font-family:inherit;font-size:1rem;text-align:center;padding:.5rem;border:1px solid var(--border);border-radius:8px}.admin-add-store__label{flex:1;min-width:200px;font-family:inherit;font-size:.875rem;padding:.5rem .625rem;border:1px solid var(--border);border-radius:8px}.new-list-form{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.new-list-form__input{min-width:260px;flex:1;font-family:inherit;font-size:.875rem;padding:.5rem .625rem;border-radius:8px;border:1px solid var(--border);background:var(--surface-2)}.lists-toolbar__label{font-size:.85rem;color:var(--text-muted)}.lists-toolbar__select{min-width:220px;font-family:inherit;font-size:.875rem;padding:.5rem .625rem;border-radius:8px;border:1px solid var(--border);background:var(--surface-2)}.lists-toolbar--store{margin-top:.5rem}.lists-toolbar__hint{margin:0;font-size:.75rem;flex:1 1 100%}.add-form{display:flex;gap:.625rem}.add-form__input{flex:1;font-family:inherit;font-size:.9375rem;padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface-2);outline:none;transition:border-color .15s}.add-form__input:focus{border-color:var(--accent)}.hint{margin:.75rem 0 0;font-size:.8125rem;color:var(--text-muted)}.list-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.list-header h2{margin:0;display:flex;align-items:center;gap:.5rem}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .5rem;font-size:.75rem;font-weight:700;background:var(--accent-light);color:var(--accent);border-radius:999px}.badge--sm{min-width:1.25rem;height:1.25rem;font-size:.6875rem}.empty-state{text-align:center;padding:2.5rem 1rem;color:var(--text-muted)}.empty-state p{margin:.25rem 0}.categories{display:flex;flex-direction:column;gap:1rem}.store-block{background:var(--surface);border-radius:var(--radius);padding:1rem 1.125rem;border:1.5px solid var(--accent)}.store-block__title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;margin:0 0 .75rem;color:var(--accent)}.store-block__categories{display:flex;flex-direction:column;gap:.625rem}.category-block{background:var(--surface-2);border-radius:calc(var(--radius) - 2px);padding:1rem 1.125rem;border:1px solid var(--border)}.category-block--nested{background:var(--surface-2);padding:.75rem .875rem;border:1px solid var(--border)}.category-block__title{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;margin:0 0 .625rem;color:var(--accent)}.category-block--nested .category-block__title{font-size:.8125rem;margin-bottom:.5rem}.category-block__list{list-style:none;margin:0;padding:0}.item-row{display:flex;align-items:center;gap:.5rem;padding:.375rem 0;border-bottom:1px solid var(--border)}.item-row:last-child{border-bottom:none}.item-row__text{flex:1;font-size:.9375rem}.item-row__store,.item-row__category{font-family:inherit;font-size:.75rem;padding:.25rem .375rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-muted);max-width:130px}.item-row__store{max-width:120px}.item-row__remove{background:none;border:none;font-size:1.25rem;line-height:1;color:var(--text-muted);cursor:pointer;padding:.125rem .375rem;border-radius:4px}.item-row__remove:hover{color:var(--danger);background:#c1121f14}.modal{border:none;border-radius:var(--radius);padding:0;max-width:640px;width:calc(100% - 2rem);box-shadow:0 8px 40px #00000026}.modal::backdrop{background:#1a1a1a66}.modal__content{padding:0}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.modal__header h2{margin:0;font-size:1.125rem}.modal__close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-muted);padding:.25rem}.modal__desc{padding:0 1.5rem;margin:1rem 0 0;font-size:.875rem;color:var(--text-muted)}.modal__hint{padding:0 1.5rem;margin-top:.5rem}.import-tools{display:flex;gap:.625rem;flex-wrap:wrap;padding:0 1.5rem;margin-top:.75rem}.import-tools__file{display:inline-flex}.import-textarea{display:block;width:calc(100% - 3rem);margin:1rem 1.5rem 0;font-family:inherit;font-size:.875rem;padding:.875rem;border:1.5px solid var(--border);border-radius:var(--radius);resize:vertical;min-height:160px;background:var(--surface-2)}.modal__actions{display:flex;gap:.625rem;padding:1rem 1.5rem;justify-content:flex-end}.import-preview{padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--border);margin-top:.5rem}.import-preview h3{font-size:.875rem;margin:0 0 .625rem}.import-stats{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.stat{font-size:.75rem;font-weight:600;padding:.25rem .625rem;border-radius:999px;background:var(--surface-2)}.stat--ok{background:var(--accent-light);color:var(--ok)}.stat--warn{background:#fef3c7;color:#92400e}.import-lines{list-style:none;margin:0;padding:0;max-height:280px;overflow-y:auto}.import-line{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem;border-radius:8px;margin-bottom:.375rem;font-size:.8125rem}.import-line--ok{background:#f0fdf4}.import-line--warn{background:#fffbeb}.import-line--skip{background:var(--surface-2);opacity:.6}.import-line__body{flex:1;display:flex;flex-direction:column;gap:.125rem}.import-line__raw{font-weight:500}.import-line__parsed{color:var(--ok);font-size:.75rem}.import-line__warn{color:#92400e;font-size:.75rem}.import-line__fix{font-family:inherit;font-size:.75rem;padding:.25rem .5rem;border:1px solid var(--border);border-radius:6px;width:100%;margin-top:.25rem}.import-line__check input{margin-top:.2rem}.print-area{display:none}.panel--preview{overflow-x:auto}.print-preview-content{background:#e9e6e0;padding:1rem;border-radius:10px}.print-preview-page{width:210mm;min-height:297mm;margin:0 auto;background:#fff;color:#000;padding:8mm 10mm;box-shadow:0 2px 12px #00000029;transform-origin:top center}.print-preview-page .print-page__header{text-align:center;margin-bottom:4mm;padding-bottom:2.5mm;border-bottom:1.5pt solid #2d6a4f}.print-preview-page .print-page__header h1{font-family:Georgia,serif;font-size:16pt;font-weight:400;margin:0}.print-preview-page .print-page__date{margin:1.5mm 0 0;font-size:9pt;color:#555;text-transform:capitalize}.print-preview-page .print-store{break-inside:avoid-page;margin-bottom:4mm;padding-bottom:2mm;border-bottom:.5pt dashed #ccc}.print-preview-page .print-store__title{font-size:11pt;font-weight:700;margin:0 0 2mm;padding:1mm 2mm;background:#e8f5e9;border-left:3pt solid #2d6a4f}.print-preview-page .print-category,.print-preview-page .print-category--nested{break-inside:avoid;margin-bottom:2mm}.print-preview-page .print-category h2,.print-preview-page .print-category--nested h3{font-size:9pt;font-weight:700;margin:0 0 1mm;padding:.5mm 2mm;background:#f0f0f0;border-left:2pt solid #2d6a4f}.print-preview-page .print-category ul{list-style:none;margin:0;padding:0 0 0 1mm;columns:2;column-gap:5mm}.print-preview-page .print-category li{display:flex;align-items:baseline;gap:1.5mm;padding:.35mm 0;font-size:8.5pt;break-inside:avoid}.print-preview-page .print-checkbox{display:inline-block;width:3.2mm;height:3.2mm;border:.8pt solid #333;flex-shrink:0}.print-preview-page .print-page__footer{margin-top:4mm;padding-top:2mm;border-top:.5pt solid #ccc;text-align:center;font-size:7pt;color:#888}@media print{@page{size:A4 portrait;margin:8mm 10mm}body{background:#fff;color:#000;font-size:9pt}#app,.modal{display:none!important}.print-area{display:block!important}.print-page{width:100%}.print-page__header{text-align:center;margin-bottom:4mm;padding-bottom:2.5mm;border-bottom:1.5pt solid #2d6a4f}.print-page__header h1{font-family:Georgia,serif;font-size:16pt;font-weight:400;margin:0;letter-spacing:.02em}.print-page__date{margin:1.5mm 0 0;font-size:9pt;color:#555;text-transform:capitalize}.print-store{break-inside:avoid-page;margin-bottom:4mm;padding-bottom:2mm;border-bottom:.5pt dashed #ccc}.print-store__title{font-size:11pt;font-weight:700;margin:0 0 2mm;padding:1mm 2mm;background:#e8f5e9;border-left:3pt solid #2d6a4f}.print-category,.print-category--nested{break-inside:avoid;margin-bottom:2mm}.print-category h2,.print-category--nested h3{font-size:9pt;font-weight:700;margin:0 0 1mm;padding:.5mm 2mm;background:#f0f0f0;border-left:2pt solid #2d6a4f}.print-category ul{list-style:none;margin:0;padding:0 0 0 1mm;columns:2;column-gap:5mm}.print-category li{display:flex;align-items:baseline;gap:1.5mm;padding:.35mm 0;font-size:8.5pt;break-inside:avoid}.print-checkbox{display:inline-block;width:3.2mm;height:3.2mm;border:.8pt solid #333;flex-shrink:0;margin-top:.25mm}.print-page__footer{margin-top:4mm;padding-top:2mm;border-top:.5pt solid #ccc;text-align:center;font-size:7pt;color:#888}}.mobile-nav{display:none}.mobile-more{border:none;padding:0;max-width:100%;width:100%;margin:0;max-height:100%;background:transparent}.mobile-more::backdrop{background:#1a1a1a73}.mobile-more__sheet{position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-radius:16px 16px 0 0;padding:1rem 1.25rem calc(1.25rem + env(safe-area-inset-bottom));box-shadow:0 -8px 32px #0000001f}.mobile-more__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.mobile-more__header h2{margin:0;font-size:1rem}.mobile-more__actions{display:flex;flex-direction:column;gap:.5rem}.mobile-more__action{font-family:inherit;font-size:.9375rem;font-weight:600;text-align:left;padding:.875rem 1rem;border:1px solid var(--border);border-radius:10px;background:var(--surface-2);cursor:pointer}.mobile-more__action:disabled{opacity:.45}@media(max-width:768px){#app{padding:1rem 1rem calc(5rem + env(safe-area-inset-bottom))}.header{margin-bottom:1rem}.header h1{font-size:1.35rem}.header__subtitle,.header__actions--desktop{display:none}body.is-mobile .layout>.mobile-panel:not(.is-mobile-active){display:none!important}body.is-mobile .layout>.mobile-panel.is-mobile-active{display:block}body.is-mobile #panel-admin.is-mobile-active{display:block!important}.mobile-nav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:100;background:var(--surface);border-top:1px solid var(--border);padding:.35rem .5rem calc(.35rem + env(safe-area-inset-bottom));box-shadow:0 -4px 20px #00000014}.mobile-nav__btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:.375rem .25rem;border:none;background:transparent;font-family:inherit;font-size:.6875rem;font-weight:600;color:var(--text-muted);cursor:pointer;border-radius:8px;min-height:44px}.mobile-nav__btn.is-active{color:var(--accent);background:var(--accent-light)}.mobile-nav__icon{font-size:1.25rem;line-height:1}.btn{min-height:44px}.modal{width:100%;max-width:100%;margin:0;max-height:100%;border-radius:16px 16px 0 0;align-self:flex-end}.item-row{flex-wrap:wrap}.item-row__store,.item-row__category{max-width:100%;flex:1 1 45%;font-size:.8125rem}.add-form{flex-direction:column}.print-preview-page{width:100%;min-height:auto;transform:scale(.92);transform-origin:top center}}@media(min-width:769px){.mobile-nav,.mobile-more{display:none!important}}.modal-auth::backdrop{background:#1a1a1a8c}.auth-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.auth-tabs__btn{flex:1;padding:.5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);cursor:pointer;font:inherit}.auth-tabs__btn.is-active{background:var(--accent-light);border-color:var(--accent);color:var(--accent-hover);font-weight:600}.auth-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.auth-field input{padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);font:inherit}.auth-error{color:var(--danger);font-size:.875rem;min-height:1.25rem}
