:root{--primary-orange:#ff6b35;--secondary-red:#f7931e;--accent-pink:#ff8a95;--dark:#1a1a2e;--dark-soft:#2d2d44;--surface:#fafaf8;--surface-warm:#fff8f5;--border-subtle:rgba(255,107,53,0.12);--shadow-sm:0 2px 8px rgba(26,26,46,0.06);--shadow-md:0 8px 30px rgba(26,26,46,0.1);--shadow-lg:0 20px 60px rgba(26,26,46,0.12);--shadow-orange:0 8px 30px rgba(255,107,53,0.25);--radius-sm:12px;--radius-md:20px;--radius-lg:28px;--radius-xl:40px;--green:#22c55e}
*,*::before,*::after{box-sizing:border-box}
body{font-family:'DM Sans',-apple-system,sans-serif;margin:0;padding:0;overflow-x:hidden;color:var(--dark);background:var(--surface);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5,h6{font-family:'Sora',sans-serif}

/* HERO */
.hero-section{min-height:100vh;min-height:100dvh;background:var(--dark);position:relative;display:flex;flex-direction:column;color:white;overflow:hidden}
.hero-section::before{content:'';position:absolute;top:-20%;right:-20%;width:80%;height:80%;background:radial-gradient(circle,rgba(255,107,53,0.4) 0%,transparent 60%);filter:blur(80px);z-index:0;animation:mf1 8s ease-in-out infinite}
.hero-section::after{content:'';position:absolute;bottom:-10%;left:-15%;width:60%;height:60%;background:radial-gradient(circle,rgba(247,147,30,0.3) 0%,transparent 60%);filter:blur(80px);z-index:0;animation:mf2 10s ease-in-out infinite}
@keyframes mf1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,20px) scale(1.1)}}
@keyframes mf2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-30px) scale(1.05)}}
.floating-circles{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:1}
.floating-circle{position:absolute;border-radius:50%;border:1px solid rgba(255,107,53,0.15);background:transparent;animation:fo 8s ease-in-out infinite}
.floating-circle:nth-child(1){width:200px;height:200px;top:15%;left:5%}
.floating-circle:nth-child(2){width:300px;height:300px;top:50%;left:75%;animation-delay:2s;border-color:rgba(255,138,149,0.1)}
.floating-circle:nth-child(3){width:150px;height:150px;top:75%;left:15%;animation-delay:4s}
.floating-circle:nth-child(4){width:250px;height:250px;top:25%;left:65%;animation-delay:1s;border-color:rgba(247,147,30,0.12)}
.floating-circle:nth-child(5){width:180px;height:180px;top:60%;left:50%;animation-delay:3s}
@keyframes fo{0%,100%{transform:translateY(0) rotate(0);opacity:.5}50%{transform:translateY(-30px) rotate(180deg);opacity:1}}
.content-wrapper{position:relative;z-index:2;flex:1;display:flex;flex-direction:column}
.logo-section{text-align:center;padding:70px 0 30px}
.logo-circle{width:100px;height:100px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));display:inline-flex;align-items:center;justify-content:center;margin-bottom:28px;animation:lp 3s ease-in-out infinite;box-shadow:var(--shadow-orange),inset 0 1px 0 rgba(255,255,255,0.2);position:relative}
.logo-circle::after{content:'';position:absolute;inset:-6px;border-radius:34px;border:1px solid rgba(255,107,53,0.3);animation:lp 3s ease-in-out infinite reverse}
@keyframes lp{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}
.logo-icon{font-size:48px;color:white;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.2))}
.main-title{font-size:clamp(2.2rem,6vw,3.2rem);font-weight:800;margin-bottom:12px;letter-spacing:-0.03em;line-height:1.1}
.main-title .highlight{background:linear-gradient(135deg,var(--primary-orange),var(--accent-pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.subtitle{font-size:1.1rem;opacity:.6;margin-bottom:0;font-weight:400}
.features-carousel{flex:1;display:flex;align-items:center;padding:30px 0}
.feature-card{text-align:center;padding:40px 24px;height:260px;display:flex;flex-direction:column;justify-content:center}
.feature-icon-wrap{width:72px;height:72px;border-radius:22px;background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));display:inline-flex;align-items:center;justify-content:center;margin:0 auto 24px;box-shadow:var(--shadow-orange)}
.feature-icon{font-size:2rem;color:white}
.feature-title{font-size:1.4rem;font-weight:700;margin-bottom:12px;letter-spacing:-0.02em}
.feature-description{font-size:.95rem;opacity:.55;line-height:1.6;max-width:320px;margin:0 auto}
.action-buttons{padding:30px 0}
.btn-primary-custom{background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));color:white;border:none;padding:18px 28px;font-size:1rem;font-weight:600;border-radius:var(--radius-md);box-shadow:var(--shadow-orange);transition:all .4s cubic-bezier(.16,1,.3,1);width:100%;margin-bottom:14px;min-height:76px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Sora',sans-serif;position:relative;overflow:hidden}
.btn-primary-custom::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);opacity:0;transition:opacity .3s}
.btn-primary-custom:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(255,107,53,0.4);color:white}
.btn-primary-custom:hover::before{opacity:1}
.btn-secondary-custom{background:rgba(255,255,255,0.05);color:white;border:1px solid rgba(255,255,255,0.12);padding:18px 28px;font-size:1rem;font-weight:500;border-radius:var(--radius-md);backdrop-filter:blur(20px);transition:all .4s cubic-bezier(.16,1,.3,1);width:100%;min-height:76px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Sora',sans-serif}
.btn-secondary-custom:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,107,53,0.4);transform:translateY(-3px);color:white}
.footer-stats{text-align:center;padding:24px 0 40px}
.stats-text{font-size:.85rem;opacity:.4;margin-bottom:16px;font-weight:500;text-transform:uppercase;letter-spacing:.08em}
.stats-logos{display:flex;justify-content:center;gap:12px}.stat-logo{width:48px;height:16px;background:rgba(255,255,255,0.15);border-radius:4px}
.carousel-indicators{bottom:-40px}
.carousel-indicators button{width:8px;height:8px;border-radius:50%;border:none;background:rgba(255,255,255,0.2);transition:all .3s}
.carousel-indicators button.active{background:var(--primary-orange);width:28px;border-radius:4px}
.animate-on-scroll{opacity:0;transform:translateY(24px);transition:all .8s cubic-bezier(.16,1,.3,1)}
.animate-on-scroll.visible{opacity:1;transform:translateY(0)}

