*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #fb923c;--primary-dark: #ea580c;--accent: #fdba74;--bg: #fff7ed;--white: #fff;--text: #1c1917;--muted: #78716c;--border: #e7e5e4}body.dark{--bg: #1a1a1a;--white: #2d2d2d;--text: #e5e5e5;--muted: #a3a3a3;--border: #404040}body.dark .cart-footer{background:var(--white)!important;border-top:1px solid var(--border)}body.dark .cart-total,body.dark .cart-total span{color:var(--text)}body.dark .checkout-btn{background:var(--primary);color:var(--white)}body{font-family:Quicksand,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:16px;line-height:1.5;font-weight:500}body.theme-transitioning,body.theme-transitioning *{transition:background-color .8s ease,color .5s ease,border-color .5s ease!important}body.theme-transitioning:before{content:"";position:fixed;top:50px;right:60px;width:10px;height:10px;background:var(--bg);z-index:9999;border-radius:50%;animation:expandCircle .8s ease forwards;pointer-events:none}@keyframes expandCircle{0%{transform:scale(1);opacity:1}to{transform:scale(300);opacity:0}}.app{min-height:100vh}header{background:var(--white);position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #00000014}.main-nav{padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:60px}.theme-switch{width:44px;height:24px;flex-shrink:0;background:var(--white);border-radius:12px;padding:.5rem;text-align:center;box-shadow:0 2px 8px #0000000f;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;position:relative;contain:layout style paint;will-change:transform}.loading-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;width:100%}button:disabled{opacity:.6;cursor:not-allowed}button:disabled:hover{transform:none;box-shadow:none}button .spinner{margin-right:.5rem}.product-skeleton{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.info-bar{background:var(--primary);padding:.5rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.75rem}@media(min-width:600px){.info-bar{flex-direction:row;justify-content:center;gap:1.5rem;font-size:.85rem}}.info-link{color:var(--white);text-decoration:none;font-weight:700;display:flex;align-items:center;gap:.3rem;background:#ffffff26;padding:.4rem .85rem;border-radius:20px;transition:all .2s;white-space:nowrap}.info-link:first-child{animation:blink 1.5s infinite}.info-link:hover{background:#ffffff4d;animation:none}.link-arrow{font-size:1rem;transition:transform .2s}.info-link:hover .link-arrow{transform:translate(3px)}.store-status{font-weight:700;padding:.4rem .85rem;border-radius:20px;font-size:.85rem;white-space:nowrap;display:inline-block}.store-status.open{background:#dcfce7;color:#166534}.store-status.closed{background:#fee2e2;color:#dc2626;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.status-bar{background:var(--bg);padding:.5rem;text-align:center;border-bottom:1px solid var(--border)}@media(max-width:768px){.add-btn,.checkout-btn,.confirm-btn{min-height:44px;padding:.75rem 1rem;font-size:1rem}.cat-btn{min-height:40px;padding:.5rem 1rem}.qty-control button{width:36px;height:36px;font-size:1.2rem}.cart-btn{min-height:44px;padding:.75rem 1rem}.theme-switch{width:50px;height:28px}.theme-switch .slider:before{width:22px;height:22px;font-size:12px}.cart-footer{position:fixed!important;bottom:0!important;left:0!important;right:0!important;z-index:1000!important;background:#fff!important;border-top:1px solid #e5e7eb!important;box-shadow:0 -4px 20px #00000026!important;padding:1rem!important}.checkout-btn{width:100%!important;min-height:50px!important;font-size:1.1rem!important;font-weight:700!important;background:#f97316!important;border-radius:12px!important;box-shadow:0 4px 12px #f973164d!important}body{padding-bottom:100px!important}.cart-items{padding-bottom:120px!important;max-height:calc(100vh - 180px)!important;overflow-y:auto!important}}@media(min-width:768px){.main-nav{padding:.75rem 3rem}.logo-icon{font-size:2.5rem}.logo-name{font-size:1.5rem}.logo-tagline{font-size:.7rem}.nav-links{display:flex;gap:2rem}.nav-links a{font-size:1rem}.cart-btn{padding:.7rem 1.2rem}.cart-icon-btn{font-size:1.3rem}.info-bar{padding:.7rem 3rem;font-size:1rem;gap:2rem}.info-link{padding:.5rem 1rem}.status-bar{padding:.6rem}.store-status{font-size:.95rem;padding:.5rem 1rem}.new-slider{max-width:1200px;margin:0 auto}.slider-container{height:260px}.slide{padding:1.5rem 2rem;gap:2rem}.slide img{width:200px;height:200px}.slide-info h3{font-size:1.6rem}.slide-info p{font-size:1.4rem}.slide-info button{padding:.8rem 1.8rem;font-size:1rem}.products-section{padding:2.5rem 2rem;max-width:1400px;margin:0 auto}.products-section h2{font-size:1.8rem;margin-bottom:1.5rem}.categories{gap:.75rem;top:110px;justify-content:center}.cat-btn{padding:.6rem 1.5rem;font-size:.95rem}.products{grid-template-columns:repeat(3,1fr);gap:1.5rem}.product-card{padding:1rem;border-radius:16px;min-height:340px}.product-img{border-radius:12px}.product-card h3{font-size:1rem;height:auto;min-height:2.2rem}.product-card .ingredients{height:auto;min-height:2.2rem}.price{font-size:1.1rem}.add-btn{padding:.75rem;font-size:.95rem}footer{padding:2rem;font-size:1rem}.cart-overlay{justify-content:flex-end}.cart{max-width:420px;width:420px;height:100vh;border-radius:0;animation:slideLeft .3s ease}@keyframes slideLeft{0%{transform:translate(100%)}to{transform:translate(0)}}.cart-footer{position:relative!important;box-shadow:none!important}.cart-items{padding-bottom:1rem!important;max-height:none!important}body{padding-bottom:0!important}.modal-overlay{align-items:center;padding:1rem}.modal{border-radius:16px;max-height:85vh}}@media(min-width:1024px){.main-nav{padding:1rem 3rem;max-width:1400px;margin:0 auto}.info-bar{padding:.6rem 3rem}.new-slider{max-width:1200px;margin:1.5rem auto;border-radius:16px;overflow:hidden}.slider-container{height:280px}.slide{padding:2rem 3rem;gap:2rem}.slide img{width:220px;height:220px;border-radius:12px}.slide-info h3{font-size:1.8rem}.slide-info p{font-size:1.4rem}.slide-info button{padding:.8rem 2rem;font-size:1rem}.products-section{padding:2rem 3rem;max-width:1400px;margin:0 auto}.products-section h2{font-size:1.6rem;margin-bottom:1.5rem}.categories{justify-content:center;gap:.75rem;margin-bottom:1.5rem;position:relative;top:0}.cat-btn{padding:.6rem 1.5rem;font-size:.95rem}.products{grid-template-columns:repeat(4,1fr)!important;gap:1.5rem}.product-card{padding:1rem;min-height:320px;border-radius:12px}.product-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.product-card h3{font-size:1rem}.product-card .price{font-size:1.1rem}.add-btn{padding:.7rem;font-size:.9rem;border-radius:8px}.cart-overlay{justify-content:flex-end}.cart{max-width:400px;width:400px;height:100vh;border-radius:0;animation:slideLeft .25s ease}.cart-header{padding:1.25rem}.cart-items{padding:1rem}.cart-footer{position:relative!important;padding:1.25rem!important;box-shadow:none!important}.checkout-btn{padding:.9rem!important;font-size:1rem!important}.modal-overlay{align-items:center;padding:2rem}.modal{max-width:420px;border-radius:16px;padding:1.5rem}.modal h3{font-size:1.1rem;text-align:center}body{padding-bottom:0!important}}@media(min-width:1280px){.main-nav{padding:1rem 4rem;max-width:1600px}.products-section{padding:2.5rem 4rem;max-width:1600px}.products{grid-template-columns:repeat(5,1fr)!important;gap:1.75rem}.new-slider{max-width:1400px}.slider-container{height:320px}.slide img{width:260px;height:260px}}.checkout-btn{padding:1rem!important;font-size:1rem!important;min-height:auto!important;border-radius:12px!important}.modal-overlay{align-items:center;padding:2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{max-width:500px;border-radius:24px;max-height:85vh;padding:2rem;box-shadow:0 24px 48px #0003}.modal h3{font-size:1.3rem;text-align:center;padding-right:0}.options-row{gap:1.5rem}.option-btns button{padding:.75rem .5rem;font-size:.9rem;border-radius:10px}.confirm-btn{padding:1rem;font-size:1rem;border-radius:12px}.success-modal,.history-modal{max-width:450px;padding:2rem;border-radius:24px}body{padding-bottom:0!important}} @media (min-width: 1280px){.main-nav{padding:1rem 4rem;max-width:1600px}.products-section{padding:2.5rem 4rem;max-width:1600px}.products{grid-template-columns:repeat(5,1fr)!important;gap:1.75rem}.new-slider{max-width:1400px}.slider-container{height:320px}.slide img{width:260px;height:260px}}@media(min-width:1536px){.products{grid-template-columns:repeat(6,1fr)!important}.products-section{max-width:1800px}}.logo{display:flex;align-items:center;gap:.5rem}.logo-icon{font-size:2rem;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.logo-text{display:flex;flex-direction:column;line-height:1.1}.logo-name{font-size:1.2rem;font-weight:800;color:var(--primary);letter-spacing:-.5px}.logo-tagline{font-size:.6rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:1px}.nav-links{display:none;gap:1.5rem}.nav-links a{text-decoration:none;color:var(--muted);font-weight:600;font-size:.9rem;transition:color .2s;padding:.5rem 0;position:relative}.nav-links a:hover,.nav-links a.active{color:var(--primary)}.nav-links a.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--primary);border-radius:2px}.cart-btn{background:var(--white);border:2px solid var(--primary);padding:.5rem .75rem;border-radius:10px;cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:all .2s ease;flex-shrink:0;min-height:40px}.cart-btn:hover{background:var(--primary)}.cart-btn:hover .cart-icon-btn{color:var(--white)}.cart-btn:hover .cart-count{background:var(--white);color:var(--primary)}.cart-icon-btn{font-size:1.2rem;color:var(--primary);transition:color .2s}.cart-count{background:var(--primary);color:var(--white);font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;transition:all .2s}.nav-actions{display:flex;align-items:center;gap:1rem;flex-shrink:0}.theme-switch{position:relative;width:44px;height:24px}.theme-switch input{opacity:0;width:0;height:0}.theme-switch .slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:24px;transition:.3s}.theme-switch .slider:before{content:"☀️";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:var(--white);border-radius:50%;transition:.3s;font-size:10px;display:flex;align-items:center;justify-content:center}.theme-switch input:checked+.slider{background:var(--primary)}.theme-switch input:checked+.slider:before{content:"🌙";transform:translate(20px)}@media(min-width:768px){.main-nav{padding:.75rem 2rem}.logo{font-size:1.4rem}.nav-links{display:flex}.cart-btn{padding:.6rem 1rem}.cart-icon-btn{font-size:1.2rem}.cart-count{min-width:20px;height:20px;font-size:.75rem}}.new-slider{position:relative;overflow:hidden;background:linear-gradient(135deg,#fef9c3,#fde68a)}.slider-container{position:relative;height:180px}.slide{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;padding:1rem;gap:1rem;opacity:0;transition:opacity .5s ease;cursor:pointer}.slide.active{opacity:1}.slide img{width:140px;height:140px;border-radius:16px;object-fit:cover;box-shadow:0 4px 12px #00000026}.slide-info{flex:1}.slide-badge{display:inline-block;background:var(--accent);color:var(--text);font-size:.7rem;font-weight:700;padding:.25rem .6rem;border-radius:12px;margin-bottom:.5rem}.slide-info h3{font-size:1.2rem;color:var(--primary-dark);margin-bottom:.3rem}.slide-info p{font-size:1.1rem;font-weight:700;color:var(--accent);margin-bottom:.8rem}.slide-info button{background:var(--primary);color:var(--white);border:none;padding:.5rem 1.2rem;border-radius:20px;font-weight:600;font-size:.85rem;cursor:pointer}.slider-dots{display:flex;justify-content:center;gap:.5rem;padding-bottom:1rem}.dot{width:8px;height:8px;border-radius:50%;background:#0003;cursor:pointer;transition:all .3s}.dot.active{background:var(--primary);width:24px;border-radius:4px}.hero{background:linear-gradient(135deg,#fef3c7,#fdba74);padding:4rem 2rem;text-align:center}.hero h1{font-size:2.2rem;color:var(--primary-dark);margin-bottom:.8rem;font-weight:700}.hero p{font-size:1.1rem;color:var(--muted);margin-bottom:2rem;font-weight:500}.cta-btn{background:var(--accent);color:var(--white);border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.cta-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f9731666}.products-section{max-width:1200px;margin:0 auto;padding:2rem .75rem}.products-section h2{font-size:1.5rem;font-weight:700;text-align:center;margin-bottom:1.5rem}.categories{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding:.75rem 0;position:sticky;top:95px;background:var(--bg);z-index:5;scrollbar-width:none}.categories::-webkit-scrollbar{display:none}@media(max-width:400px){.categories{top:105px}}.cat-btn{flex-shrink:0;padding:.5rem 1rem;border:2px solid var(--border);border-radius:20px;background:var(--white);color:var(--muted);cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s;white-space:nowrap}.cat-btn:hover{border-color:var(--primary);color:var(--primary)}.cat-btn.active{background:var(--primary);border-color:var(--primary);color:var(--white)}.products{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.product-card{background:var(--white);border-radius:12px;padding:.75rem;text-align:center;box-shadow:0 2px 8px #0000000f;transition:all .2s ease;display:flex;flex-direction:column;position:relative;height:100%}.product-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.product-img-container{position:relative;width:100%;aspect-ratio:1;overflow:hidden;border-radius:8px;margin-bottom:.5rem;background:transparent}.product-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.product-card:hover .product-img{transform:scale(1.05)}.product-img.loading{opacity:0}.product-img.loaded{opacity:1;transition:opacity .3s ease}.image-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;background:#f5f5f5;color:#999;text-align:center;padding:.5rem}.badge-new{position:absolute;top:.75rem;left:.75rem;background:var(--accent);color:var(--text);font-size:.65rem;font-weight:700;padding:.2rem .5rem;border-radius:4px;z-index:1}.badge-hot{position:absolute;top:.75rem;right:.75rem;font-size:1rem;z-index:1}.product-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;margin-bottom:.5rem}.product-card h3{font-size:.95rem;font-weight:600;margin:0;color:var(--text-primary);line-height:1.3;text-align:left;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}.product-title{transition:color .2s}.product-title:hover{color:var(--primary)}.price{color:var(--primary);font-size:1rem;font-weight:700;margin:.25rem 0;text-align:left}.ingredients{font-size:.75rem;color:var(--muted);margin:0;text-align:left;margin-bottom:.5rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.1em;flex-grow:1}.add-btn{width:100%;padding:.6rem;border:none;border-radius:8px;background:var(--primary);color:var(--white);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:auto;position:relative;overflow:hidden}.add-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#fff3;border-radius:50%;transform:translate(-50%,-50%);transition:width .4s,height .4s}.add-btn:hover:before{width:300px;height:300px}.add-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 16px #fb923c59}.add-btn:active{transform:translateY(0);box-shadow:0 2px 8px #fb923c4d}footer{background:var(--text);color:var(--white);text-align:center;padding:2rem;margin-top:2rem}.cart-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:100;display:flex;justify-content:flex-end}.cart{background:var(--white);width:100%;max-width:100%;height:100dvh;display:flex;flex-direction:column;animation:slideUp .3s ease;position:fixed;left:0;right:0;top:0;bottom:0;overflow:hidden}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--white)}.empty-cart{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;text-align:center;flex:1;min-height:0}.empty-cart .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.6}.empty-cart h3{color:var(--text-primary);margin:0 0 .5rem;font-size:1.25rem}.empty-cart p{color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.5}.browse-btn{background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s;font-size:1rem}.browse-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.cart-header h2{font-size:1.1rem}.close-btn{background:var(--bg);border:none;font-size:1.2rem;cursor:pointer;color:var(--text);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:var(--border)}.empty{text-align:center;padding:3rem;color:var(--muted)}.cart-items{flex:1;overflow-y:auto;padding:.75rem;-webkit-overflow-scrolling:touch;min-height:0}.cart-item:last-child{border-bottom:none}.cart-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-bottom:1px solid var(--border)}.cart-icon{font-size:2.5rem}.cart-img{width:50px;height:50px;border-radius:8px;object-fit:cover;flex-shrink:0}.cart-info{flex:1;min-width:0}.cart-name{display:block;font-weight:600;margin-bottom:4px;font-size:1rem;color:var(--text-primary);line-height:1.4}.cart-options{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:4px;line-height:1.3}.cart-price{color:var(--accent);font-weight:700;font-size:.95rem}.qty-control{display:flex;align-items:center;gap:.5rem;border:1px solid var(--border);border-radius:8px;padding:.25rem;flex-shrink:0;background:var(--white)}.qty-control button{width:30px;height:30px;border:none;background:var(--bg);color:var(--primary);border-radius:6px;font-size:1rem;cursor:pointer;font-weight:700;transition:background .2s;display:flex;align-items:center;justify-content:center}.qty-control button:hover{background:var(--primary);color:var(--white)}.qty-control span{min-width:24px;text-align:center;font-weight:700;font-size:.95rem;color:var(--text)}.cart-footer{padding:1rem;border-top:1px solid var(--border);background:var(--bg);flex-shrink:0;color:var(--text)}.cart-total{display:flex;justify-content:space-between;font-size:1.1rem;font-weight:700;margin-bottom:.75rem;color:var(--text)}.cart-total span{color:var(--text)}.checkout-btn{width:100%;padding:.85rem;border:none;border-radius:10px;background:var(--primary);color:var(--white);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s}.checkout-btn:hover{background:var(--primary-dark)}.checkout-btn:disabled{background:var(--muted);cursor:not-allowed}.checkout-form{display:flex;flex-direction:column;gap:.6rem}.checkout-form input{padding:.7rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;font-family:inherit;transition:border-color .2s}.checkout-form input:focus{outline:none;border-color:var(--primary)}.payment-note{color:var(--muted);padding:.5rem 0;font-size:.85rem;font-weight:500;text-align:center}.delivery-options{display:flex;gap:.5rem;border:none;padding:0;margin:0}.delivery-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem;border:2px solid var(--border);border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;background:var(--white);color:var(--text)}.delivery-option:hover{border-color:var(--primary)}.delivery-option input{display:none}.delivery-option.active{border-color:var(--primary);background:var(--primary);color:var(--white)}.address-section{display:flex;flex-direction:column;gap:.5rem}.address-input{display:flex}.address-input input{flex:1;border-radius:10px}.location-btn{width:100%;padding:.7rem;border:2px dashed var(--primary);border-radius:10px;background:transparent;color:var(--primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.location-btn:hover{background:var(--primary);color:var(--white);border-style:solid}.location-btn:disabled{opacity:.6;cursor:wait}.checkout-btn:disabled{opacity:.7;cursor:not-allowed}.confirm-page .cart-items{padding:.75rem}.confirm-customer{background:var(--bg);padding:.75rem;border-radius:10px;margin-bottom:.75rem}.confirm-customer p{margin:.2rem 0;font-size:.9rem}.confirm-item{padding:.75rem;border-bottom:1px solid var(--border)}.confirm-item-header{display:flex;justify-content:space-between;margin-bottom:.3rem}.confirm-name{font-weight:600;font-size:.95rem}.confirm-price{color:var(--primary);font-weight:700}.confirm-options{font-size:.75rem;color:var(--muted);margin-bottom:.5rem}.item-note{font-size:.8rem;color:var(--primary);cursor:pointer;padding:.4rem 0}.edit-note input{width:100%;padding:.5rem;border:1px solid var(--primary);border-radius:6px;font-size:.85rem;background:var(--bg);color:var(--text)}.error-message{background:#fee2e2;color:#dc2626;padding:.75rem;border-radius:8px;font-size:.85rem;font-weight:600;text-align:center;margin-bottom:.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}.modal{background:var(--white);width:100%;max-width:420px;border-radius:16px;padding:1.5rem;position:relative;box-shadow:0 20px 40px #00000026;animation:modalIn .3s cubic-bezier(.34,1.56,.64,1);color:var(--text)}@keyframes modalIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal .close-btn{position:absolute;top:1rem;right:1rem;width:32px;height:32px;border:none;background:var(--bg);border-radius:50%;color:var(--muted);font-size:1.2rem;cursor:pointer;transition:all .2s}.modal .close-btn:hover{background:var(--border);color:var(--text)}.modal-img{width:120px;height:120px;border-radius:12px;margin:0 auto 1rem;display:block;object-fit:cover}.modal h3{font-size:1.2rem;font-weight:700;margin-bottom:1rem;text-align:center;color:var(--text)}.option-group{margin-bottom:1.5rem}.option-group:last-child{margin-bottom:0}.option-group label{display:block;font-weight:600;margin-bottom:.75rem;font-size:.9rem;color:var(--text)}.options-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.options-row .option-group{margin-bottom:0}.option-btns{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.option-btns button{padding:.75rem .5rem;border:2px solid var(--border);border-radius:10px;background:var(--white);color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.option-btns button:hover{border-color:var(--primary);background:var(--bg)}.option-btns button.active{border-color:var(--primary);background:var(--primary);color:var(--white);font-weight:600}.note-input{width:100%;padding:.75rem;border:2px solid var(--border);border-radius:10px;font-size:.9rem;transition:border-color .2s;margin-bottom:1.5rem}.note-input:focus{outline:none;border-color:var(--primary)}.confirm-btn{width:100%;padding:1rem;background:var(--primary);color:var(--white);border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.scroll-top{position:fixed;bottom:2rem;right:1rem;width:44px;height:44px;border-radius:50%;background:var(--primary);color:var(--white);border:none;font-size:1.2rem;cursor:pointer;box-shadow:0 2px 8px #00000026;z-index:50;transition:background .2s}.scroll-top:hover{background:var(--primary-dark)}html{scroll-behavior:smooth}.coupon-section{display:flex;gap:.5rem;margin-bottom:.5rem}.coupon-section input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:8px}.coupon-section button{padding:.5rem 1rem;background:#10b981;color:#fff;border:none;border-radius:8px}.coupon-error{color:#ef4444;font-size:.85rem;margin:.25rem 0}.coupon-success{color:#10b981;font-size:.85rem;margin:.25rem 0}.cart-discount{display:flex;justify-content:space-between;color:#10b981}.cart-total.final{font-size:1.2rem;font-weight:700;border-top:1px solid #ddd;padding-top:.5rem;margin-top:.5rem}.success-modal{background:#fff;padding:2rem;border-radius:16px;text-align:center;max-width:320px}.success-icon{width:64px;height:64px;background:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 1rem}.success-modal h2{color:#10b981;margin-bottom:1rem}.success-modal p{margin:.5rem 0;color:#666}.success-modal button{margin:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:background .2s}.success-modal button:first-of-type{background:#f59e0b;color:#fff}.success-modal button:first-of-type:hover{background:#d97706}.success-modal button:last-of-type{background:#e5e7eb}.success-modal button:last-of-type:hover{background:#d1d5db}.rating-modal{background:#fff;padding:1.5rem;border-radius:16px;text-align:center;max-width:320px}.rating-modal h3{margin-bottom:1rem}.stars{font-size:2rem;margin-bottom:1rem}.star{color:#ddd;cursor:pointer;transition:color .2s}.star.active{color:#f59e0b}.rating-modal textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;min-height:80px;margin-bottom:1rem;resize:none}.rating-modal button{width:100%;padding:.75rem;background:#10b981;color:#fff;border:none;border-radius:8px;cursor:pointer}.history-modal{background:#fff;padding:1.5rem;border-radius:16px;max-width:400px;width:90%;max-height:70vh;overflow-y:auto}.history-modal h3{margin-bottom:1rem}.history-item{background:#f9fafb;padding:.75rem;border-radius:8px;margin-bottom:.5rem}.history-header{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:.25rem}.history-total{font-weight:700;color:#10b981}.history-item button{margin-top:.5rem;padding:.25rem .5rem;background:#f59e0b;color:#fff;border:none;border-radius:4px;font-size:.8rem;cursor:pointer}.status-pending{color:#eab308}.status-confirmed{color:#3b82f6}.status-done{color:#10b981}.status-cancelled{color:#ef4444}.history-modal .close-btn{width:100%;margin-top:1rem;padding:.75rem;background:#e5e7eb;border:none;border-radius:8px;cursor:pointer}.history-btn{background:#f3f4f6;border:1px solid #ddd;padding:.5rem;border-radius:8px;cursor:pointer;font-size:.85rem}.add-btn.disabled{background:#9ca3af;cursor:not-allowed;opacity:.7}.add-btn.disabled:hover{background:#9ca3af;transform:none}.closed-banner{background:#fef3c7;color:#92400e;padding:.75rem;text-align:center;font-weight:500}.modal-content{background:#fff;padding:24px;border-radius:12px;max-width:400px;width:90%;text-align:center}.modal-content h3{margin:0 0 12px;color:#1f2937}.modal-content p{margin:0 0 24px;color:#6b7280}.modal-actions{display:flex;gap:12px;justify-content:center}.btn-cancel,.btn-confirm{padding:8px 16px;border:none;border-radius:8px;cursor:pointer;font-weight:500}.btn-cancel{background:#f3f4f6;color:#374151}.btn-confirm{background:var(--primary);color:#fff}.skeleton{animation:pulse 1.5s ease-in-out infinite alternate}.skeleton-img{width:100%;height:200px;background:#e2e8f0;border-radius:8px;margin-bottom:12px}.skeleton-text{height:16px;background:#e2e8f0;border-radius:4px;margin-bottom:8px}.skeleton-text.short{width:60%}.skeleton-button{height:40px;background:#e2e8f0;border-radius:8px;margin-top:12px}.loading-spinner{display:flex;flex-direction:column;align-items:center;padding:2rem}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.spinner-md{width:40px;height:40px;border-width:4px}.spinner-lg{width:60px;height:60px;border-width:6px}.toast-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;pointer-events:none}.toast{background:var(--white);border:2px solid var(--primary);border-radius:10px;padding:1rem 1.5rem;box-shadow:0 4px 16px #00000026;animation:toastIn .2s ease;font-size:.95rem;font-weight:600;text-align:center;color:var(--primary);min-width:180px}@keyframes toastIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.toast.removing{animation:toastOut .2s ease forwards}@keyframes toastOut{to{opacity:0;transform:scale(.9)}}.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted)}.empty-state .empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h3{margin:0 0 .5rem;color:var(--text)}.empty-state p{margin:0}.bottom-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:flex-end}.bottom-sheet{background:#fff;width:100%;max-height:85vh;border-radius:20px 20px 0 0;padding:1rem 1.5rem 2rem;animation:slideUp .3s ease;position:relative;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:40px;height:4px;background:#ddd;border-radius:2px;margin:0 auto 1rem}.bottom-sheet .close-btn{position:absolute;top:1rem;right:1rem;background:#f0f0f0;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:1.2rem}.bottom-sheet h3{margin:0 0 .25rem;font-size:1.25rem}.sheet-price{color:#e74c3c;font-weight:600;font-size:1.1rem;margin:0 0 1rem}.bottom-sheet .option-group{margin-bottom:1rem}.bottom-sheet .option-group label{display:block;font-weight:600;margin-bottom:.5rem;font-size:.9rem}.bottom-sheet .option-btns{display:flex;gap:.5rem}.bottom-sheet .option-btns button{flex:1;padding:.6rem;border:1px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:.9rem}.bottom-sheet .option-btns button.active{border-color:#4caf50;background:#e8f5e9;color:#4caf50}.bottom-sheet .options-row{display:flex;gap:1rem}.bottom-sheet .options-row .option-group{flex:1}@media(max-width:500px){.bottom-sheet .options-row{flex-direction:column}}.bottom-sheet .note-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;margin-bottom:1rem;font-size:.95rem}.bottom-sheet .confirm-btn{width:100%;padding:1rem;background:#4caf50;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer}@media(min-width:768px){.bottom-sheet{max-width:480px;margin:0 auto;border-radius:20px;margin-bottom:2rem}}
