.toast-container{bottom:24px;display:flex;flex-direction:column;gap:12px;position:fixed;right:24px;z-index:9999}.toast{align-items:center;animation:slideIn .3s ease forwards,fadeOut .3s ease 2.7s forwards;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;max-width:400px;min-width:300px;overflow:hidden;padding:16px;position:relative}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.toast:before{bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.toast--success:before{background-color:#10b981}.toast--error:before{background-color:#ef4444}.toast--warning:before{background-color:#f59e0b}.toast--info:before{background-color:#3b82f6}.toast__icon{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;margin-right:12px;width:24px}.toast--success .toast__icon{background-color:#10b981}.toast--error .toast__icon{background-color:#ef4444}.toast--warning .toast__icon{background-color:#f59e0b}.toast--info .toast__icon{background-color:#3b82f6}.toast__message{color:#374151;flex:1 1;font-size:14px;font-weight:500;line-height:1.4}.toast__close{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:20px;margin-left:12px;padding:0 4px;transition:color .2s}.toast__close:hover{color:#4b5563}.landing-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;overflow:hidden;position:relative}.landing-page:before{animation:backgroundShift 20s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#7877c64d 0,#0000 50%),radial-gradient(circle at 80% 80%,#ec48994d 0,#0000 50%),radial-gradient(circle at 40% 90%,#6366f133 0,#0000 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:0}@keyframes backgroundShift{0%,to{opacity:1;transform:scale(1) rotate(0deg)}50%{opacity:.8;transform:scale(1.1) rotate(5deg)}}.landing-page>*{position:relative;z-index:1}.landing-page__nav{-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);background:#ffffff1a;border-bottom:1px solid #ffffff4d;box-shadow:0 8px 32px #0000001a;padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.landing-page__nav-container{align-items:center;display:flex;justify-content:center;margin:0 auto;max-width:1400px;padding:0 2rem}.landing-page__logo{align-items:center;color:#fff;display:flex;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));font-size:1.5rem;font-weight:700;gap:.5rem}.landing-page__logo-icon{font-size:2rem}.landing-page__hero{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1400px;min-height:calc(100vh - 80px);padding:6rem 2rem}.landing-page__hero-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50px;box-shadow:var(--shadow-md);color:#fff;display:inline-block;font-size:.875rem;font-weight:600;margin-bottom:2rem;padding:.5rem 1rem}.landing-page__hero-title{color:#fff;font-size:4rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem;text-shadow:0 4px 20px #0003}.landing-page__hero-title--gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ffd89b,#19547b);-webkit-background-clip:text;background-clip:text}.landing-page__hero-subtitle{color:#fffffff2;font-size:1.25rem;line-height:1.7;max-width:600px;text-shadow:0 2px 10px #0003}.landing-page__hero-visual{align-items:center;display:flex;height:500px;justify-content:center;position:relative}.landing-page__hero-card{-webkit-backdrop-filter:blur(30px) saturate(180%);backdrop-filter:blur(30px) saturate(180%);background:#ffffff26;border:1px solid #ffffff4d;border-radius:2rem;box-shadow:0 8px 32px #0003,inset 0 1px 1px #ffffff4d;padding:3rem;position:absolute}.landing-page__hero-card--login{animation:float 6s ease-in-out infinite;max-width:480px;width:100%}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.landing-page__login-title{color:#fff;font-size:2rem;font-weight:800;margin-bottom:2rem;text-align:center;text-shadow:0 2px 10px #0003}.landing-page__login-form{display:flex;flex-direction:column;gap:1.5rem}.landing-page__login-error{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ef444433;border:1px solid #ef444480;border-radius:var(--border-radius);color:#fff;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:1rem}.landing-page__login-error-icon{font-size:1.25rem}.landing-page__form-group{display:flex;flex-direction:column;gap:.5rem}.landing-page__form-label{color:#fff;font-size:.95rem;font-weight:600;text-shadow:0 2px 4px #0003}.landing-page__form-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #ffffff4d;border-radius:var(--border-radius);color:#fff;font-family:inherit;font-size:1rem;padding:.875rem 1.125rem;transition:all .3s ease}.landing-page__form-input::placeholder{color:#fff9}.landing-page__form-input:focus{background:#ffffff26;border-color:#fffc;box-shadow:0 0 0 3px #ffffff1a;outline:none}.landing-page__form-input:disabled{background:#ffffff0d;cursor:not-allowed;opacity:.5}.landing-page__login-submit{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #ffffff4d;border-radius:var(--border-radius);box-shadow:0 4px 20px #0003;color:#fff;cursor:pointer;display:flex;font-size:1.05rem;font-weight:700;gap:.5rem;justify-content:center;margin-top:.5rem;padding:1rem;text-shadow:0 2px 4px #0003;transition:all .3s ease}.landing-page__login-submit:hover:not(:disabled){background:linear-gradient(135deg,#764ba2,#667eea);border-color:#ffffff80;box-shadow:0 6px 30px #0000004d;transform:translateY(-2px)}.landing-page__login-submit:disabled{cursor:not-allowed;opacity:.7;transform:none}.landing-page__login-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@media (max-width:1024px){.landing-page__hero{gap:3rem;grid-template-columns:1fr;padding:4rem 2rem}.landing-page__hero-title{font-size:3rem}.landing-page__hero-visual{height:auto}.landing-page__hero-card--login{margin:0 auto;max-width:500px;position:relative;width:100%}}@media (max-width:768px){.landing-page__nav-container{padding:0 1rem}.landing-page__hero-title{font-size:2.5rem}.landing-page__hero-subtitle{font-size:1.125rem}}@media (max-width:480px){.landing-page__hero-title{font-size:2rem}.landing-page__hero-subtitle{font-size:1rem}.landing-page__hero-card--login{padding:2rem}.landing-page__login-title{font-size:1.5rem}}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-page__container{background:#fff;border-radius:2rem;box-shadow:0 25px 50px #00000040;display:grid;grid-template-columns:1fr 1fr;max-width:1200px;overflow:hidden;width:100%}.login-page__left{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:4rem}.login-page__logo{align-items:center;display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;margin-bottom:2rem}.login-page__logo-icon{font-size:2.5rem}.login-page__title{font-size:3rem;font-weight:800;line-height:1.2;margin-bottom:1rem}.login-page__description{font-size:1.25rem;line-height:1.6;opacity:.95}.login-page__features{display:flex;flex-direction:column;gap:1.5rem}.login-page__feature{align-items:center;display:flex;font-size:1.125rem;gap:1rem}.login-page__feature-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;flex-shrink:0;font-weight:700;height:32px;justify-content:center;width:32px}.login-page__right{display:flex;flex-direction:column;justify-content:space-between;padding:4rem}.login-page__form-container{margin:0 auto;max-width:400px;width:100%}.login-page__form-header{margin-bottom:2.5rem}.login-page__form-title{color:var(--color-text);font-size:2rem;font-weight:800;margin-bottom:.5rem}.login-page__form-subtitle{color:var(--color-text-light);font-size:1rem}.login-page__link{color:var(--color-primary);font-weight:600;text-decoration:none;transition:color .3s ease}.login-page__link:hover{color:var(--color-primary-dark)}.login-page__form{display:flex;flex-direction:column;gap:1.5rem}.login-page__error{align-items:center;background:#ef44441a;border:1px solid var(--color-danger);border-radius:var(--border-radius);color:var(--color-danger);display:flex;font-size:.95rem;gap:.5rem;padding:1rem}.login-page__error-icon{font-size:1.25rem}.login-page__form-group{display:flex;flex-direction:column;gap:.5rem}.login-page__label{color:var(--color-text);font-size:.95rem;font-weight:600}.login-page__input{border:2px solid #e5e7eb;border-radius:var(--border-radius);font-family:inherit;font-size:1rem;padding:.875rem 1.125rem;transition:all .3s ease}.login-page__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a;outline:none}.login-page__input:disabled{background:var(--color-bg-secondary);cursor:not-allowed;opacity:.6}.login-page__form-options{align-items:center;display:flex;justify-content:space-between;margin-top:-.5rem}.login-page__checkbox{align-items:center;color:var(--color-text-light);cursor:pointer;display:flex;font-size:.95rem;gap:.5rem}.login-page__checkbox input{cursor:pointer;height:18px;width:18px}.login-page__submit{align-items:center;background:var(--color-primary);border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;display:flex;font-size:1.05rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.5rem;padding:1rem;transition:all .3s ease}.login-page__submit:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.login-page__submit:disabled{cursor:not-allowed;opacity:.7;transform:none}.login-page__spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}.login-page__divider{margin:2rem 0;position:relative;text-align:center}.login-page__divider:before{background:#e5e7eb;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.login-page__divider span{background:#fff;color:var(--color-text-light);font-size:.875rem;padding:0 1rem;position:relative}.login-page__social{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.login-page__social-button{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:var(--border-radius);color:var(--color-text);cursor:pointer;display:flex;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem;transition:all .3s ease}.login-page__social-button:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.login-page__social-button span{font-size:1.25rem;font-weight:800}.login-page__footer{margin-top:2rem;text-align:center}.login-page__back-link{color:var(--color-text-light);font-size:.95rem;text-decoration:none;transition:color .3s ease}.login-page__back-link:hover{color:var(--color-primary)}@media (max-width:1024px){.login-page__container{grid-template-columns:1fr;max-width:600px}.login-page__left{padding:3rem}.login-page__title{font-size:2.5rem}.login-page__right{padding:3rem}}@media (max-width:768px){.login-page{padding:1rem}.login-page__container{border-radius:1.5rem}.login-page__left{padding:2rem}.login-page__title{font-size:2rem}.login-page__description{font-size:1.125rem}.login-page__right{padding:2rem}.login-page__form-title{font-size:1.75rem}.login-page__social{grid-template-columns:1fr}}@media (max-width:480px){.login-page__left{padding:1.5rem}.login-page__title{font-size:1.75rem}.login-page__description{font-size:1rem}.login-page__right{padding:1.5rem}.login-page__form-title{font-size:1.5rem}.login-page__form-options{align-items:flex-start;flex-direction:column;gap:1rem}}.register-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.register-page__container{background:#fff;border-radius:2rem;box-shadow:0 25px 50px #00000040;max-width:500px;padding:4rem;text-align:center;width:100%}.register-page__title{color:var(--color-text);font-size:2rem;font-weight:800;margin-bottom:1rem}.register-page__text{color:var(--color-text-light);font-size:1.125rem;margin-bottom:2rem}.register-page__link{background:var(--color-primary);border-radius:var(--border-radius);color:#fff;display:inline-block;font-weight:600;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.register-page__link:hover{background:var(--color-primary-dark);box-shadow:var(--shadow-lg);transform:translateY(-2px)}@media (max-width:768px){.register-page__container{padding:3rem 2rem}.register-page__title{font-size:1.75rem}}.product-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:.5rem;overflow:hidden;transition:all .2s}.product-card:hover{box-shadow:0 2px 8px #00000026}.product-card--expanded{box-shadow:0 4px 12px #00000026}.product-card__compact{align-items:center;cursor:pointer;display:flex;gap:1rem;justify-content:space-between;padding:1rem 1.5rem;transition:background .2s}.product-card__compact:hover{background:#f9fafb}.product-card__compact-left{align-items:center;display:flex;flex:1 1;gap:1rem;min-width:0}.product-card__name{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-card__category-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-block;flex-shrink:0;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase;white-space:nowrap}.product-card__compact-right{align-items:center;display:flex;flex-shrink:0;gap:1.5rem}.product-card__compact-actions{align-items:center;display:flex;gap:.4rem}.product-card__compact-actions .product-card__button{align-items:center;border-radius:6px;display:flex;font-size:1rem;height:34px;justify-content:center;padding:0;width:34px}.product-card__macro-compact{align-items:center;display:flex;flex-direction:column;gap:.25rem;min-width:70px}.product-card__macro-label{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.product-card__macro-value{color:#1f2937;font-size:1rem;font-weight:700}.product-card__expand-btn{align-items:center;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:.875rem;height:36px;justify-content:center;transition:all .2s;width:36px}.product-card__expand-btn:hover{background:#e5e7eb;border-color:#d1d5db;color:#374151}.product-card__details-expanded{animation:slideDown .3s ease-out;background:#fafbfc;border-top:2px solid #f3f4f6;padding:1.5rem}.product-card__details-section{margin-bottom:1.5rem}.product-card__details-section:last-of-type{margin-bottom:1rem}.product-card__details-title{color:#374151;font-size:1rem;font-weight:600;letter-spacing:.05em;margin:0 0 1rem;text-transform:uppercase}.product-card__details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.product-card__detail-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:.75rem;padding:.75rem 1rem;transition:all .2s}.product-card__detail-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.product-card__detail-icon{flex-shrink:0;font-size:1.5rem}.product-card__detail-label{color:#6b7280;flex:1 1;font-size:.875rem}.product-card__detail-value{color:#1f2937;flex-shrink:0;font-size:1rem;font-weight:700}.product-card__description{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#4b5563;font-size:.875rem;line-height:1.6;margin:0;padding:1rem}.product-card__button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.625rem 1rem;transition:all .2s}.product-card__button--edit{background:#3b82f6;color:#fff}.product-card__button--edit:hover{background:#2563eb}.product-card__button--delete{background:#ef4444;color:#fff}.product-card__button--delete:hover{background:#dc2626}.product-card__button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1024px){.product-card__compact{padding:1rem}.product-card__compact-right{gap:1rem}.product-card__macro-compact{min-width:60px}.product-card__details-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width:768px){.product-card__compact{align-items:stretch;flex-direction:column;padding:1rem}.product-card__compact-left{align-items:flex-start;flex-direction:column}.product-card__compact-right{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;width:100%}.product-card__macro-compact{flex:1 1 40%;min-width:auto}.product-card__compact-actions{display:flex;flex:1 1 auto;justify-content:flex-start}.product-card__expand-btn{flex:0 0 auto}.product-card__details-grid{grid-template-columns:1fr}.product-card__name{font-size:1rem;white-space:normal}}.product-list{display:flex;flex-direction:column;gap:.5rem;padding:1rem 0}.product-list__loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;padding:4rem 2rem}.product-list__spinner{animation:product-list-spin .8s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#3b82f6;height:48px;width:48px}@keyframes product-list-spin{to{transform:rotate(1turn)}}.product-list__loading p{color:#6b7280;font-size:1rem;margin:0}.product-list__error{background:#fee2e2;border:2px solid #ef4444;border-radius:8px;padding:2rem;text-align:center}.product-list__error p{color:#991b1b;font-size:1rem;font-weight:500;margin:0}.product-list__empty{background:#f9fafb;border:2px dashed #d1d5db;border-radius:12px;padding:4rem 2rem;text-align:center}.product-list__empty p{color:#6b7280;font-size:1.125rem;margin:0}@media (max-width:768px){.product-list{gap:.5rem}}.product-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:600px;padding:2rem}.product-form__title{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem;text-align:center}.product-form__row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.product-form__group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.product-form__label{color:#374151;font-size:.875rem;font-weight:500}.product-form__input,.product-form__textarea{border:2px solid #e5e7eb;border-radius:6px;color:#1f2937;font-size:1rem;padding:.75rem;transition:border-color .2s}.product-form__input:focus,.product-form__textarea:focus{border-color:#3b82f6;outline:none}.product-form__input:disabled,.product-form__textarea:disabled{background:#f9fafb;cursor:not-allowed;opacity:.6}.product-form__textarea{font-family:inherit;min-height:80px;resize:vertical}.product-form__actions{border-top:1px solid #e5e7eb;display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem}.product-form__button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.product-form__button--cancel{background:#f3f4f6;color:#374151}.product-form__button--cancel:hover:not(:disabled){background:#e5e7eb}.product-form__button--submit{background:#3b82f6;color:#fff}.product-form__button--submit:hover:not(:disabled){background:#2563eb}.product-form__button:disabled{cursor:not-allowed;opacity:.5}.product-form__hint{color:#6b7280;font-size:.75rem;font-style:italic;margin-top:.25rem}@media (max-width:768px){.product-form{padding:1.5rem}.product-form__row{grid-template-columns:1fr}}.products-page{margin:0 auto;max-width:1400px;padding:24px}.products-page__create-icon{font-size:18px}.products-page__container{margin:0 auto;max-width:1400px}.products-page__form-wrapper{animation:products-page-fade-in .3s ease-in}@keyframes products-page-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.products-page__stats{display:flex;gap:1rem;margin-bottom:2rem}.products-page__stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:.5rem;min-width:200px;padding:1.5rem}.products-page__stat-label{color:#6b7280;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.products-page__stat-value{color:#1f2937;font-size:2rem;font-weight:700}.products-page__stat-total{color:#9ca3af;font-size:1.25rem;font-weight:400}.products-page__controls{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem}.products-page__search-wrapper{flex:1 1;min-width:250px;position:relative}.products-page__search{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem 2.5rem .75rem 1rem;transition:border-color .2s;width:100%}.products-page__search:focus{border-color:#3b82f6;outline:none}.products-page__clear-search{align-items:center;background:#e5e7eb;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;height:28px;justify-content:center;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:all .2s;width:28px}.products-page__clear-search:hover{background:#d1d5db;color:#374151}.products-page__filter,.products-page__sort{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:1rem;min-width:180px;padding:.75rem 1rem;transition:border-color .2s}.products-page__filter:focus,.products-page__sort:focus{border-color:#3b82f6;outline:none}.products-page__header{align-items:center;display:flex;gap:24px;justify-content:space-between;margin-bottom:32px}.products-page__header-content{flex:1 1}.products-page__title{align-items:center;color:#333;display:flex;font-size:32px;font-weight:700;gap:12px;margin:0}.products-page__subtitle{color:#666;font-size:16px;line-height:1.5;margin:0}.products-page__create-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.products-page__create-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.products-page__create-button:active{transform:translateY(0)}.products-page__create-icon{font-size:20px}@media (max-width:1024px){.products-page__header-content{padding:1rem 1.5rem}.products-page__main{padding:1.5rem}}@media (max-width:768px){.products-page{padding:16px}.products-page__header{align-items:flex-start;flex-direction:column}.products-page__title{font-size:24px}.products-page__subtitle{font-size:14px}.products-page__create-button{justify-content:center;width:100%}.products-page__header-content{align-items:stretch;flex-direction:column;gap:1rem}.products-page__title{font-size:1.5rem;text-align:center}.products-page__header-actions{flex-direction:column}.products-page__button{width:100%}.products-page__main{padding:1rem}.products-page__stats{flex-direction:column}.products-page__stat-card{min-width:auto}.products-page__controls{align-items:stretch;flex-direction:column}.products-page__search-wrapper{min-width:auto}.products-page__filter,.products-page__sort{min-width:auto;width:100%}}.meal-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:.5rem;overflow:hidden;transition:all .2s}.meal-card:hover{box-shadow:0 2px 8px #00000026}.meal-card--expanded{box-shadow:0 4px 12px #00000026}.meal-card__compact{align-items:center;cursor:pointer;display:flex;gap:1rem;justify-content:space-between;padding:1rem 1.5rem;transition:background .2s}.meal-card__compact:hover{background:#f9fafb}.meal-card__compact-left{align-items:center;display:flex;flex:1 1;gap:1rem;min-width:0}.meal-card__name{color:#1f2937;font-size:1.125rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meal-card__products-count{background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;color:#fff;display:inline-block;flex-shrink:0;font-size:.75rem;font-weight:600;padding:.25rem .75rem;white-space:nowrap}.meal-card__compact-right{align-items:center;display:flex;flex-shrink:0;gap:1.5rem}.meal-card__compact-actions{align-items:center;display:flex;gap:.4rem}.meal-card__compact-actions .meal-card__button{align-items:center;border-radius:6px;display:flex;font-size:1rem;height:34px;justify-content:center;padding:0;width:34px}.meal-card__macro-compact{align-items:center;display:flex;flex-direction:column;gap:.25rem;min-width:70px}.meal-card__macro-label{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.meal-card__macro-value{color:#1f2937;font-size:1rem;font-weight:700}.meal-card__expand-btn{align-items:center;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:.875rem;height:36px;justify-content:center;transition:all .2s;width:36px}.meal-card__expand-btn:hover{background:#e5e7eb;border-color:#d1d5db;color:#374151}.meal-card__details-expanded{animation:slideDown .3s ease-out;background:#fafbfc;border-top:2px solid #f3f4f6;padding:1.5rem}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:2000px;opacity:1}}.meal-card__details-section{margin-bottom:1.5rem}.meal-card__details-section:last-of-type{margin-bottom:1rem}.meal-card__details-title{color:#374151;font-size:1rem;font-weight:600;letter-spacing:.05em;margin:0 0 1rem;text-transform:uppercase}.meal-card__products-list{display:flex;flex-direction:column;gap:.75rem}.meal-card__product-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1rem;transition:all .2s}.meal-card__product-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.meal-card__product-name{color:#1f2937;font-size:1rem;font-weight:600}.meal-card__product-weight{color:#6b7280;font-size:.875rem;font-weight:500}.meal-card__product-macros{color:#4b5563;display:flex;flex-wrap:wrap;font-size:.875rem;gap:1rem}.meal-card__product-macros span{align-items:center;display:flex;gap:.25rem}.meal-card__recipe{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#4b5563;font-size:.875rem;line-height:1.6;margin:0;padding:1rem;white-space:pre-wrap}.meal-card__details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.meal-card__detail-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:.75rem;padding:.75rem 1rem;transition:all .2s}.meal-card__detail-item:hover{border-color:#d1d5db;box-shadow:0 2px 4px #0000000d}.meal-card__detail-icon{flex-shrink:0;font-size:1.5rem}.meal-card__detail-label{color:#6b7280;flex:1 1;font-size:.875rem}.meal-card__detail-value{color:#1f2937;flex-shrink:0;font-size:1rem;font-weight:700}.meal-card__actions{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;padding-top:1rem}.meal-card__button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.625rem 1rem;transition:all .2s}.meal-card__button--edit{background:#3b82f6;color:#fff}.meal-card__button--edit:hover{background:#2563eb}.meal-card__button--delete{background:#ef4444;color:#fff}.meal-card__button--delete:hover{background:#dc2626}.meal-card__button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1024px){.meal-card__compact{padding:1rem}.meal-card__compact-right{gap:1rem}.meal-card__macro-compact{min-width:60px}.meal-card__details-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media (max-width:768px){.meal-card__compact{align-items:stretch;flex-direction:column;gap:1rem;padding:1rem}.meal-card__compact-left{align-items:flex-start;flex-direction:column;width:100%}.meal-card__compact-right{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;width:100%}.meal-card__macro-compact{flex:1 1 40%;min-width:auto}.meal-card__compact-actions{display:flex;flex:1 1 auto;justify-content:flex-start}.meal-card__expand-btn{flex:0 0 auto}.meal-card__details-grid{grid-template-columns:1fr}.meal-card__name{font-size:1rem;overflow-wrap:break-word;white-space:normal;word-break:break-word}}.meal-list{gap:.5rem;padding:1rem 0}.meal-list,.meal-list__loading{display:flex;flex-direction:column}.meal-list__loading{align-items:center;gap:1rem;justify-content:center;padding:4rem 2rem}.meal-list__spinner{animation:meal-list-spin .8s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#10b981;height:48px;width:48px}@keyframes meal-list-spin{to{transform:rotate(1turn)}}.meal-list__loading p{color:#6b7280;font-size:1rem;margin:0}.meal-list__error{background:#fee2e2;border:2px solid #ef4444;border-radius:8px;padding:2rem;text-align:center}.meal-list__error p{color:#991b1b;font-size:1rem;font-weight:500;margin:0}.meal-list__empty{background:#f9fafb;border:2px dashed #d1d5db;border-radius:12px;padding:4rem 2rem;text-align:center}.meal-list__empty p{color:#6b7280;font-size:1.125rem;margin:0}@media (max-width:768px){.meal-list{gap:.5rem}}.meal-form{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;margin:0 auto;max-width:800px;padding:2rem}.meal-form__title{border-bottom:2px solid #f3f4f6;color:#1f2937;font-size:1.5rem;font-weight:700;margin:0 0 2rem;padding-bottom:1rem}.meal-form__section{margin-bottom:1.5rem}.meal-form__label{color:#4b5563;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.meal-form__input,.meal-form__textarea{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:.75rem 1rem;transition:all .2s;width:100%}.meal-form__input:focus,.meal-form__textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.meal-form__product-search{margin-bottom:1rem;position:relative}.meal-form__search-input{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:.75rem 1rem;width:100%}.meal-form__dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;left:0;margin-top:.25rem;max-height:250px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:50}.meal-form__dropdown-item{cursor:pointer;padding:.75rem 1rem;transition:background .2s}.meal-form__dropdown-item--highlighted,.meal-form__dropdown-item:hover{background:#f3f4f6}.meal-form__dropdown-item--disabled{color:#9ca3af;cursor:not-allowed}.meal-form__dropdown-item--disabled:hover{background:#fff}.meal-form__dropdown-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:40}.meal-form__products-list{display:flex;flex-direction:column;gap:.5rem}.meal-form__product-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:1rem;padding:.75rem 1rem}.meal-form__product-number{color:#6b7280;font-weight:700;min-width:1.5rem}.meal-form__product-info{display:flex;flex:1 1;flex-direction:column}.meal-form__product-name{color:#1f2937;font-weight:600}.meal-form__product-macros{color:#6b7280;font-size:.75rem}.meal-form__product-controls{align-items:center;display:flex;gap:.5rem}.meal-form__product-weight{border:1px solid #d1d5db;border-radius:6px;font-size:1rem;padding:.5rem;text-align:right;width:80px}.meal-form__product-unit{color:#6b7280;font-weight:500}.meal-form__product-remove{background:none;border:none;border-radius:4px;color:#ef4444;cursor:pointer;font-size:1.25rem;padding:.25rem;transition:background .2s}.meal-form__product-remove:hover{background:#fee2e2}.meal-form__empty-message{background:#f9fafb;border:1px dashed #d1d5db;border-radius:8px;color:#6b7280;font-size:.875rem;font-style:italic;margin:0;padding:1rem;text-align:center}.meal-form__subtitle{color:#374151;font-size:1.125rem;margin:0 0 1rem}.meal-form__macros-preview{grid-gap:1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);padding:1rem}.meal-form__macro-item{align-items:center;display:flex;flex-direction:column}.meal-form__macro-label{color:#166534;font-size:.75rem;font-weight:600;text-transform:uppercase}.meal-form__macro-value{color:#15803d;font-size:1.25rem;font-weight:700}.meal-form__actions{border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}.meal-form__button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.meal-form__button--cancel{background:#fff;border:1px solid #d1d5db;color:#4b5563}.meal-form__button--cancel:hover{background:#f3f4f6}.meal-form__button--submit{background:#3b82f6;color:#fff}.meal-form__button--submit:hover{background:#2563eb}.meal-form__button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:640px){.meal-form__macros-preview{grid-template-columns:repeat(2,1fr)}.meal-form__product-item{flex-wrap:wrap}.meal-form__product-controls{justify-content:flex-end;width:100%}}.meals-page{margin:0 auto;max-width:1400px;padding:24px}.meals-page__header{align-items:center;display:flex;gap:24px;justify-content:space-between;margin-bottom:32px}.meals-page__title{align-items:center;color:#333;display:flex;font-size:32px;font-weight:700;gap:12px;margin:0}.meals-page__create-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.meals-page__create-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.meals-page__create-button:active{transform:translateY(0)}.meals-page__create-icon{font-size:20px}.meals-page__subtitle{color:#666;font-size:16px;line-height:1.5;margin:0}.meals-page__button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.meals-page__button--products{background:#8b5cf6;color:#fff}.meals-page__button--products:hover{background:#7c3aed}.meals-page__button--create{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.meals-page__button--create:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.meals-page__button--create:active{transform:translateY(0)}.meals-page__button--mealsinday{background:#f59e0b;color:#fff}.meals-page__button--mealsinday:hover{background:#d97706}.meals-page__button--logout{background:#ef4444;color:#fff}.meals-page__button--logout:hover{background:#dc2626}.meals-page__button--cancel{background:#6b7280;color:#fff}.meals-page__button--cancel:hover{background:#4b5563}.meals-page__button:disabled{cursor:not-allowed;opacity:.5}.meals-page__main{padding:2rem}.meals-page__container{margin:0 auto;max-width:1400px}.meals-page__form-wrapper{animation:meals-page-fade-in .3s ease-in}@keyframes meals-page-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.meals-page__form-placeholder{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:3rem;text-align:center}.meals-page__form-placeholder h3{color:#1f2937;font-size:1.5rem;margin:0 0 1rem}.meals-page__form-placeholder p{color:#6b7280;margin:0 0 2rem}.meals-page__controls{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem}.meals-page__search-wrapper{flex:1 1;min-width:250px;position:relative}.meals-page__search{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem 2.5rem .75rem 1rem;transition:border-color .2s;width:100%}.meals-page__search:focus{border-color:#10b981;outline:none}.meals-page__clear-search{align-items:center;background:#e5e7eb;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;height:28px;justify-content:center;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:all .2s;width:28px}.meals-page__clear-search:hover{background:#d1d5db;color:#374151}.meals-page__sort{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:1rem;min-width:180px;padding:.75rem 1rem;transition:border-color .2s}.meals-page__sort:focus{border-color:#10b981;outline:none}@media (max-width:1024px){.meals-page__header-content{padding:1rem 1.5rem}.meals-page__main{padding:1.5rem}}@media (max-width:768px){.meals-page{padding:16px}.meals-page__header{align-items:flex-start;flex-direction:column}.meals-page__title{font-size:24px}.meals-page__subtitle{font-size:14px}.meals-page__create-button{justify-content:center;width:100%}}.meal-in-day-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:16px;transition:all .3s ease}.meal-in-day-card:hover{box-shadow:0 4px 12px #00000026}.meal-in-day-card--expanded{box-shadow:0 4px 16px #00000026}.meal-in-day-card__header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:20px 24px;transition:background-color .2s ease}.meal-in-day-card__header:hover{background-color:#fafafa}.meal-in-day-card__title{align-items:center;display:flex;flex:1 1;gap:12px}.meal-in-day-card__title h3{color:#333;font-size:18px;font-weight:600;margin:0}.meal-in-day-card__badge{background:linear-gradient(135deg,#4caf50,#45a049);border-radius:16px;box-shadow:0 2px 4px #4caf5033;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.meal-in-day-card__summary{align-items:center;display:flex;gap:20px}.meal-in-day-card__summary-item{align-items:center;border-radius:8px;display:flex;gap:8px;justify-content:center;min-width:-webkit-max-content;min-width:max-content;padding:8px 12px;transition:transform .2s ease}.meal-in-day-card__summary-item:hover{transform:translateY(-2px)}.meal-in-day-card__summary-item--calories{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;padding:10px 16px}.meal-in-day-card__summary-item--protein{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff}.meal-in-day-card__summary-item--carbs{background:linear-gradient(135deg,#f7b731,#f89e1b);color:#fff}.meal-in-day-card__summary-item--fats{background:linear-gradient(135deg,#a8e063,#56ab2f);color:#fff}.meal-in-day-card__summary-icon{align-items:center;display:flex;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:24px;justify-content:center}.meal-in-day-card__summary-content{align-items:flex-start;display:flex;flex-direction:column;gap:2px;justify-content:center}.meal-in-day-card__summary-label{font-size:10px;font-weight:600;letter-spacing:.5px;opacity:.8;text-transform:uppercase}.meal-in-day-card__summary-value{font-size:16px;font-weight:700;line-height:1}.meal-in-day-card__summary-unit{font-size:11px;font-weight:600;opacity:.9}.meal-in-day-card__expand-icon{color:#999;font-size:16px;margin-left:12px;transition:transform .3s ease}.meal-in-day-card--expanded .meal-in-day-card__expand-icon{transform:rotate(180deg)}.meal-in-day-card__content{padding:20px}.meal-in-day-card__meals h4{color:#333;font-size:16px;font-weight:600;margin:0 0 16px}.meal-in-day-card__meal{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;margin-bottom:12px;padding:12px;transition:all .2s ease}.meal-in-day-card__meal:hover{box-shadow:0 2px 8px #667eea26;transform:translateX(2px)}.meal-in-day-card__meal-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:8px}.meal-in-day-card__meal-title{align-items:center;display:flex;flex:1 1;gap:8px}.meal-in-day-card__meal-label{color:#666;font-size:14px;font-weight:600}.meal-in-day-card__meal-name{color:#333;font-size:14px;font-weight:600}.meal-in-day-card__meal-factor{background:#ff9800;border-radius:8px;color:#fff;font-size:12px;font-weight:600;padding:2px 8px}.meal-in-day-card__meal-macros-summary{display:flex;flex-wrap:wrap;gap:8px}.meal-in-day-card__meal-macro{background:#fff;border-radius:4px;color:#666;font-size:11px;font-weight:600;padding:4px 8px;white-space:nowrap}.meal-in-day-card__products{display:flex;flex-direction:column;gap:6px;padding-left:24px}.meal-in-day-card__product{align-items:center;color:#666;display:flex;font-size:13px;justify-content:space-between}.meal-in-day-card__product-name{flex:1 1}.meal-in-day-card__product-weight{color:#999;font-weight:600}.meal-in-day-card__loose-products{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:20px}.meal-in-day-card__loose-products h4{color:#333;font-size:16px;font-weight:600;margin:0 0 12px}.meal-in-day-card__loose-product{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-left:4px solid #ff9800;border-radius:8px;margin-bottom:12px;padding:12px;transition:all .2s ease}.meal-in-day-card__loose-product:hover{box-shadow:0 2px 8px #ff980033;transform:translateX(4px)}.meal-in-day-card__loose-product-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.meal-in-day-card__loose-product-name{color:#333;font-size:14px;font-weight:600}.meal-in-day-card__loose-product-weight{background:#fff;border-radius:4px;color:#ff9800;font-size:14px;font-weight:700;padding:4px 8px}.meal-in-day-card__loose-product-macros{display:flex;flex-wrap:wrap;gap:12px}.meal-in-day-card__loose-product-macro{background:#fffc;border-radius:4px;color:#666;font-size:12px;font-weight:500;padding:4px 8px}.meal-in-day-card__total-macros{border-top:2px solid #e0e0e0;margin-top:20px;padding-top:20px}.meal-in-day-card__total-macros h4{color:#333;font-size:16px;font-weight:600;margin:0 0 16px}.meal-in-day-card__macros-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.meal-in-day-card__macro-item{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;flex-direction:column;gap:4px;padding:16px}.meal-in-day-card__macro-label{font-size:12px;opacity:.9}.meal-in-day-card__macro-value{font-size:20px;font-weight:700}.meal-in-day-card__actions{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px}.meal-in-day-card__header-actions{align-items:center;display:flex;gap:.4rem}.meal-in-day-card__header-actions .meal-in-day-card__button{align-items:center;border-radius:6px;display:flex;font-size:1rem;height:34px;justify-content:center;padding:0;width:34px}.meal-in-day-card__button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.meal-in-day-card__button--edit{background:#2196f3;color:#fff}.meal-in-day-card__button--edit:hover{background:#1976d2;box-shadow:0 4px 8px #2196f34d;transform:translateY(-2px)}.meal-in-day-card__button--delete{background:#f44336;color:#fff}.meal-in-day-card__button--delete:hover{background:#d32f2f;box-shadow:0 4px 8px #f443364d;transform:translateY(-2px)}@media (max-width:768px){.meal-in-day-card__header{align-items:flex-start;flex-direction:column;gap:16px}.meal-in-day-card__summary{flex-wrap:wrap;gap:12px;width:100%}.meal-in-day-card__summary-item{flex:1 1;min-width:calc(50% - 6px)}.meal-in-day-card__summary-item--calories{flex-basis:100%}.meal-in-day-card__expand-icon{position:absolute;right:24px;top:20px}.meal-in-day-card__macros-grid{grid-template-columns:1fr 1fr}.meal-in-day-card__actions{flex-direction:column}.meal-in-day-card__button{width:100%}}.meal-in-day-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:900px;padding:2rem}.meal-in-day-form__header{border-bottom:2px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1rem}.meal-in-day-form__title{color:#1f2937;font-size:1.75rem;font-weight:700;margin:0}.meal-in-day-form__section{margin-bottom:2rem}.meal-in-day-form__section-title{color:#374151;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.meal-in-day-form__row{display:flex;gap:1rem;margin-bottom:1rem}.meal-in-day-form__field{display:flex;flex:1 1;flex-direction:column}.meal-in-day-form__field--full{flex:1 0 100%}.meal-in-day-form__label{color:#4b5563;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.meal-in-day-form__input{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem;transition:all .2s}.meal-in-day-form__input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a;outline:none}.meal-in-day-form__checkbox-label{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:1rem;gap:.5rem}.meal-in-day-form__checkbox{cursor:pointer;height:20px;width:20px}.meal-in-day-form__loading{color:#6b7280;font-style:italic;padding:2rem;text-align:center}.meal-in-day-form__meals{display:flex;flex-direction:column;gap:1.5rem}.meal-in-day-form__meal-slot{display:flex;flex-direction:column;gap:.5rem}.meal-in-day-form__meal-row{align-items:flex-start;display:flex;gap:1rem}.meal-in-day-form__meal-selector{flex:1 1;position:relative}.meal-in-day-form__selected-meal{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:1rem;justify-content:space-between;padding:.75rem 2.5rem .75rem 1rem;transition:all .2s}.meal-in-day-form__selected-meal:hover{border-color:#f59e0b}.meal-in-day-form__clear-meal,.meal-in-day-form__dropdown-arrow{color:#6b7280;font-size:.75rem}.meal-in-day-form__clear-meal{align-items:center;background:#e5e7eb;border:none;border-radius:50%;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:2.5rem;top:50%;transform:translateY(-50%);transition:all .2s;width:24px;z-index:1}.meal-in-day-form__clear-meal:hover{background:#d1d5db;color:#374151}.meal-in-day-form__dropdown{background:#fff;border:2px solid #f59e0b;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;left:0;margin-top:.25rem;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:10}.meal-in-day-form__dropdown-search{border:none;border-bottom:1px solid #e5e7eb;font-size:.875rem;outline:none;padding:.75rem}.meal-in-day-form__dropdown-list{max-height:240px;overflow-y:auto}.meal-in-day-form__dropdown-item{color:#374151;cursor:pointer;font-size:.875rem;padding:.75rem 1rem;transition:background .15s}.meal-in-day-form__dropdown-item:hover{background:#fef3c7}.meal-in-day-form__dropdown-item--selected{background:#fde68a;font-weight:600}.meal-in-day-form__dropdown-item--highlighted{background:#fef3c7;outline:2px solid #f59e0b;outline-offset:-2px}.meal-in-day-form__dropdown-empty{color:#9ca3af;font-size:.875rem;font-style:italic;padding:1rem;text-align:center}.meal-in-day-form__factor{align-items:center;display:flex;gap:.5rem;min-width:100px}.meal-in-day-form__factor-label{color:#f59e0b;font-size:1.25rem;font-weight:600}.meal-in-day-form__factor-input{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem .5rem;text-align:center;transition:all .2s;width:70px}.meal-in-day-form__factor-input:focus{border-color:#f59e0b;outline:none}.meal-in-day-form__macros{grid-gap:1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));padding:1.5rem}.meal-in-day-form__macro{align-items:center;display:flex;flex-direction:column;gap:.5rem}.meal-in-day-form__macro-label{color:#92400e;font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.meal-in-day-form__macro-value{color:#78350f;font-size:1.5rem;font-weight:700}.meal-in-day-form__actions{border-top:2px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem}.meal-in-day-form__button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .2s}.meal-in-day-form__button:disabled{cursor:not-allowed;opacity:.5}.meal-in-day-form__button--cancel{background:#e5e7eb;color:#374151}.meal-in-day-form__button--cancel:hover:not(:disabled){background:#d1d5db}.meal-in-day-form__button--submit{background:#f59e0b;color:#fff}.meal-in-day-form__button--submit:hover:not(:disabled){background:#d97706;box-shadow:0 4px 8px #f59e0b4d;transform:translateY(-2px)}@media (max-width:768px){.meal-in-day-form{padding:1.5rem}.meal-in-day-form__title{font-size:1.5rem}.meal-in-day-form__row{flex-direction:column}.meal-in-day-form__meal-row{flex-direction:column;gap:.75rem}.meal-in-day-form__factor{justify-content:center}.meal-in-day-form__macros{grid-template-columns:repeat(2,1fr)}.meal-in-day-form__actions{flex-direction:column-reverse}.meal-in-day-form__button{width:100%}}.meal-in-day-form__product-search{margin-bottom:1.5rem;position:relative}.meal-in-day-form__search-input{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:all .2s;width:100%}.meal-in-day-form__search-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a;outline:none}.meal-in-day-form__dropdown-container{position:relative}.meal-in-day-form__dropdown-wrapper{left:0;margin-top:.25rem;position:absolute;right:0;top:100%;z-index:20}.meal-in-day-form__dropdown-wrapper .meal-in-day-form__dropdown{background:#fff;border:2px solid #f59e0b;border-radius:8px;box-shadow:0 4px 12px #00000026;display:block;margin-top:0;max-height:300px;overflow-y:auto;position:static}.meal-in-day-form__dropdown-wrapper .meal-in-day-form__dropdown-item{cursor:pointer;padding:.75rem 1rem;transition:background .15s}.meal-in-day-form__dropdown-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:15}.meal-in-day-form__dropdown-item--disabled{color:#9ca3af;cursor:default;font-style:italic}.meal-in-day-form__dropdown-item--disabled:hover{background:#fff}.meal-in-day-form__loose-products-list{display:flex;flex-direction:column;gap:1rem}.meal-in-day-form__loose-product-item{align-items:center;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a;border-radius:12px;display:flex;gap:1rem;margin-bottom:.75rem;padding:1rem;transition:all .2s}.meal-in-day-form__loose-product-item:hover{box-shadow:0 4px 12px #f59e0b26;transform:translateX(4px)}.meal-in-day-form__loose-product-number{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;box-shadow:0 2px 4px #f59e0b4d;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:700;height:32px;justify-content:center;width:32px}.meal-in-day-form__loose-product-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.meal-in-day-form__loose-product-name{color:#78350f;font-size:1rem;font-weight:600}.meal-in-day-form__loose-product-macros{color:#92400e;font-size:.875rem}.meal-in-day-form__loose-product-controls{align-items:center;display:flex;gap:.5rem}.meal-in-day-form__loose-product-weight{border:2px solid #f59e0b;border-radius:6px;color:#78350f;font-size:1rem;font-weight:600;padding:.5rem;text-align:center;width:80px}.meal-in-day-form__loose-product-weight:focus{box-shadow:0 0 0 3px #f59e0b33;outline:none}.meal-in-day-form__loose-product-unit{color:#92400e;font-size:.875rem;font-weight:600}.meal-in-day-form__loose-product-remove{align-items:center;background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:700;height:32px;justify-content:center;padding:.5rem;transition:all .2s;width:32px}.meal-in-day-form__loose-product-remove:hover{background:#b91c1c;transform:scale(1.1)}.meal-in-day-form__count{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:12px;box-shadow:0 2px 4px #f59e0b4d;color:#fff;display:inline-block;font-size:.875rem;font-weight:600;margin-left:.5rem;padding:.25rem .75rem}.meal-in-day-form__hint{color:#6b7280;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.meal-in-day-form__hint-add-more{animation:fadeIn .3s ease-in;background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b;border-radius:8px;color:#92400e;font-size:.875rem;font-weight:500;margin-top:1rem;padding:.75rem 1rem}.meal-in-day-form__empty-message{background:#f9fafb;border:2px dashed #e5e7eb;border-radius:12px;color:#9ca3af;font-size:.875rem;margin-top:1rem;padding:2rem;text-align:center}@media (max-width:768px){.meal-in-day-form__loose-product-item{align-items:stretch;flex-direction:column;gap:1rem}.meal-in-day-form__loose-product-controls{justify-content:flex-end}}.generate-sl-dialog-overlay{align-items:center;background-color:#00000080;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:1000}.generate-sl-dialog{background-color:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;max-height:90vh;max-width:600px;width:90%}.generate-sl-dialog__header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px 20px}.generate-sl-dialog__header h2{color:#333;font-size:1.2rem;margin:0}.generate-sl-dialog__close{background:none;border:none;color:#666;cursor:pointer;font-size:1.5rem}.generate-sl-dialog__content{flex:1 1;overflow-y:auto;padding:20px}.generate-sl-dialog__field label{display:block;font-weight:700;margin-bottom:8px}.generate-sl-dialog__field input[type=text]{border:1px solid #ccc;border-radius:4px;padding:8px;width:100%}.generate-sl-dialog__section{margin-top:24px}.generate-sl-dialog__section h3{color:#444;font-size:1.1rem;margin-bottom:12px}.generate-sl-dialog__item{align-items:center;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px}.generate-sl-dialog__item-name{font-weight:500}.generate-sl-dialog__item-controls{align-items:center;display:flex;gap:8px}.generate-sl-dialog__item-controls input{padding:4px;text-align:right;width:60px}.generate-sl-dialog__search-wrap{margin-top:12px;position:relative}.generate-sl-dialog__search-wrap input{border:1px solid #ccc;border-radius:4px;padding:8px;width:100%}.generate-sl-dialog__dropdown{background:#fff;border:1px solid #ccc;border-radius:0 0 4px 4px;border-top:none;box-shadow:0 4px 6px #0000001a;left:0;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:10}.generate-sl-dialog__dropdown-item{cursor:pointer;padding:8px 12px}.generate-sl-dialog__dropdown-item.highlighted,.generate-sl-dialog__dropdown-item:hover{background:#f0f0f0}.generate-sl-dialog__actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.generate-sl-dialog__btn{border:none;border-radius:4px;cursor:pointer;font-weight:700;padding:8px 16px}.generate-sl-dialog__btn-icon{background:none;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;padding:4px}.generate-sl-dialog__btn-icon:hover{background-color:#f0f0f0}.btn-cancel{background:#f0f0f0;color:#333}.btn-cancel:hover{background:#e0e0e0}.btn-submit{background:#4caf50;color:#fff}.btn-submit:hover{background:#45a049}.btn-submit:disabled{background:#a5d6a7;cursor:not-allowed}.meals-in-day-page{margin:0 auto;max-width:1400px;padding:24px}.meals-in-day-page__header{align-items:center;display:flex;gap:24px;justify-content:space-between;margin-bottom:32px}.meals-in-day-page__title{align-items:center;color:#333;display:flex;font-size:32px;font-weight:700;gap:12px;margin:0}.meals-in-day-page__create-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.meals-in-day-page__create-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.meals-in-day-page__create-button:active{transform:translateY(0)}.meals-in-day-page__create-icon{font-size:20px}.meals-in-day-page__loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px}.meals-in-day-page__spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:48px;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.meals-in-day-page__loading p{color:#666;font-size:16px;margin:0}.meals-in-day-page__error{align-items:center;background:#ffebee;border-left:4px solid #f44336;border-radius:8px;display:flex;gap:12px;margin-bottom:24px;padding:16px 20px}.meals-in-day-page__error-icon{font-size:24px}.meals-in-day-page__error p{color:#c62828;font-weight:500;margin:0}.meals-in-day-page__form-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #00000014;margin-bottom:24px;padding:24px}.meals-in-day-page__controls{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem}.meals-in-day-page__search-wrapper{flex:1 1;min-width:250px;position:relative}.meals-in-day-page__search{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem 2.5rem .75rem 1rem;transition:border-color .2s;width:100%}.meals-in-day-page__search:focus{border-color:#3b82f6;outline:none}.meals-in-day-page__clear-search{align-items:center;background:#e5e7eb;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;height:28px;justify-content:center;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:all .2s;width:28px}.meals-in-day-page__clear-search:hover{background:#d1d5db;color:#374151}.meals-in-day-page__sort{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-size:1rem;min-width:180px;padding:.75rem 1rem;transition:border-color .2s}.meals-in-day-page__sort:focus{border-color:#3b82f6;outline:none}.meals-in-day-page__list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px;padding:0 4px}.meals-in-day-page__count{color:#666;font-size:14px}.meals-in-day-page__count strong{color:#333;font-weight:700}.meals-in-day-page__empty{align-items:center;background:#fff;border:2px dashed #e0e0e0;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:80px 20px;text-align:center}.meals-in-day-page__empty-icon{font-size:64px;margin-bottom:16px}.meals-in-day-page__empty h3{color:#333;font-size:24px;margin:0 0 8px}.meals-in-day-page__empty p{color:#666;font-size:16px;margin:0;max-width:400px}@media (max-width:768px){.meals-in-day-page{padding:16px}.meals-in-day-page__header{align-items:flex-start;flex-direction:column}.meals-in-day-page__title{font-size:24px}.meals-in-day-page__create-button{justify-content:center;width:100%}.meals-in-day-page__form-container{padding:16px}.meals-in-day-page__controls{align-items:stretch;flex-direction:column}.meals-in-day-page__search-wrapper{min-width:auto}.meals-in-day-page__sort{min-width:auto;width:100%}}.shopping-list-card{background:#fff;border:2px solid #0000;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;flex-direction:column;height:100%;padding:1.5rem;transition:transform .2s,box-shadow .2s,border-color .2s}.shopping-list-card--clickable{cursor:pointer}.shopping-list-card--clickable:hover{border-color:#10b981;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-4px)}.shopping-list-card__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.shopping-list-card__name{color:#111827;font-size:1.25rem;font-weight:700;margin:0 0 .25rem}.shopping-list-card__date{color:#6b7280;font-size:.75rem}.shopping-list-card__actions{display:flex;gap:.5rem}.shopping-list-card__action-btn{background:#f3f4f6;border:none;border-radius:.375rem;cursor:pointer;font-size:1rem;padding:.5rem;transition:background .2s}.shopping-list-card__action-btn:hover{background:#e5e7eb}.shopping-list-card__action-btn--delete:hover{background:#fee2e2}.shopping-list-card__progress-container{align-items:center;background:#f3f4f6;border-radius:1rem;display:flex;height:.75rem;margin-bottom:1.5rem;overflow:hidden;position:relative}.shopping-list-card__progress-bar{background:#10b981;height:100%;transition:width .3s ease}.shopping-list-card__progress-text{color:#374151;font-size:.625rem;font-weight:700;position:absolute;right:.5rem;text-transform:uppercase}.shopping-list-card__footer{margin-top:auto;padding-top:1rem;text-align:right}.shopping-list-card__open-text{color:#10b981;font-size:.875rem;font-weight:500}.shopping-list-form{background:#fff;border-radius:1rem;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;margin:0 auto;max-width:800px;padding:2rem}.shopping-list-form__title{border-bottom:2px solid #f3f4f6;color:#111827;font-size:1.5rem;font-weight:700;margin-bottom:2rem;padding-bottom:1rem}.shopping-list-form__section{margin-bottom:2rem}.shopping-list-form__label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.shopping-list-form__input{border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem 1rem;transition:all .2s;width:100%}.shopping-list-form__input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.shopping-list-form__product-search{margin-bottom:1.5rem;position:relative}.shopping-list-form__dropdown{background:#fff;border:1px solid #d1d5db;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;left:0;margin-top:.25rem;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:50}.shopping-list-form__dropdown-item{cursor:pointer;padding:.75rem 1rem;transition:background .2s}.shopping-list-form__dropdown-item:hover{background-color:#f3f4f6}.shopping-list-form__dropdown-item--empty{color:#6b7280;cursor:default;font-style:italic}.shopping-list-form__dropdown-item--create{background-color:#eff6ff;border-top:1px solid #f3f4f6;color:#2563eb;font-weight:500}.shopping-list-form__dropdown-item--create:hover{background-color:#dbeafe}.shopping-list-form__products-list{background:#f9fafb;border-radius:.5rem;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.shopping-list-form__product-row{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:.375rem;display:flex;justify-content:space-between;padding:.75rem 1rem}.shopping-list-form__product-name{color:#111827;font-weight:600}.shopping-list-form__product-inputs{align-items:center;display:flex;gap:1rem}.shopping-list-form__input-group{align-items:center;background:#f3f4f6;border-radius:.375rem;display:flex;gap:.5rem;padding:.25rem .5rem}.shopping-list-form__number-input{background:#0000;border:none;font-size:.875rem;font-weight:600;text-align:right;width:60px}.shopping-list-form__number-input:focus{outline:none}.shopping-list-form__unit{color:#6b7280;font-size:.75rem}.shopping-list-form__remove-btn{align-items:center;background:#fee2e2;border:none;border-radius:50%;color:#ef4444;cursor:pointer;display:flex;height:2rem;justify-content:center;transition:all .2s;width:2rem}.shopping-list-form__remove-btn:hover{background:#fecaca;transform:scale(1.1)}.shopping-list-form__actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.shopping-list-form__btn{border:none;border-radius:.5rem;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.shopping-list-form__btn--cancel{background-color:#f3f4f6;color:#374151}.shopping-list-form__btn--cancel:hover{background-color:#e5e7eb}.shopping-list-form__btn--submit{background-color:#2563eb;color:#fff}.shopping-list-form__btn--submit:hover{background-color:#1d4ed8;box-shadow:0 4px 12px #2563eb40}.shopping-list-form__btn:disabled{cursor:not-allowed;opacity:.5}.shopping-list-page{margin:0 auto;max-width:1200px;padding:2rem}.shopping-list-page__header{align-items:center;background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.shopping-list-page__title{color:#1f2937;font-size:1.875rem;font-weight:700;margin:0}.shopping-list-page__create-button{align-items:center;background-color:#2563eb;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.shopping-list-page__create-button:hover{background-color:#1d4ed8;box-shadow:0 4px 12px #2563eb40;transform:translateY(-1px)}.shopping-list-page__create-icon{font-size:1.25rem}.shopping-list-page__controls{display:flex;gap:1rem;margin-bottom:2rem}.shopping-list-page__search{border:1px solid #d1d5db;border-radius:.5rem;box-shadow:0 1px 2px 0 #0000000d;flex:1 1;font-size:1rem;padding:.75rem 1rem;transition:all .2s}.shopping-list-page__search:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.shopping-list-page__list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.shopping-list-page__empty{background:#fff;border-radius:1rem;color:#6b7280;grid-column:1/-1;padding:4rem 2rem;text-align:center}.shopping-list-page__empty-icon{display:block;font-size:3rem;margin-bottom:1rem}.shopping-list-page__error{align-items:center;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b;display:flex;gap:.5rem;margin-bottom:1.5rem;padding:1rem}.shopping-list-details{margin:0 auto;max-width:800px;padding:2rem}.shopping-list-details__header{margin-bottom:2rem}.shopping-list-details__back-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1rem;margin-bottom:1rem;padding:0}.shopping-list-details__back-btn:hover{color:#374151;text-decoration:underline}.shopping-list-details__title-group{align-items:center;display:flex;justify-content:space-between}.shopping-list-details__title{color:#111827;font-size:2rem;font-weight:700;margin:0}.shopping-list-details__progress-container{align-items:center;background:#f3f4f6;border-radius:1rem;display:flex;height:1rem;margin-bottom:2rem;overflow:hidden;position:relative}.shopping-list-details__progress-bar{background:#10b981;height:100%;transition:width .3s ease}.shopping-list-details__progress-text{color:#374151;font-size:.75rem;font-weight:700;position:absolute;right:1rem;text-transform:uppercase}.shopping-list-details__content{display:flex;flex-direction:column;gap:1.5rem}.shopping-list-details__category{background:#0000;border:2px solid #0000;padding:0;transition:transform .2s,box-shadow .2s,border-color .2s}.shopping-list-details__category:active{cursor:grabbing}.shopping-list-details__category--dragging{opacity:.5;transform:scale(.98)}.shopping-list-details__category--drag-over{border-color:#3b82f6;border-style:dashed}.shopping-list-details__category-header{align-items:center;cursor:pointer;display:flex;gap:.75rem;margin-bottom:.25rem;padding:.5rem .25rem}.shopping-list-details__category-header:hover{background-color:#f9fafb80;border-radius:.5rem}.shopping-list-details__drag-handle{color:#9ca3af;cursor:grab;font-size:1.25rem}.shopping-list-details__category-name{color:#6b7280;flex:1 1;font-size:.85rem;font-weight:600;letter-spacing:.1em;margin:0;text-transform:uppercase}.shopping-list-details__collapse-icon{color:#9ca3af;font-size:.75rem;margin-left:auto}.shopping-list-details__products{list-style:none;margin:0;padding:0}.shopping-list-details__product{align-items:center;background:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;display:flex;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem;transition:opacity .2s}.shopping-list-details__product:last-child{border-bottom:none}.shopping-list-details__product--bought{opacity:.6}.shopping-list-details__product--bought .shopping-list-details__product-name{color:#9ca3af;text-decoration:line-through}.shopping-list-details__checkbox-container{cursor:pointer;display:block;height:1.5rem;position:relative;width:1.5rem}.shopping-list-details__checkbox-container input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.shopping-list-details__checkmark{background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;height:1.5rem;left:0;position:absolute;top:0;transition:background-color .2s,border-color .2s;width:1.5rem}.shopping-list-details__checkbox-container:hover input~.shopping-list-details__checkmark{background-color:#e5e7eb}.shopping-list-details__checkbox-container input:checked~.shopping-list-details__checkmark{background-color:#10b981;border-color:#10b981}.shopping-list-details__checkmark:after{border:solid #fff;border-width:0 2px 2px 0;content:"";display:none;height:10px;left:8px;position:absolute;top:3px;transform:rotate(45deg);width:5px}.shopping-list-details__checkbox-container input:checked~.shopping-list-details__checkmark:after{display:block}.shopping-list-details__product-info{align-items:center;display:flex;flex:1 1;justify-content:space-between}.shopping-list-details__product-name{color:#111827;font-size:1.05rem;font-weight:600}.shopping-list-details__product-amount{align-items:baseline;display:flex;gap:.5rem}.shopping-list-details__product-quantity{color:#111827;font-size:1.05rem;font-weight:700}.shopping-list-details__product-weight-secondary{color:#9ca3af;font-size:.85rem}.shopping-list-details__save-btn{background-color:#10b981;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;margin-left:auto;padding:.5rem 1rem;transition:background-color .2s}.shopping-list-details__save-btn:hover{background-color:#059669}.shopping-list-details__empty-msg{color:#9ca3af;font-style:italic;margin:2rem 0;text-align:center}.sidebar__hamburger{align-items:center;background:#f59e0b;border:none;border-radius:8px;box-shadow:0 2px 8px #f59e0b4d;cursor:pointer;display:flex;flex-direction:column;gap:6px;height:40px;justify-content:center;left:20px;padding:0;position:fixed;top:20px;transition:all .3s ease;width:40px;z-index:1001}.sidebar__hamburger:hover{background:#d97706;transform:scale(1.05)}.sidebar__hamburger span{background:#fff;border-radius:2px;display:block;height:3px;transition:all .3s ease;width:24px}.sidebar__hamburger--open span:first-child{transform:rotate(45deg) translate(6px,6px)}.sidebar__hamburger--open span:nth-child(2){opacity:0}.sidebar__hamburger--open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.sidebar__overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:999}.sidebar{background:linear-gradient(135deg,#1f2937,#111827);box-shadow:2px 0 12px #0003;display:flex;flex-direction:column;height:100vh;left:-280px;overflow-y:auto;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:1000}.sidebar--open{left:0}.sidebar__header{border-bottom:1px solid #ffffff1a;padding:24px 20px}.sidebar__logo{align-items:center;color:#fff;display:flex;font-size:20px;font-weight:700;gap:12px}.sidebar__logo-icon{font-size:32px}.sidebar__logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f59e0b,#d97706);-webkit-background-clip:text;background-clip:text}.sidebar__nav{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:20px 0}.sidebar__nav-item{align-items:center;background:#0000;border:none;border-left:3px solid #0000;color:#d1d5db;cursor:pointer;display:flex;font-size:15px;gap:12px;padding:14px 20px;text-align:left;transition:all .2s ease;width:100%}.sidebar__nav-item:hover{background:#f59e0b1a;border-left-color:#f59e0b;color:#f59e0b}.sidebar__nav-item--active{background:#f59e0b26;border-left-color:#f59e0b;color:#f59e0b;font-weight:600}.sidebar__nav-icon{font-size:20px;text-align:center;width:24px}.sidebar__nav-label{flex:1 1}.sidebar__footer{border-top:1px solid #ffffff1a;padding:20px}.sidebar__logout{align-items:center;background:#ef44441a;border:none;border-radius:8px;color:#ef4444;cursor:pointer;display:flex;font-size:15px;gap:12px;padding:14px 20px;text-align:left;transition:all .2s ease;width:100%}.sidebar__logout:hover{background:#ef444433;transform:translateY(-1px)}@media (max-width:768px){.sidebar__overlay{display:block}}@media (min-width:769px){.sidebar__hamburger{display:none}.sidebar{left:0}}.layout{background:#f3f4f6;display:flex;min-height:100vh}.layout__content{flex:1 1;transition:margin-left .3s ease}@media (min-width:769px){.layout__content{margin-left:280px}}@media (max-width:768px){.layout__content{margin-left:0}}:root{--color-primary:#6366f1;--color-primary-dark:#4f46e5;--color-secondary:#ec4899;--color-success:#10b981;--color-danger:#ef4444;--color-warning:#f59e0b;--color-text:#1f2937;--color-text-light:#6b7280;--color-bg:#fff;--color-bg-secondary:#f9fafb;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--border-radius:0.75rem;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a;--shadow-xl:0 20px 25px #00000026}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.a454fc97.css.map*/