.app-layout{display:flex;height:100vh;overflow:hidden;background-color:var(--background-color)}.content-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.content-area{flex:1;overflow-y:auto;width:100%;margin:0 auto;padding:1.5rem 2rem}@media (max-width: 768px){.content-area{padding-top:70px;padding-bottom:75px;padding-left:1rem;padding-right:1rem}}@media (max-width: 480px){.content-area{padding-left:.5rem;padding-right:.5rem}}.bottom-nav{display:none}@media (max-width: 768px){.bottom-nav{display:flex;justify-content:space-around;align-items:center;position:fixed;bottom:0;left:0;width:100%;height:60px;background-color:var(--surface-color);border-top:1px solid var(--border-color);z-index:1000}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary-color);text-decoration:none;font-size:.75rem}.bottom-nav a.active{color:var(--primary-color)}}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;white-space:nowrap}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-color-dark)}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-danger:hover{background-color:var(--danger-color-dark)}.btn-secondary{background-color:var(--surface-color);color:var(--text-color);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--bg-color)}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;z-index:10001;display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .3s}.modal{background-color:var(--surface-color);padding:2rem;border-radius:12px;width:90%;max-width:400px;text-align:center;transform:scale(1);transition:transform .3s}.modal-title{font-size:1.25rem;margin-bottom:.5rem;color:var(--text-color)}.modal-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.main-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;border-bottom:1px solid var(--border-color);background-color:var(--surface-color);height:60px;width:100%;box-sizing:border-box;z-index:1001}.mobile-header-title{flex-grow:1;display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:700;font-size:1.2rem;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-header-title .logo-icon{width:24px;height:24px;color:var(--primary-color);flex-shrink:0;transform:translateY(-1px)}.icon-btn{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--text-color);display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.icon-btn:hover{background-color:var(--hover-color)}.header-actions{display:flex;align-items:center;gap:.5rem}.notification-btn{position:relative}.notification-btn.has-unread{color:var(--primary-color)}.notification-btn.has-unread{animation:ring 1.5s ease-in-out infinite}@keyframes ring{0%{transform:rotate(0)}10%{transform:rotate(25deg)}20%{transform:rotate(-20deg)}30%{transform:rotate(15deg)}40%{transform:rotate(-10deg)}50%{transform:rotate(5deg)}60%{transform:rotate(0)}to{transform:rotate(0)}}.hamburger-menu-btn{display:none}@media (max-width: 768px){.main-header{position:fixed;top:0;left:0;padding:.5rem 1rem}.hamburger-menu-btn{display:flex}}.notification-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;z-index:9999;display:flex;align-items:center;justify-content:center}.notification-modal{display:flex;flex-direction:column;background-color:var(--surface-color);width:90%;max-width:450px;height:80%;max-height:600px;border-radius:12px;box-shadow:0 8px 24px #0003;overflow:hidden}.notification-list-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.notification-list-header h2{margin:0}.notification-list-header .header-actions{display:flex;align-items:center;gap:1rem}.notification-list-header .clear-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:500;padding:0}.notification-list-header .close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary-color)}.notification-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1}.notification-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;cursor:pointer;border-bottom:1px solid var(--border-color)}.notification-item:hover{background-color:var(--bg-color)}.notification-dot{width:10px;height:10px;border-radius:50%;background-color:var(--warning-color);flex-shrink:0}.notification-item.read .notification-dot{background-color:transparent}.notification-item-content{display:flex;flex-direction:column}.notification-item-content span{font-size:.8rem;color:var(--text-secondary-color)}.no-notifications{padding:2rem;text-align:center;color:var(--text-secondary-color)}.notification-view{display:flex;flex-direction:column;height:100%}.notification-view-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.notification-view-header h3{margin:0}.notification-view-header button{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:500}.notification-view-content{padding:1.5rem;flex:1;overflow-y:auto}.notification-view-footer{padding:1rem;text-align:center;border-top:1px solid var(--border-color)}.notification-view-footer button{background-color:var(--primary-color);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer}.sidebar{width:250px;background-color:var(--surface-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:transform .3s ease-in-out}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.sidebar-title{font-size:1.25rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.sidebar-title-icon{color:var(--primary-color);transform:translateY(-1px)}.sidebar-close-btn,.sidebar-overlay{display:none}.sidebar-nav{display:flex;flex-direction:column;padding:1rem 0;flex-grow:1}.sidebar-nav a{padding:1rem 1.5rem;color:var(--text-secondary-color);text-decoration:none;font-weight:500;transition:background-color .2s}.sidebar-nav a:hover{background-color:var(--bg-color)}.sidebar-nav a.active{background-color:var(--primary-color);color:#fff}.sidebar-footer{padding:1rem;border-top:1px solid var(--border-color)}.notification-btn-desktop{width:100%;display:flex;align-items:center;gap:.75rem;background:none;border:1px solid var(--border-color);padding:.75rem;border-radius:8px;font-size:1rem;color:var(--text-color);cursor:pointer}.notification-btn-desktop:hover{background-color:var(--bg-color)}.notification-btn-desktop.has-unread{color:var(--warning-color);border-color:var(--warning-color);font-weight:700}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:10000;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-close-btn{display:inline-flex;background:none;border:none;color:var(--text-color);cursor:pointer}.sidebar-overlay.open{display:block;position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:9999}.sidebar-footer{display:none}}:root{--primary-color: #3b82f6;--primary-color-dark: #2563eb;--danger-color: #ef4444;--danger-color-dark: #dc2626;--success-color: #22c55e;--warning-color: #f59e0b;--bg-color: #f1f5f9;--surface-color: #ffffff;--text-color: #1e293b;--text-secondary-color: #64748b;--border-color: #cbd5e1;--input-bg-color: #ffffff;--shadow-color: rgba(0, 0, 0, .05);--tutorial-next-font: #dc2626}body.dark-theme{--bg-color: #0f172a;--surface-color: #1e293b;--text-color: #f1f5f9;--text-secondary-color: #94a3b8;--border-color: #334155;--input-bg-color: #334155;--shadow-color: rgba(0, 0, 0, .2);--tutorial-next-font: #f1f5f9}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;background-color:var(--bg-color);color:var(--text-color);transition:background-color .3s,color .3s;line-height:1.6}.container{max-width:800px;margin:2rem auto;padding:0 1rem}.form-control{display:flex;flex-direction:column;justify-content:center;height:100%}.form-control label{font-size:.8rem;color:var(--text-secondary-color);margin-bottom:.25rem;display:block;text-align:left}.form-control input{padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--input-bg-color);color:var(--text-color);font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.form-control input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color-rgb),.2)}.autocomplete-wrapper{position:relative;width:100%}.suggestions-list{position:absolute;top:100%;left:0;right:0;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);list-style:none;padding:.5rem 0;margin:.25rem 0 0;z-index:100;max-height:200px;overflow-y:auto}.suggestions-list li{padding:.75rem 1rem;cursor:pointer;color:var(--text-color);text-align:left}.suggestions-list li:hover{background-color:var(--bg-color)}.suggestions-list .no-suggestions{color:var(--text-secondary-color);font-style:italic;padding:.75rem 1rem;cursor:default}.card{background-color:var(--surface-color);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 12px var(--shadow-color);transition:background-color .3s}.form-control{display:flex;flex-direction:column;position:relative}.form-control label{margin-bottom:.5rem;font-weight:500;color:var(--text-secondary-color)}.form-control input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--input-bg-color);color:var(--text-color);font-size:1rem;transition:all .3s}.form-control input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f64d}.quantity-input-wrapper{display:flex;align-items:center;border:1px solid var(--border-color);border-radius:8px;background-color:var(--input-bg-color);height:44px}.quantity-input-wrapper:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f64d}.quantity-input-wrapper input{width:100%;flex:1;height:100%;border:none;background-color:transparent;text-align:center;font-size:1rem;color:var(--text-color);padding:.75rem;-moz-appearance:textfield;appearance:none}.quantity-input-wrapper input::-webkit-outer-spin-button,.quantity-input-wrapper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quantity-input-wrapper input:focus{outline:none}.quantity-buttons-stack{display:flex;flex-direction:column;height:100%;border-left:1px solid var(--border-color)}.quantity-buttons-stack button{background-color:transparent;border:none;cursor:pointer;padding:0 .5rem;color:var(--text-secondary-color);flex:1;display:flex;align-items:center;justify-content:center}.quantity-buttons-stack button:hover{background-color:var(--bg-color);color:var(--text-color)}.quantity-buttons-stack button:last-of-type{border-top:1px solid var(--border-color)}.shopping-list{padding:0;margin:0;list-style-type:none;display:flex;flex-direction:column;gap:.5rem}.empty-list-message{text-align:center;color:var(--text-secondary);padding:2rem 0}.list-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:8px;background-color:var(--surface-color);border:1px solid var(--border-color);position:relative}.item-checkbox{flex-shrink:0;width:20px;height:20px;accent-color:var(--primary-color);cursor:pointer}.list-item.checked .item-details,.list-item.checked .item-total-price{text-decoration:line-through;opacity:.6}.item-info{flex-grow:1;display:flex;justify-content:space-between;align-items:center;gap:1rem;overflow:hidden}.item-details{display:flex;flex-direction:column;overflow:hidden}.item-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-sub-details{font-size:.9rem;color:var(--text-secondary)}.item-total-price{font-weight:700;color:var(--primary-color);flex-shrink:0}.item-actions{display:flex;gap:.5rem}.item-actions .btn{padding:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.item-actions .button-text{display:none}.item-actions .button-icon{display:block}@media (min-width: 769px){.item-actions .btn{padding:.75rem 1.5rem;width:auto;height:auto;display:flex;align-items:center;justify-content:center}.item-actions .button-text{display:inline}.item-actions .button-icon{display:none}}.list-item.edit-mode{display:flex;align-items:flex-end;flex-wrap:nowrap;gap:.75rem}.edit-form-inputs{flex-grow:1;display:grid;grid-template-columns:1fr 1.5fr;gap:.75rem}.edit-form-actions{flex-shrink:0;display:flex;gap:.5rem;align-items:flex-end}.edit-form-actions .btn .button-icon{display:block}.edit-form-actions .btn .button-text{display:none}@media (max-width: 768px){.edit-form-actions .btn{padding:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center}}@media (min-width: 769px){.edit-form-actions .btn{padding:.75rem 1.5rem;width:auto;height:auto;display:flex;align-items:center;justify-content:center}.edit-form-actions .btn .button-icon{display:none}.edit-form-actions .btn .button-text{display:inline}}@media (max-width: 768px){.item-actions:not(.context-menu-visible){display:none}.list-item.context-menu-visible .item-info,.list-item.context-menu-visible .item-checkbox{opacity:.2;pointer-events:none}.list-item.context-menu-visible .item-actions{display:flex;position:absolute;right:1rem;top:50%;transform:translateY(-50%);background-color:var(--card-bg);padding:.5rem;border-radius:12px;box-shadow:0 4px 12px var(--shadow-color);z-index:10}}.add-item-form>div{width:100%;box-sizing:border-box}.add-item-form>div>*{width:100%;box-sizing:border-box}.add-item-form{display:grid;align-items:end;gap:.75rem;grid-template-columns:1fr 1fr auto;gap:1rem .75rem}.form-field-wrapper{display:flex;flex-direction:column;gap:.25rem;width:100%;box-sizing:border-box}.add-item-form .form-field-wrapper,.add-item-form .form-field-product{grid-column:1 / -1}.input-label{font-size:.8rem;color:var(--text-secondary-color);display:block;margin-left:.75rem}input:disabled{background-color:var(--input-disabled-bg-color, var(--background-color));color:var(--text-disabled-color, var(--text-secondary-color));border-color:var(--input-disabled-border-color, var(--border-color));cursor:not-allowed;opacity:.8}.form-control input:disabled,.autocomplete-wrapper input:disabled{background-color:var(--input-disabled-bg-color, var(--background-color));color:var(--text-disabled-color, var(--text-secondary-color));border-color:var(--input-disabled-border-color, var(--border-color))}@media (min-width: 801px){.add-item-form{grid-template-columns:1.5fr 2fr .75fr 1fr auto;gap:.75rem}.add-item-form .form-field-wrapper{grid-column:1 / 2}.add-item-form .form-field-product{grid-column:2 / 3}.add-item-form .form-field-quantity{grid-column:3 / 4}.add-item-form .form-field-price{grid-column:4 / 5}.add-item-form .form-field-button{grid-column:5 / 6;align-self:end}}@media (max-width: 420px){.form-add-button span{display:none}.form-add-button:after{content:"ADD";font-weight:600}}.shopping-totals-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px dashed var(--border-color)}.total-item{border-radius:8px;padding:.75rem 1rem;display:flex;flex-direction:column;box-shadow:0 1px 3px #0000000d;border:1px solid var(--border-color);align-items:center;text-align:center}.total-item:first-child{background-color:#28a745cc;border-left:4px solid #28a745}.total-item:last-child{background-color:#dc3545cc;border-left:4px solid #dc3545}.total-label{font-size:.8rem;font-weight:500;color:#fff;margin-bottom:.25rem}.total-value{font-size:1.5rem;font-weight:700;color:#fff;line-height:1.2}@media (max-width: 480px){.total-value{font-size:1.3rem}}.search-bar{margin-bottom:1rem}@media (max-width: 800px){.finish-purchase-container{width:100%;box-sizing:border-box}.finish-purchase-container>button{width:100%;box-sizing:border-box}}.products-page{display:flex;flex-direction:column;min-height:100vh}.products-content{flex-grow:1;display:flex;flex-direction:column;gap:1rem}.empty-list-message{text-align:center;color:var(--text-secondary-color);padding:2rem 0}.product-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.product-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--surface-color);min-height:48px;gap:1rem;user-select:none;-webkit-user-select:none;position:relative}.product-name{font-weight:500;color:var(--text-color);flex-grow:1;flex-shrink:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:100px}.product-actions{display:flex;align-items:center;flex-shrink:0;gap:.5rem}.product-actions .btn,.edit-product-form .btn{padding:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.edit-product-form .btn .button-text{display:none}.button-icon{display:block;width:20px;height:20px}@media (min-width: 601px){.product-actions .btn,.edit-product-form .btn{padding:.75rem 1.5rem;width:auto;height:auto;gap:.5rem}.button-icon{display:none}.button-text{display:inline}}.edit-product-form{display:flex;flex-grow:1;gap:.5rem;align-items:center;flex-wrap:wrap}.edit-product-form .input-group{flex-grow:1;min-width:150px}.bulk-add-form{display:flex;flex-direction:column;gap:1rem}.bulk-add-form label{font-weight:600;color:var(--text-secondary-color)}.bulk-add-form textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--background-color);color:var(--text-color);font-family:inherit;min-height:100px;resize:vertical}@media (max-width: 600px){.bulk-add-form .btn{width:100%;box-sizing:border-box}}.search-bar{position:relative;margin-bottom:1.5rem}@media (max-width: 600px){.product-item.context-menu-visible .product-name{opacity:.2}.product-item.context-menu-visible .product-actions{position:absolute;right:1rem;top:50%;transform:translateY(-50%);background-color:var(--card-bg);padding:.5rem;border-radius:8px;box-shadow:0 2px 8px var(--shadow-color);z-index:10}}.bulk-add-form{display:flex;flex-direction:column;gap:.5rem}.bulk-add-form textarea{width:100%;min-height:100px;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--input-bg-color);color:var(--text-color);font-size:1rem;resize:vertical}.bulk-add-form button{align-self:flex-start}.catalog-list{list-style:none;margin-top:1rem}.catalog-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:6px;background-color:var(--surface-color);border:1px solid var(--border-color);margin-bottom:.5rem}.catalog-item-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.catalog-item-actions{display:flex;gap:.5rem;flex-shrink:0;padding-left:1rem}.catalog-edit-form{display:flex;gap:.5rem;width:100%;align-items:center}.catalog-edit-form input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--input-bg-color);color:var(--text-color);font-size:1rem}@media (max-width: 768px){.catalog-item-actions .btn,.catalog-edit-form .btn{padding:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.catalog-item-actions .btn span,.catalog-edit-form .btn span{display:none}.catalog-item-actions .btn svg,.catalog-edit-form .btn svg{display:block}}@media (min-width: 769px){.catalog-item-actions .btn,.catalog-edit-form .btn{padding:.75rem 1.5rem;width:auto;height:auto;display:flex;align-items:center;justify-content:center}.catalog-item-actions .btn span,.catalog-edit-form .btn span{display:inline}.catalog-item-actions .btn svg,.catalog-edit-form .btn svg{display:none}}.empty-history-message{text-align:center;color:var(--text-secondary-color);padding:2rem 0}.history-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.history-item{border:1px solid var(--border-color);border-radius:8px}.history-item-summary{padding:1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:500;list-style:none}.history-item-summary::-webkit-details-marker{display:none}.history-item-summary:after{content:"+";font-size:1.5rem;color:var(--text-secondary-color);transition:transform .2s}.history-item[open]>.history-item-summary{border-bottom:1px solid var(--border-color)}.history-item[open]>.history-item-summary:after{transform:rotate(45deg)}.summary-info{display:flex;flex-direction:column;gap:.25rem}.summary-date{font-weight:700;color:var(--text-color)}.summary-establishment{font-size:.9rem;color:var(--text-secondary-color)}.summary-total{font-size:1.25rem;color:var(--success-color)}.history-item-details{padding:1rem}.history-item-details ul{list-style:none;padding:0;margin:0}.history-item-details li{display:flex;justify-content:space-between;padding:.25rem 0}.history-item-actions{margin-top:1.5rem;padding-top:1rem;border-top:1px dashed var(--border-color);display:flex;flex-wrap:wrap;gap:.5rem}.history-item-actions .button{flex:1 1 0px;min-width:0;box-sizing:border-box;min-height:40px;display:flex;align-items:center;justify-content:center;text-align:center}@media (min-width: 601px){.history-item-actions{justify-content:flex-end}.history-item-actions .button{flex:1;max-width:calc(50% - .25rem)}}@media (max-width: 600px){.history-item-actions{flex-direction:column}.history-item-actions .button{width:100%;max-width:100%}}.settings-option{border-bottom:1px dashed var(--border-color)}.settings-option:last-child{border-bottom:none}.settings-option p{color:var(--text-secondary-color);margin-bottom:1rem}.settings-option-content{padding:1rem}.theme-switcher,.settings-buttons-group,.settings-buttons-single,.settings-buttons-danger{display:flex;gap:1rem;justify-content:flex-start}.theme-switcher{flex-wrap:nowrap}.theme-switcher .button{flex:1 1 auto;min-width:80px;max-width:calc(50% - .5rem);box-sizing:border-box;display:flex;align-items:center;justify-content:center;text-align:center}.settings-buttons-group{flex-wrap:nowrap}.settings-buttons-group .button{flex:1 1 auto;min-width:120px;max-width:calc(50% - .5rem);box-sizing:border-box;display:flex;align-items:center;justify-content:center;text-align:center}.settings-buttons-single{flex-wrap:nowrap;justify-content:flex-start}.settings-buttons-single .button{width:100%;flex:none;box-sizing:border-box;display:flex;align-items:center;justify-content:center;text-align:center}.settings-buttons-danger{flex-wrap:wrap}.settings-buttons-danger .button{flex:1 1 auto;min-width:140px;max-width:calc(33.33% - .66rem);box-sizing:border-box;display:flex;align-items:center;justify-content:center;text-align:center;background-color:var(--danger-color)!important;border-color:var(--danger-color)!important;color:#fff!important}.settings-buttons-danger .button:hover{background-color:var(--danger-color-dark)!important;border-color:var(--danger-color-dark)!important}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;z-index:10000;display:flex;align-items:center;justify-content:center}.modal{background-color:var(--surface-color);padding:2rem;border-radius:12px;width:90%;max-width:500px;text-align:center}.modal-title{font-size:1.25rem;margin-bottom:.5rem}.modal-text{margin-bottom:1.5rem;color:var(--text-secondary-color)}.modal-textarea{width:100%;height:150px;margin-bottom:1rem;padding:.75rem;font-family:monospace;resize:vertical;border-radius:8px;background-color:var(--input-bg-color);color:var(--text-color);border:1px solid var(--border-color)}.modal-buttons{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:1rem}.modal-buttons .button{flex:1 1 auto;min-width:120px;max-width:calc(50% - .5rem);box-sizing:border-box;display:flex;align-items:center;justify-content:center;text-align:center}@media (max-width: 600px){.theme-switcher,.settings-buttons-group,.settings-buttons-single,.settings-buttons-danger,.modal-buttons{flex-direction:column;align-items:stretch;width:100%;gap:.5rem}.settings-buttons-single .button{width:100%;flex:none;margin:0 auto}.theme-switcher{flex-direction:row;justify-content:center;align-items:center}.theme-switcher .button{width:auto;max-width:calc(50% - .25rem);flex:1 1 auto}}.monthly-list-page{display:flex;flex-direction:column;gap:1rem}@media (max-width: 600px){.monthly-list-page{gap:.5rem}}.search-bar{position:relative}.search-bar input{padding-right:2.5rem!important}.clear-search-button{position:absolute;right:1rem;top:70%;transform:translateY(-50%);width:24px;height:24px;border:1px solid var(--danger-color, red);border-radius:50%;color:var(--danger-color, red);background:transparent;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.clear-search-button:hover{background-color:#ff00001a}.list-section{margin-bottom:2rem}.list-section:last-of-type{margin-bottom:0}.list-section h3{margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);color:var(--text-color)}.monthly-product-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.empty-list-message,.all-in-cart-message{text-align:center;color:var(--text-secondary-color);padding:2rem 1rem;background-color:var(--background-color);border-radius:8px;border:1px dashed var(--border-color)}.monthly-list-item{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:center;padding:.5rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--surface-color);min-height:54px}.monthly-product-list.in-cart .monthly-list-item{background-color:var(--background-color)}.monthly-product-list.in-cart .product-name{text-decoration:line-through;color:var(--text-secondary-color)}.product-name{font-weight:500;padding:0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-actions{display:flex;align-items:center;gap:.5rem}.quantity-control{max-width:120px;display:flex;align-items:center;transform:translateY(-3px)}.remove-button{padding:.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.remove-button .button-text{display:none}.remove-button .button-icon{display:block;margin:0}.main-actions-container{display:flex;flex-direction:column;gap:.75rem;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--border-color)}.main-actions-container .btn{width:100%;justify-content:center;box-sizing:border-box}.main-actions-container .btn .button-icon-right{display:none}.main-actions-container .btn.is-disabled{opacity:.6;cursor:not-allowed}@media (min-width: 601px){.remove-button .button-text{display:inline}.remove-button .button-icon{display:none}.remove-button{width:auto;height:auto}.main-actions-container{flex-direction:row;justify-content:flex-end}.main-actions-container .btn{width:auto}.main-actions-container .btn .button-icon-right{display:inline-block;margin-left:.5rem}.desktop-add-button-container{display:flex;justify-content:flex-end;margin-bottom:1rem;padding-right:1rem}.add-product-desktop-btn{padding:.75rem 1.5rem;font-size:1rem}}.fab{position:fixed;width:56px;height:56px;border-radius:16px;right:2rem;bottom:2rem;z-index:1000;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003;padding:0}@media (max-width: 768px){.fab{right:1rem;bottom:90px}}@media (min-width: 601px){.fab{display:none}}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-content{width:100%;max-width:500px;animation:fadeIn .3s ease-out}.modal-content form h2{margin-top:0;margin-bottom:1.5rem}.modal-form-fields{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1rem}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.notes-page{display:flex;flex-direction:column;min-height:100vh}.notes-content{flex-grow:1}.notes-actions-header{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.notes-actions-header .btn{padding:.75rem 1.5rem;font-size:1rem}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.note-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:1rem;display:flex;flex-direction:column;break-inside:avoid;cursor:pointer;transition:transform .2s ease-in-out}.note-card:hover{transform:translateY(-5px)}.note-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.note-card-title{font-weight:600;font-size:1.1rem;color:var(--text-color);margin:0;word-break:break-word;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 40px)}.note-card-actions{display:flex;gap:.25rem}.icon-button{background:transparent;border:none;color:var(--text-secondary-color);cursor:pointer;padding:.25rem;border-radius:50%;display:flex;align-items:center}.icon-button:hover{background-color:var(--bg-color);color:var(--text-color)}.icon-button.danger:hover{color:var(--danger-color)}.note-card-content{position:relative;font-size:1rem;color:var(--text-color);white-space:pre-wrap;word-wrap:break-word;margin:0;max-height:120px;overflow:hidden}.note-card-content:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:30px;background:linear-gradient(to top,var(--surface-color),transparent);pointer-events:none}.note-card-footer{margin-top:auto;padding-top:1rem;text-align:right}.note-date{font-size:.75rem;color:var(--text-tertiary-color)}.checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.checklist-item{display:flex;align-items:center;gap:.5rem}.checklist-item .checkbox-button{background:none;border:none;padding:0;color:var(--text-secondary-color);cursor:pointer;display:flex}.checklist-item.checked span{text-decoration:line-through;color:var(--text-secondary-color)}.empty-notes-message{text-align:center;color:var(--text-secondary-color);padding:2rem 0}.notes-page-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#0009;display:flex;justify-content:center;align-items:flex-start;z-index:1000;padding:1rem;box-sizing:border-box;overflow-y:auto}.notes-content-modal{width:100%;max-width:600px;background-color:transparent;display:flex;flex-direction:column;min-height:150px;margin-top:50px;margin-bottom:1rem;position:relative;box-shadow:none;max-height:calc(100vh - 100px)}.note-creator-card{width:100%;margin:0;display:flex;flex-direction:column;height:100%;min-height:150px}.note-creator-card>.card{display:flex;flex-direction:column;flex-grow:1;background-color:var(--surface-color);border:1px solid var(--border-color);box-shadow:0 4px 15px #0000001a;overflow:hidden;padding:0;border-radius:8px 8px 0 0}.note-creator-content-wrapper{flex-grow:1;overflow-y:auto;padding:.5rem 1rem 1rem;min-height:50px}.note-creator-title-input{font-size:1.5rem;font-weight:600;border:none;background:transparent;padding:1rem 1rem .5rem;color:var(--text-color);width:100%;flex-shrink:0}.note-creator-title-input:focus{outline:none}.note-creator-content-textarea{width:100%;border:none;background:transparent;padding:0;color:var(--text-color);resize:none;outline:none;font-family:inherit;font-size:1rem;line-height:1.5;flex-grow:1;overflow-y:hidden;min-height:50px}.note-creator-footer{width:100%;background-color:var(--surface-color);padding:.75rem 1rem;display:flex;justify-content:flex-end;gap:.5rem;box-shadow:0 -2px 8px #0000001a;z-index:10;border-top:1px solid var(--border-color);flex-shrink:0;border-bottom-left-radius:8px;border-bottom-right-radius:8px;border-left:1px solid var(--border-color);border-right:1px solid var(--border-color)}.checklist-editor{display:flex;flex-direction:column;gap:.25rem}.checklist-editor-item{display:flex;align-items:center;padding:.25rem 0;background-color:var(--surface-color);border-radius:4px;transition:transform .2s ease,box-shadow .2s ease}.checklist-editor-item.is-dragging{box-shadow:0 4px 10px #0003;opacity:.9;cursor:grabbing}.checklist-editor-item .grip-handle{color:var(--border-color);cursor:grab;padding:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.checklist-editor-item.is-dragging .grip-handle{cursor:grabbing}.checklist-item-input{flex-grow:1;border:none;border-bottom:1px solid transparent;background:transparent;padding:.5rem 0;color:var(--text-color);font-size:1rem}.checklist-item-input:focus{outline:none;border-bottom:1px solid var(--primary-color)}.add-item-btn{justify-content:flex-start;padding-left:32px;color:var(--text-secondary-color);margin-top:.5rem}.hidden-checkbox{display:none}
