:root{--bg:#f4f7fa;--card-bg:#fff;--text:#1a202c;--text-secondary:#64748b;--primary:#0891b2;--primary-hover:#0e7490;--primary-light:#0891b214;--danger:#dc2626;--danger-hover:#b91c1c;--success:#059669;--warning:#9f5ab5;--border:#e2e8f0;--border-strong:#cbd5e1;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 6px #0000000f, 0 2px 4px #0000000a;--radius:10px;--radius-sm:6px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono:"SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased}body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.6}.app{max-width:1280px;min-height:100vh;margin:0 auto}.main-content{padding:1rem}.header{z-index:100;background:var(--card-bg);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0}.header-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.header-left{align-items:center;gap:1.5rem;display:flex}.header-title{color:var(--primary);font-size:1.25rem;font-weight:700}.header-nav{gap:.5rem;display:flex}.nav-link{color:var(--text-secondary);border-radius:var(--radius-sm);padding:.35rem .75rem;font-size:.9rem;text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{background:var(--primary-light);color:var(--primary)}.nav-link.active{background:var(--primary-light);color:var(--primary);font-weight:600}.header-right{align-items:center;gap:.75rem;display:flex}.settings-btn{text-decoration:none}.settings-btn-active{background:var(--primary);color:#fff;border-color:var(--primary)}.import-btn{cursor:pointer}.settings-page{max-width:480px;padding:1rem 0}.settings-title{margin-bottom:1.5rem;font-size:1.5rem;font-weight:700}.settings-section{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:1rem;padding:1.25rem}.settings-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.75rem;font-size:.9rem;font-weight:600}.settings-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text);width:100%;max-width:200px;min-height:40px;padding:.5rem .75rem;font-size:.9rem}.settings-actions{flex-wrap:wrap;gap:.5rem;display:flex}.settings-hint{color:var(--text-secondary);margin-top:.75rem;font-size:.8rem}.settings-danger-zone{border-top:2px solid var(--danger);margin-top:1rem;padding-top:1.5rem}.category-add-row{gap:.5rem;margin-bottom:1rem;display:flex}.category-add-input{border:1px solid var(--border);border-radius:var(--radius-sm);flex:1;padding:.5rem .75rem;font-size:.9rem}.category-add-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light);outline:none}.category-list{flex-direction:column;gap:.35rem;display:flex}.category-list-item{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:.5rem .75rem;display:flex}.category-list-name{align-items:center;gap:.5rem;font-weight:500;display:flex}.category-list-count{background:var(--primary-light);color:var(--primary);border-radius:999px;padding:.1rem .45rem;font-size:.7rem;font-weight:600}.btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.35rem;min-height:44px;padding:.5rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s,border-color .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.btn-secondary{background:var(--card-bg);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);border-color:var(--border-strong)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-hover);border-color:var(--danger-hover)}.btn-pdf{color:#fff;background:linear-gradient(135deg,#0891b2,#9f5ab5);border-color:#0891b2}.btn-pdf:hover:not(:disabled){background:linear-gradient(135deg,#0e7490,#8b4d9e);border-color:#0e7490}.dashboard{grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem;display:grid}@media (width>=768px){.dashboard{grid-template-columns:repeat(6,1fr)}}.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-sm);padding:1rem}.stat-card.stat-warning{border-color:var(--warning);border-left:3px solid var(--warning)}.stat-card.stat-borderline{border-color:var(--primary);border-left:3px solid var(--primary)}.stat-card.stat-ok{border-color:var(--success);border-left:3px solid var(--success)}.stat-card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.stat-card-clickable:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.stat-card-selected{outline:2px solid var(--primary);outline-offset:-2px;background:var(--primary-light)}.stat-card.stat-buy-value{border:1.5px solid var(--primary);box-shadow:var(--shadow), 0 0 0 1px #0891b214;background:linear-gradient(135deg,#0891b20f,#0891b224)}.stat-card.stat-buy-value .stat-value{color:var(--primary)}.stat-card.stat-buy-value .stat-label{color:var(--primary-hover);font-weight:600}.ok-icon{color:var(--success);margin-right:.25rem}.borderline-icon{color:var(--primary);margin-right:.25rem}.stat-value{font-size:1.75rem;font-weight:700;font-family:var(--font-mono);color:var(--primary);display:block}.stat-value-price{font-size:1.25rem}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-top:.25rem;font-size:.8rem;display:block}.warning-icon{color:var(--warning)}.toolbar{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.search-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);width:100%;min-height:44px;padding:.5rem .75rem;font-size:.9rem;transition:border-color .15s}.search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #0891b226}.filter-sort-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.filter-buttons{gap:.5rem;display:flex}.sort-control{align-items:center;gap:.5rem;display:flex}.sort-label{color:var(--text-secondary);font-size:.85rem}.sort-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);min-height:36px;padding:.35rem .5rem;font-size:.85rem}.toolbar-actions{flex-wrap:wrap;align-items:flex-start;gap:.5rem;display:flex}.mark-menu-wrapper{position:relative}.mark-menu{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:200;min-width:260px;margin-top:4px;position:absolute;top:100%;left:0;overflow:hidden}.mark-menu-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:.6rem 1rem;font-size:.85rem;transition:background .12s;display:block}.mark-menu-item:hover{background:var(--primary-light);color:var(--primary)}.mark-menu-item:not(:last-child){border-bottom:1px solid var(--border)}.mark-menu-item-active{background:var(--primary-light);color:var(--primary);font-weight:600}.mark-check{color:var(--primary);margin-right:.4rem;font-weight:700}.mark-menu-checkbox{cursor:pointer;border-bottom:1px solid var(--border);color:var(--text);align-items:center;gap:.5rem;padding:.6rem 1rem;font-size:.85rem;display:flex}.mark-menu-checkbox:hover{background:var(--primary-light)}.mark-menu-item-danger{color:var(--danger)}.mark-menu-item-danger:hover{color:var(--danger);background:#fee2e2}.pill,.category-filter button{border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;border-radius:999px;padding:.35rem .75rem;font-size:.85rem;transition:background .15s,color .15s,border-color .15s}.pill:hover{background:var(--primary-light);color:var(--primary)}.pill-active,.category-filter button.pill-active{background:var(--primary);color:#fff;border-color:var(--primary)}.pill-active:hover,.category-filter button.pill-active:hover{background:var(--primary-hover)}.category-filter{flex-wrap:wrap;gap:.5rem;display:flex}.product-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.product-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:.75rem;padding:1rem;display:flex}.product-card-warning{border-left:3px solid var(--warning)}.product-card-borderline{border-left:3px solid var(--success)}.product-card-dimmed{opacity:.4;order:1}.product-card-header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.product-card-title-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.product-card-name{font-size:1rem;font-weight:600}.category-badge{background:var(--primary-light);color:var(--primary);border-radius:999px;padding:.15rem .5rem;font-size:.75rem;font-weight:500}.category-badge-sm{padding:.1rem .4rem;font-size:.7rem}.budget-priority-badge{color:var(--warning);background:#d977061a;border-radius:999px;align-items:center;gap:.2rem;margin-left:.35rem;padding:.15rem .5rem;font-size:.7rem;font-weight:600;display:inline-flex}.low-stock-badge{color:var(--warning);white-space:nowrap;background:#f3e8ff;border-radius:999px;align-items:center;gap:.25rem;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.borderline-badge,.ok-badge{color:var(--success);white-space:nowrap;background:#ecfdf5;border-radius:999px;align-items:center;gap:.25rem;padding:.15rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.product-card-body{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.quantity-control{align-items:center;gap:.25rem;display:flex}.btn-qty{justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:0;font-size:1.25rem;font-weight:700;display:flex}.quantity-input{text-align:center;border:1px solid var(--border);border-radius:var(--radius-sm);width:60px;font-size:1rem;font-family:var(--font-mono);min-height:44px;padding:.35rem}.quantity-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #0891b226}.quantity-input-sm{width:50px;min-height:36px;font-size:.85rem}.product-card-price{font-size:1rem;font-weight:600;font-family:var(--font-mono);color:var(--primary)}.product-card-meta{color:var(--text-secondary);font-size:.8rem}.meta-label{margin-right:.25rem}.product-card-footer{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;padding-top:.75rem;display:flex}.checkbox-label{cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.checkbox-label input[type=checkbox]{accent-color:var(--primary);width:18px;height:18px}.product-card-actions{gap:.35rem;display:flex}.product-card-consumption{margin-top:.25rem}.consumption-badge{color:var(--primary);font-size:.75rem;font-weight:500}.product-card-note{color:var(--text-secondary);word-break:break-word;margin-top:.35rem;font-size:.8rem;font-style:italic;line-height:1.4}.note-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;font-family:var(--font);resize:vertical;min-height:60px;padding:.5rem .75rem;font-size:.9rem;transition:border-color .15s}.note-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #0891b226}.consumption-input-row{align-items:center;gap:.75rem;display:flex}.consumption-input-row input{max-width:100px}.consumption-hint{color:var(--text-secondary);font-size:.78rem}.modal-overlay{z-index:10000;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;width:100%;max-width:480px;max-height:90vh;padding:1.5rem;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-title{color:var(--primary);margin-bottom:1rem;font-size:1.25rem;font-weight:700}.form-group{margin-bottom:.75rem}.form-group label{color:var(--text-secondary);margin-bottom:.25rem;font-size:.85rem;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);width:100%;min-height:44px;padding:.5rem .75rem;font-size:.9rem;transition:border-color .15s}.form-group input:focus,.form-group select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #0891b226}.input-error{border-color:var(--danger)!important}.error-text{color:var(--danger);margin-top:.25rem;font-size:.8rem;display:block}.form-row{grid-template-columns:repeat(3,1fr);gap:.75rem;display:grid}.category-select-row{gap:.5rem;display:flex}.category-select-row select,.category-select-row input{flex:1}.modal-actions{justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.shopping-list-page,.history-page{max-width:900px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.page-header h2{color:var(--primary);font-size:1.25rem}.page-header-actions{gap:.5rem;display:flex}.shopping-table-wrap,.history-table-wrap{overflow-x:auto}.shopping-table,.history-table{border-collapse:collapse;background:var(--card-bg);border-radius:var(--radius);width:100%;box-shadow:var(--shadow-sm);overflow:hidden}.shopping-table th,.shopping-table td,.history-table th,.history-table td{text-align:left;border-bottom:1px solid var(--border);padding:.5rem .75rem;font-size:.85rem}.shopping-table th,.history-table th{background:var(--bg);text-transform:uppercase;letter-spacing:.03em;color:var(--text-secondary);font-size:.7rem;font-weight:600}.shopping-table tbody tr:last-child td{border-bottom:none}.shopping-table tbody tr:nth-child(odd){background:linear-gradient(90deg,#fff 40%,#faf5ff80)}.shopping-table tbody tr:nth-child(2n){background:linear-gradient(90deg,#fff 40%,#fdf2f880)}.shopping-table tbody tr:hover{background:linear-gradient(90deg,#fff 40%,#0891b20f)}.shopping-row-low{background:linear-gradient(90deg,#fff 40%,#f3e8ff99)!important}.shopping-row-low:hover{background:linear-gradient(90deg,#fff 40%,#ede2f799)!important}.shopping-row-borderline{background:linear-gradient(90deg,#fff 40%,#fce7f399)!important}.shopping-row-borderline:hover{background:linear-gradient(90deg,#fff 40%,#fbcfe880)!important}.shopping-row-clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.shopping-row-picked{opacity:.7;background:linear-gradient(90deg,#f0fdf4 40%,#dcfce7)!important}.shopping-row-picked:hover{opacity:.8;background:linear-gradient(90deg,#e8fbed 40%,#bbf7d0)!important}.shopping-picked-text{color:var(--text-secondary);text-decoration:line-through}.shopping-row-picked input:disabled{opacity:.4;cursor:default}.shopping-product-meta{flex-wrap:wrap;gap:.3rem;margin-top:.2rem;display:flex}.btn-remove-shopping{color:#fff;border-radius:var(--radius);cursor:pointer;background:#c084fc;border:none;min-height:auto;padding:.25rem .5rem;font-size:.8rem}.btn-remove-shopping:hover{background:#a855f7}.text-center{text-align:center}.text-right{text-align:right}.total-label{font-size:1rem;font-weight:700}.total-value{font-size:1.1rem;font-weight:700;font-family:var(--font-mono);color:var(--primary)}.shopping-product-name{margin-right:.5rem;font-weight:500}.budget-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:1rem}.budget-row{flex-direction:column;gap:.5rem;display:flex}.budget-input-group{align-items:center;gap:.5rem;display:flex}.budget-label{color:var(--text);font-size:.9rem;font-weight:600}.budget-tooltip-wrapper{position:relative}.budget-tooltip-trigger{border:1px solid var(--border-strong);background:var(--bg);width:20px;height:20px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;transition:all .15s;display:inline-flex}.budget-tooltip-trigger:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.budget-tooltip{background:var(--text);color:#fff;border-radius:var(--radius-sm);width:280px;box-shadow:var(--shadow-md);z-index:100;padding:.75rem;font-size:.8rem;line-height:1.4;position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%)}.budget-tooltip:before{content:"";border-left:6px solid #0000;border-right:6px solid #0000;border-bottom:6px solid var(--text);position:absolute;top:-6px;left:50%;transform:translate(-50%)}.budget-controls{align-items:center;gap:.5rem;display:flex}.budget-input{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-family:var(--font-mono);flex:1;max-width:200px;padding:.5rem .75rem;transition:border-color .15s}.budget-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #0891b226}.btn-sm{min-height:36px;padding:.35rem .75rem;font-size:.8rem}.budget-status{border-radius:var(--radius-sm);margin-top:.5rem;padding:.4rem .75rem;font-size:.85rem;font-weight:500}.budget-over{color:var(--danger);background:#fef2f2;border:1px solid #fecaca}.budget-under{color:var(--success);background:#ecfdf5;border:1px solid #a7f3d0}.budget-exact{background:var(--primary-light);color:var(--primary);border:1px solid #0891b233}.budget-result{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.budget-included{color:var(--text-secondary);font-size:.85rem}.change-positive{color:var(--success);font-weight:600}.change-negative{color:var(--danger);font-weight:600}.change-cell{font-family:var(--font-mono);font-size:.85rem}.overview-page{max-width:820px;padding:1rem 0}.overview-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.overview-title{margin-bottom:0;font-size:1.5rem;font-weight:700}.overview-sort{align-items:center;gap:.4rem;display:flex}.overview-sort-label{color:var(--text-secondary);font-size:.8rem}.overview-category{margin-bottom:2rem}.overview-category-title{align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:1.1rem;font-weight:600;display:flex}.overview-category-count{background:var(--primary-light);color:var(--primary);border-radius:999px;padding:.15rem .5rem;font-size:.75rem;font-weight:600}.overview-table-wrap{overflow-x:auto}.overview-table{border-collapse:collapse;background:var(--card-bg);border-radius:var(--radius);width:100%;box-shadow:var(--shadow-sm);table-layout:fixed;overflow:hidden}.overview-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;background:var(--bg);border-bottom:1px solid var(--border);padding:.5rem .75rem;font-size:.7rem;font-weight:600}.overview-table td{border-bottom:1px solid var(--border);padding:.5rem .75rem;font-size:.85rem}.overview-table tbody tr:last-child td{border-bottom:none}.overview-table tbody tr:nth-child(odd){background:linear-gradient(90deg,#fff 40%,#faf5ff80)}.overview-table tbody tr:nth-child(2n){background:linear-gradient(90deg,#fff 40%,#fdf2f880)}.overview-table tbody tr:hover{background:linear-gradient(90deg,#fff 40%,#0891b20f)}.overview-product-name{font-weight:500}.overview-note{color:var(--text-secondary);word-break:break-word;white-space:normal;margin-top:2px;font-size:.75rem;font-style:italic;font-weight:400;line-height:1.35}.overview-col-qty,.overview-col-min{text-align:center;width:60px;font-family:var(--font-mono);white-space:nowrap;font-size:.85rem}.overview-col-consumption{text-align:center;white-space:nowrap;width:120px}.overview-col-status{text-align:right;white-space:nowrap;width:100px}.overview-qty-low{color:var(--danger);font-weight:700}.overview-row-low{background:linear-gradient(90deg,#fff 40%,#f3e8ff99)!important}.overview-row-low:hover{background:linear-gradient(90deg,#fff 40%,#ede2f799)!important}.overview-row-borderline{background:linear-gradient(90deg,#fff 40%,#fce7f399)!important}.overview-row-borderline:hover{background:linear-gradient(90deg,#fff 40%,#fbcfe880)!important}.overview-qty-borderline{color:#ec4899;font-weight:600}.overview-borderline-badge{color:var(--success);font-size:.75rem;font-weight:600}.overview-low-badge{color:var(--warning);font-size:.75rem;font-weight:600}.overview-consumption-badge{color:var(--primary);font-size:.75rem;font-weight:500}.overview-ok-badge{color:var(--success);font-size:.75rem;font-weight:500}.overview-row-clickable{cursor:pointer}.overview-col-history-toggle{text-align:center;width:30px}.overview-expand-icon{color:var(--text-secondary);font-size:.75rem;transition:transform .15s;display:inline-block}.overview-expand-icon.expanded{transform:rotate(90deg)}.overview-history-row td{background:var(--bg);padding:0!important}.overview-history-empty{color:var(--text-secondary);margin:0;padding:.5rem .75rem;font-size:.8rem}.overview-history-list{flex-direction:column;gap:.25rem;padding:.5rem .75rem;display:flex}.overview-history-item{align-items:center;gap:1rem;font-size:.8rem;display:flex}.overview-history-date{color:var(--text-secondary);min-width:130px;font-size:.75rem}.overview-history-change{font-family:var(--font-mono);font-size:.8rem}.storage-warning{color:#991b1b;border-radius:var(--radius-sm);background:#fee2e2;border:1px solid #fca5a5;margin:.5rem 1rem;padding:.75rem 1rem;font-size:.9rem}.error-boundary{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:60vh;padding:2rem;display:flex}.error-boundary h1{color:var(--danger);margin-bottom:.5rem;font-size:1.5rem}.error-boundary p{color:var(--text-secondary);margin-bottom:1.5rem}.error-boundary-actions{gap:.75rem;display:flex}.empty-state{text-align:center;color:var(--text-secondary);padding:3rem 1rem;font-size:1rem}@media (width<=768px){.dashboard{grid-template-columns:repeat(2,1fr)}.product-grid{grid-template-columns:1fr}.header-inner{flex-direction:column;align-items:flex-start}.header-right{justify-content:space-between;width:100%}.form-row{grid-template-columns:1fr}.filter-sort-row{flex-direction:column;align-items:flex-start}}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.price-input{border:1px solid var(--border);border-radius:var(--radius-sm);text-align:right;width:80px;font-size:.85rem;font-family:var(--font-mono);padding:.3rem .4rem}.price-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light);outline:none}.price-input-changed{border-color:var(--warning);background:#d977060d}.shopping-complete{border-top:1px solid var(--border);align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.btn-complete-purchase{padding:.75rem 1.5rem;font-size:1rem}.shopping-complete-hint{color:var(--text-secondary);font-size:.8rem}.purchase-history-page{max-width:900px;margin:0 auto}.purchase-stats{gap:.75rem;margin-bottom:1.5rem;display:flex}.purchase-top-lists{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem;display:grid}@media (width<=768px){.purchase-top-lists{grid-template-columns:1fr}}.purchase-top-list{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1rem}.purchase-top-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.75rem;font-size:.85rem;font-weight:600}.purchase-top-ol{counter-reset:top-list;margin:0;padding:0;list-style:none}.purchase-top-ol li{border-bottom:1px solid var(--border);counter-increment:top-list;justify-content:space-between;align-items:center;padding:.4rem 0;display:flex}.purchase-top-ol li:last-child{border-bottom:none}.purchase-top-ol li:before{content:counter(top-list) ".";color:var(--primary);min-width:1.5rem;margin-right:.5rem;font-weight:600}.purchase-top-name{flex:1;font-size:.9rem}.purchase-top-value{font-family:var(--font-mono);color:var(--primary);font-size:.85rem;font-weight:600}.purchase-list-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.75rem;font-size:.85rem;font-weight:600}.purchase-tabs{gap:.5rem;margin-bottom:1.5rem;display:flex}.purchase-tab-content{animation:.15s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.purchase-month-section{margin-bottom:2rem}.purchase-month-header{border-bottom:2px solid var(--primary);justify-content:space-between;align-items:baseline;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.purchase-month-title{text-transform:capitalize;color:var(--text);font-size:1.1rem;font-weight:700}.purchase-month-summary{align-items:baseline;gap:1rem;display:flex}.purchase-month-count{color:var(--text-secondary);font-size:.85rem}.purchase-month-total{font-family:var(--font-mono);color:var(--primary);font-size:1.1rem;font-weight:700}.purchase-list{flex-direction:column;gap:.5rem;display:flex}.purchase-entry{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.purchase-entry-header{cursor:pointer;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:background .15s;display:flex}.purchase-entry-header:hover{background:var(--primary-light)}.purchase-entry-info{flex-direction:column;gap:.15rem;display:flex}.purchase-entry-date{font-size:.9rem;font-weight:500}.purchase-entry-count{color:var(--text-secondary);font-size:.8rem}.purchase-entry-total{font-family:var(--font-mono);color:var(--primary);align-items:center;gap:.5rem;font-size:1rem;font-weight:700;display:flex}.purchase-entry-details{border-top:1px solid var(--border);padding:.75rem 1rem}.purchase-entry-actions{justify-content:flex-end;margin-top:.75rem;display:flex}.purchase-detail-table{border-collapse:collapse;width:100%;font-size:.85rem}.purchase-detail-table th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.05em;padding:.3rem .5rem;font-size:.75rem;font-weight:600}.purchase-detail-table td{border-bottom:1px solid var(--border);padding:.4rem .5rem}.purchase-detail-table tr:last-child td{border-bottom:none}.receipt-upload{text-align:center;padding:2rem 1rem}.receipt-description{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.5}.receipt-upload-btn{cursor:pointer;align-items:center;gap:.5rem;font-size:1rem;display:inline-flex}.receipt-scanning{text-align:center;padding:2rem 1rem}.receipt-progress-bar{background:var(--border);border-radius:4px;width:100%;height:8px;margin-bottom:1rem;overflow:hidden}.receipt-progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s}.receipt-progress-text{color:var(--text-secondary);font-size:.9rem}.receipt-error{text-align:center;padding:2rem 1rem}.receipt-error .error-text{color:var(--danger);margin-bottom:1rem}.receipt-review{flex-direction:column;gap:1rem;display:flex}.receipt-review-intro{color:var(--text-secondary);font-size:.9rem}.receipt-items{flex-direction:column;gap:.75rem;max-height:50vh;padding-right:.25rem;display:flex;overflow-y:auto}.receipt-item{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.75rem;transition:opacity .2s}.receipt-item-skipped{opacity:.5}.receipt-item-header{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.receipt-item-original{font-family:var(--font-mono);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.8rem;overflow:hidden}.receipt-action-select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text);cursor:pointer;padding:.25rem .5rem;font-size:.85rem}.receipt-item-delete{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:.25rem .4rem;font-size:1rem;line-height:1;transition:color .15s,background .15s}.receipt-item-delete:hover{color:var(--danger);background:#dc262614}.receipt-item-fields{grid-template-columns:1fr auto auto;align-items:end;gap:.5rem;display:grid}.receipt-field{flex-direction:column;gap:.2rem;display:flex}.receipt-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.receipt-field-sm{max-width:100px}.receipt-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);color:var(--text);width:100%;padding:.35rem .5rem;font-size:.85rem}.receipt-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #0891b226}.receipt-field-checkbox{grid-column:1/-1;padding-top:.25rem}.receipt-field-checkbox .checkbox-label{font-size:.85rem}.receipt-match-info{color:var(--success);grid-column:1/-1;padding-top:.25rem;font-size:.8rem}.receipt-summary{background:var(--primary-light);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:.75rem 1rem;font-weight:500;display:flex}.receipt-summary-total{color:var(--primary);font-size:1.1rem;font-weight:700}.modal-wide{max-width:600px}@media (width<=768px){.receipt-item-fields{grid-template-columns:1fr 1fr}.receipt-field-sm{max-width:none}.receipt-item-header{flex-direction:column;align-items:flex-start}.receipt-action-select{align-self:flex-end}}