/* MODALS */
.modal-content{border-radius:var(--radius-lg);border:none;overflow:hidden;box-shadow:var(--shadow-lg)}
.modal-header{background:var(--dark);color:white;border:none;padding:28px 30px;position:relative;overflow:hidden}
.modal-header::before{content:'';position:absolute;top:-50%;right:-20%;width:60%;height:200%;background:radial-gradient(circle,rgba(255,107,53,0.3) 0%,transparent 60%);filter:blur(40px)}
.modal-header .modal-title{position:relative;z-index:1;font-family:'Sora',sans-serif;font-weight:700}
.btn-close{filter:brightness(0) invert(1)}
.feature-benefit{display:flex;align-items:center;padding:16px 0;border-bottom:1px solid var(--border-subtle)}.feature-benefit:last-child{border-bottom:none}
.benefit-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));border-radius:14px;display:flex;align-items:center;justify-content:center;color:white;margin-right:16px;flex-shrink:0;box-shadow:0 4px 12px rgba(255,107,53,0.2)}
.qr-scanner-placeholder{width:200px;height:200px;background:var(--surface-warm);border:2px dashed rgba(255,107,53,0.3);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin:30px auto;position:relative;overflow:hidden}
.qr-scanner-placeholder::before{content:'';position:absolute;top:10px;left:10px;right:10px;height:3px;background:linear-gradient(90deg,transparent,var(--primary-orange),transparent);animation:scan 2s linear infinite;border-radius:2px}
@keyframes scan{0%{transform:translateY(0);opacity:1}100%{transform:translateY(180px);opacity:0}}
.btn-download-app{background:var(--dark);color:white;border:none;padding:16px 28px;border-radius:var(--radius-md);font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;box-shadow:var(--shadow-md);transition:all .4s cubic-bezier(.16,1,.3,1);width:100%;margin-top:8px}
.btn-download-app:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);background:var(--dark-soft);color:white}
.btn-download-app i{margin-right:10px;font-size:1.1rem}
.btn-download-app.google-play{background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red))}
.btn-download-app.google-play:hover{box-shadow:var(--shadow-orange);color:white}
.promo-badge{background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));color:white;padding:6px 18px;border-radius:var(--radius-xl);font-weight:700;font-size:.8rem;display:inline-block;margin-top:12px;letter-spacing:.03em;font-family:'Sora',sans-serif}

