:root{--primary:#3c1000;--secondary:#f6f0e9;--bg:#f6f0e9;--bg2:#ece3d8;--bgm:rgba(246,240,233,.95);--bgo:rgba(246,240,233,.8);--sh:0 4px 6px rgba(60,16,0,.1)}
*{margin:0;font-family:"Poppins","Plus Jakarta Sans","Noto Sans",sans-serif;scroll-behavior:smooth;box-sizing:border-box;font-size:16px;}
body{display:flex;flex-direction:column;min-height:100vh;width:100%;background:#f6f0e9;overflow-x:hidden}

/* Product list styles */
.product-section {
    padding: 20px;
  
}

.section-title {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 20px;
    color: var(--primary);
    text-transform: uppercase;
}

.products-list {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.product-item {
    display: flex;
    align-items: center;
    padding: 15px;
    border-radius: 15px;
    background-color: var(--bg2);
    cursor: pointer;
    transition: all 0.3s ease;
}

.product-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(244, 179, 28, 0.2);
}

.product-image {
    min-width: 80px;
    width: 80px;
    height: 80px;
    flex: 0 0 80px;
    border-radius: 10px;
    object-fit: cover;
    margin-right: 15px;
    display: block;
}

.product-details {
    flex: 1;
}

.product-name {
    font-size: 14px;
    font-weight: 500;
    margin-bottom: 5px;
    color: var(--primary);
}

.product-price {
    font-size: 16px;
    font-weight: 700;
    color: var(--primary);
}

.product-cart-icon {
    font-size: 24px;
    color: var(--primary);
    margin-left: 15px;
    padding: 10px;
    background-color: var(--primary);
    color: var(--secondary);
    border-radius: 10px;
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.product-item:hover .product-cart-icon {
    transform: scale(1.15);
    background-color: var(--secondary);
    color: var(--primary);
    box-shadow: 0 4px 8px rgba(60, 16, 0, 0.2);
}

.header-container{display:flex;align-items:center;background:var(--bg);border-bottom:2px solid var(--primary);padding:1rem 0 .5rem;justify-content:center;position:relative;min-height:80px}
.animated-header{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.main-title,.main-logo{opacity:0;animation:ht 4s ease-in-out forwards}
.slogan-text{position:absolute;color:var(--primary);font-size:1.5rem;font-weight:600;text-align:center;opacity:0;animation:hs 4s ease-in-out forwards;font-style:italic}
.main-title{color:var(--primary);font-size:2.25rem;font-weight:bold;line-height:1.1;letter-spacing:-.015em;text-align:center}
.logo-image{max-height:120px;max-width:100%;object-fit:contain;transition:transform .3s}
.logo-image:hover{transform:scale(1.05)}
.navbar{position:fixed;top:0;left:0;right:0;z-index:50;background:var(--bg);border-bottom:2px solid var(--primary);box-shadow:var(--sh);width:100%;transition:all .3s}
.navbar.navbar-sticky{position:fixed;top:0;left:0;right:0}
.navbar-spacer{height:110px;transition:height .3s}
.navbar-spacer.active{height:110px}
.navbar-content{display:flex;align-items:center;padding:1rem 0.5rem;justify-content:center;gap:1rem}
.search-container{position:relative;width:100%;max-width:28rem}
.search-input{width:100%;padding:10px 34px 10px 8px;background:var(--bg)!important;color:var(--primary)!important;border:2px solid var(--primary)!important;border-radius:.5rem!important;outline:none;transition:all .15s;box-shadow:var(--sh);font-size:16px}
.search-input:focus{border-color:var(--primary)}
.search-input::placeholder{color:var(--primary)!important}
.search-input::-webkit-input-placeholder{color:var(--primary)!important;opacity:0.7}
.search-input::-moz-placeholder{color:var(--primary)!important;opacity:0.7}
.search-input:-ms-input-placeholder{color:var(--primary)!important;opacity:0.7}
.search-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:var(--primary)}
.search-results{position:absolute;top:100%;left:0;right:0;background:var(--bg);border:2px solid var(--primary);border-top:none;border-radius:0 0 .5rem .5rem;max-height:300px;overflow-y:auto;z-index:50;display:none;box-shadow:var(--sh)}
.search-result-item{padding:10px 8px;border-bottom:1px solid var(--primary);cursor:pointer;transition:background-color .15s;color:var(--primary)}
.search-result-item:hover{background:var(--bg2);box-shadow:var(--sh)}
.search-result-content{display:flex;align-items:center;gap:0.75rem}
.search-result-image{width:50px;height:50px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--bg2)}
.search-result-image img{width:100%;height:100%;object-fit:cover;border-radius:8px}
.search-result-info{flex:1;display:flex;flex-direction:column;gap:0.25rem}
.search-result-title{font-weight:500;font-size:1rem;color:var(--primary);line-height:1.2}
.search-result-price{font-size:0.9rem;font-weight:600;color:var(--primary)}
.nav-buttons{display:flex;align-items:center;gap:1rem}
.dropdown-container{position:relative}
.dropdown-button{display:flex;align-items:center;gap:.5rem;padding:10px 8px;background:var(--bg);color:var(--primary);border:2px solid var(--primary);border-radius:.5rem;cursor:pointer;outline:none;transition:all .15s;box-shadow:var(--sh)}
.dropdown-button:hover{background:var(--primary);color:var(--secondary);border-color:var(--primary);box-shadow:var(--sh)}
.dropdown-arrow{width:1rem;height:1rem;color:var(--primary);transition:transform .15s}
.dropdown-menu{position:absolute;right:0;margin-top:.5rem;width:12rem;background:var(--bg);border:2px solid var(--primary);border-radius:.5rem;box-shadow:var(--sh);opacity:0;visibility:hidden;transform:scale(.95);transition:all .2s;transform-origin:top right}
.dropdown-menu.opacity-100.visible.scale-100{opacity:1;visibility:visible;transform:scale(1)}
.dropdown-list{padding:.5rem 0;list-style:none;margin:0}
.dropdown-link{display:block;padding:.5rem 1rem;color:var(--primary);text-decoration:none;transition:all .15s}
.dropdown-link:hover{background:var(--bg2);color:var(--primary)}
.nav-cart-button{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;background-color:var(--bg);border:2px solid var(--primary);border-radius:.5rem;color:var(--primary);cursor:pointer;position:relative;transition:all .3s}
.nav-cart-button:hover{background-color:var(--bg2)}
.nav-cart-button i{font-size:20px;transition:transform .3s}
.nav-cart-button:hover i{transform:scale(1.1)}
.nav-cart-count{position:absolute;top:-8px;right:-8px;background-color:var(--primary);color:var(--secondary);border-radius:50%;padding:.25rem;min-width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:bold}
.section-title{color:var(--primary);font-size:1.75rem;font-weight:bold;line-height:1.1;letter-spacing:-.015em;padding:1rem 1rem 1rem 1.5rem}
.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:10px}
.product-card{display:flex;flex-direction:column;cursor:pointer;transition:transform .2s;border:1px solid var(--primary);border-radius:.75rem}
.product-card:hover{transform:translateY(-4px);border-color:var(--primary)}
.product-image{width:100%;background-position:center;background-repeat:no-repeat;aspect-ratio:1;background-size:cover;border-radius:.75rem .75rem .75rem .75rem;position:relative}
.product-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:rgba(246,240,233,.25);border-radius:.75rem .75rem 0 0;animation:fb 4s ease-in-out infinite}

