*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;color:#333;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem 2rem;box-shadow:0 2px 8px #0000001a}.header-title{margin:0 0 1rem;font-size:1.75rem;font-weight:600}.nav{display:flex;gap:1rem;flex-wrap:wrap}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:6px;transition:background-color .2s;font-weight:500}.nav-link:hover{background-color:#fff3}.nav-link.active{background-color:#ffffff4d}.main-content{flex:1;padding:2rem;max-width:1200px;width:100%;margin:0 auto}@media (max-width: 768px){.header{padding:1rem}.header-title{font-size:1.5rem;margin-bottom:.75rem}.nav{gap:.5rem}.nav-link{padding:.4rem .8rem;font-size:.9rem}.main-content{padding:1rem}}.inventory-log{width:100%}.log-list{display:flex;flex-direction:column;gap:1rem}.log-entry{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.log-entry-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.log-entry-info{flex:1}.log-entry-info h3{margin:0 0 .5rem;font-size:1.1rem;color:#333}.log-timestamp{color:#666;font-size:.9rem}.log-entry-changes{margin-top:1rem;padding-top:1rem;border-top:1px solid #f0f0f0}.log-entry-changes h4{margin:0 0 .75rem;font-size:.95rem;color:#555;font-weight:600}.log-entry-changes ul{list-style:none;padding:0;margin:0}.log-entry-changes li{padding:.5rem 0;color:#666;font-size:.9rem;border-bottom:1px solid #f8f8f8}.log-entry-changes li:last-child{border-bottom:none}@media (max-width: 768px){.log-entry-header{flex-direction:column}.log-entry-header .btn{width:100%}}.bulk-edit{width:100%}.bulk-edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.bulk-edit-header h2{margin:0;font-size:2rem;color:#333}.bulk-edit-actions{display:flex;gap:.5rem}.bulk-edit-table-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000000d;margin-bottom:2rem;overflow-x:auto}.bulk-edit-table{width:100%;border-collapse:collapse;min-width:800px}.bulk-edit-table th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap}.bulk-edit-table td{padding:1rem;border-bottom:1px solid #f0f0f0;color:#555;vertical-align:middle}.bulk-edit-table tr:hover{background:#f8f9fa}.bulk-edit-table tr.unlimited-row{opacity:.6}.bulk-edit-table input[type=number]{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;font-family:inherit}.bulk-edit-table input[type=number]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.bulk-edit-table input[type=number].disabled{background:#f5f5f5;color:#999;cursor:not-allowed;opacity:.6}.bulk-edit-table input[type=number]::placeholder{color:#999;font-size:.85rem}.unlimited-badge{background:#28a745;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.bulk-edit-footer{display:flex;justify-content:flex-end;gap:.5rem;padding-top:1rem;border-top:1px solid #e0e0e0}@media (max-width: 768px){.bulk-edit-header{flex-direction:column;align-items:stretch}.bulk-edit-actions{width:100%}.bulk-edit-actions .btn{flex:1}.bulk-edit-table{font-size:.9rem}.bulk-edit-table th,.bulk-edit-table td{padding:.75rem .5rem}.bulk-edit-table input[type=number]{font-size:.85rem;padding:.4rem}}.inventory{width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.page-header h2{margin:0;font-size:2rem;color:#333}.page-actions{display:flex;gap:.5rem}.btn{padding:.6rem 1.2rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.btn-small{padding:.4rem .8rem;font-size:.9rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:12px;padding:2rem;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal h3{margin:0 0 1.5rem;color:#333}.form-group{margin-bottom:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.disabled,.form-group select.disabled{background:#f5f5f5;color:#999;cursor:not-allowed;opacity:.6}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-weight:500;color:#555}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer;margin:0}.unlimited-badge{background:#28a745;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.quantity-mode-toggle{display:flex;gap:.5rem;margin-bottom:.5rem}.mode-btn{flex:1;padding:.5rem 1rem;border:2px solid #ddd;border-radius:6px;background:#fff;color:#666;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.mode-btn:hover{border-color:#667eea;color:#667eea}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.mode-hint{margin:.5rem 0 0;font-size:.85rem;color:#666;font-style:italic}.current-quantity{display:block;font-size:.85rem;color:#666;font-weight:400;margin-top:.25rem;margin-bottom:.5rem}.form-row .form-group:first-child{display:flex;flex-direction:column;justify-content:flex-end}.form-row .form-group:first-child input{margin-top:0}.form-row .form-group:last-child{display:flex;flex-direction:column;justify-content:flex-end}.form-row .form-group:last-child label{margin-bottom:.5rem}.form-actions{display:flex;gap:.5rem;margin-top:1.5rem;justify-content:flex-end}.empty-state{text-align:center;padding:3rem;color:#666}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.inventory-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d;transition:transform .2s,box-shadow .2s}.inventory-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.card-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem}.card-header h3{margin:0;font-size:1.25rem;color:#333;flex:1}.type-badge{background:#e9ecef;color:#495057;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.card-content{margin-bottom:1rem}.quantity{font-size:1.1rem;font-weight:600;color:#667eea;margin:.5rem 0}.notes{color:#666;font-size:.9rem;margin:.5rem 0 0}.card-actions{display:flex;gap:.5rem;padding-top:1rem;border-top:1px solid #e0e0e0}.inventory-list{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000000d}.inventory-list table{width:100%;border-collapse:collapse}.inventory-list th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.inventory-list td{padding:1rem;border-bottom:1px solid #f0f0f0;color:#555}.inventory-list tr:hover{background:#f8f9fa}.inventory-list .list-actions{display:flex;gap:.5rem}@media (max-width: 768px){.page-header{flex-direction:column;align-items:stretch}.page-title-section{width:100%;justify-content:space-between}.page-actions{width:100%}.btn{flex:1}.form-row,.inventory-grid{grid-template-columns:1fr}.inventory-list{overflow-x:auto}.inventory-list table{font-size:.9rem}.inventory-list th,.inventory-list td{padding:.75rem .5rem}.inventory-list .list-actions{flex-direction:column}.modal{padding:1.5rem}}.recipes{width:100%}.recipes-list{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000000d}.recipes-list table{width:100%;border-collapse:collapse}.recipes-list th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.recipes-list td{padding:1rem;border-bottom:1px solid #f0f0f0;color:#555;vertical-align:top}.recipes-list tr:hover{background:#f8f9fa}.recipes-list .description{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ingredients-summary{display:flex;flex-wrap:wrap;gap:.5rem}.ingredient-tag{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;background:#e9ecef;color:#495057}.ingredient-tag.in-stock{background:#d4edda;color:#155724}.ingredient-tag.out-of-stock{background:#f8d7da;color:#721c24}.recipes-list .list-actions{display:flex;gap:.5rem}.modal-large{max-width:700px}.ingredients-section{margin:1.5rem 0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header label{font-weight:500;color:#555;font-size:1rem}.ingredient-row{display:grid;grid-template-columns:2fr 1fr auto auto;gap:.5rem;margin-bottom:.75rem;align-items:center}.ingredient-name-wrapper{position:relative}.ingredient-name{padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;width:100%}.ingredient-suggestions{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;max-height:200px;overflow-y:auto;z-index:1000;margin-top:.25rem}.suggestion-item{padding:.75rem 1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .2s}.suggestion-item:hover{background:#f8f9fa}.suggestion-item:first-child{border-top-left-radius:6px;border-top-right-radius:6px}.suggestion-item:last-child{border-bottom-left-radius:6px;border-bottom-right-radius:6px}.suggestion-type{font-size:.75rem;color:#666;background:#e9ecef;padding:.25rem .5rem;border-radius:4px;text-transform:capitalize}.ingredient-amount{padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.ingredient-unit{padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;min-width:80px}.ingredient-name:focus,.ingredient-amount:focus,.ingredient-unit:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.recipes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.recipe-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d;transition:transform .2s,box-shadow .2s}.recipe-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.recipe-description{color:#666;margin:.5rem 0 1rem;font-size:.95rem}.ingredients-list{margin:1rem 0}.ingredients-list h4{margin:0 0 .75rem;font-size:1rem;color:#333}.ingredients-list ul{list-style:none;padding:0;margin:0}.ingredients-list li{padding:.5rem 0;border-bottom:1px solid #f0f0f0;color:#555;font-size:.9rem}.ingredients-list li:last-child{border-bottom:none}.ingredients-list li.in-stock{color:#28a745}.ingredients-list li.out-of-stock{color:#dc3545}.stock-indicator{font-size:.85rem;color:#666;margin-left:.5rem}@media (max-width: 768px){.page-title-section{width:100%;justify-content:space-between}.ingredient-row{grid-template-columns:1fr;gap:.75rem}.ingredient-name-wrapper,.ingredient-row .btn{width:100%}.recipes-grid{grid-template-columns:1fr}.recipes-list{overflow-x:auto}.recipes-list table{font-size:.9rem}.recipes-list th,.recipes-list td{padding:.75rem .5rem}.recipes-list .list-actions{flex-direction:column}.modal-large{max-width:100%}}.projects{width:100%}.page-title-section{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.view-toggle{display:flex;gap:.25rem;background:#e9ecef;border-radius:6px;padding:.25rem}.toggle-btn{padding:.4rem .8rem;border:none;border-radius:4px;background:transparent;color:#666;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.toggle-btn:hover{background:#667eea1a;color:#667eea}.toggle-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.projects-list{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000000d}.projects-list table{width:100%;border-collapse:collapse}.projects-list th{background:#f8f9fa;padding:1rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.projects-list td{padding:1rem;border-bottom:1px solid #f0f0f0;color:#555;vertical-align:top}.projects-list tr:hover{background:#f8f9fa}.projects-list .description{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recipes-summary{display:flex;flex-wrap:wrap;gap:.5rem}.recipe-tag{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;background:#e9ecef;color:#495057}.no-needs-badge{background:#d4edda;color:#155724;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.projects-list .list-actions{display:flex;gap:.5rem}.recipes-section{margin:1.5rem 0}.recipe-quantity-row{display:grid;grid-template-columns:2fr 1fr auto;gap:.5rem;margin-bottom:.75rem;align-items:center}.recipe-select{padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.recipe-quantity-wrapper{display:flex;align-items:center;gap:.5rem}.recipe-quantity{flex:1;padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.quantity-unit{color:#666;font-size:.9rem;font-weight:500;min-width:1.5rem}.recipe-select:focus,.recipe-quantity:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.project-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d;transition:transform .2s,box-shadow .2s}.project-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.needs-badge{background:#ffc107;color:#333;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.project-description{color:#666;margin:.5rem 0 1rem;font-size:.95rem}.project-recipes{margin:1rem 0}.project-recipes h4{margin:0 0 .75rem;font-size:1rem;color:#333}.project-recipes ul{list-style:none;padding:0;margin:0}.project-recipes li{padding:.5rem 0;border-bottom:1px solid #f0f0f0;color:#555;font-size:.9rem}.project-recipes li:last-child{border-bottom:none}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{margin:0}.no-needs{text-align:center;padding:2rem;color:#28a745;font-weight:500}.needs-list{margin:1.5rem 0}.needs-list table{width:100%;border-collapse:collapse}.needs-list th,.needs-list td{padding:.75rem;text-align:left;border-bottom:1px solid #e0e0e0}.needs-list th{background:#f8f9fa;font-weight:600;color:#333}.needs-list tr:hover{background:#f8f9fa}.needed-amount{font-weight:600;color:#dc3545}@media (max-width: 768px){.page-title-section{width:100%;justify-content:space-between}.recipe-quantity-row{grid-template-columns:1fr;gap:.75rem}.recipe-quantity-row .btn{width:100%}.projects-grid{grid-template-columns:1fr}.projects-list{overflow-x:auto}.projects-list table{font-size:.9rem}.projects-list th,.projects-list td{padding:.75rem .5rem}.projects-list .list-actions{flex-direction:column}.modal-header{flex-direction:column;align-items:stretch;gap:1rem}.needs-list{overflow-x:auto}.needs-list table{font-size:.9rem}.needs-list th,.needs-list td{padding:.5rem}}.users{width:100%}.info-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:1rem;margin-bottom:2rem;color:#856404}.info-banner p{margin:0}.current-user-section{margin-bottom:2rem}.current-user-section h3{margin-bottom:1rem;color:#333}.current-user-card{background:#fff;border:2px solid #667eea;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.current-user-card p{margin:.5rem 0;color:#555}.users-section h3{margin-bottom:1rem;color:#333}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.user-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d;transition:transform .2s,box-shadow .2s,border-color .2s;cursor:pointer;position:relative}.user-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:#667eea}.user-card.active{border-color:#667eea;background:#f8f9ff}.user-card h4{margin:0 0 .5rem;color:#333}.user-id{color:#666;font-size:.85rem;margin:0}.active-badge{position:absolute;top:1rem;right:1rem;background:#667eea;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}@media (max-width: 768px){.users-grid{grid-template-columns:1fr}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-box{background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:450px;box-shadow:0 10px 40px #0000001a}.login-box h1{margin:0 0 .5rem;color:#333;text-align:center;font-size:2rem}.login-subtitle{text-align:center;color:#666;margin-bottom:2rem}.login-box .form-group{margin-bottom:1.5rem}.login-box label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.login-box input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.login-box input:focus{outline:none;border-color:#667eea}.login-box input:disabled{background-color:#f5f5f5;cursor:not-allowed}.login-box small{display:block;margin-top:.25rem;color:#888;font-size:.875rem}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #fcc}.btn-block{width:100%;padding:.875rem;font-size:1rem}.local-mode-notice{margin-top:1.5rem;padding:1rem;background-color:#f0f7ff;border-radius:6px;border:1px solid #b3d9ff}.local-mode-notice p{margin:.5rem 0;color:#06c;font-size:.875rem}.local-mode-notice p:first-child{margin-top:0}.local-mode-notice p:last-child{margin-bottom:0}@media (max-width: 768px){.login-box{padding:1.5rem}.login-box h1{font-size:1.5rem}}
