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}body{background:#f8f8f8;color:#222;font-family:Inter,Segoe UI,Arial,sans-serif;margin:0;padding:0}.app-container{background:#f8f8f8;box-shadow:0 0 24px #0000000a;display:flex;flex-direction:column;margin:0 auto;max-width:430px;min-height:100vh;position:relative}.main-content{flex:1 1;padding:0 16px 80px}.section-title{align-items:center;display:flex;font-size:20px;font-weight:700;justify-content:space-between;margin:10px 0}.see-all{color:#1ecb6c;cursor:pointer;font-size:15px;font-weight:600;margin-left:8px}@media (max-width:500px){.app-container{box-shadow:none;max-width:100vw}.main-content{padding:0 6px}}.login-admin-bg{align-items:center;background:linear-gradient(120deg,#e8f5e9 60%,#c8e6c9);display:flex;justify-content:center;min-height:100vh}.login-admin-form{align-items:center;background:#fff;border-radius:18px;box-shadow:0 4px 32px #1ecb6c1a;display:flex;flex-direction:column;max-width:370px;padding:36px 28px 28px;width:100%}.login-logo-area{align-items:center;display:flex;margin-bottom:18px}.login-logo-icon{color:#1ecb6c;font-size:2.2rem;margin-right:10px}.login-logo-title{color:#1ecb6c;font-size:1.25rem;font-weight:700;letter-spacing:1px}.login-title{color:#222;font-size:1.5rem;font-weight:700;margin-bottom:18px}.login-field{display:flex;flex-direction:column;margin-bottom:16px;width:100%}.login-field label{color:#1ecb6c;font-size:.98rem;font-weight:600;margin-bottom:4px}.login-field input{border:1.5px solid #e0e0e0;border-radius:8px;font-size:1rem;outline:none;padding:10px 12px;transition:border .2s}.login-field input:focus{border:1.5px solid #1ecb6c}.login-password-wrapper{align-items:center;display:flex;position:relative}.login-eye-btn{background:none;color:#888;padding:0;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.login-btn,.login-eye-btn{border:none;cursor:pointer;font-size:1.1rem}.login-btn{background:#1ecb6c;border-radius:8px;color:#fff;font-weight:700;margin-top:8px;padding:12px 0;transition:background .2s;width:100%}.login-btn:disabled{background:#b2dfdb;cursor:not-allowed}.login-btn:hover:not(:disabled){background:#0fa958}.login-error{background:#ffebee;border-radius:6px;color:#d32f2f;font-size:.98rem;margin-bottom:8px;padding:8px 10px;text-align:center;width:100%}@media (max-width:500px){.login-admin-form{max-width:98vw;padding:24px 8px 18px}}.sidebar{background:#fff;box-shadow:0 0 20px #ff98004d;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transform:translateX(-100%);transition:transform .3s ease;width:280px;z-index:1000}.sidebar.open{transform:translateX(0)}.sidebar-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:999}@media (max-width:768px){.sidebar-overlay{display:block}}.sidebar-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;padding:1.5rem}.logo,.sidebar-header{align-items:center;display:flex}.logo{gap:.75rem}.logo-icon{font-size:1.5rem}.logo-text{color:#1a202c;font-size:1.25rem;font-weight:700}.close-btn{border-radius:8px;color:#718096;display:none;font-size:1.25rem;padding:.5rem;transition:all .2s ease}.close-btn:hover{background:#f7fafc;color:#4a5568}@media (max-width:768px){.close-btn{display:block}}.sidebar-nav{flex:1 1;padding:1rem 0}.nav-section{margin-bottom:2rem}.nav-title{color:#718096;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.75rem;padding:0 1.5rem;text-transform:uppercase}.nav-list{list-style:none;margin:0;padding:0}.nav-link{align-items:center;color:#4a5568;display:flex;gap:.75rem;padding:.75rem 1.5rem;position:relative;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:#f7fafc;color:#1a202c}.nav-link.active{background:linear-gradient(135deg,#ff9800,#ff5722);box-shadow:0 4px 6px -1px #ff98004d;color:#fff}.nav-link.active:before{background:#ff9800;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.nav-icon{font-size:1.125rem;text-align:center;width:20px}.nav-text{flex:1 1;font-size:.875rem;font-weight:500}.nav-arrow{font-size:.75rem;opacity:.5;transition:opacity .2s ease}.nav-link:hover .nav-arrow{opacity:1}.sidebar-footer{border-top:1px solid #e2e8f0;padding:1.5rem}.user-info{align-items:center;gap:.75rem}.user-details{display:flex;flex-direction:column}@media (min-width:769px){.sidebar{height:100vh;position:relative;width:280px}.sidebar,.sidebar.open{transform:translateX(0)}.sidebar-overlay{display:none!important}}@media (max-width:768px){.sidebar{background:#fff;box-shadow:2px 0 10px #0000001a;height:100vh;left:0;max-width:320px;position:fixed;top:0;width:100%;z-index:1001}.sidebar-overlay{display:block;opacity:0;transition:all .3s ease;visibility:hidden}.sidebar.open+.sidebar-overlay{opacity:1;visibility:visible}.logo-text{font-size:1.125rem}.nav-link{font-size:1rem;padding:1rem 1.5rem}.nav-icon{font-size:1.25rem;width:24px}.nav-text{font-size:1rem;font-weight:500}.nav-title{font-size:.8rem;margin-bottom:1rem;margin-top:1rem;padding:0 1.5rem}.sidebar-header{background:linear-gradient(135deg,#ff9800,#ff5722);color:#fff;padding:1.5rem}.logo-text{color:#fff}.close-btn{background:#ffffff1a;border-radius:8px;color:#fff;padding:8px}.close-btn:hover{background:#fff3;color:#fff}}@media (max-width:480px){.sidebar{max-width:100%;width:100%}.nav-link{padding:1.2rem 1rem}.nav-icon{font-size:1.3rem;width:28px}.nav-text{font-size:1.1rem}.sidebar-header{padding:1.2rem 1rem}.logo-text{font-size:1.2rem}.user-info{padding:0 .5rem}.user-avatar{font-size:1.1rem;height:36px;width:36px}.user-name{font-size:.9rem}.user-role{font-size:.75rem}}.sidebar-toggle-btn{align-items:center!important;background:linear-gradient(135deg,#ff9800,#ff5722)!important;border:none!important;border-radius:50%!important;box-shadow:0 4px 12px #ff980066!important;color:#fff!important;cursor:pointer!important;display:none!important;font-size:20px!important;height:48px!important;justify-content:center!important;left:20px!important;position:fixed!important;top:20px!important;transition:all .3s ease!important;width:48px!important;z-index:2000!important}.sidebar-toggle-btn:hover{box-shadow:0 6px 16px #ff980099!important;transform:scale(1.1)!important}.sidebar-toggle-btn:active{transform:scale(.95)!important}@media (max-width:768px){.sidebar-toggle-btn{display:flex!important}}.sidebar{transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar.open{animation:slideIn .3s cubic-bezier(.4,0,.2,1)}.sidebar-overlay{transition:all .3s cubic-bezier(.4,0,.2,1)}@keyframes slideIn{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes slideOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-100%)}}@media (max-width:768px){.sidebar{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.sidebar-overlay{backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.nav-link:active{background:#ff98001a;transform:scale(.98)}}@media (max-width:480px){.sidebar-toggle-btn{font-size:18px!important;height:44px!important;left:15px!important;top:15px!important;width:44px!important}}.header-bar{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 4px -1px #0000001a;justify-content:space-between;padding:1rem 2rem;position:sticky;top:0;z-index:100}.header-bar,.header-left{align-items:center;display:flex}.header-left{gap:1.5rem}.menu-toggle{background:none;border:none;border-radius:8px;color:#4a5568;cursor:pointer;display:none;font-size:1.5rem;padding:.5rem;transition:all .2s ease}.menu-toggle:hover{background:#f7fafc;color:#1a202c}@media (max-width:768px){.menu-toggle{display:block}}.search-bar{align-items:center;display:flex;position:relative}.search-bar input{border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;padding:.75rem 1rem .75rem 2.5rem;transition:border-color .2s ease;width:300px}.search-bar input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.search-icon{color:#718096;font-size:.875rem;left:.75rem}.header-right{align-items:center;display:flex}.action-btn{background:none;color:#718096;font-size:1.25rem;padding:.5rem}.action-btn:hover{background:#f7fafc;color:#4a5568}.user-profile{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.5rem;transition:all .2s ease}.user-profile:hover{background:#f7fafc}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.25rem;height:40px;justify-content:center;width:40px}.user-info{display:flex;flex-direction:column}.user-name{color:#1a202c;font-size:.875rem;font-weight:600}.user-role{color:#718096;font-size:.75rem}@media (max-width:768px){.header-bar{padding:1rem}.search-bar input{width:200px}.user-info{display:none}}@media (max-width:480px){.search-bar{display:none}.action-btn{font-size:1rem}}.dashboard-layout{background:#f8f8f8;display:flex;min-height:100vh}.dashboard-main{display:flex;flex:1 1;flex-direction:column;min-width:0}.dashboard-content{background:#f8f8f8;flex:1 1;min-width:0;overflow-y:auto;padding:0}@media (max-width:900px){.dashboard-layout{flex-direction:column}.dashboard-main{width:100vw}}.pos-ventas-page{background:#f8f9fa;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:20px}.pos-header{margin-bottom:20px}.pos-ventas-title{align-items:center;color:#1ecb6c;display:flex;font-size:2rem;font-weight:700;gap:10px;margin:0}.pos-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 400px;height:calc(100vh - 120px)}.products-panel{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;overflow-y:auto;padding:20px}.search-section{margin-bottom:20px}.search-box{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:12px 16px}.search-box input{color:#495057;margin-left:10px}.search-box svg{color:#6c757d;font-size:1.1rem}.categories-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.category-btn{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .2s;white-space:nowrap}.category-btn.active{background:#1ecb6c;border-color:#1ecb6c;color:#fff}.products-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.product-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;overflow:hidden;position:relative;transition:all .2s}.product-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.product-image{height:160px}.discount-badge{background:#ff6b6b;border-radius:6px;color:#fff;font-size:.8rem;font-weight:600;padding:4px 8px;position:absolute;right:8px;top:8px}.product-info{padding:16px}.product-name{color:#212529;font-size:1rem;font-weight:600;line-height:1.3;margin:0 0 8px}.product-description{color:#6c757d;font-size:.85rem;line-height:1.4;margin:0 0 12px}.product-meta{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.product-price{color:#1ecb6c;font-size:1.1rem;font-weight:700}.dietary-tag{border-radius:6px;font-size:.75rem;font-weight:600;padding:4px 8px}.dietary-tag.veg{background:#d4edda;color:#155724}.dietary-tag.non-veg{background:#f8d7da;color:#721c24}.add-to-dish-btn{background:#1ecb6c;border:none;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px;transition:background .2s;width:100%}.add-to-dish-btn:hover{background:#0fa958}.quantity-controls{background:#f8f9fa;gap:12px;padding:10px}.quantity-btn,.quantity-controls{align-items:center;display:flex;justify-content:center}.quantity-btn{background:#1ecb6c;border:none;border-radius:50%;color:#fff;cursor:pointer;height:32px;transition:background .2s;width:32px}.quantity-btn:hover{background:#0fa958}.quantity{color:#212529;font-size:1rem;font-weight:600;min-width:20px;text-align:center}.cart-panel{background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014;display:flex;flex-direction:column;height:100%;padding:20px}.table-info{margin-bottom:20px}.table-header{align-items:center;display:flex;justify-content:space-between}.table-header h3{color:#212529;font-size:1.2rem;font-weight:700;margin:0}.table-header p{color:#6c757d;font-size:.9rem;margin:4px 0 0}.edit-btn{background:none;color:#6c757d;padding:4px}.order-type-selector{display:flex;gap:8px;margin-bottom:20px}.order-type-btn{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;flex:1 1;font-size:.85rem;padding:8px 12px;transition:all .2s}.order-type-btn.active{background:#1ecb6c;border-color:#1ecb6c;color:#fff}.cart-items{flex:1 1;margin-bottom:20px;overflow-y:auto}.cart-item{align-items:center;border-bottom:1px solid #e9ecef;display:flex;gap:12px;padding:12px 0}.client-modal{max-width:600px}.modal-header{padding:20px 24px}.modal-header h3{font-size:1.25rem}.close-modal{border-radius:4px;color:#6c757d;padding:4px;transition:all .2s}.close-modal:hover{background:#e9ecef;color:#495057}.modal-body{padding:24px}.search-client input{border:1px solid #e9ecef;border-radius:8px;font-size:1rem;outline:none;padding:12px 16px;transition:border-color .2s;width:100%}.search-client input:focus{border-color:#1ecb6c;box-shadow:0 0 0 3px #1ecb6c1a}.clients-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));max-height:400px;overflow-y:auto}.client-card{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:12px;cursor:pointer;display:flex;padding:16px;transition:all .2s}.client-card:hover{border-color:#1ecb6c;box-shadow:0 4px 12px #1ecb6c1a;transform:translateY(-2px)}.client-card.selected{background:#f0fdf4;border-color:#1ecb6c;box-shadow:0 4px 12px #1ecb6c26}.client-avatar{align-items:center;background:#1ecb6c;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;height:48px;justify-content:center;margin-right:12px;width:48px}.client-info h4{color:#212529;font-size:1rem;font-weight:600;margin:0 0 4px}.client-info p{color:#6c757d;font-size:.85rem;margin:2px 0}.no-clients{grid-column:1/-1}.no-clients svg{font-size:3rem;margin-bottom:16px;opacity:.5}.modal-actions{border-top:1px solid #e9ecef;margin-top:20px;padding-top:20px;text-align:center}.clear-client-btn{background:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 20px;transition:background .2s}.clear-client-btn:hover{background:#5a6268}.client-details{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:8px;padding:12px}.client-details p{color:#495057;font-size:.85rem;margin:4px 0}.client-details strong{color:#212529}.edit-btn{background:#1ecb6c;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;padding:8px;transition:all .2s}.edit-btn:hover{background:#0fa958;transform:scale(1.05)}.item-info{flex:1 1}.item-info h4{color:#212529;font-size:.9rem;font-weight:600;margin:0 0 4px}.item-info p{color:#6c757d;font-size:.8rem;margin:0}.item-total{color:#1ecb6c;font-size:.9rem;font-weight:600}.remove-btn{background:#f8d7da;border:none;border-radius:6px;color:#721c24;cursor:pointer;padding:6px;transition:background .2s}.remove-btn:hover{background:#f5c6cb}.empty-cart{color:#6c757d;padding:40px 20px;text-align:center}.empty-cart svg{font-size:3rem;margin-bottom:16px;opacity:.5}.order-summary{margin-bottom:20px}.summary-row{display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:8px}.summary-row.total{border-top:1px solid #e9ecef;color:#1ecb6c;font-size:1.1rem;font-weight:700;margin-top:8px;padding-top:8px}.payment-methods{margin-bottom:20px}.payment-methods h4{color:#212529;font-size:1rem;margin:0 0 12px}.payment-options{display:flex;gap:8px}.payment-btn{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.8rem;gap:4px;padding:10px 8px;transition:all .2s}.payment-btn.active{background:#1ecb6c;border-color:#1ecb6c;color:#fff}.payment-btn svg{font-size:1.2rem}.place-order-btn{background:#1ecb6c;border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;margin-top:auto;padding:16px;transition:background .2s}.place-order-btn:hover:not(:disabled){background:#0fa958}.place-order-btn:disabled{background:#6c757d;cursor:not-allowed}@media (max-width:1200px){.pos-container{grid-template-columns:1fr 350px}}@media (max-width:900px){.pos-container{grid-template-columns:1fr;grid-template-rows:1fr auto}.cart-panel{height:auto;max-height:400px}}@media (max-width:600px){.pos-ventas-page{padding:10px}.products-grid{grid-template-columns:1fr}.categories-filter{overflow-x:auto;padding-bottom:8px}.category-btn{white-space:nowrap}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.client-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;max-height:80vh;max-width:500px;overflow:hidden;width:90%}.modal-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:20px}.modal-header h3{align-items:center;color:#212529;display:flex;font-size:1.2rem;gap:8px}.close-btn{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;font-size:1.2rem;padding:4px;transition:all .2s}.close-btn:hover{background:#e9ecef;color:#495057}.modal-body{max-height:60vh;overflow-y:auto;padding:20px}.search-client{margin-bottom:20px}.client-search-input{border:1px solid #e9ecef;border-radius:8px;font-size:1rem;outline:none;padding:12px 16px;transition:border-color .2s;width:100%}.client-search-input:focus{border-color:#1ecb6c;box-shadow:0 0 0 3px #1ecb6c1a}.clients-list{display:flex;flex-direction:column;gap:8px}.client-item{align-items:center;border:1px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:12px;transition:all .2s}.client-item:hover{background:#f8f9fa;border-color:#1ecb6c;transform:translateX(4px)}.client-info{flex:1 1}.client-name{color:#212529;font-weight:600;margin-bottom:4px}.client-details{color:#6c757d;display:flex;font-size:.85rem;gap:16px}.client-email,.client-phone{align-items:center;display:flex}.client-select{color:#1ecb6c;font-size:1.1rem}.no-clients{color:#6c757d;padding:40px 20px;text-align:center}.no-clients p{font-size:1rem;margin:0}.select-client-btn{align-items:center;background:#1ecb6c;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;justify-content:center;margin-top:12px;padding:12px 16px;transition:all .2s;width:100%}.select-client-btn:hover{background:#0fa958;transform:translateY(-1px)}.selected-client-info{background:#f8f9fa;border-left:4px solid #1ecb6c;border-radius:8px;margin:12px 0;padding:12px}.selected-client-info p{color:#495057;font-size:.85rem;margin:4px 0}.product-image{background:#f8f9fa;height:180px;overflow:hidden;position:relative}.product-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.product-card:hover .product-image img{transform:scale(1.05)}.item-image{background:#f8f9fa;border-radius:8px;flex-shrink:0;height:50px;overflow:hidden;width:50px}.item-image img{height:100%;object-fit:cover;width:100%}.inventario-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.inventario-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.inventario-title{color:#ff9800;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.search-box{margin-top:10px}.search-box input{width:180px}.inventario-add-btn{align-items:center;background:linear-gradient(135deg,#ff9800,#ffb347);border:none;border-radius:12px;box-shadow:0 4px 6px -1px #ff98001a;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.7rem 1.4rem;transition:all .2s ease}.inventario-add-btn:hover{box-shadow:0 8px 15px -3px #ff98002e;transform:translateY(-2px)}.filter-select,.sort-select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;font-size:1rem;outline:none;padding:6px 12px;transition:border .2s}.filter-select:focus,.sort-select:focus{border:1.5px solid #ff9800}.inventario-table-container{background:#fff;border-radius:16px;box-shadow:0 4px 12px -2px #ff980014;margin-top:1.5rem;overflow-x:auto;padding:1.5rem 1rem}.inventario-table{border-collapse:collapse;font-size:1rem;width:100%}.inventario-table td,.inventario-table th{padding:.75rem .5rem;text-align:left}.inventario-table th{background:#fff3e0;border-bottom:2px solid #ffe0b2;color:#ff9800;font-weight:700}.inventario-table tr{transition:background .2s}.inventario-table tr:hover{background:#fff8e1}.inventario-table td{border-bottom:1px solid #f5f5f5}.btn-icon.btn-view{background:#e3f2fd;color:#1976d2}.btn-icon.btn-view:hover{background:#bbdefb}.pagination-controls button{background:linear-gradient(135deg,#ff9800,#ffb347)}.pagination-controls button:disabled{background:#ffe0b2}.modal-bar{background:linear-gradient(90deg,#ff9800,#ffb347);border-top-left-radius:16px;border-top-right-radius:16px;height:6px;margin-bottom:8px;width:100%}.modal-overlay{padding:20px}.modal-content{max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.modal-header{border-bottom:1px solid #f0f0f0;padding:1.5rem 2rem 1rem}.modal-header h3{color:#333;font-weight:600}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;padding:.5rem;transition:all .2s ease;width:40px}.modal-close:hover{background:#f5f5f5;color:#666}.modal-form{padding:1.5rem 2rem 2rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.form-group label{color:#333;font-size:.9rem;margin-bottom:.5rem}.form-group input{background:#fafafa;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s ease}.form-group input:focus{background:#fff;border-color:#ff9800;box-shadow:0 0 0 3px #ff98001a;outline:none}.form-group input::placeholder{color:#999}.error-msg{background:#ffebee;border-left:4px solid #f44336;color:#c62828}.error-msg,.success-msg{align-items:center;border-radius:8px;display:flex;gap:.5rem;margin:1rem 0;padding:.75rem 1rem}.success-msg{background:#e8f5e8;border-left:4px solid #4caf50;color:#2e7d32}.modal-actions{border-top:1px solid #f0f0f0;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem}.btn-cancel{background:#fff;border:2px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.btn-cancel:hover{background:#f5f5f5;border-color:#ccc}.btn-submit{background:linear-gradient(135deg,#ff9800,#ffb347);border:none;border-radius:8px;box-shadow:0 2px 4px #ff980033;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.btn-submit:hover{box-shadow:0 4px 8px #ff98004d;transform:translateY(-1px)}@media (max-width:900px){.inventario-header{align-items:flex-start;flex-direction:column;gap:1rem}.inventario-table-container{padding:1rem .2rem}}.ingredient-name{align-items:center;display:flex;font-weight:500;gap:.5rem}.warning-icon{animation:pulse 2s infinite;color:#ff5722;font-size:.9rem}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.stock-badge{border-radius:20px;display:inline-block;font-size:.875rem;font-weight:600;min-width:50px;padding:.25rem .75rem;text-align:center}.stock-badge.low{background:#ffebee;border:1px solid #ffcdd2;color:#c62828}.stock-badge.medium{background:#fff3e0;border:1px solid #ffe0b2;color:#ef6c00}.stock-badge.high{background:#e8f5e8;border:1px solid #c8e6c9;color:#2e7d32}.price-cell{color:#2e7d32;font-family:Courier New,monospace;font-weight:600}.actions-cell{white-space:nowrap}.low-stock{background:#fff5f5!important;border-left:4px solid #ff5722}.low-stock:hover{background:#ffebee!important}.empty-cell,.loading-cell{padding:3rem 2rem;text-align:center}.loading-spinner{color:#ff9800}.loading-spinner .spinning{animation:spin 1s linear infinite;font-size:2rem}.empty-state{align-items:center;color:#666;display:flex;flex-direction:column;gap:1rem}.empty-state .empty-icon{color:#ccc;font-size:3rem;margin-bottom:.5rem}.empty-state h3{color:#333;margin:0}.empty-state p{color:#666}@media (max-width:900px){.inventario-header{align-items:flex-start;flex-direction:column;gap:1rem}.inventario-table-container{padding:1rem .2rem}.inventario-table{font-size:.9rem}.stock-badge{font-size:.8rem;min-width:40px;padding:.2rem .5rem}}@media (max-width:600px){.inventario-page{padding:1rem 2px}.inventario-header{align-items:flex-start;flex-direction:column;gap:1rem}.inventario-table-container{padding:.5rem 0}.inventario-table td,.inventario-table th{font-size:.85rem;padding:.5rem .2rem}.pagination-controls{flex-direction:column;gap:.5rem}.ingredient-name{align-items:flex-start;flex-direction:column;gap:.25rem}.stock-badge{font-size:.75rem;min-width:35px;padding:.15rem .4rem}.btn-icon{font-size:.9rem;height:32px;width:32px}.modal-content{margin:1rem;max-width:95%}.modal-header{padding:1rem 1.5rem .75rem}.modal-header h3{font-size:1.25rem}.modal-form{padding:1rem 1.5rem 1.5rem}.form-row{gap:.75rem;grid-template-columns:1fr}.modal-actions{flex-direction:column;gap:.75rem}.btn-cancel,.btn-submit{padding:1rem;width:100%}}.usuarios-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.usuarios-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.usuarios-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.usuarios-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.usuario-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.usuario-card:hover{border-color:#cbd5e0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.usuario-avatar{flex-shrink:0}.usuario-content{flex:1 1}.usuario-content h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.usuario-email{color:#718096;font-size:.875rem;margin:0 0 .75rem}.usuario-meta{align-items:center;display:flex;gap:1rem}.role-badge{border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.usuario-actions{display:flex;gap:.5rem}@media (max-width:768px){.usuarios-container{padding:1rem}.usuarios-header{align-items:flex-start;flex-direction:column;gap:1rem}.header-content h1{font-size:2rem}.usuarios-grid,.usuarios-stats{grid-template-columns:1fr}.usuario-card{flex-direction:column;text-align:center}.usuario-actions{margin-top:1rem}.modal-content{margin:1rem;padding:1.5rem}.form-actions{flex-direction:column}}.categorias-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.categorias-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.header-content{display:flex;flex-direction:column}.header-content p{margin:0 0 1rem}.categorias-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.categorias-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.categoria-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.categoria-card:hover{border-color:#cbd5e0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.categoria-icon{align-items:center;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;height:60px;justify-content:center;width:60px}.categoria-content{flex:1 1}.categoria-content h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.categoria-content p{color:#718096;font-size:.875rem;margin:0 0 .75rem}.categoria-meta{align-items:center;display:flex;gap:1rem}.productos-count{background:#f7fafc;border-radius:6px;color:#718096;font-size:.75rem;padding:.25rem .5rem}.categoria-actions{display:flex;gap:.5rem}@media (max-width:768px){.categorias-container{padding:1rem}.categorias-header{align-items:flex-start;flex-direction:column;gap:1rem}.header-content h1{font-size:2rem}.categorias-grid,.categorias-stats{grid-template-columns:1fr}.categoria-card{flex-direction:column;text-align:center}.categoria-actions{margin-top:1rem}.modal-content{margin:1rem;padding:1.5rem}.form-actions{flex-direction:column}}.categorias-table-container{background:#fff;border-radius:16px;box-shadow:0 4px 12px -2px #667eea14;margin-top:1.5rem;overflow-x:auto;padding:1.5rem 1rem}.categorias-table{border-collapse:collapse;font-size:1rem;width:100%}.categorias-table td,.categorias-table th{padding:.75rem .5rem;text-align:left}.categorias-table th{background:#f8f9ff;border-bottom:2px solid #e8eaff;color:#667eea;font-weight:700}.categorias-table tr{transition:background .2s}.categorias-table tr:hover{background:#f8f9ff}.categorias-table td{border-bottom:1px solid #f5f5f5}.btn-icon{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1.1rem;height:36px;justify-content:center;margin-right:4px;transition:background .2s,color .2s;width:36px}.btn-icon.btn-edit{background:#fffde7;color:#fbc02d}.btn-icon.btn-edit:hover{background:#ffe082}.btn-icon.btn-delete{background:#ffebee;color:#e53935}.btn-icon.btn-delete:hover{background:#ffcdd2}.search-box{align-items:center;background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000a;display:flex;padding:8px 14px;width:300px}.search-box input{background:#0000;border:none;color:#222;font-size:1rem;margin-left:8px;outline:none;width:100%}.filter-section,.header-actions{align-items:center;display:flex;gap:1rem}.sort-select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;font-size:1rem;outline:none;padding:6px 12px;transition:border .2s}.sort-select:focus{border:1.5px solid #667eea}.pagination-controls button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin:0 4px;padding:6px 16px;transition:background .2s,transform .2s}.pagination-controls button:disabled{background:#e8eaff;color:#bdbdbd;cursor:not-allowed}.pagination-controls select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;font-size:1rem;outline:none;padding:4px 10px}@media (max-width:900px){.categorias-header{gap:1rem}.categorias-header,.header-actions{align-items:flex-start;flex-direction:column}.header-actions,.search-box{width:100%}.pagination-controls{flex-direction:column;gap:.5rem}}@media (max-width:600px){.categorias-table td,.categorias-table th{font-size:.95rem;padding:.5rem .2rem}}.proveedores-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.proveedores-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.proveedores-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.proveedores-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.proveedor-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.proveedor-card:hover{border-color:#cbd5e0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.proveedor-avatar{flex-shrink:0}.proveedor-content{flex:1 1}.proveedor-content h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin:0 0 .75rem}.proveedor-info{margin-bottom:.75rem}.proveedor-info p{align-items:center;display:flex;gap:.5rem}.proveedor-address,.proveedor-contact,.proveedor-email,.proveedor-info p,.proveedor-phone{color:#718096;font-size:.875rem;margin:.25rem 0}.proveedor-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.products-count{background:#f7fafc;border-radius:6px;color:#718096;font-size:.75rem;padding:.25rem .5rem}.proveedor-actions{display:flex;flex-shrink:0;gap:.5rem}@media (max-width:768px){.proveedores-container{padding:1rem}.proveedores-header{align-items:flex-start;flex-direction:column;gap:1rem}.header-content h1{font-size:2rem}.proveedores-grid,.proveedores-stats{grid-template-columns:1fr}.proveedor-card{flex-direction:column;text-align:center}.proveedor-actions{justify-content:center;margin-top:1rem}.modal-content{margin:1rem;padding:1.5rem}.form-actions{flex-direction:column}}.clientes-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.clientes-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.clientes-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.clientes-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.cliente-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.cliente-card:hover{border-color:#cbd5e0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.cliente-avatar{flex-shrink:0}.avatar-circle{align-items:center;border-radius:50%;box-shadow:0 4px 6px -1px #0000001a;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:60px;justify-content:center;width:60px}.cliente-content{flex:1 1}.cliente-content h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin:0 0 .75rem}.cliente-info{margin-bottom:.75rem}.cliente-info p{align-items:center;display:flex;gap:.5rem}.cliente-address,.cliente-email,.cliente-info p,.cliente-phone{color:#718096;font-size:.875rem;margin:.25rem 0}.cliente-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.orders-count{background:#f7fafc;border-radius:6px;color:#718096;font-size:.75rem;padding:.25rem .5rem}.cliente-actions{display:flex;flex-shrink:0;gap:.5rem}.form-group input,.form-group textarea{border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}@media (max-width:768px){.clientes-container{padding:1rem}.clientes-header{align-items:flex-start;flex-direction:column;gap:1rem}.header-content h1{font-size:2rem}.clientes-grid,.clientes-stats{grid-template-columns:1fr}.cliente-card{flex-direction:column;text-align:center}.cliente-actions{justify-content:center;margin-top:1rem}.modal-content{margin:1rem;padding:1.5rem}.form-actions{flex-direction:column}}.egresos-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.egresos-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.egresos-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.egresos-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.egreso-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.egreso-card:hover{border-color:#cbd5e0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.egreso-icon{flex-shrink:0}.egreso-content{flex:1 1}.egreso-content h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin:0 0 .75rem}.egreso-details{margin-bottom:.75rem}.egreso-details p{align-items:center;color:#718096;display:flex;font-size:.875rem;gap:.5rem;margin:.25rem 0}.egreso-amount{color:#e53e3e;font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.egreso-category,.egreso-date{color:#718096;font-size:.875rem;margin:.25rem 0}.egreso-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.egreso-actions{display:flex;flex-shrink:0;gap:.5rem}@media (max-width:768px){.egresos-container{padding:1rem}.egresos-header{align-items:flex-start;flex-direction:column;gap:1rem}.header-content h1{font-size:2rem}.egresos-grid,.egresos-stats{grid-template-columns:1fr}.egreso-card{flex-direction:column;text-align:center}.egreso-actions{justify-content:center;margin-top:1rem}.modal-content{margin:1rem;padding:1.5rem}.form-actions{flex-direction:column}}.ingresos-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:100vh;padding:2rem}.ingresos-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.header-content h1{color:#1a202c;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.header-content p{color:#718096;font-size:1.1rem;margin:0}.add-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.add-button:hover{box-shadow:0 8px 15px -3px #0003;transform:translateY(-2px)}.add-button span{font-size:1.25rem;font-weight:700}.ingresos-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px)}.stat-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;height:50px;justify-content:center;width:50px}.stat-content h3{color:#718096;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin:0 0 .5rem;text-transform:uppercase}.stat-value{color:#1a202c;font-size:1.5rem;font-weight:700;margin:0}.ingresos-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.ingreso-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.ingreso-card:hover{border-color:#cbd5e0;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.ingreso-icon{flex-shrink:0}.icon-circle{align-items:center;border-radius:50%;box-shadow:0 4px 6px -1px #0000001a;color:#fff;display:flex;font-size:1.5rem;height:60px;justify-content:center;width:60px}.ingreso-content{flex:1 1}.ingreso-content h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin:0 0 .75rem}.ingreso-details{margin-bottom:.75rem}.ingreso-details p{align-items:center;color:#718096;display:flex;font-size:.875rem;gap:.5rem;margin:.25rem 0}.ingreso-amount{color:#38a169;font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.ingreso-category,.ingreso-date{color:#718096;font-size:.875rem;margin:.25rem 0}.ingreso-meta{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.payment-method{border-radius:12px;color:#fff;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.payment-method,.status{font-size:.75rem;font-weight:600}.status{border-radius:6px;padding:.25rem .5rem}.status.active{background:#f0fff4;color:#38a169}.ingreso-actions{display:flex;flex-shrink:0;gap:.5rem}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.action-btn.edit{background:#ebf8ff;color:#3182ce}.action-btn.edit:hover{background:#bee3f8}.action-btn.delete{background:#fff5f5;color:#e53e3e}.action-btn.delete:hover{background:#fed7d7}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;padding:2rem;width:90%}.modal-header{margin-bottom:1.5rem}.modal-header h2{color:#1a202c;font-size:1.5rem;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:8px;color:#718096;cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .2s ease}.close-button:hover{background:#f7fafc;color:#4a5568}.modal-form{gap:1.5rem}.form-group,.modal-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#4a5568;font-size:.875rem;font-weight:600}.form-group input,.form-group select{border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.75rem;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.cancel-button{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease}.cancel-button:hover{background:#f7fafc;border-color:#cbd5e0}.save-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.save-button:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.loading-spinner{align-items:center;display:flex;flex-direction:column;gap:1rem;height:50vh;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.ingresos-container{padding:1rem}.ingresos-header{align-items:flex-start;flex-direction:column;gap:1rem}.header-content h1{font-size:2rem}.ingresos-grid,.ingresos-stats{grid-template-columns:1fr}.ingreso-card{flex-direction:column;text-align:center}.ingreso-actions{justify-content:center;margin-top:1rem}.modal-content{margin:1rem;padding:1.5rem}.form-actions{flex-direction:column}}.platos-container{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.platos-header{background:#fff;border-radius:15px;box-shadow:0 4px 20px #0000001a;justify-content:space-between;margin-bottom:30px;padding:20px}.platos-header,.platos-title{align-items:center;display:flex}.platos-title{color:#2c3e50;font-size:2.5rem;font-weight:700;gap:15px;margin:0}.platos-title svg{color:#e74c3c;font-size:2.2rem}.add-plato-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.add-plato-btn:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.search-container{margin-bottom:25px;position:relative}.search-input{background:#fff;border:2px solid #e0e6ed;border-radius:25px;box-shadow:0 2px 10px #0000001a;font-size:1rem;padding:15px 20px 15px 50px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 4px 20px #667eea33;outline:none}.search-icon{color:#95a5a6;font-size:1.2rem;left:18px;position:absolute;top:50%;transform:translateY(-50%)}.platos-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-bottom:30px}.plato-card{background:#fff;border-radius:20px;box-shadow:0 8px 25px #0000001a;overflow:hidden;position:relative;transition:all .3s ease}.plato-card:hover{box-shadow:0 15px 35px #00000026;transform:translateY(-5px)}.plato-image-container{height:200px;overflow:hidden;position:relative}.plato-image{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.plato-card:hover .plato-image{transform:scale(1.05)}.plato-image-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:3rem;height:100%;justify-content:center;width:100%}.plato-category-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#e74c3ce6;border-radius:15px;color:#fff;font-size:.8rem;font-weight:600;padding:5px 12px;position:absolute;right:15px;top:15px}.plato-content{padding:20px}.plato-name{color:#2c3e50;font-size:1.4rem;font-weight:700;line-height:1.3;margin:0 0 8px}.plato-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#7f8c8d;display:-webkit-box;font-size:.95rem;line-height:1.5;margin-bottom:15px;overflow:hidden}.plato-price{color:#27ae60;font-size:1.8rem;font-weight:700;margin-bottom:15px}.plato-ingredients{margin-bottom:20px}.ingredients-label{color:#34495e;display:block;font-size:.9rem;font-weight:600;margin-bottom:8px}.ingredients-list{display:flex;flex-wrap:wrap;gap:6px}.ingredient-tag{background:#ecf0f1;border-radius:12px;color:#2c3e50;font-size:.8rem;font-weight:500;padding:4px 10px}.plato-actions{display:flex;gap:10px;justify-content:flex-end}.delete-btn,.edit-btn{align-items:center;border:none;border-radius:20px;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:6px;padding:8px 16px;transition:all .3s ease}.edit-btn{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.edit-btn:hover{box-shadow:0 4px 12px #3498db66;transform:translateY(-1px)}.delete-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff}.delete-btn:hover{box-shadow:0 4px 12px #e74c3c66;transform:translateY(-1px)}.plato-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.plato-modal-content{animation:modalSlideIn .3s ease;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #ecf0f1;border-radius:20px 20px 0 0;color:#fff;display:flex;justify-content:space-between;padding:25px 30px}.modal-header h3{font-size:1.5rem;font-weight:700;margin:0}.close-modal{background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:1.5rem;padding:5px;transition:all .3s ease}.close-modal:hover{background:#fff3;transform:rotate(90deg)}.plato-form{padding:30px}.plato-form-group{margin-bottom:25px}.plato-form-group label{color:#2c3e50;display:block;font-size:1rem;font-weight:600;margin-bottom:8px}.plato-form-group input,.plato-form-group select,.plato-form-group textarea{background:#f8f9fa;border:2px solid #e0e6ed;border-radius:10px;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.plato-form-group input:focus,.plato-form-group select:focus,.plato-form-group textarea:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.plato-form-group textarea{min-height:80px;resize:vertical}.ingredients-checkbox-list{grid-gap:12px;background:#f8f9fa;border:2px solid #e0e6ed;border-radius:10px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));max-height:200px;overflow-y:auto;padding:15px}.ingredient-checkbox{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:8px;transition:background .2s ease}.ingredient-checkbox:hover{background:#e9ecef}.ingredient-checkbox input[type=checkbox]{margin:0;transform:scale(1.2);width:auto}.ingredient-checkbox span{color:#495057;font-size:.9rem}.plato-modal-actions{border-top:2px solid #ecf0f1;display:flex;gap:15px;justify-content:flex-end;margin-top:30px;padding-top:20px}.cancel-btn,.submit-btn{border:none;border-radius:25px;cursor:pointer;font-size:1rem;font-weight:600;min-width:120px;padding:12px 24px;transition:all .3s ease}.cancel-btn{background:#95a5a6;color:#fff}.cancel-btn:hover{background:#7f8c8d;transform:translateY(-1px)}.submit-btn{background:linear-gradient(135deg,#27ae60,#229954);color:#fff}.submit-btn:hover{box-shadow:0 4px 15px #27ae6066;transform:translateY(-1px)}.loading-container{align-items:center;color:#7f8c8d;display:flex;font-size:1.2rem;height:300px;justify-content:center}.empty-state{color:#7f8c8d;padding:60px 20px;text-align:center}.empty-state svg{color:#bdc3c7;font-size:4rem;margin-bottom:20px}.empty-state h3{color:#2c3e50;font-size:1.5rem;margin-bottom:10px}.empty-state p{font-size:1rem;margin:0}.error-message{background:#fee;border-left:4px solid #e74c3c;color:#c0392b}.error-message,.success-message{border-radius:8px;font-weight:500;margin-bottom:15px;padding:12px 16px}.success-message{background:#eafaf1;border-left:4px solid #27ae60;color:#27ae60}@media (max-width:768px){.platos-container{padding:15px}.platos-header{flex-direction:column;gap:20px;text-align:center}.platos-title{font-size:2rem}.platos-grid{gap:20px;grid-template-columns:1fr}.plato-modal-content{margin:10px;width:95%}.plato-form{padding:20px}.ingredients-checkbox-list{grid-template-columns:1fr}.plato-modal-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}@media (max-width:480px){.platos-title{font-size:1.8rem}.add-plato-btn{font-size:.9rem;padding:10px 20px}.plato-card{margin-bottom:15px}.plato-content{padding:15px}.plato-name{font-size:1.2rem}.plato-price{font-size:1.5rem}}.image-upload-container{background:#f8f9fa;border:2px dashed #e0e6ed;border-radius:12px;cursor:pointer;padding:20px;position:relative;text-align:center;transition:all .3s ease}.image-upload-container:hover{background:#f0f2ff;border-color:#667eea}.image-upload-placeholder{align-items:center;color:#95a5a6;display:flex;flex-direction:column;font-size:1rem;gap:10px}.image-upload-placeholder svg{color:#667eea;font-size:2rem}.image-input{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%}.image-preview{display:inline-block;position:relative}.preview-image{border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:150px;max-width:200px;object-fit:cover}.remove-image-btn{align-items:center;background:#e74c3c;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.8rem;height:24px;justify-content:center;position:absolute;right:-8px;top:-8px;transition:all .3s ease;width:24px}.remove-image-btn:hover{background:#c0392b;transform:scale(1.1)}.image-help{color:#7f8c8d;display:block;font-size:.85rem;margin-top:8px}.mock-banner{animation:slideDown .5s ease-out;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;font-size:14px;left:0;padding:8px 0;position:fixed;right:0;top:0;z-index:9999}.mock-banner-content{align-items:center;display:flex;gap:10px;justify-content:center;margin:0 auto;max-width:1200px;padding:0 20px}.mock-banner-icon{animation:bounce 2s infinite;font-size:18px}.mock-banner-text{font-size:15px;font-weight:600}.mock-banner-info{font-size:12px;font-style:italic;opacity:.9}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}body{padding-top:40px}@media (max-width:768px){.mock-banner{font-size:12px;padding:6px 0}.mock-banner-content{flex-direction:column;gap:5px;padding:0 15px}.mock-banner-text{font-size:13px}.mock-banner-info{font-size:11px;text-align:center}body{padding-top:50px}}
/*# sourceMappingURL=main.ed338d59.css.map*/