.product-name {
    color: var(--primary);
    font-size: 22px;
    font-weight: bold;
    text-align: left;
    animation: f 4s ease-in-out infinite;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    position: relative;
}
.product-name-below{color:var(--primary);font-size:1.5rem;font-weight:bold;text-align:center;margin:0;padding:10px 5px 5px}
.product-info{display:flex;flex-direction:column;align-items:center;padding:0}
.price-container{text-align:center}
.price-text{color:var(--primary);font-size:1.5rem;font-weight:600;line-height:1.33;margin:5px 0 10px;text-align:center}
.product-badges{position:absolute;top:.5rem;left:.5rem;display:flex;flex-direction:column;gap:.25rem}
.product-badge{background:var(--primary);color:var(--secondary);padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:500}
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bgo);backdrop-filter:blur(3px);display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;visibility:hidden;transition:all .3s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal-content{background:var(--bgm);border:2px solid var(--primary);box-shadow:var(--sh);border-radius:1rem;max-width:400px;width:94%;max-height:90vh;overflow-y:auto;position:relative;transform:scale(.8);transition:transform .3s}
.modal-overlay.active .modal-content{transform:scale(1)}
.modal-close{position:absolute;top:1rem;right:1rem;background:var(--bg);border:2px solid var(--primary);color:var(--primary);font-size:1.4rem;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;box-shadow:var(--sh)}
.modal-close:hover{background:var(--primary);color:var(--secondary);border-color:var(--primary);box-shadow:var(--sh);transform:scale(1.1)}
.modal-image{width:100%;height:250px;background-size:cover;background-position:center;border-radius:1rem 1rem 0 0}
.modal-body{padding:1.5rem}
.modal-title{color:var(--primary);font-size:1.5rem;font-weight:bold;margin-bottom:1rem}
.modal-price{color:var(--primary);font-size:1.25rem;font-weight:bold;margin-bottom:1rem}
.modal-description{color:var(--primary);line-height:1.6;margin-bottom:1.5rem}
.modal-ingredients-title{color:var(--primary);font-size:1.25rem;font-weight:bold;margin-bottom:1rem}
.modal-ingredients{background:linear-gradient(135deg,rgba(60,16,0,.03) 0%,rgba(60,16,0,.08) 100%);border-radius:1rem;border:2px dashed rgba(60,16,0,.15);position:relative;overflow:hidden}
.ingredients-container{max-height:140px;overflow-y:auto;border-radius:.75rem;scrollbar-width:thin;scrollbar-color:var(--primary) var(--bg)}
.ingredients-container::-webkit-scrollbar{width:6px}
.ingredients-container::-webkit-scrollbar-track{background:var(--bg);border-radius:.5rem}
.ingredients-container::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--primary) 0%,#5a2000 100%);border-radius:.5rem;transition:all .3s}
.ingredients-container::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#5a2000 0%,var(--primary) 100%)}
.ingredients-list{display:flex;flex-wrap:wrap;gap:.75rem;padding:.5rem}
.ingredient-item{background:linear-gradient(135deg,var(--secondary) 0%,var(--bg2) 100%);color:var(--primary);padding:.5rem 1rem;border-radius:2rem;font-size:.85rem;font-weight:600;border:2px solid var(--primary);box-shadow:0 2px 8px rgba(60,16,0,.1),inset 0 1px 0 rgba(255,255,255,.3);position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);animation:fadeInUp .5s ease-out forwards;opacity:0}
.ingredient-item:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 6px 16px rgba(60,16,0,.2),inset 0 1px 0 rgba(255,255,255,.5);border-color:#5a2000;background:linear-gradient(135deg,#fff 0%,var(--secondary) 100%)}
.ingredient-item:nth-child(1){animation-delay:.1s}
.ingredient-item:nth-child(2){animation-delay:.2s}
.ingredient-item:nth-child(3){animation-delay:.3s}
.ingredient-item:nth-child(4){animation-delay:.4s}
.ingredient-item:nth-child(5){animation-delay:.5s}
.ingredient-item:nth-child(6){animation-delay:.6s}
.ingredient-item:nth-child(7){animation-delay:.7s}
.ingredient-item:nth-child(8){animation-delay:.8s}
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulseGlow{0%,100%{opacity:.3;transform:rotate(0deg) scale(1)}50%{opacity:.5;transform:rotate(180deg) scale(1.1)}}
.modal-order-button{background:var(--primary);color:var(--secondary);padding:10px 14px;border-radius:.75rem;font-weight:bold;border:2px solid var(--primary);cursor:pointer;font-size:1rem;transition:all .3s;box-shadow:var(--sh);margin-left:.5rem;display:flex;align-items:center;gap:.5rem;min-width:auto}
.modal-order-button:hover{background:var(--bg2);color:var(--primary);border-color:var(--primary);box-shadow:var(--sh);transform:translateY(-2px) scale(1.05)}
.modal-quantity-section{margin-bottom:0}
.modal-quantity-controls{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem}
.modal-quantity-btn{background:var(--bg);border:2px solid var(--primary);color:var(--primary);border-radius:50%;width:36px;height:36px;font-size:1.2rem;font-weight:bold;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh)}
.modal-quantity-btn:hover{background:var(--primary);color:var(--secondary);border-color:var(--primary);box-shadow:var(--sh);transform:scale(1.1)}
.modal-quantity-input{color:var(--primary);font-weight:bold;width:70px;text-align:center;font-size:1.3rem;background:var(--bg2);padding:.75rem .5rem;border-radius:.75rem;border:2px solid var(--primary);outline:none;margin:0 .25rem}
.modal-quantity-input:focus{border-color:var(--primary);box-shadow:var(--sh)}

