:root{--primary-color: #4caf50;--secondary-color: #ffc107;--accent-color: #2196f3;--danger-color: #d32f2f;--text-color-dark: #333333;--text-color-light: #ffffff;--background-color-light: #f4f4f4;--background-color-dark: #222222;--border-color: #cccccc;--card-background: #ffffff;--font-size-small: .875rem;--font-size-medium: 1rem;--font-size-large: 1.25rem;--font-size-x-large: 1.5rem;--font-size-xx-large: 2rem;--shadow-elevation-1: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);--shadow-elevation-2: 0 3px 6px rgba(0, 0, 0, .16), 0 3px 6px rgba(0, 0, 0, .23)}body{margin:0;font-family:Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color-light);color:var(--text-color-dark);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}.app-container{max-width:3000px;margin:20px auto;padding:0 20px;display:flex;flex-direction:column;gap:20px;align-items:center;flex-grow:1;width:100%;box-sizing:border-box}.main-content{width:95%;flex-grow:1;display:flex;flex-direction:column;align-items:center;box-sizing:border-box}h1,h2,h3,h4,h5,h6{color:var(--primary-color);margin-top:0;margin-bottom:15px}button{background-color:var(--primary-color);color:var(--text-color-light);border:none;padding:10px 15px;border-radius:5px;cursor:pointer;font-size:var(--font-size-medium);transition:background-color .3s ease,transform .2s ease;text-transform:uppercase;letter-spacing:.5px}button:hover{background-color:var(--accent-color);transform:translateY(-1px)}button:active{transform:translateY(0)}input[type=text],input[type=number],input[type=url],input[type=password],textarea,select{padding:10px;border:1px solid var(--border-color);border-radius:5px;font-size:var(--font-size-medium);outline:none;transition:border-color .3s ease,box-shadow .3s ease;box-sizing:border-box}input:focus,textarea:focus,select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f333}@media (max-width: 768px){.app-container{padding:0 15px;margin:15px auto;gap:15px}}.main-header{width:100%;background-color:var(--primary-color);color:var(--text-color-light);box-shadow:var(--shadow-elevation-2);padding:10px 0;margin-bottom:20px;position:sticky;top:0;z-index:900}.header-content{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;box-sizing:border-box}.site-logo{color:var(--text-color-light);text-decoration:none;font-size:var(--font-size-x-large);font-weight:700;display:flex;align-items:center;gap:10px;padding:5px 0;transition:color .3s ease}.site-logo:hover{color:var(--secondary-color)}.main-nav ul{list-style:none;margin:0;padding:0;display:flex;align-items:center}.main-nav li{margin-left:25px}.main-nav a,.main-nav button{color:var(--text-color-light);text-decoration:none;font-size:var(--font-size-medium);font-weight:500;padding:8px 0;border:none;background:none;cursor:pointer;transition:color .3s ease;display:flex;align-items:center;gap:8px;text-transform:none}.main-nav a:hover,.main-nav button:hover{color:var(--secondary-color)}.main-nav a.active,.main-nav button.active{color:var(--secondary-color);font-weight:700}.logout-button{background-color:var(--danger-color);padding:8px 12px;border-radius:5px;font-size:var(--font-size-small);text-transform:none;display:flex;align-items:center;gap:8px;margin-left:25px}.hamburger-menu{display:none;background:none;border:none;color:var(--text-color-light);font-size:var(--font-size-x-large);cursor:pointer;padding:5px}@media (max-width: 768px){.header-content{padding:0 15px}.main-nav{display:none;flex-direction:column;position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--primary-color);justify-content:center;align-items:center;z-index:950;transform:translate(100%);transition:transform .3s ease-in-out;padding:20px;box-sizing:border-box}.main-nav.open{display:flex;transform:translate(0)}.main-nav ul{flex-direction:column;width:80%;max-width:1200px;background-color:#ffffff1a;border-radius:8px;padding:20px;box-shadow:var(--shadow-elevation-2)}.main-nav li{margin:15px 0;width:100%;text-align:center}.main-nav a,.main-nav button{font-size:var(--font-size-x-large);padding:10px 0;justify-content:center;width:100%}.main-nav a:hover,.main-nav button:hover{color:var(--secondary-color);background-color:#ffffff1a;border-radius:5px}.hamburger-menu{display:block}.logout-button{margin-left:0;margin-top:20px}}.app-footer{width:100%;padding:20px 0;background-color:var(--background-color-dark);color:var(--text-color-light);text-align:center;font-size:var(--font-size-small);margin-top:auto;display:flex;justify-content:center;align-items:center;gap:8px}.app-footer p{margin:0}@media (max-width: 768px){.app-footer{padding:15px 0;font-size:var(--font-size-small)}}.home-page{text-align:center;padding:40px 20px;margin:20px auto;background-color:var(--card-background);border-radius:8px;box-shadow:var(--shadow-elevation-2)}.home-page h1{color:var(--primary-color);font-size:var(--font-size-xx-large);margin-bottom:25px}.home-page p{font-size:var(--font-size-large);color:var(--text-color-dark);line-height:1.6;margin-bottom:30px}.home-content-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:25px;margin-top:40px}.info-block{background-color:#fcfcfc;border:1px solid var(--border-color);border-radius:8px;padding:20px;box-shadow:var(--shadow-elevation-1);transition:transform .2s ease,box-shadow .2s ease}.info-block:hover{transform:translateY(-5px);box-shadow:var(--shadow-elevation-2)}.info-block h3{color:var(--accent-color);font-size:var(--font-size-x-large);margin-bottom:15px}.info-block p{font-size:var(--font-size-medium);color:#666;text-align:left;margin-bottom:0}@media (max-width: 768px){.home-page{padding:30px 15px;margin:15px auto}.home-page h1{font-size:var(--font-size-x-large)}.home-page p{font-size:var(--font-size-medium)}}.recipe-card{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-elevation-1);overflow:hidden;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;height:100%;width:300px}.recipe-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-elevation-2)}.recipe-card-image-container{width:100%;height:200px;overflow:hidden;display:flex;justify-content:center;align-items:center;background-color:#f0f0f0}.recipe-card-image{width:100%;height:100%;object-fit:cover;display:block}.recipe-card-content{padding:15px;flex-grow:1;display:flex;flex-direction:column}.recipe-card-title{font-size:var(--font-size-large);color:var(--primary-color);margin-top:0;margin-bottom:10px;min-height:2.5em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-clamp:2}.recipe-card-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 15px;margin-top:auto;padding-top:10px}.recipe-card-meta{font-size:var(--font-size-small);color:var(--text-color-dark);line-height:1.4;display:flex;align-items:center;gap:8px;margin:0}.meta-icon{color:var(--primary-color);font-size:1.1em;min-width:16px}.recipe-card-meta strong{color:var(--text-color-dark);font-weight:500}.recipe-card-actions{display:flex;justify-content:flex-end;gap:8px;padding:10px 15px;border-top:1px solid #eee;background-color:#f9f9f9}.recipe-card-actions .action-button{flex-grow:1;min-width:80px;padding:6px 10px;font-size:var(--font-size-small);text-transform:none;letter-spacing:normal;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.recipe-form-container{max-width:1500px;margin:20px auto;padding:25px;border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-elevation-2);background-color:var(--card-background)}.recipe-form-container h2{text-align:center;color:var(--primary-color);margin-bottom:25px;font-size:var(--font-size-x-large)}.recipe-form .form-group{margin-bottom:15px;display:flex;flex-direction:column}.recipe-form label{font-weight:500;margin-bottom:8px;color:var(--text-color-dark);font-size:var(--font-size-medium)}.recipe-form input[type=text],.recipe-form input[type=number],.recipe-form input[type=url],.recipe-form textarea,.recipe-form select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:5px;font-size:var(--font-size-medium);box-sizing:border-box;outline:none;transition:border-color .3s ease,box-shadow .3s ease}.recipe-form input:focus,.recipe-form textarea:focus,.recipe-form select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f333}.recipe-form textarea{min-height:100px;resize:none}.recipe-form select{height:40px;background-color:var(--card-background)}.form-fieldset{border:1px solid var(--border-color);border-radius:8px;padding:15px;margin-bottom:25px}.form-fieldset legend{font-size:var(--font-size-large);font-weight:600;color:var(--primary-color);padding:0 10px;margin-left:-10px}.form-group-inline{display:flex;align-items:center;margin-bottom:10px;gap:10px;flex-wrap:wrap}.form-group-inline label{margin-bottom:0;flex-basis:150px;flex-shrink:0}.form-group-inline input{flex-grow:1;min-width:100px}.form-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px}.image-upload-group{margin-bottom:25px;text-align:center}.custom-file-input{display:inline-block;width:100%;max-width:300px}.file-input-hidden{display:none}.file-input-label{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background-color:var(--secondary-color);color:var(--text-color-dark);border-radius:5px;cursor:pointer;transition:background-color .3s ease,transform .2s ease;font-size:var(--font-size-medium);text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--shadow-elevation-1)}.file-input-label:hover{background-color:#ffb300;transform:translateY(-1px);box-shadow:var(--shadow-elevation-2)}.image-preview-container{position:relative;max-width:300px;margin:15px auto;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;box-shadow:var(--shadow-elevation-1)}.image-preview{width:100%;height:auto;display:block;object-fit:cover}.remove-image-button{position:absolute;top:5px;right:5px;background-color:#0009;color:var(--text-color-light);border:none;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--font-size-large);transition:background-color .2s ease;z-index:10;padding:0;text-transform:none}.remove-image-button:hover{background-color:#000c;transform:scale(1.1)}.ingredient-row{display:grid;grid-template-columns:1fr .5fr .5fr auto;gap:10px;margin-bottom:10px;align-items:flex-end;padding:10px;border:1px solid #eee;border-radius:5px;background-color:#fcfcfc}.ingredient-row .form-group-inline{margin-bottom:0;flex-direction:column;align-items:flex-start;gap:5px}.ingredient-row .form-group-inline label{font-size:var(--font-size-small);font-weight:400;margin-bottom:0;width:auto;flex-basis:auto}.ingredient-row select,.ingredient-row input{width:100%;box-sizing:border-box}.add-item-button{background-color:var(--accent-color);color:var(--text-color-light);border:none;border-radius:5px;padding:10px 15px;cursor:pointer;font-size:var(--font-size-medium);transition:background-color .3s ease;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:15px;width:auto;text-transform:none}.add-item-button:hover{background-color:#1976d2}.remove-item-button{background-color:#757575;color:var(--text-color-light);border:none;border-radius:4px;padding:8px 12px;cursor:pointer;transition:background-color .2s ease;align-self:flex-end;display:flex;align-items:center;justify-content:center;gap:5px;font-size:var(--font-size-small);text-transform:none}.remove-item-button.danger{background-color:var(--danger-color)}.remove-item-button:hover{transform:none}.remove-item-button.danger:hover{background-color:#b71c1c}.instruction-row{display:flex;gap:10px;margin-bottom:10px;padding:10px;border:1px solid #eee;border-radius:5px;background-color:#fcfcfc;align-items:flex-start}.instruction-text-group{flex-grow:1}.instruction-text-group label{margin-bottom:5px}.instruction-textarea{width:100%;box-sizing:border-box;height:80px;resize:none}@media (max-width: 768px){.recipe-form-container{padding:15px;margin:15px auto}.form-actions{flex-direction:column;align-items:stretch;gap:10px}.form-actions button{width:100%;max-width:none}.form-group-inline{flex-direction:column;align-items:flex-start;gap:5px}.form-group-inline label{width:100%;flex-basis:auto}.form-group-inline input{width:100%;min-width:unset}.ingredient-row,.instruction-row{grid-template-columns:1fr;align-items:stretch;padding:10px}.ingredient-row .form-group-inline,.instruction-row .form-group-inline{width:100%}.ingredient-input-quantity,.ingredient-input-unit,.instruction-textarea{max-width:none}.remove-item-button{width:100%;align-self:auto}.add-item-button{width:100%}}.tabs-navigation{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:20px}.tab-button{padding:10px 20px;cursor:pointer;border:none;background-color:transparent;font-size:var(--font-size-medium);color:var(--text-color-dark);border-bottom:3px solid transparent;transform:translateY(2px);transition:all .3s ease;text-transform:none}.tab-button:hover{background-color:#f0f0f0}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:700}.tab-content{padding-top:10px;animation:fadeIn .5s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;background-color:#fdfdfd;padding:15px;border:1px solid #f0f0f0;border-radius:5px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:var(--font-size-medium)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1001;overflow-y:auto;padding:20px;box-sizing:border-box}.modal-content{background-color:var(--card-background);border-radius:8px;box-shadow:var(--shadow-elevation-2);width:90%;max-width:1700px;padding:25px;position:relative;max-height:90vh;display:flex;flex-direction:column}.modal-header h2{margin:0;font-size:var(--font-size-large);color:var(--primary-color)}.modal-close-button{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:#888;transition:color .3s ease}.modal-close-button:hover{color:var(--danger-color)}.add-form .form-group{margin-bottom:15px;display:flex;flex-direction:column;gap:8px}.add-form label{font-weight:500;color:var(--text-color-dark);font-size:var(--font-size-medium)}.add-form input[type=text],.add-form input[type=url],.add-form select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:5px;font-size:var(--font-size-medium);box-sizing:border-box;outline:none;transition:border-color .3s ease,box-shadow .3s ease}.add-form input:focus,.add-form select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f333}.add-form .form-actions{margin-top:20px;text-align:right}.add-form button[type=submit]{background-color:var(--primary-color);color:var(--text-color-light);padding:10px 20px;border-radius:5px;font-size:var(--font-size-medium);text-transform:none;letter-spacing:normal;display:inline-flex;align-items:center;gap:8px}.add-form button[type=submit]:hover{background-color:var(--accent-color)}@media (max-width: 768px){.modal-content{padding:15px}.modal-header h2{font-size:var(--font-size-medium)}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;overflow-y:auto;padding:20px 0}.modal-content{background-color:var(--card-background);border-radius:8px;box-shadow:var(--shadow-elevation-2);width:90%;max-width:1900px;padding:25px;position:relative;max-height:95vh;overflow-y:auto}.modal-close-button{position:absolute;top:15px;right:15px;background-color:var(--danger-color);color:var(--text-color-light);border:none;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-large);cursor:pointer;transition:background-color .2s ease,transform .2s ease;z-index:10;padding:0;text-transform:none;letter-spacing:normal}.modal-close-button:hover{background-color:#b71c1c;transform:rotate(90deg)}.recipe-details-header{text-align:center;margin-bottom:25px}.recipe-details-title{color:var(--primary-color);font-size:2.2em;margin-bottom:15px}.recipe-details-image{max-width:100%;height:auto;border-radius:8px;box-shadow:var(--shadow-elevation-1);margin-bottom:20px;max-height:450px;object-fit:cover;width:100%}.recipe-details-summary{font-size:var(--font-size-large);color:var(--text-color-dark);margin-bottom:15px}.recipe-details-summary strong{font-weight:500}.recipe-meta-info{display:flex;flex-wrap:wrap;justify-content:center;gap:15px}.recipe-meta-info p{font-size:var(--font-size-medium);margin:0;color:var(--text-color-dark);background-color:#f0f0f0;padding:5px 10px;border-radius:4px}.recipe-meta-info p strong{color:var(--primary-color)}.recipe-tabs-container{display:block;margin-top:20px}.recipe-tab-section{background-color:#fcfcfc;border:1px solid #eee;border-radius:8px;padding:20px;margin-bottom:20px}.recipe-tab-section h3{color:var(--accent-color);font-size:var(--font-size-x-large);margin-bottom:15px;text-align:left}.ingredients-list,.instructions-list{list-style:none;padding:0;margin:0;text-align:left}.ingredients-list li,.instructions-list li{font-size:var(--font-size-medium);margin-bottom:8px;padding:5px 0;border-bottom:1px dashed #eee}.ingredients-list li:last-child,.instructions-list li:last-child{border-bottom:none}.instructions-list li label{display:flex;align-items:flex-start;cursor:pointer}.instructions-list li input[type=checkbox]{margin-right:10px;margin-top:4px;min-width:18px;min-height:18px;cursor:pointer}.instructions-list li .instruction-text{flex-grow:1;line-height:1.5;padding-right:5px}.instructions-list li.completed .instruction-text{text-decoration:line-through;color:#888}.recipe-details-description p{text-align:justify;margin-bottom:1em;font-size:var(--font-size-medium)}.nutrition-tabs{display:flex;gap:10px;margin-bottom:15px;border-bottom:1px solid var(--border-color)}.nutrition-tab-button{padding:8px 15px;cursor:pointer;border:none;background-color:transparent;border-bottom:3px solid transparent;font-size:var(--font-size-medium);color:#888}.nutrition-tab-button.active{font-weight:700;color:var(--primary-color);border-bottom-color:var(--primary-color)}.nutrition-tab-content,.nutrition-info{text-align:left}.nutrition-info div{background-color:transparent;padding:0}.nutrition-info p{font-size:var(--font-size-medium);margin-bottom:5px}.nutrition-info p strong{color:var(--primary-color)}.source-details{text-align:left}.source-details p{margin:4px 0;font-size:var(--font-size-medium)}.source-details strong{color:var(--text-color-dark)}@media (max-width: 768px){.modal-content{width:95%;padding:15px}.modal-close-button{top:10px;right:10px;width:30px;height:30px;font-size:var(--font-size-medium)}.recipe-details-title{font-size:1.8em}}.filter-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;padding:15px;background-color:#f9f9f9;border:1px solid var(--border-color);border-radius:8px;margin-bottom:25px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{font-size:var(--font-size-small);font-weight:500;color:var(--text-color-dark)}.filter-input{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:5px;font-size:var(--font-size-medium)}.recipe-list-container{max-width:2500px;margin:20px auto;text-align:center;width:100%}.recipe-list-container h2{color:var(--primary-color);margin-bottom:30px;font-size:var(--font-size-x-large)}.add-recipe-button{margin:20px auto;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 25px;font-size:var(--font-size-large);background-color:var(--primary-color);color:var(--text-color-light);border-radius:8px;box-shadow:var(--shadow-elevation-1);text-transform:none}.add-recipe-button:hover{background-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-elevation-2)}.recipe-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:25px;padding-bottom:20px}@media (max-width: 768px){.recipe-cards-grid{grid-template-columns:1fr;padding:0 15px;gap:15px}.recipe-list-container{padding:0 15px;margin:15px auto}}.product-list-container{width:100%;margin:0 auto;padding:10px;display:flex;flex-direction:column;height:100%}.product-list-container h2{text-align:center;color:var(--primary-color);margin-bottom:20px;font-size:var(--font-size-x-large)}.product-form{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;align-items:center}.product-input{flex-grow:1;padding:10px;border:1px solid var(--border-color);border-radius:5px;font-size:var(--font-size-medium);min-width:150px;width:100%;box-sizing:border-box}.product-button{width:100%;max-width:300px;text-align:center;padding:10px 15px;background-color:var(--primary-color);color:var(--text-color-light);border:none;border-radius:5px;cursor:pointer;font-size:var(--font-size-medium);transition:background-color .3s ease,transform .2s ease;text-transform:none;letter-spacing:normal;display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.product-button:hover{background-color:var(--accent-color);transform:translateY(-1px)}.product-button:active{transform:translateY(0)}.error-message{color:var(--danger-color);background-color:#d32f2f1a;border:1px solid var(--danger-color);padding:10px;border-radius:5px;margin-top:10px;font-size:var(--font-size-small);text-align:center}.product-items{list-style:none;padding:0;flex-grow:1}.product-item{background-color:#fff;border:1px solid var(--border-color);padding:10px 15px;margin-bottom:8px;border-radius:5px;display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-medium);box-shadow:0 1px 2px #0000000d;transition:box-shadow .2s ease;flex-wrap:wrap;gap:10px}.product-item:hover{box-shadow:0 2px 4px #0000001a}.product-item:last-child{margin-bottom:0}.item-actions{display:flex;gap:8px;flex-shrink:0;width:100%;max-width:200px}.action-button{padding:6px 10px;border-radius:4px;font-size:var(--font-size-small);cursor:pointer;transition:background-color .2s ease,transform .2s ease;text-transform:none;letter-spacing:normal;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;flex-grow:1;min-width:80px}.edit-form{display:flex;flex-grow:1;gap:10px;align-items:center;flex-wrap:wrap}.edit-form .product-input{flex-grow:1;min-width:120px}.edit-buttons{display:flex;gap:8px;flex-shrink:0}.save-button{background-color:var(--primary-color);color:var(--text-color-light);border:none;padding:6px 10px;border-radius:4px;font-size:var(--font-size-small);cursor:pointer;transition:background-color .3s ease;text-transform:uppercase}.save-button:hover{background-color:var(--accent-color)}.cancel-button{background-color:#757575;color:var(--text-color-light);border:none;padding:6px 10px;border-radius:4px;font-size:var(--font-size-small);cursor:pointer;transition:background-color .3s ease;text-transform:uppercase}.cancel-button:hover{background-color:#424242}@media (max-width: 768px){.product-list-container{padding:15px}.product-form{flex-direction:column;align-items:stretch}.product-input,.product-button{width:100%;max-width:none}.product-item{flex-direction:column;align-items:flex-start;gap:8px}.item-actions{flex-direction:row;justify-content:flex-end;width:100%;max-width:none;margin-top:5px}.edit-form{flex-direction:column;align-items:flex-start}.edit-form .product-input{width:100%}}.source-manager-container{width:100%;padding:10px;display:flex;flex-direction:column;gap:20px}.source-form{display:flex;flex-direction:column;gap:15px;padding:15px;border:1px solid var(--border-color);border-radius:8px;background-color:#f9f9f9}.source-form .form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.source-form .form-group{display:flex;flex-direction:column;gap:5px}.source-form label{font-weight:500;font-size:var(--font-size-small)}.source-items{list-style:none;padding:0;margin:0}.source-item{background-color:#fff;border:1px solid var(--border-color);padding:15px;margin-bottom:10px;border-radius:5px;box-shadow:var(--shadow-elevation-1)}.source-item-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:10px}.source-item-name{font-size:var(--font-size-large);font-weight:700;color:var(--primary-color)}.source-item-details p{margin:4px 0;font-size:var(--font-size-small)}.source-item-details strong{color:var(--text-color-dark)}.source-item-details span{color:#555}.user-manager-container{width:100%;padding:10px;display:flex;flex-direction:column;gap:20px}.user-manager-container h3{text-align:center;color:var(--primary-color);margin-bottom:20px;font-size:var(--font-size-x-large)}.user-form{display:flex;flex-direction:column;gap:15px;padding:15px;border:1px solid var(--border-color);border-radius:8px;background-color:#f9f9f9}.user-form .form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.user-form .form-group{display:flex;flex-direction:column;gap:5px}.user-form label{font-weight:500;font-size:var(--font-size-small);color:var(--text-color-dark)}.user-form input[type=text],.user-form input[type=password],.user-form select{width:100%;padding:8px;border:1px solid var(--border-color);border-radius:5px;font-size:var(--font-size-medium);box-sizing:border-box;outline:none;transition:border-color .3s ease,box-shadow .3s ease}.user-form input:focus,.user-form select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f333}.user-form .form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.user-form .form-actions button{padding:10px 15px;font-size:var(--font-size-medium);text-transform:none;letter-spacing:normal;display:flex;align-items:center;justify-content:center;gap:8px}.user-items{list-style:none;padding:0;margin:0}.user-item{background-color:#fff;border:1px solid var(--border-color);padding:15px;margin-bottom:10px;border-radius:5px;box-shadow:var(--shadow-elevation-1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.user-info{flex-grow:1;display:flex;flex-direction:column;text-align:left}.user-username{font-size:var(--font-size-large);font-weight:700;color:var(--primary-color);margin:0}.user-role,.user-created-at{font-size:var(--font-size-small);color:#555;margin:4px 0 0}.user-role span,.user-created-at span{font-weight:500;color:var(--text-color-dark)}.item-actions{display:flex;gap:8px;flex-shrink:0}.action-button{padding:6px 10px;border-radius:4px;font-size:var(--font-size-small);cursor:pointer;transition:background-color .2s ease,transform .2s ease;text-transform:none;letter-spacing:normal;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.action-button:hover{transform:translateY(-1px)}.edit-button-small{background-color:var(--accent-color);color:var(--text-color-light);border:none}.edit-button-small:hover{background-color:#1976d2}.delete-button-small{background-color:var(--danger-color);color:var(--text-color-light);border:none}.delete-button-small:hover{background-color:#b71c1c}.list-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:10px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:15px}.pagination-controls{display:flex;align-items:center;gap:10px}.pagination-controls button{padding:5px 10px;font-size:var(--font-size-small);text-transform:none}.pagination-controls button:disabled{background-color:#ccc;cursor:not-allowed}.pagination-controls select{padding:5px;font-size:var(--font-size-small)}@media (max-width: 768px){.user-manager-container{padding:15px}.user-form .form-grid{grid-template-columns:1fr}.user-form .form-actions{flex-direction:column;align-items:stretch}.user-item{flex-direction:column;align-items:flex-start}.item-actions{width:100%;justify-content:flex-end}.list-controls{flex-direction:column;align-items:stretch}.pagination-controls{width:100%;justify-content:space-between}}.accordion-container{width:100%;margin:0 auto 20px;overflow:hidden}.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background-color:var(--primary-color);color:var(--text-color-light);border:none;cursor:pointer;font-size:var(--font-size-large);border-bottom:1px solid rgba(255,255,255,.2);transition:background-color .3s ease}.accordion-header:hover{background-color:var(--accent-color)}.accordion-header h3{margin:0;color:inherit;font-size:var(--font-size-large)}.accordion-icon{font-size:1.2em;transition:transform .3s ease}.accordion-header[aria-expanded=false] .accordion-icon{transform:rotate(0)}.accordion-header[aria-expanded=true] .accordion-icon{transform:rotate(180deg)}.accordion-content{padding:20px;display:block;overflow:hidden;transition:height .3s ease-out,padding .3s ease-out}.accordion-header[aria-expanded=false]+.accordion-content{height:0;padding-top:0;padding-bottom:0;opacity:0}@media (max-width: 768px){.accordion-container{margin-left:15px;margin-right:15px;max-width:none}.accordion-header{padding:12px 15px;font-size:var(--font-size-medium)}.accordion-header h3{font-size:var(--font-size-large)}.accordion-content{padding:15px}}.admin-page-container{max-width:2000px;margin:30px auto;padding:0 20px;display:flex;flex-direction:column;gap:20px;width:100%}.admin-page-container h2{text-align:center;color:var(--primary-color);font-size:var(--font-size-x-large);margin-bottom:25px}.admin-page-container .accordion-container{max-width:100%;margin-left:0;margin-right:0}.admin-page-container .accordion-content .product-list-container{border:none;box-shadow:none;margin:0;padding:0}@media (max-width: 768px){.admin-page-container{padding:0 15px;margin:15px auto;gap:15px}}.admin-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.admin-header h2{margin:0}.admin-user-info{display:flex;align-items:center;gap:15px}.logout-button{background-color:var(--danger-color);padding:8px 12px;font-size:var(--font-size-small);text-transform:none;display:flex;align-items:center;gap:8px}.logout-button:hover{background-color:#b71c1c}.login-container{display:flex;justify-content:center;align-items:center;height:80vh}.login-form{padding:40px;background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-elevation-2);width:100%;max-width:1000px;display:flex;flex-direction:column;gap:20px}.login-form h2{text-align:center;margin-bottom:10px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.login-form label{font-weight:500}.login-form .form-actions{margin-top:10px}.login-form .login-button{width:100%;padding:12px;font-size:var(--font-size-large)}.link-button{background:none;border:none;color:var(--primary-color);text-decoration:underline;cursor:pointer;padding:0;font-size:inherit;text-transform:none}.link-button:hover{color:var(--accent-color);background:none;transform:none}.switch-form-text{text-align:center;margin-top:15px;font-size:var(--font-size-small)}.success-message{color:#2e7d32;background-color:#e8f5e9;border:1px solid #a5d6a7;padding:10px;border-radius:5px;margin-top:10px;font-size:var(--font-size-small);text-align:center}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;overflow-y:auto;padding:20px;box-sizing:border-box}.modal-content-large{background-color:var(--card-background);border-radius:8px;box-shadow:var(--shadow-elevation-2);width:95%;max-width:1900px;padding:25px;position:relative;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:15px;margin-bottom:15px}.modal-header h2{margin:0}.modal-close-button-planner{background:none;border:none;font-size:2rem;line-height:1;cursor:pointer;color:#888}.modal-close-button-planner:hover{color:var(--danger-color)}.modal-body{overflow-y:auto}.planner-container{margin-top:20px;max-width:3000px}.planner-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.planner-header h2{margin:0;font-size:var(--font-size-x-large)}.planner-nav{display:flex;gap:10px}.planner-nav button{padding:8px 15px;font-size:var(--font-size-medium)}.planner-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;background-color:#e0e0e0;padding:10px;border-radius:8px}.day-column{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:15px}.day-header{text-align:center;font-weight:700;margin-bottom:5px;border-bottom:1px solid var(--border-color);padding-bottom:10px}.day-header .day-name{font-size:1.1em}.day-header .day-date{font-size:.9em;color:#666}.meal-slot{background-color:#f9f9f9;border-radius:5px;padding:10px}.meal-slot h4{font-size:var(--font-size-medium);color:var(--primary-color);margin-top:0;margin-bottom:8px;border-bottom:1px dashed #ddd;padding-bottom:5px}.add-recipe-slot{display:flex;justify-content:center;align-items:center;height:60px;border:2px dashed var(--border-color);border-radius:5px;color:#aaa;cursor:pointer;transition:all .2s ease;margin-top:10px}.add-recipe-slot:hover{background-color:#f0f0f0;color:var(--primary-color);border-color:var(--primary-color)}.planned-recipe-item{display:flex;align-items:center;background-color:#fff;border:1px solid #eee;border-radius:5px;padding:8px;margin-bottom:8px;box-shadow:var(--shadow-elevation-1);position:relative}.planned-recipe-info{flex-grow:1;display:flex;flex-direction:column;font-size:var(--font-size-small);padding-left:0}.planned-recipe-title{font-weight:700;color:var(--primary-color);margin-bottom:4px}.planned-recipe-title.clickable{cursor:pointer;text-decoration:underline}.planned-recipe-title.clickable:hover{color:var(--accent-color)}.planned-recipe-portion{color:#666;margin-bottom:4px}.planned-recipe-nutrition{display:flex;flex-wrap:wrap;gap:5px 10px;font-size:.8em;color:#555}.delete-planner-item-button{position:absolute;top:5px;right:5px;background-color:var(--danger-color);color:var(--text-color-light);border:none;border-radius:50%;width:25px;height:25px;display:flex;align-items:center;justify-content:center;font-size:1.2em;cursor:pointer;transition:background-color .2s ease;padding:0;text-transform:none;letter-spacing:normal;z-index:10}.delete-planner-item-button:hover{background-color:#b71c1c;transform:scale(1.1)}.daily-nutrition-summary{background-color:var(--background-color-light);border:1px dashed var(--border-color);border-radius:8px;padding:10px;margin-top:15px;text-align:left}.daily-nutrition-summary h4{color:var(--accent-color);margin-bottom:10px;font-size:var(--font-size-medium)}.daily-nutrition-summary p{margin:4px 0;font-size:var(--font-size-small);color:var(--text-color-dark)}.daily-nutrition-summary p strong{color:var(--primary-color);font-size:var(--font-size-medium)}@media (max-width: 768px){.planner-container{margin:15px auto;padding:0 15px}.planner-grid{grid-template-columns:1fr;padding:10px;gap:15px}}.shopping-list-container{width:100%;margin:20px auto;padding:25px;background-color:var(--card-background);text-align:center;box-sizing:border-box}.shopping-list-container h2{color:var(--primary-color);margin-bottom:25px;font-size:var(--font-size-x-large)}.shopping-list-container .planner-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.shopping-list-container .planner-header h3{margin:0;font-size:var(--font-size-large);color:var(--text-color-dark)}.shopping-list-container .planner-nav{display:flex;gap:10px}.shopping-list-container .planner-nav button{padding:8px 15px;font-size:var(--font-size-medium);text-transform:none}.shopping-list-filters{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.shopping-list-filters label{font-weight:500;font-size:var(--font-size-medium);color:var(--text-color-dark)}.shopping-list-filters select{padding:8px 12px;border:1px solid var(--border-color);border-radius:5px;font-size:var(--font-size-medium);background-color:var(--card-background);outline:none;transition:border-color .3s ease,box-shadow .3s ease}.shopping-list-filters select:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #2196f333}.shopping-list-items{list-style:none;padding:0;margin:0}.shopping-list-item{display:flex;justify-content:space-between;align-items:center;background-color:#fcfcfc;border:1px solid #eee;border-radius:8px;padding:12px 15px;margin-bottom:10px;box-shadow:var(--shadow-elevation-1);flex-wrap:nowrap;gap:15px;transition:transform .2s ease,box-shadow .2s ease}.shopping-list-item.purchased{background-color:#e8f5e9;text-decoration:line-through;opacity:.7}.shopping-list-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-elevation-2)}.item-info{display:flex;align-items:center;flex-grow:1;gap:10px}.product-name{font-size:var(--font-size-large);font-weight:700;color:var(--primary-color);margin-bottom:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quantity-unit,.needed-date{font-size:var(--font-size-medium);color:var(--text-color-dark);margin-bottom:0;flex-shrink:0}.item-actions{display:flex;gap:10px;flex-shrink:0}.action-button{padding:8px 12px;font-size:var(--font-size-small);border-radius:5px;text-transform:none;display:flex;align-items:center;gap:5px}.mark-purchased{background-color:var(--primary-color);color:var(--text-color-light)}.mark-purchased:hover{background-color:#388e3c}.mark-unpurchased{background-color:var(--secondary-color);color:var(--text-color-dark)}.mark-unpurchased:hover{background-color:#ffa000}.delete-item-button{background-color:var(--danger-color);color:var(--text-color-light)}.delete-item-button:hover{background-color:#b71c1c}@media (max-width: 768px){.shopping-list-container{padding:15px;margin:15px auto}.shopping-list-item{flex-direction:column;align-items:flex-start;flex-wrap:wrap;gap:8px}.item-info{flex-direction:column;align-items:flex-start;gap:5px;width:100%}.item-actions{width:100%;justify-content:flex-end;margin-top:10px}.action-button{flex-grow:1}.shopping-list-filters{flex-direction:column;align-items:stretch}}