/* MENU SECTION */
.menu-section{background:var(--surface);min-height:100vh;padding:0 0 120px}

/* HERO HEADER CAROUSEL - Safari iOS + Chrome iOS Fix */
.hero-header-container{
    position:relative;
    width:100%;
    height:250px;
    overflow:hidden;
    margin-bottom:-40px;
    z-index:1;
    background-color:#1a1a2e;
    /* iOS Chrome/Safari GPU acceleration fix */
    -webkit-transform:translateZ(0);
    transform:translateZ(0);
    -webkit-backface-visibility:hidden;
    backface-visibility:hidden
}
.hero-carousel-bg{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background-color:#1a1a2e;
    /* iOS Chrome fix - force layer creation */
    -webkit-transform:translateZ(0);
    transform:translateZ(0)
}
.hero-carousel-image{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    object-fit:cover;
    opacity:0;
    transition:opacity 1s ease;
    /* iOS Chrome/Safari image rendering fix */
    -webkit-transform:translateZ(0);
    transform:translateZ(0);
    -webkit-backface-visibility:hidden;
    backface-visibility:hidden;
    /* Prevent iOS image stretching */
    -webkit-user-drag:none;
    user-drag:none
}
.hero-carousel-image.active{opacity:1}
.hero-carousel-indicators{position:absolute;bottom:16px;left:0;right:0;display:flex;justify-content:center;z-index:2}
.hero-carousel-dot{width:8px;height:8px;border-radius:50%;background-color:rgba(255,255,255,0.4);transition:all 0.3s;cursor:pointer;border:none;padding:0;margin:0 4px}
.hero-carousel-dot.active{background-color:#ff6b35;width:24px;border-radius:4px}
.hero-floating-card{position:relative;background-color:white;border-radius:24px;margin:-40px 16px 0;padding:20px;box-shadow:0 8px 30px rgba(26,26,46,0.15);z-index:2}
@keyframes floatCardSlideUp{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}
.hero-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.hero-card-info{flex:1;min-width:0}
.hero-card-name{font-family:'Sora',sans-serif;font-size:1.4rem;font-weight:700;color:var(--dark);margin:0 0 4px;letter-spacing:-0.02em;animation:fadeInContent 0.5s ease 0.4s backwards}
.hero-card-meta{font-size:0.9rem;color:#666;margin-bottom:8px;animation:fadeInContent 0.5s ease 0.5s backwards}
.hero-card-rating{display:flex;align-items:center;gap:6px;font-size:0.9rem;animation:fadeInContent 0.5s ease 0.6s backwards}
.hero-card-rating i{color:#FFD700;font-size:1rem}
.hero-card-rating-value{font-weight:700;color:var(--dark)}
.hero-card-rating-count{color:#999}
.hero-card-logo{width:64px;height:64px;border-radius:16px;object-fit:cover;border:3px solid rgba(255,107,53,0.15);box-shadow:0 4px 15px rgba(0,0,0,0.1);flex-shrink:0;animation:logoScale 0.5s cubic-bezier(0.16,1,0.3,1) 0.5s backwards}
@keyframes logoScale{0%{opacity:0;transform:scale(0.8)}100%{opacity:1;transform:scale(1)}}
@keyframes fadeInContent{0%{opacity:0;transform:translateY(8px)}100%{opacity:1;transform:translateY(0)}}
.hero-card-mesa{background:var(--surface-warm);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:8px 12px;margin-top:12px;text-align:center;font-size:0.88rem;color:#666;animation:fadeInContent 0.5s ease 0.7s backwards}
.hero-card-mesa i{color:var(--primary-orange);margin-right:6px}
.hero-card-mesa strong{color:var(--dark);font-family:'Sora',sans-serif}

.menu-header{background:var(--dark);color:white;padding:24px 0;margin-bottom:32px;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.menu-header::after{content:'';position:absolute;top:-30%;right:-10%;width:50%;height:160%;background:radial-gradient(circle,rgba(255,107,53,0.25) 0%,transparent 60%);filter:blur(50px);pointer-events:none}
.menu-header h2{font-weight:700;margin-bottom:4px;letter-spacing:-0.02em}
.search-filter-bar{background:white;padding:20px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border-subtle)}
.search-box{position:relative}.search-box i{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:#aaa;font-size:1rem}
.search-box input{padding-left:46px;border-radius:var(--radius-xl);border:2px solid #eee;height:48px;transition:all .3s;font-family:'DM Sans',sans-serif;font-size:.95rem}
.search-box input:focus{border-color:var(--primary-orange);box-shadow:0 0 0 4px rgba(255,107,53,0.08)}
.search-box input::placeholder{color:#bbb}
.btn-filter{background:white;border:2px solid #eee;border-radius:var(--radius-xl);padding:10px 20px;font-weight:600;font-family:'DM Sans',sans-serif;transition:all .3s;white-space:nowrap;font-size:.9rem}
.btn-filter:hover,.btn-filter.active{background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));color:white;border-color:var(--primary-orange)}
.allergen-accordion .accordion-item{border:0;background:transparent}
.allergen-accordion .accordion-button{background:white;border:1px solid var(--primary-orange);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:16px 20px;font-family:'Sora',sans-serif;font-weight:700;color:var(--dark)}
.allergen-accordion .accordion-button:not(.collapsed){background:white;color:var(--dark);box-shadow:var(--shadow-sm)}
.allergen-accordion .accordion-button:focus{box-shadow:0 0 0 4px rgba(255,107,53,0.12);border-color:var(--primary-orange)}
.allergen-accordion .accordion-button::after{display:none}
.allergen-accordion-button{display:flex;align-items:center;gap:12px}
.allergen-accordion-state{margin-left:auto;font-size:.82rem;font-weight:600;color:var(--primary-orange)}
.allergen-accordion-chevron{font-size:1rem;transition:transform .2s ease}
.allergen-accordion-button[aria-expanded="true"] .allergen-accordion-chevron{transform:rotate(180deg)}
.allergen-filters{background:white;padding:20px;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--primary-orange)}
.allergen-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-xl);border:2px solid #eee;background:white;color:#888;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);user-select:none}
.allergen-chip:hover{border-color:var(--primary-orange);background:var(--surface-warm);transform:translateY(-2px)}
.allergen-chip.active{border-color:var(--primary-orange);background:var(--surface-warm);color:var(--primary-orange);box-shadow:0 4px 15px rgba(255,107,53,0.2)}
.allergen-chip .allergen-icon{font-size:1.1rem;line-height:1}
.allergen-chip.active .allergen-icon{animation:shake .5s ease}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.category-section{margin-bottom:28px}
/* ── Category Chips Bar ─────────────────────────────── */
.category-chips-bar{overflow:hidden}
.category-chips-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 2px 8px;scrollbar-width:none;-ms-overflow-style:none}
.category-chips-scroll::-webkit-scrollbar{display:none}
.category-chip-btn{flex-shrink:0;display:inline-flex;align-items:center;padding:8px 18px;border-radius:var(--radius-xl);border:2px solid #eee;background:#fff;color:#666;font-size:.85rem;font-weight:600;font-family:'Sora',sans-serif;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);white-space:nowrap;user-select:none}
.category-chip-btn:hover{border-color:var(--primary-orange);background:var(--surface-warm);color:var(--primary-orange);transform:translateY(-1px)}
.category-chip-btn.active{border-color:var(--primary-orange);background:var(--primary-orange);color:#fff;box-shadow:0 4px 14px rgba(255,107,53,.3)}
.category-header{background:var(--dark);color:white;padding:14px 24px;border-radius:var(--radius-md) var(--radius-md) 0 0;font-family:'Sora',sans-serif;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;position:relative;overflow:hidden}
.category-header::after{content:'';position:absolute;right:0;top:0;bottom:0;width:120px;background:linear-gradient(90deg,transparent,rgba(255,107,53,0.3));pointer-events:none}
.products-horizontal-scroll{display:flex;overflow-x:auto;overflow-y:hidden;gap:16px;padding:20px;background:white;border-radius:0 0 var(--radius-md) var(--radius-md);box-shadow:var(--shadow-sm);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;border:1px solid var(--border-subtle);border-top:none}
.products-horizontal-scroll::-webkit-scrollbar{height:6px}
.products-horizontal-scroll::-webkit-scrollbar-thumb{background:linear-gradient(90deg,var(--primary-orange),var(--secondary-red));border-radius:10px}
.product-card-horizontal{flex:0 0 260px;background:white;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .4s cubic-bezier(.16,1,.3,1);border:1px solid #f0f0f0;position:relative;cursor:pointer;-webkit-tap-highlight-color:rgba(255,107,53,0.08)}
.product-card-horizontal *{cursor:pointer}
.product-card-horizontal:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(255,107,53,0.2)}
.product-card-horizontal:hover .product-card-title{color:var(--primary-orange)}
.product-card-horizontal .product-card-image{transition:transform .35s cubic-bezier(.16,1,.3,1)}
.product-card-horizontal:hover .product-card-image{transform:scale(1.03)}
.product-card-horizontal.in-cart{border-color:var(--green)}
.product-card-horizontal.in-cart .btn-add-to-cart{background:var(--green)}
.product-card-image{width:100%;height:170px;object-fit:cover;background:var(--surface)}
.product-card-content{padding:16px}
.product-card-title{font-family:'Sora',sans-serif;font-size:1rem;font-weight:700;color:var(--dark);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:48px;letter-spacing:-0.01em}
.product-card-description{font-size:.82rem;color:#999;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px;line-height:1.5}
.product-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid #f5f5f5}
.product-card-price{font-family:'Sora',sans-serif;font-size:1.25rem;font-weight:800;background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.product-allergen-badge{background:var(--surface-warm);color:var(--primary-orange);padding:4px 10px;border-radius:8px;font-size:.72rem;font-weight:600;display:inline-flex;align-items:center;gap:4px;border:1px solid var(--border-subtle)}
.btn-add-to-cart{width:auto;background:var(--dark);color:white;border:none;padding:10px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;transition:all .3s}
.btn-add-to-cart:hover{background:var(--primary-orange);transform:scale(1.05)}
.cart-added-feedback{position:absolute;top:10px;right:10px;background:var(--green);color:white;padding:6px 14px;border-radius:var(--radius-xl);font-size:.78rem;font-weight:700;font-family:'Sora',sans-serif;opacity:0;transform:translateY(-8px) scale(0.9);transition:all .35s cubic-bezier(.16,1,.3,1);pointer-events:none;z-index:5;box-shadow:0 4px 12px rgba(34,197,94,0.3)}
.cart-added-feedback.show{opacity:1;transform:translateY(0) scale(1)}

/* FLOATING CART */
.floating-cart{position:fixed;bottom:0;left:0;right:0;background:var(--dark);color:white;z-index:999;transform:translateY(100%);transition:transform .5s cubic-bezier(.16,1,.3,1);box-shadow:0 -8px 40px rgba(26,26,46,0.3);border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.floating-cart.visible{transform:translateY(0)}
.floating-cart-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;max-width:600px;margin:0 auto}
.cart-summary{display:flex;align-items:center;gap:14px;flex:1;min-width:0;cursor:pointer}
.cart-badge-count{background:var(--primary-orange);color:white;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-family:'Sora',sans-serif;font-weight:800;font-size:.95rem;flex-shrink:0;box-shadow:0 4px 12px rgba(255,107,53,0.3)}
.cart-info{min-width:0}
.cart-items-label{font-size:.82rem;opacity:.6}
.cart-total{font-family:'Sora',sans-serif;font-size:1.2rem;font-weight:800;letter-spacing:-0.02em}
.btn-confirm-order{background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));color:white;border:none;padding:14px 28px;border-radius:var(--radius-md);font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;white-space:nowrap;box-shadow:var(--shadow-orange);transition:all .3s;display:flex;align-items:center;gap:8px}
.btn-confirm-order:hover{transform:scale(1.03);box-shadow:0 12px 35px rgba(255,107,53,0.4)}
.cart-details-panel{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.16,1,.3,1);border-top:1px solid rgba(255,255,255,0.08)}
.cart-details-panel.expanded{max-height:400px;overflow-y:auto}
.cart-details-inner{padding:16px 24px;max-width:600px;margin:0 auto}
.cart-item-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,0.06);font-size:.9rem}
.cart-item-row:last-child{border-bottom:none}
.cart-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:12px}
.cart-item-qty{display:flex;align-items:center;gap:10px;margin-right:16px}
.cart-item-qty button{background:rgba(255,255,255,0.1);border:none;color:white;width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:background .2s}
.cart-item-qty button:hover{background:var(--primary-orange)}
.cart-item-qty span{font-family:'Sora',sans-serif;font-weight:700;min-width:20px;text-align:center}
.cart-item-price{font-family:'Sora',sans-serif;font-weight:700;color:var(--primary-orange);white-space:nowrap}
.back-to-landing{position:fixed;top:16px;left:16px;background:var(--dark);color:white;padding:10px 20px;border-radius:var(--radius-xl);font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow-md);transition:all .3s;z-index:1000;font-family:'DM Sans',sans-serif;font-size:.9rem;border:1px solid rgba(255,255,255,0.1)}
.back-to-landing:hover{background:var(--primary-orange);color:white;transform:translateY(-2px)}

/* CHECKOUT MODAL — TWO ZONES */
.checkout-modal .modal-header{background:var(--dark);text-align:center;padding:32px;position:relative;overflow:hidden}
.checkout-modal .modal-header::before{content:'';position:absolute;top:-40%;right:-20%;width:60%;height:180%;background:radial-gradient(circle,rgba(34,197,94,0.25) 0%,transparent 60%);filter:blur(40px)}
.checkout-order-summary{background:var(--surface);border-radius:var(--radius-md);padding:20px;margin-bottom:20px;border:1px solid var(--border-subtle)}
.checkout-item{display:flex;justify-content:space-between;padding:8px 0;font-size:.9rem}
.checkout-item-name{color:#666}.checkout-item-price{font-family:'Sora',sans-serif;font-weight:700;color:var(--dark)}
.checkout-total{display:flex;justify-content:space-between;padding-top:14px;margin-top:10px;border-top:2px solid var(--primary-orange);font-family:'Sora',sans-serif;font-weight:800;font-size:1.2rem;color:var(--dark)}
/* Call waiter CTA — eliminado */
.mesa-reminder{background:var(--surface-warm);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:12px 16px;text-align:center;font-size:.88rem;color:#666;margin-top:12px}
.mesa-reminder strong{color:var(--dark);font-family:'Sora',sans-serif}
/* Divider */
.checkout-divider{position:relative;text-align:center;margin:28px 0 24px;border-top:1px solid #eee}
.checkout-divider span{position:relative;top:-12px;background:white;padding:0 16px;font-size:.8rem;color:#aaa;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
/* App upgrade zone */
.app-upgrade-zone{background:var(--surface);border-radius:var(--radius-md);padding:24px;border:1px solid var(--border-subtle)}
.app-upgrade-zone h6{font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;color:var(--dark);margin-bottom:16px;text-align:center}
.upgrade-feature{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:.88rem;color:#555}
.upgrade-feature i{color:var(--primary-orange);font-size:1.1rem;flex-shrink:0;width:20px;text-align:center}
.upgrade-feature strong{color:var(--dark)}
.upgrade-disclaimer{font-size:.78rem;color:#999;text-align:center;margin:12px 0 4px;font-style:italic}
.app-buttons-subtle{margin-top:20px}
.app-buttons-cta{font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;color:var(--dark);text-align:center;margin-bottom:0;display:block;width:100%}
.app-buttons-row{display:flex;flex-direction:column;gap:10px}
.app-buttons-subtle a{background:var(--dark);color:white;border:none;padding:14px 16px;border-radius:var(--radius-sm);font-family:'Sora',sans-serif;font-weight:600;font-size:.9rem;text-align:center;text-decoration:none;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px}
.app-buttons-subtle a:hover{background:var(--dark-soft);color:white;transform:translateY(-2px)}
.app-buttons-subtle a.gplay{background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red))}
.app-buttons-subtle a.gplay:hover{box-shadow:var(--shadow-orange);color:white}


/* PRODUCT DETAIL MODAL */
.product-detail-modal .modal-dialog{max-width:540px}
.pd-modal-content{border-radius:var(--radius-lg);overflow:hidden;border:none;box-shadow:var(--shadow-lg)}
.pd-hero{position:relative;width:100%;height:280px;background:var(--dark);overflow:hidden;flex-shrink:0}
.pd-hero-image{width:100%;height:100%;object-fit:cover;display:block}
.pd-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(26,26,46,0.55) 100%)}
.pd-close-btn{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(26,26,46,0.65);backdrop-filter:blur(8px);border:none;color:white;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:all .2s;z-index:5}
.pd-close-btn:hover{background:var(--primary-orange);transform:scale(1.08)}
.pd-body{padding:24px 24px 28px;background:white}
.pd-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.pd-name{font-family:'Sora',sans-serif;font-size:1.35rem;font-weight:800;color:var(--dark);margin:0;letter-spacing:-0.02em;flex:1;line-height:1.3}
.pd-price{font-family:'Sora',sans-serif;font-size:1.45rem;font-weight:800;background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;flex-shrink:0}
.pd-description{font-size:.93rem;color:#666;line-height:1.65;margin-bottom:18px}
.pd-allergen-section{background:var(--surface-warm);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:20px}
.pd-allergen-title{font-family:'Sora',sans-serif;font-size:.82rem;font-weight:700;color:var(--primary-orange);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.pd-allergen-pills{display:flex;flex-wrap:wrap;gap:8px}
.detail-allergen-pill{background:white;border:1.5px solid var(--border-subtle);border-radius:var(--radius-xl);padding:5px 12px;font-size:.8rem;font-weight:600;color:var(--dark);display:inline-flex;align-items:center;gap:5px}
.pd-add-btn{width:100%;background:linear-gradient(135deg,var(--primary-orange),var(--secondary-red));color:white;border:none;padding:18px 28px;border-radius:var(--radius-md);font-family:'Sora',sans-serif;font-weight:700;font-size:1rem;box-shadow:var(--shadow-orange);transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;justify-content:center}
.pd-add-btn:hover{transform:translateY(-2px);box-shadow:0 12px 35px rgba(255,107,53,0.4);color:white}
.pd-add-btn.added{background:linear-gradient(135deg,var(--green),#16a34a);box-shadow:0 8px 25px rgba(34,197,94,0.35)}
/* tap hint on cards */

@media(max-width:768px){
  .pd-hero{height:220px}
  .pd-name{font-size:1.15rem}
  .pd-price{font-size:1.25rem}
  .product-detail-modal .modal-dialog{margin:0;position:fixed;bottom:0;left:0;right:0;max-width:100%}
  .pd-modal-content{border-radius:var(--radius-lg) var(--radius-lg) 0 0}
  .main-title{font-size:2rem}.logo-circle{width:84px;height:84px;border-radius:24px}.logo-circle::after{border-radius:30px;inset:-5px}.logo-icon{font-size:40px}.product-card-horizontal{flex:0 0 230px}.category-header{font-size:.9rem;padding:12px 18px}.back-to-landing{top:10px;left:10px;padding:8px 14px;font-size:.82rem}.floating-cart-inner{padding:14px 18px}.btn-confirm-order{padding:12px 20px;font-size:.88rem}.cart-total{font-size:1.05rem}
  .hero-header-container{margin-bottom:-36px;height:200px}.hero-floating-card{margin:-36px 12px 0;padding:16px}.hero-card-name{font-size:1.2rem}.hero-card-logo{width:56px;height:56px;border-radius:14px}.hero-carousel-indicators{bottom:12px}.hero-carousel-dot{width:6px;height:6px;margin:0 3px}.hero-carousel-dot.active{width:20px}
}