/* Estilos específicos para iconos de Bootstrap dentro de modales */
.modal-overlay i[class^="bi-"],
.modal-overlay i[class*=" bi-"],
.modal-content i[class^="bi-"],
.modal-content i[class*=" bi-"] {
    font-size: 20px !important;
}

.modal-close i[class^="bi-"],
.modal-close i[class*=" bi-"] {
    font-size: 20px !important;
}

.modal-quantity-btn i[class^="bi-"],
.modal-quantity-btn i[class*=" bi-"] {
    font-size: 20px !important;
}

.modal-order-button i[class^="bi-"],
.modal-order-button i[class*=" bi-"] {
    font-size: 24px !important;
}

.unified-tab i[class^="bi-"],
.unified-tab i[class*=" bi-"] {
    font-size: 24px !important;
}

.cart-action-btn i[class^="bi-"],
.cart-action-btn i[class*=" bi-"],
.quantity-btn i[class^="bi-"],
.quantity-btn i[class*=" bi-"],
.remove-item-btn i[class^="bi-"],
.remove-item-btn i[class*=" bi-"],
.notes-action-btn i[class^="bi-"],
.notes-action-btn i[class*=" bi-"],
.add-note-btn i[class^="bi-"],
.add-note-btn i[class*=" bi-"] {
    font-size: 20px !important;
}

