.recipe-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;transition:all .3s ease}.recipe-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.recipe-card.selected{border-color:#4caf50;box-shadow:0 4px 16px #4caf504d}.recipe-image-container{height:200px;overflow:hidden;position:relative}.recipe-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.recipe-card:hover .recipe-image{transform:scale(1.05)}.recipe-badges{display:flex;flex-direction:column;gap:6px;position:absolute;right:12px;top:12px}.category-badge,.difficulty-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:12px;font-size:.75rem;padding:4px 8px}.recipe-content{padding:16px}.recipe-title{color:#333;font-size:1.25rem;font-weight:600;line-height:1.3;margin:0 0 8px}.recipe-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.9rem;line-height:1.4;margin:0 0 16px;overflow:hidden}.recipe-meta{background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px}.meta-item{align-items:center;display:flex;flex-direction:column;gap:4px}.meta-label{font-size:.75rem}.meta-value{font-size:.9rem;font-weight:600}.recipe-actions{display:flex;gap:8px}.btn{border:none;flex:1 1}.btn-primary:hover{background:#1976d2}.btn-secondary{border:1px solid #ddd}.btn-secondary:hover{background:#e0e0e0}.btn-success:hover{background:#45a049}@media (max-width:768px){.recipe-meta{flex-direction:column;gap:8px}.meta-item{flex-direction:row;justify-content:space-between}.recipe-actions{flex-direction:column}}.modal-backdrop{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.modal-header{display:flex;justify-content:flex-end;padding:16px 20px 0}.close-button{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;padding:0;transition:all .2s ease;width:40px}.close-button:hover{background:#f0f0f0;color:#333}.modal-body{flex:1 1;overflow-y:auto;padding:0 20px 20px}.recipe-image-section{margin-bottom:24px;position:relative}.modal-recipe-image{border-radius:12px;height:300px;object-fit:cover;width:100%}.modal-badges{display:flex;flex-direction:column;gap:8px;position:absolute;right:16px;top:16px}.category-badge,.difficulty-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;color:#fff;font-size:.8rem;font-weight:600;padding:6px 12px;text-transform:capitalize}.recipe-details{display:flex;flex-direction:column;gap:24px}.modal-recipe-title{color:#333;font-size:2rem;font-weight:700;line-height:1.2;margin:0}.modal-recipe-description{color:#666;font-size:1.1rem;line-height:1.5;margin:0}.recipe-meta-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.meta-card{background:#f8f9fa;border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:16px;text-align:center}.meta-label{color:#666;font-size:.85rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.meta-value{color:#333;font-size:1.2rem;font-weight:700}.ingredients-section h3,.instructions-section h3{border-bottom:2px solid #e0e0e0;color:#333;font-size:1.4rem;font-weight:600;margin:0 0 16px;padding-bottom:8px}.ingredients-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));list-style:none;margin:0;padding:0}.ingredient-item{align-items:center;background:#f8f9fa;border-left:4px solid #2196f3;border-radius:8px;display:flex;justify-content:space-between;padding:12px 16px}.ingredient-amount{color:#2196f3;font-size:.9rem;font-weight:600}.ingredient-name{font-weight:500}.instructions-list{display:flex;flex-direction:column;gap:16px;list-style:none;margin:0;padding:0}.instruction-item{align-items:flex-start;display:flex;gap:16px}.instruction-step{align-items:center;background:#2196f3;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:600;height:32px;justify-content:center;width:32px}.instruction-text{color:#333;flex:1 1;line-height:1.5;padding-top:4px}.modal-footer{border-top:1px solid #eee;display:flex;justify-content:center;padding:20px}.modal-footer-buttons{align-items:center;display:flex;gap:12px;justify-content:space-between;width:100%}.modal-action-buttons{align-items:center;display:flex;gap:8px}.btn-edit{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-edit:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.btn-edit:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-delete{background:#dc3545;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-delete:hover:not(:disabled){background:#c82333;transform:translateY(-1px)}.btn-delete:disabled{cursor:not-allowed;opacity:.6;transform:none}.delete-confirm-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1100}.delete-confirm-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-width:400px;padding:24px;width:100%}.delete-confirm-dialog h3{color:#dc3545;font-size:1.25rem;margin:0 0 16px}.delete-confirm-dialog p{color:#333;line-height:1.5;margin:0 0 12px}.delete-warning{color:#666;font-size:.9rem;font-style:italic;margin-bottom:20px!important}.delete-confirm-buttons{display:flex;gap:12px;justify-content:flex-end}.delete-confirm-buttons .btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .2s ease}.delete-confirm-buttons .btn-secondary{background:#6c757d;color:#fff}.delete-confirm-buttons .btn-secondary:hover:not(:disabled){background:#5a6268}.delete-confirm-buttons .btn-danger{background:#dc3545;color:#fff}.delete-confirm-buttons .btn-danger:hover:not(:disabled){background:#c82333}.delete-confirm-buttons .btn:disabled{cursor:not-allowed;opacity:.6}.btn-large{font-size:1.1rem;font-weight:600;padding:16px 24px;width:100%}@media (max-width:768px){.modal-backdrop{padding:10px}.modal-content{max-height:95vh}.modal-recipe-image{height:200px}.modal-recipe-title{font-size:1.5rem}.recipe-meta-grid{grid-template-columns:repeat(2,1fr)}.ingredients-list{grid-template-columns:1fr}.instruction-item{gap:12px}}@media (max-width:480px){.recipe-meta-grid{grid-template-columns:1fr}.modal-body{padding:0 16px 16px}.modal-footer{padding:16px}}.recipe-list-container{margin:0 auto;max-width:1200px;padding:20px}.filters-container{grid-gap:16px;align-items:end;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:grid;gap:16px;grid-template-columns:2fr 1fr 1fr;margin-bottom:24px;padding:20px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{color:#333;font-size:.9rem;font-weight:600}.filter-input,.filter-select{border:2px solid #e0e0e0;border-radius:8px;font-size:.9rem;padding:10px 12px;transition:border-color .2s ease}.filter-input:focus,.filter-select:focus{border-color:#2196f3;outline:none}.recipes-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-top:24px}.error-container{align-items:center;background:#fff5f5;border:1px solid #fed7d7;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.error-message{color:#e53e3e;font-weight:600;margin-bottom:16px}.no-recipes{background:#f8f9fa;border-radius:12px;color:#666;grid-column:1/-1;padding:60px 20px;text-align:center}.no-recipes p{font-size:1.1rem;margin:0}@media (max-width:768px){.filters-container{gap:12px;grid-template-columns:1fr}.recipes-grid{gap:16px;grid-template-columns:1fr}.recipe-list-container{padding:16px}}@media (max-width:480px){.filters-container{padding:16px}.recipes-grid{grid-template-columns:1fr}}.shopping-list-container{margin:0 auto;max-width:1200px;padding:20px}.error-banner{align-items:center;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;display:flex;justify-content:space-between;margin-bottom:20px;padding:12px 16px}.error-banner button{background:none;border:none;color:#c33;cursor:pointer;font-size:1.2rem;height:24px;padding:0;width:24px}.empty-state{background:#f8f9fa;border-radius:12px;color:#666;padding:60px 20px;text-align:center}.empty-state h2{color:#333;margin:0 0 12px}.empty-state p{font-size:1.1rem;margin:0}.shopping-list-header{align-items:flex-end;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:16px}.header-info h2{color:#333;font-size:1.8rem;margin:0 0 8px}.header-info p{color:#666;font-size:1rem;margin:0}.btn-danger{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 20px;transition:background .2s ease}.btn-danger:disabled{cursor:not-allowed;opacity:.6}.clear-all-btn{flex-shrink:0;max-width:120px;white-space:nowrap}.shopping-list-content{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1fr 1fr}.aggregated-ingredients-section h3,.selected-recipes-section h3{border-bottom:2px solid #e0e0e0;color:#333;font-size:1.4rem;font-weight:600;margin:0 0 20px;padding-bottom:8px}.selected-recipes-list{display:flex;flex-direction:column;gap:16px}.selected-recipe-item{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;justify-content:space-between;padding:16px}.recipe-info{align-items:center;display:flex;flex:1 1;gap:12px}.recipe-thumbnail{border-radius:8px;flex-shrink:0;height:60px;object-fit:cover;width:60px}.recipe-details{flex:1 1}.recipe-details h4{color:#333;font-size:1.1rem;margin:0 0 4px}.recipe-details p{-webkit-line-clamp:1;-webkit-box-orient:vertical;color:#666;display:-webkit-box;font-size:.9rem;margin:0 0 4px;overflow:hidden}.recipe-meta{color:#999;font-size:.8rem;text-transform:capitalize}.quantity-controls{align-items:center;display:flex;flex-direction:column;gap:8px}.quantity-controls label{color:#666;font-size:.8rem;font-weight:600}.quantity-input-group{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;gap:8px;padding:4px}.quantity-btn{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;height:28px;transition:background .2s ease;width:28px}.quantity-btn:hover:not(:disabled){background:#1976d2}.quantity-btn:disabled{background:#ccc;cursor:not-allowed}.quantity-display{color:#333;font-weight:600;min-width:24px;text-align:center}.remove-btn{background:none;border-radius:4px;padding:4px;transition:background .2s ease}.remove-btn:hover:not(:disabled){background:#ffebee}.no-ingredients{background:#f8f9fa;border-radius:8px;color:#666;font-style:italic;padding:40px 20px;text-align:center}.ingredients-grid{display:flex;flex-direction:column;gap:16px}.ingredient-card{background:#fff;border-left:4px solid #4caf50;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:16px}.ingredient-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.ingredient-name{color:#333;font-size:1.1rem;font-weight:600;margin:0;text-transform:capitalize}.ingredient-total{background:#e8f5e8;border-radius:16px;color:#4caf50;font-size:1rem;font-weight:700;padding:4px 12px}.ingredient-breakdown{border-top:1px solid #e0e0e0;padding-top:12px}.breakdown-label{color:#666;display:block;font-size:.85rem;font-weight:600;margin-bottom:8px}.recipe-breakdown{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.recipe-breakdown-item{align-items:center;display:flex;font-size:.9rem;justify-content:space-between;padding:4px 0}.recipe-name{color:#333;font-weight:500}.recipe-amount{color:#666;font-size:.85rem}@media (max-width:768px){.shopping-list-content{gap:24px;grid-template-columns:1fr}.shopping-list-header{align-items:flex-start;flex-direction:column;gap:16px}.clear-all-btn{max-width:none;width:100%}.selected-recipe-item{align-items:stretch;flex-direction:column;gap:12px}.recipe-info{align-items:flex-start}.quantity-controls{align-items:center;flex-direction:row;justify-content:space-between}.shopping-list-container{padding:16px}}@media (max-width:480px){.ingredient-header{gap:8px}.ingredient-header,.recipe-breakdown-item{align-items:flex-start;flex-direction:column}.recipe-breakdown-item{gap:2px}}.dashboard{background:#f8f9fa;min-height:100vh}.dashboard-header{background:#fff;box-shadow:0 2px 8px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:20px}.header-left{display:flex;flex-direction:column;gap:4px}.app-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#333;font-size:2rem;font-weight:700;margin:0}.welcome-text{color:#666;font-size:1rem;margin:0}.header-right{align-items:center;display:flex;gap:24px}.stats-container{display:flex;gap:20px}.stat-item{align-items:center;display:flex;flex-direction:column;gap:4px}.stat-number{color:#2196f3;font-size:1.5rem;font-weight:700}.stat-label{color:#666;font-size:.8rem;text-align:center}.header-actions{align-items:center;display:flex;gap:12px}.create-recipe-button{align-items:center;background:#ff6b35;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s ease}.create-recipe-button:hover{background:#e55a2b;transform:translateY(-1px)}.logout-button{background:#f44336;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s ease}.logout-button:hover{background:#d32f2f;transform:translateY(-1px)}.tab-navigation{border-top:1px solid #e0e0e0;display:flex;margin:0 auto;max-width:1200px}.tab-button{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:16px 24px;position:relative;transition:all .2s ease}.tab-button:hover{background:#f8f9fa;color:#333}.tab-button.active{background:#f8f9fa;border-bottom-color:#2196f3;color:#2196f3}.tab-badge{align-items:center;background:#2196f3;border-radius:12px;color:#fff;display:flex;font-size:.75rem;height:20px;justify-content:center;min-width:20px;padding:2px 8px}.dashboard-content{min-height:calc(100vh - 140px)}@media (max-width:768px){.header-content{align-items:stretch;flex-direction:column;gap:16px}.header-left{text-align:center}.header-right{justify-content:space-between}.app-title{font-size:1.5rem}.stats-container{gap:16px}.tab-navigation{flex-direction:column}.tab-button{border-bottom:1px solid #e0e0e0;border-right:none}.tab-button.active{border-bottom-color:#e0e0e0;border-left:3px solid #2196f3}}@media (max-width:480px){.header-content{padding:16px}.stats-container{flex-direction:column;gap:8px}.stat-item{flex-direction:row;gap:8px}.tab-button{font-size:.9rem;padding:12px 16px}}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:400px;padding:40px;width:100%}.auth-header{margin-bottom:32px;text-align:center}.auth-header h1{color:#333;font-size:2rem;font-weight:700;margin:0 0 8px}.auth-header p{color:#666;font-size:1rem;margin:0}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{color:#333}.form-group input{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:12px 16px;transition:all .2s ease}.form-group input:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a;outline:none}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.error-message{background:#fee;border:1px solid #fcc;color:#c33;font-size:.9rem;padding:12px 16px;text-align:center}.auth-button{background:#2196f3;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:8px;padding:14px 20px;transition:all .2s ease}.auth-button:hover:not(:disabled){background:#1976d2;transform:translateY(-1px)}.auth-button:disabled{background:#ccc;cursor:not-allowed;transform:none}.auth-footer{border-top:1px solid #e0e0e0;margin-top:24px;padding-top:24px;text-align:center}.auth-footer p{color:#666;font-size:.9rem;margin:0}.auth-link{color:#2196f3;font-weight:600;text-decoration:none;transition:color .2s ease}.auth-link:hover{color:#1976d2;text-decoration:underline}@media (max-width:480px){.auth-container{padding:16px}.auth-card{padding:24px}.auth-header h1{font-size:1.5rem}}.ingredient-autocomplete{position:relative;width:100%}.suggestion-name{color:#2c3e50;flex:1 1;font-weight:500}.suggestion-count{background:#e9ecef;border-radius:12px;color:#6c757d;font-size:.8rem;padding:.25rem .5rem;white-space:nowrap}@media (max-width:768px){.autocomplete-suggestions{max-height:150px}.suggestion-item{padding:.6rem}.suggestion-name{font-size:.9rem}.suggestion-count{font-size:.75rem;padding:.2rem .4rem}}@media (prefers-contrast:high){.autocomplete-input{border-color:#000}.autocomplete-input:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b354d}.suggestion-item.selected{background-color:#ff6b35;color:#fff}.suggestion-item.selected .suggestion-count{background:#fff3;color:#fff}}.autocomplete-input-container,.unit-autocomplete{position:relative;width:100%}.autocomplete-input{background:#fff;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:.75rem 2.5rem .75rem .75rem;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.autocomplete-input:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a;outline:none}.autocomplete-loading{align-items:center;display:flex;justify-content:center;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.loading-spinner-small{animation:spin 1s linear infinite;border:2px solid #e9ecef;border-radius:50%;border-top-color:#ff6b35;height:16px;width:16px}.autocomplete-suggestions{background:#fff;border:1px solid #e9ecef;border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.suggestions-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;border-radius:8px 8px 0 0;color:#495057;font-size:.85rem;font-weight:600;padding:.75rem}.suggestion-item{align-items:center;border-bottom:1px solid #f8f9fa;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem;transition:background-color .2s ease}.suggestion-item:last-child{border-bottom:none;border-radius:0 0 8px 8px}.suggestion-item.selected,.suggestion-item:hover{background-color:#f8f9fa}.suggestion-item.selected{background-color:#e3f2fd}.suggestion-main{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:.25rem}.suggestion-unit{color:#2c3e50;font-size:1rem;font-weight:600}.suggestion-meta{align-items:center;color:#6c757d;display:flex;font-size:.8rem;gap:.5rem}.avg-amount{color:#28a745;font-weight:500}.autocomplete-suggestions::-webkit-scrollbar{width:6px}.autocomplete-suggestions::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.autocomplete-suggestions::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.autocomplete-suggestions::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:768px){.autocomplete-suggestions{max-height:150px}.suggestion-item{padding:.6rem}.suggestion-unit{font-size:.9rem}.suggestion-meta{font-size:.75rem}.suggestions-header{font-size:.8rem;padding:.6rem}}.autocomplete-suggestions{animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.suggestion-item:focus{outline:2px solid #ff6b35;outline-offset:-2px}@media (prefers-contrast:high){.autocomplete-input{border-color:#000}.autocomplete-input:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b354d}.suggestion-item.selected{background-color:#ff6b35;color:#fff}.suggestion-item.selected .suggestion-meta{color:#fffc}.suggestion-item.selected .avg-amount{color:#ffffffe6}}@media (prefers-reduced-motion:reduce){.autocomplete-input,.loading-spinner-small,.suggestion-item{animation:none;transition:none}.autocomplete-suggestions{animation:none}}.create-recipe-container{background:#f8f9fa;margin:0 auto;max-width:800px;min-height:100vh;padding:2rem}.create-recipe-header{margin-bottom:2rem;text-align:center}.create-recipe-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.create-recipe-header p{color:#6c757d;font-size:1.1rem;margin:0}.create-recipe-form{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:2rem}.form-section{margin-bottom:2.5rem}.form-section h2{border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:1.5rem;padding-bottom:.5rem}.form-group,.form-section h2{margin-bottom:1.5rem}.form-group label{color:#495057;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#ff6b35;box-shadow:0 0 0 3px #ff6b351a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.ingredient-row{grid-gap:.75rem;align-items:end;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:grid;gap:.75rem;grid-template-columns:2fr 1fr 1fr auto;margin-bottom:1rem;padding:1rem}.ingredient-row .form-group,.ingredient-row input{margin-bottom:0}.instruction-row{grid-gap:1rem;align-items:start;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:grid;gap:1rem;grid-template-columns:auto 1fr auto;margin-bottom:1rem;padding:1rem}.step-number{align-items:center;background:#ff6b35;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:32px;justify-content:center;margin-top:.75rem;width:32px}.instruction-row .form-group,.instruction-row textarea{margin-bottom:0}.add-btn{align-items:center;background:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .3s ease,transform .2s ease}.add-btn:hover{background:#218838;transform:translateY(-1px)}.remove-btn{align-items:center;background:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:32px;justify-content:center;transition:background-color .3s ease,transform .2s ease;width:32px}.remove-btn:hover:not(:disabled){background:#c82333;transform:scale(1.1)}.remove-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.5}.form-actions{border-top:2px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:2rem}.cancel-btn{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:background-color .3s ease,transform .2s ease}.cancel-btn:hover:not(:disabled){background:#5a6268;transform:translateY(-1px)}.submit-btn{background:#ff6b35;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:background-color .3s ease,transform .2s ease}.submit-btn:hover:not(:disabled){background:#e55a2b;transform:translateY(-1px)}.cancel-btn:disabled,.submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24}.error-message,.success-message{font-weight:500;margin-bottom:1.5rem;padding:1rem}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724}@media (max-width:768px){.create-recipe-container{padding:1rem}.create-recipe-form{padding:1.5rem}.create-recipe-header h1{font-size:2rem}.form-row{grid-template-columns:1fr}.ingredient-row,.instruction-row{gap:.5rem;grid-template-columns:1fr}.step-number{align-self:start;margin-top:0}.form-actions{flex-direction:column}.form-actions button{width:100%}}@media (max-width:480px){.create-recipe-container{padding:.5rem}.create-recipe-form{padding:1rem}.create-recipe-header h1{font-size:1.75rem}.form-section h2{font-size:1.25rem}}.App{min-height:100vh;text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-container{align-items:center;background:#f8f9fa;color:#666;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:60px 20px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#2196f3;height:40px;margin-bottom:16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.btn{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;justify-content:center;padding:10px 16px;text-align:center;text-decoration:none;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover:not(:disabled){background:#1976d2}.btn-secondary{background:#f5f5f5;border-color:#ddd;color:#333}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.btn-success{background:#4caf50;color:#fff}.btn-success:hover:not(:disabled){background:#45a049}.btn-danger{background:#f44336;color:#fff}.btn-danger:hover:not(:disabled){background:#d32f2f}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.5bf2c648.css.map*/