.notification-close-btn i[class^="bi-"],
.notification-close-btn i[class*=" bi-"] {
    font-size: 20px !important;
}

.unified-modal-content{max-width:500px;max-height:95vh;display:flex;flex-direction:column;overflow:hidden}

/* Nuevo header del carrito */
.cart-header {
    background: var(--primary);
    color: var(--secondary);
    padding: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    border-bottom: 2px solid var(--primary);
}

.cart-title {
    font-size: 1.5rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--secondary);
}

.cart-badge {
    background: rgba(255, 255, 255, 0.2);
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.85rem;
    color: var(--primary);
    border: 1px solid var(--primary);
}

/* Navegación del carrito */
.cart-nav {
    display: flex;
    border-bottom: 1px solid var(--primary);
    background: var(--bg2);
}

.nav-btn {
    flex: 1;
    padding: 18px 15px;
    background: none;
    border: none;
    font-size: 1rem;
    font-weight: 500;
    color: var(--primary);
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    position: relative;
}

.nav-btn.active {
    color: var(--primary);
    background: var(--bg);
    font-weight: 600;
}

.nav-btn.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: var(--primary);
    border-radius: 3px 3px 0 0;
}



.nav-btn i {
    font-size: 1.1rem;
}

/* Estilos legacy que se mantienen para compatibilidad */
.unified-modal-header{position:sticky;top:0;background:var(--bgm);border-bottom:2px solid var(--primary);z-index:10}
.unified-tabs{display:flex;align-items:center;padding:1rem;gap:.5rem}
.unified-tab{flex:1;padding:.75rem;background:var(--bg2);border:1px solid var(--primary);border-radius:.5rem;color:var(--primary);cursor:pointer;transition:all .3s;font-weight:500}
.unified-tab.active{background:var(--primary);border-color:var(--primary);color:var(--secondary)}
.unified-modal-body{flex:1;overflow-y:auto;padding:1rem}
.modal-section{display:none}
.modal-section.active{display:block}
.cart-items{margin-bottom:1rem;max-height:400px;overflow-y:auto}
.empty-cart{text-align:center;padding:2rem;color:var(--primary)}
.cart-item{display:flex;flex-direction:column;padding:1rem;margin-bottom:1rem;background:var(--bg2);border-radius:.5rem;border:1px solid var(--primary);position:relative;transition:all .3s}
.cart-item:hover{background:var(--bg2);border-color:var(--primary);box-shadow:var(--sh)}
.cart-item-header{display:flex;align-items:center;margin-bottom:.75rem}
.cart-item-footer{display:flex;justify-content:space-between;align-items:center}
.cart-item-image{width:60px;height:60px;border-radius:.5rem;overflow:hidden;margin-right:1rem;flex-shrink:0}
.cart-item-image img{width:100%;height:100%;object-fit:cover}
.cart-item-details{flex:1;margin-right:1rem;margin-left:1rem}
.cart-item-details h4{color:var(--primary);font-size:1rem;margin:0 0 .25rem;font-weight:600}
.cart-item-price{color:var(--primary);font-weight:bold;margin:0;font-size:.9rem}
.cart-item-controls{display:flex;align-items:center;gap:.75rem;margin-right:1rem;background:var(--bg);padding:.5rem;border-radius:1rem;border:1px solid var(--primary)}
.quantity-btn{background:var(--bg);border:2px solid var(--primary);color:var(--primary);border-radius:50%;width:36px;height:36px;font-size:1.2rem;font-weight:bold;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh)}
.quantity-btn:hover{background:var(--primary);color:var(--secondary);border-color:var(--primary);box-shadow:var(--sh);transform:scale(1.1)}
.quantity{color:var(--primary);font-weight:bold;min-width:40px;text-align:center;font-size:1.1rem;background:var(--bg2);padding:.5rem;border-radius:.75rem;border:2px solid var(--primary);outline:none}
.quantity:focus{border-color:var(--primary);box-shadow:var(--sh)}
.cart-item-total{color:var(--primary);font-weight:bold;font-size:1rem;margin-right:.5rem}
.subtotal-container{display:flex;flex-direction:column;align-items:center;text-align:center}
.subtotal-label{color:var(--primary);font-weight:normal;font-size:0.8rem;margin-bottom:0.25rem}
.subtotal-amount{color:var(--primary);font-weight:bold;font-size:1rem}
.remove-item-btn{background:var(--primary);color:var(--secondary);padding:10px 14px;border-radius:.75rem;font-weight:bold;border:2px solid var(--primary);cursor:pointer;font-size:1rem;transition:all .3s;display:flex;align-items:center;gap:.5rem;min-width:auto}
.remove-item-btn:hover{background:var(--bg2);color:var(--primary);border-color:var(--primary);transform:translateY(-2px) scale(1.05)}
.add-note-btn{background:var(--bg);border:2px solid var(--primary);color:var(--primary);padding:.25rem .5rem;border-radius:.5rem;font-size:.75rem;cursor:pointer;transition:all .3s;margin-top:.5rem;box-shadow:var(--sh)}
.add-note-btn:hover{background:var(--primary);color:var(--secondary);border-color:var(--primary);box-shadow:var(--sh);transform:scale(1.05)}
.add-note-btn.has-note{border-color:var(--primary);color:var(--primary)}
.cart-item-notes{font-size:.85rem;color:var(--primary);font-style:italic;margin-top:.5rem;padding:.5rem .75rem;background:var(--bg);border-radius:.5rem;border:2px solid var(--primary);position:relative;padding-left:2rem}
.cart-item-notes::before{content:"📝";position:absolute;left:.5rem;top:.45rem;font-style:normal}
.cart-total{border-top:2px solid var(--primary);padding-top:1rem;margin-bottom:1rem}
.total-line{display:flex;justify-content:space-between;align-items:center;font-size:1.25rem;font-weight:bold;color:var(--primary)}
.customer-form{background:var(--bg2);border-radius:.5rem;padding:1rem;margin-bottom:1rem;border:1px solid var(--primary)}
.customer-form h4{color:var(--primary);margin-bottom:1rem;text-align:center}
.form-group{margin-bottom:1rem}
.form-group label{display:block;color:var(--primary);margin-bottom:.5rem;font-weight:500}
.form-group input,.form-group select{width:100%;padding:.75rem;border-radius:.5rem;border:2px solid var(--primary);background:var(--bg);color:var(--primary);font-size:1rem;transition:border-color .3s}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:var(--sh)}
.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%233c1000' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px;padding-right:2.5rem}
.form-group select option{background:var(--bg);color:var(--primary);padding:.5rem}
.cart-actions{display:flex;flex-direction:column;gap:.75rem}
.cart-action-btn{padding:.75rem 1.5rem;border-radius:.75rem;font-weight:bold;font-size:1rem;cursor:pointer;transition:all .3s;border:2px solid;text-align:center;box-shadow:var(--sh)}
.cart-action-btn.primary{background:var(--primary);color:var(--secondary);border-color:var(--primary)}
.cart-action-btn.primary:hover{background:var(--bg2);color:var(--primary);border-color:var(--primary);box-shadow:var(--sh);transform:scale(1.05)}
.cart-action-btn.secondary{background:var(--bg);color:var(--primary);border-color:var(--primary)}
.cart-action-btn.secondary:hover{background:var(--primary);color:var(--secondary);border-color:var(--primary);box-shadow:var(--sh);transform:scale(1.05)}
.orders-intro{margin-bottom:1rem;text-align:center}
.orders-subtitle{color:var(--primary);font-size:.9rem;font-style:italic;background:var(--bg2);padding:.75rem;border-radius:.5rem;border:1px solid var(--primary)}
.empty-orders{text-align:center;padding:2rem;color:var(--primary)}
.order-completed-item{background:var(--bg2);border:2px solid var(--primary);border-radius:.75rem;margin-bottom:1rem;overflow:hidden;transition:all .3s;box-shadow:var(--sh)}
.order-completed-item:hover{background:var(--bg2);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 6px 12px rgba(60,16,0,.15)}
.order-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;cursor:pointer}
.order-info{flex:1}
.order-info h4{color:var(--primary);margin:0 0 .5rem;font-size:1.1rem;font-weight:600}
.order-date{color:var(--primary);margin:0 0 .35rem;font-size:.85rem;opacity:.8}
.order-customer,.order-phone{color:var(--primary);margin:0 0 .25rem;font-size:.9rem}
.order-total-section{display:flex;align-items:center;gap:.75rem}
.order-total{display:none;color:var(--primary);font-weight:bold;font-size:1.1rem}
.toggle-details-btn{background:var(--primary);border:2px solid var(--primary);border-radius:.5rem;color:var(--secondary);padding:.5rem .75rem;cursor:pointer;transition:all .3s;font-weight:600;font-size:1rem;min-width:44px;display:flex;align-items:center;justify-content:center}
.toggle-details-btn:hover{background:var(--bg2);color:var(--primary);transform:scale(1.1)}
.order-details{border-top:2px solid var(--primary);padding:1rem;background:var(--bg)}
.order-products{margin-bottom:1rem}
.order-details-total{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--primary);color:var(--secondary);border-radius:.5rem;font-weight:bold;font-size:1.1rem;margin-top:1rem}
.order-details-total-label{font-weight:600}
.order-details-total-amount{font-weight:bold;font-size:1.2rem}
.order-product-item{padding:.75rem;margin-bottom:.75rem;border:2px solid var(--primary);border-radius:.5rem;background:var(--bg2);transition:all .3s}
.order-product-item:hover{transform:translateX(5px)}
.order-product-item:last-child{margin-bottom:0}
.order-product-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.product-name{color:var(--primary);font-weight:500}
.product-quantity{color:var(--primary);font-size:.9rem}
.product-price{color:var(--primary);font-weight:bold}
.order-product-notes{font-size:.85rem;color:var(--primary);font-style:italic;margin-top:.5rem;padding:.5rem .75rem;background:var(--bg);border-radius:.5rem;border:2px solid var(--primary);position:relative;padding-left:2rem}
.order-product-notes::before{content:"📝";position:absolute;left:.5rem;top:.45rem;font-style:normal}
.loading-message,.error-message{text-align:center;padding:2rem;margin:1rem;border-radius:.5rem}
.loading-message{background:var(--bg2);border:1px solid var(--primary);color:var(--primary)}
.loading-spinner{width:40px;height:40px;border:4px solid var(--bg2);border-top:4px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
.error-message{background:rgba(231,76,60,.1);border:1px solid #e74c3c;color:#e74c3c}
.error-content{display:flex;flex-direction:column;align-items:center;gap:1rem}
.error-icon{font-size:3rem}
.error-retry-btn{background:#e74c3c;color:white;border:none;padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;font-weight:bold;transition:all .3s}
.error-retry-btn:hover{background:#c0392b;transform:translateY(-2px)}
@media(min-width:768px){.products-grid{grid-template-columns:repeat(3,1fr)}.main-title{font-size:3rem}.slogan-text{font-size:2rem;padding-top:2rem}.cart-actions{flex-direction:row}}
@media(min-width:1024px){.products-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:1.5rem}.navbar-content{padding:1.5rem}}
@media(max-width:480px){.logo-image{max-height:60px}.cart-item-controls{gap:.5rem;padding:.4rem}.quantity-btn,.modal-quantity-btn{width:32px;height:32px;font-size:1rem}.quantity{min-width:35px;font-size:1rem;padding:.4rem}.remove-item-btn{padding:8px 10px;font-size:0.9rem}.modal-close{width:28px;height:28px;font-size:1.2rem}}
.hidden{display:none!important}.visible{display:block!important}.rotate-180{transform:rotate(180deg)!important}
.notification{position:fixed;top:20px;right:20px;background:#4CAF50;color:white;padding:12px 24px;border-radius:8px;z-index:10000;transform:translateX(100%);transition:transform .3s ease;box-shadow:var(--sh);font-weight:500}
.notification.show{transform:translateX(0)}
.edit-notes-content{max-width:450px}
.modal-header{padding:1.5rem 1.5rem 1rem;border-bottom:2px solid var(--primary);background:var(--bgm);border-radius:1rem 1rem 0 0;position:relative}
.modal-header h3{color:var(--primary);margin:0;font-size:1.3rem;text-align:center}
.edit-notes-textarea{width:100%;min-height:100px;padding:.75rem;border:2px solid var(--primary);border-radius:.5rem;background:var(--bg);color:var(--primary);font-size:1rem;resize:vertical;font-family:inherit}
.edit-notes-textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--sh)}
.notes-helper{color:var(--primary);font-size:.8rem;margin-top:.5rem;display:block}
.notes-actions{display:flex;gap:.75rem;margin-top:1rem}
.notes-action-btn{flex:1;padding:.75rem;border-radius:.75rem;font-weight:bold;cursor:pointer;transition:all .3s;border:2px solid;box-shadow:var(--sh)}
.notes-action-btn.primary{background:var(--primary);color:var(--secondary);border-color:var(--primary)}
.notes-action-btn.secondary{background:var(--bg);color:var(--primary);border-color:var(--primary)}
.notes-action-btn:hover{transform:scale(1.05);box-shadow:var(--sh)}
.order-confirmation-content{max-width:500px;max-height:90vh}
.confirmation-header{text-align:center;padding:1rem;border-bottom:2px solid var(--primary)}
.success-icon{width:80px;height:80px;background:#4CAF50;border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-size:2rem}
.success-icon::before{content:"✓";color:white;font-weight:bold}
.confirmation-title{color:var(--primary);font-size:1.25rem;margin:0}
.order-details{padding:1rem}
.detail-section{margin-bottom:1rem}
.detail-section h4{color:var(--primary);font-size:1rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}
.details-content{background:var(--bg2);border-radius:.5rem;padding:.75rem;border:1px solid var(--primary)}
.order-item{display:flex;flex-direction:column;padding:.35rem 0;border-bottom:1px solid var(--primary)}
.order-item:last-child{border-bottom:none}
.order-item-header{display:flex;justify-content:space-between;align-items:center;width:100%}
.item-name{color:var(--primary);font-weight:500}
.item-quantity{color:var(--primary);margin:0 .5rem}
.item-price{color:var(--primary);font-weight:bold}
.order-item-notes{font-size:.85rem;color:var(--primary);font-style:italic;margin-top:.5rem;padding:.5rem .75rem;background:var(--bg);border-radius:.5rem;border:2px solid var(--primary);position:relative;padding-left:2rem}
.order-item-notes::before{content:"📝";position:absolute;left:.5rem;top:.45rem;font-style:normal}
.customer-info-row{display:flex;justify-content:space-between;align-items:center;padding:.35rem 0;border-bottom:1px solid var(--primary)}
.customer-info-row:last-child{border-bottom:none}
.info-label{color:var(--primary);font-weight:500}
.info-value{color:var(--primary);font-weight:bold}
.total-section .details-content{text-align:center}
.total-amount{font-size:1.25rem;font-weight:bold;color:var(--primary)}
.confirmation-footer{padding:1rem;border-top:2px solid var(--primary);text-align:center}
.status-message{color:var(--primary);margin-bottom:.75rem;font-style:italic;font-size:.9rem}
.close-confirmation-btn{background:var(--primary);color:var(--secondary);border:2px solid var(--primary);padding:.65rem 1.5rem;border-radius:.5rem;font-weight:bold;font-size:1rem;cursor:pointer;transition:all .3s}
.close-confirmation-btn:hover{background:var(--bg2);color:var(--primary);border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--sh)}
.confirm-order-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bgo);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:1001}
.confirm-order-modal-content{background:var(--bgm);border:2px solid var(--primary);border-radius:1rem;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 40px rgba(60,16,0,.5)}
.confirm-order-title{color:var(--primary);text-align:center;padding:1.5rem 1.5rem 1rem;margin:0;font-size:1.3rem;border-bottom:2px solid var(--primary)}
.confirm-order-summary{padding:1.5rem;max-height:300px;overflow-y:auto}
.confirm-order-text{background:var(--bg2);color:var(--primary);padding:1rem;border-radius:.5rem;border:1px solid var(--primary);white-space:pre-wrap;font-family:inherit;font-size:.9rem;line-height:1.5;margin:0}
.confirm-order-buttons{display:flex;gap:1rem;padding:1.5rem;border-top:2px solid var(--primary)}
.confirm-order-btn{flex:1;padding:.75rem;border-radius:.75rem;font-weight:bold;cursor:pointer;transition:all .3s;border:2px solid;box-shadow:var(--sh)}
.confirm-order-btn.cancel-btn{background:var(--bg);color:var(--primary);border-color:var(--primary)}
.confirm-order-btn.cancel-btn:hover{background:var(--primary);color:var(--secondary);border-color:var(--primary);transform:scale(1.05)}
.confirm-order-btn.confirm-btn{background:var(--primary);color:var(--secondary);border-color:var(--primary)}
.confirm-order-btn.confirm-btn:hover{background:var(--bg2);color:var(--primary);border-color:var(--primary);transform:scale(1.05)}
.no-animation{animation:none!important}
.animate-header-title{animation:ht 4s ease-in-out forwards!important}
.animate-header-slogan{animation:hs 4s ease-in-out forwards!important}
.click-icon{position:absolute;bottom:.5rem;right:.5rem;background:var(--primary);border-radius:50%;padding:.5rem;display:flex;align-items:center;justify-content:center;opacity:.8;transition:all .3s}
.click-icon:hover{opacity:1;transform:scale(1.1)}
.click-icon svg{width:20px;height:20px}

/* Pantalla de introducción */
.intro-screen{position:fixed;top:0;left:0;width:100%;height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .8s ease-out,visibility .8s ease-out}
.intro-screen.fade-out{opacity:0;visibility:hidden}
.intro-content{text-align:center;max-width:90%;padding:2rem}
.intro-logo{opacity:0;transform:translateY(30px) scale(0.8);animation:introLogoAnim 2s ease-out forwards}
.intro-logo-image{max-height:300px;max-width:100%;object-fit:contain}
.intro-title{color:var(--primary);font-size:3rem;font-weight:900;margin:1rem 0;opacity:0;transform:translateY(30px) scale(0.8);animation:introTitleAnim 2s ease-out forwards;animation-delay:.8s}
.intro-slogan{color:var(--primary);font-size:1.8rem;font-weight:600;margin:1rem 0;opacity:0;transform:translateY(30px) scale(0.8);animation:introSloganAnim 2s ease-out forwards;animation-delay:2.8s;font-style:italic}

/* Animaciones de introducción */
@keyframes introLogoAnim{0%{opacity:0;transform:translateY(30px) scale(0.8)}20%{opacity:1;transform:translateY(0) scale(1.1)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes introTitleAnim{0%{opacity:0;transform:translateY(30px) scale(0.8)}20%{opacity:1;transform:translateY(0) scale(1.1)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes introSloganAnim{0%{opacity:0;transform:translateY(30px) scale(0.8)}20%{opacity:1;transform:translateY(0) scale(1.05)}60%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:1;transform:translateY(0) scale(1)}}

/* Estilos para notificaciones */
.notification {
    position: fixed;
    top: 80px;
    right: 10px;
    left: 10px;
    background: var(--primary);
    color: var(--secondary);
    padding: 16px;
    border-radius: 8px;
    z-index: 10000;
    transform: translateX(100%);
    transition: transform 0.3s ease;
    box-shadow: var(--sh);
    font-weight: 500;
    border: 2px solid var(--primary);
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-width: 200px;
    margin: 10px;
}

.notification-close-btn {
    background: var(--bg);
    border: 2px solid var(--primary);
    color: var(--primary);
    cursor: pointer;
    width: 32px;
    height: 32px;
    font-size: 1.4rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: all 0.2s ease;
    box-shadow: var(--sh);
    flex-shrink: 0;
}

.notification-close-btn:hover {
    background: var(--primary);
    color: var(--secondary);
    border-color: var(--primary);
    box-shadow: var(--sh);
    transform: scale(1.1);
}

.notification-close-btn i[class^="bi-"],
.notification-close-btn i[class*=" bi-"] {
    font-size: 24px !important;
}

/* Cantidad de toppings centrada */
.modal-topping-quantity {
    appearance: textfield;
    -moz-appearance: textfield;
    width: 34px;
    height: 28px;
    text-align: center;
    padding: 0;
    margin: 0;
    line-height: 28px;
    font-weight: 700;
    border: none;
    background: transparent;
    color: inherit;
}

.modal-topping-quantity::-webkit-outer-spin-button,
.modal-topping-quantity::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
