:root{--vh:1vh;--primary-color:#2c3e50;--secondary-color:#e74c3c;--background-color:#f5f5f5;--card-background:#fff;--text-color:#333;--text-light:#666;--border-color:#e0e0e0;--header-height:56px;--footer-height:56px}*{margin:0;padding:0}html{font-size:16px;overscroll-behavior:none}body,html{height:100%}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-overflow-scrolling:touch;background-color:var(--background-color);color:var(--text-color);overflow-x:hidden;overflow-y:auto;position:relative}#root{display:flex;flex-direction:column;height:100%}.full-height{height:100vh;height:calc(var(--vh, 1vh)*100)}button{-webkit-appearance:none;appearance:none;background:none;border-radius:4px;font-size:14px;padding:8px 16px}.primary-button{background-color:#2c3e50;background-color:var(--primary-color)}.secondary-button{background-color:initial;border:1px solid #2c3e50;border:1px solid var(--primary-color)}.secondary-button,a{color:#2c3e50;color:var(--primary-color)}img{-webkit-user-drag:none;user-drag:none;display:block;image-rendering:-webkit-optimize-contrast;max-width:100%;-webkit-user-select:none;user-select:none}.loading{align-items:center;color:#666;color:var(--text-light);display:flex;height:100vh;height:calc(var(--vh, 1vh)*100);justify-content:center}.loading-spinner{padding:20px}.loading-spinner:after{animation:spin 1s linear infinite;border:2px solid #e0e0e0;border-radius:50%;border-top-color:#2c3e50;border:2px solid var(--border-color);border-top-color:var(--primary-color);content:"";display:block;height:30px;width:30px}.error-message{color:var(--secondary-color);font-weight:500}.page-container{min-height:100vh;min-height:calc(var(--vh, 1vh)*100)}.main-content{padding-bottom:env(safe-area-inset-bottom,0);padding-top:56px;padding-top:var(--header-height)}.no-select{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@supports (-webkit-touch-callout:none){.ios-safari-fix{-webkit-overflow-scrolling:touch;overflow-y:auto}.ios-safari-fix .fixed-element{position:fixed;transform:translateZ(0)}.ios-safari-fix *{touch-action:manipulation}}.text-center{text-align:center}.text-primary{color:#2c3e50;color:var(--primary-color)}.text-secondary{color:#e74c3c;color:var(--secondary-color)}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:1rem}.hidden{display:none!important}.fade-in{animation:fadeIn .3s ease-in-out}@supports (-webkit-touch-callout:none){.fade-in{animation:none;opacity:1}}@media screen and (orientation:landscape) and (-webkit-min-device-pixel-ratio:2){body{min-height:100vh}}@supports (-webkit-touch-callout:none){img{-webkit-font-smoothing:antialiased;backface-visibility:hidden;-webkit-backface-visibility:hidden;image-rendering:-webkit-optimize-contrast;transform:translateZ(0);will-change:transform}.product-image img{opacity:0;transition:opacity .2s}.product-image img.loaded{opacity:1}.categories-scroll,.main-content,.thumbnails-scroll{-webkit-overflow-scrolling:touch!important;overflow-y:auto}.back-button,.category-button,.product-card,.thumbnail{touch-action:manipulation}.back-button,.simple-header{position:-webkit-sticky;position:sticky}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.page-container,.product-detail-page{min-height:-webkit-fill-available}body,html{height:100%;overflow:hidden;overscroll-behavior-y:none;position:fixed;width:100%}#root{-webkit-overflow-scrolling:touch;height:100%;overflow-y:auto}img{-webkit-user-drag:none;user-drag:none;pointer-events:none}.simple-header{z-index:10}*{touch-action:pan-x pan-y}@media screen and (orientation:landscape){body{height:100vh}}}*{-webkit-tap-highlight-color:transparent;box-sizing:border-box}body{background-color:#f5f5f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;padding:0;-webkit-user-select:none;user-select:none}.app-container{display:flex;flex-direction:column;max-width:100vw;min-height:100vh;overflow-x:hidden;position:relative}.main-content-wrapper{flex:1 1;overflow-y:auto;padding-bottom:60px}.app-container,main{-webkit-overflow-scrolling:touch}button{border:none;cursor:pointer;outline:none}a,button{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}:not(input):not(textarea){-webkit-touch-callout:none}::-webkit-scrollbar{background:transparent;width:0}button:active{opacity:.7}.fixed-element{position:fixed;transform:translateZ(0)}@supports (-webkit-touch-callout:none){.full-height{height:-webkit-fill-available}}.page-container{background-color:#f5f5f5;display:flex;flex-direction:column;padding-top:10px}.categories-container{background-color:#fff;margin-bottom:10px;overflow:hidden;padding:10px 15px;width:100%}.categories-grid{grid-gap:8px;display:grid;grid-auto-rows:minmax(38px,auto);grid-template-columns:repeat(5,1fr);padding-bottom:5px}@media (max-width:375px){.categories-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:500px){.categories-grid{grid-template-columns:repeat(6,1fr)}}.category-button{align-items:center;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:12px;color:#666;display:flex;font-size:13px;height:36px;justify-content:center;overflow:hidden;padding:6px 2px;text-align:center;text-overflow:ellipsis;transition:all .2s ease;width:100%}.category-button.active{background-color:#2c3e50;border-color:#2c3e50;color:#fff}.main-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:15px}.products-grid{grid-gap:15px;gap:15px;padding-bottom:20px}.product-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px rgba(0,0,0,.05);display:flex;flex-direction:column;height:100%;transition:transform .2s}.product-card:active{transform:scale(.98)}.product-image.loaded .image-loading-placeholder{display:none}.product-info{display:flex;flex-direction:column;flex-grow:1;padding:10px}.product-name{font-weight:500;margin:0 0 5px;text-overflow:ellipsis}.product-price{color:#e74c3c;font-weight:600;margin-top:auto}.loading-spinner{height:100px}.error-message{color:#e74c3c;padding:20px;text-align:center}@supports (-webkit-touch-callout:none){.product-image img{z-index:1}}.product-detail-page{background-color:#fff;min-height:100vh;padding:0}.back-button{background-color:rgba(0,0,0,.05);border:1px solid rgba(0,0,0,.1);color:#333;font-size:16px;margin:15px;padding:12px 16px;position:relative;transition:all .2s ease;width:-webkit-fit-content;width:fit-content;z-index:100}.back-button:hover{background-color:rgba(0,0,0,.1);border-color:rgba(0,0,0,.2)}.back-button:active{transform:scale(.98)}.back-button svg{flex-shrink:0;margin-right:8px}.back-text{font-size:16px;font-weight:600;white-space:nowrap}.product-detail-container{display:flex;flex-direction:column;padding:0 15px 15px}.main-image-container{align-items:center;background-color:#f8f8f8;border-radius:8px;display:flex;justify-content:center;margin-bottom:10px;min-height:300px;overflow:hidden;position:relative;width:100%}.detail-page-badge{background-color:#ff9800;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,.2);color:#fff;font-size:12px;font-weight:500;padding:4px 10px;position:absolute;right:10px;top:10px;z-index:2}.main-product-image{display:block;max-height:300px;object-fit:contain;width:100%}.image-navigation{bottom:0;justify-content:space-between;left:0;padding:0 10px;position:absolute;right:0;top:0}.image-navigation,.nav-button{align-items:center;display:flex}.nav-button{background:hsla(0,0%,100%,.7);border:none;border-radius:50%;box-shadow:0 2px 5px rgba(0,0,0,.1);cursor:pointer;height:40px;justify-content:center;width:40px;z-index:1}.prev-button{left:10px}.next-button{right:10px}.thumbnails{-webkit-overflow-scrolling:touch;display:flex;flex-wrap:nowrap;gap:8px;margin-bottom:15px;overflow-x:auto;padding:5px 0;scrollbar-width:none}.thumbnails::-webkit-scrollbar{display:none}.thumbnail{border:2px solid transparent;border-radius:6px;cursor:pointer;flex:0 0 60px;height:60px;overflow:hidden}.thumbnail.active{border-color:#ff6b6b}.thumbnail img{display:block;height:100%;object-fit:cover;width:100%}.product-info{padding:10px 0}.product-name{font-size:20px;margin:0 0 10px}.product-category{margin-bottom:12px}.category-tag{background-color:#f0f0f0;border-radius:12px;color:#666;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.product-price-stock{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:15px}.product-price{align-items:center;color:#e53935;display:flex;font-size:24px}.product-stock{background-color:rgba(76,175,80,.1);border-radius:4px;color:#4caf50;font-size:14px;font-weight:500;padding:4px 8px}.product-detail-page .product-info .product-stock.preorder{background-color:rgba(255,152,0,.1);color:#ff9800}.product-sections{margin-bottom:20px}.product-section{margin-bottom:15px}.section-title{font-size:16px;font-weight:500;margin:0 0 5px}.section-content{color:#666;font-size:14px;line-height:1.5;margin:0}.product-actions{margin-bottom:15px}.quantity-controls{align-items:center;border:1px solid #ddd;border-radius:4px;display:flex;margin-bottom:15px;overflow:hidden;width:-webkit-fit-content;width:fit-content}.quantity-btn{background:#f5f5f5;border:none;color:#333;cursor:pointer;font-size:18px}.quantity-btn,.quantity-display{align-items:center;display:flex;height:40px;justify-content:center;width:40px}.quantity-display{border-left:1px solid #ddd;border-right:1px solid #ddd;font-size:16px}.add-to-cart-btn{align-items:center;background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:8px;height:44px;justify-content:center;margin-bottom:12px;touch-action:manipulation;transition:all .2s ease;user-select:none;-webkit-user-select:none;width:100%}.add-to-cart-btn:hover:not(:disabled){background:#1976d2;box-shadow:0 2px 8px rgba(33,150,243,.3);transform:translateY(-1px)}.add-to-cart-btn:active:not(:disabled){box-shadow:0 1px 4px rgba(33,150,243,.3);transform:translateY(0)}.add-to-cart-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.add-to-cart-btn:before{bottom:-5px;content:"";left:-5px;position:absolute;right:-5px;top:-5px;z-index:-1}.line-order-btn{align-items:center;background:#06c755;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:8px;height:44px;justify-content:center;margin-bottom:30px;touch-action:manipulation;transition:all .2s ease;user-select:none;-webkit-user-select:none;width:100%}.line-order-btn:hover{background:#05a647;box-shadow:0 2px 8px rgba(6,199,85,.3);transform:translateY(-1px)}.line-order-btn:active{box-shadow:0 1px 4px rgba(6,199,85,.3);transform:translateY(0)}.attribute,.label,.product-attributes,.product-description,.value{display:none}.error,.loading,.not-found{align-items:center;color:#666;display:flex;font-size:18px;justify-content:center;min-height:300px}.product-categories{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.product-categories .category-tag{background-color:#f1f1f1;border-radius:4px;color:#666;font-size:10px;padding:2px 4px}.product-categories .preorder-tag{background-color:#f8d7da;color:#721c24}.product-image{background-color:#f9f9f9;padding-top:100%}.product-image img{left:0;object-position:center;position:absolute;top:0;transition:opacity .2s ease}.image-loading-placeholder{align-items:center;display:flex;font-size:14px;height:100%;justify-content:center;left:0;top:0;width:100%;z-index:1}.preorder-page{background-color:#fff;padding:15px}.preorder-header{margin-bottom:20px;text-align:center}.preorder-header h2{color:#333;font-size:1.5rem;font-weight:700;margin-bottom:8px}.preorder-header p{color:#666;font-size:.9rem}.preorder-card{background-color:#f9fbff;border:1px solid #cce3ff;position:relative}.preorder-badge{background-color:#06c;left:8px;z-index:2}.arrival-date{color:#06c;font-size:.7rem;font-weight:700;margin-top:4px}.empty-preorder{align-items:center;display:flex;flex-direction:column;height:60vh;justify-content:center;padding:40px 20px;text-align:center}.empty-icon{margin-bottom:20px;opacity:.5}.empty-preorder p{color:#666;font-size:1.1rem;margin-bottom:20px}.primary-button{background-color:#d32323;border-radius:24px;font-weight:700}.image-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:rgba(0,0,0,.9);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-modal-container{flex-direction:column;height:100vh;position:relative;width:100vw}.image-modal-close,.image-modal-container{align-items:center;display:flex;justify-content:center}.image-modal-close{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:hsla(0,0%,100%,.1);border:2px solid hsla(0,0%,100%,.3);border-radius:50%;color:#fff;cursor:pointer;font-size:30px;font-weight:300;height:50px;line-height:1;position:absolute;right:20px;top:20px;transition:all .2s ease;width:50px;z-index:10}.image-modal-close:hover{background:hsla(0,0%,100%,.2);border-color:hsla(0,0%,100%,.5);transform:scale(1.1)}.image-modal-content{align-items:center;cursor:-webkit-grab;cursor:grab;display:flex;height:100%;justify-content:center;overflow:hidden;-webkit-user-select:none;user-select:none;width:100%}.image-modal-content:active{cursor:-webkit-grabbing;cursor:grabbing}.image-modal-img{max-height:90vh;max-width:90vw;object-fit:contain;touch-action:none;transition:transform .1s ease-out;-webkit-user-select:none;user-select:none}.image-modal-instructions{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:rgba(0,0,0,.7);border:1px solid hsla(0,0%,100%,.1);border-radius:20px;bottom:20px;color:#fff;font-size:14px;left:50%;padding:8px 16px;position:absolute;text-align:center;transform:translateX(-50%);z-index:10}.desktop-instruction{display:inline}.mobile-instruction{display:none}@media (max-width:768px){.image-modal-close{font-size:24px;height:40px;right:15px;top:15px;width:40px}.image-modal-img{max-height:95vh;max-width:95vw}.image-modal-instructions{bottom:15px;font-size:12px;padding:6px 12px}.desktop-instruction{display:none}.mobile-instruction{display:inline}}@media (min-width:769px) and (max-width:1024px){.image-modal-img{max-height:85vh;max-width:85vw}}@supports (-webkit-touch-callout:none){.image-modal-content{-webkit-overflow-scrolling:touch}.image-modal-img{-webkit-touch-callout:none;-webkit-user-drag:none;-webkit-user-select:none}}.image-modal-overlay *{-webkit-user-select:none;user-select:none}@media only screen and (-webkit-min-device-pixel-ratio:2),only screen and (min-device-pixel-ratio:2),only screen and (min-resolution:192dpi),only screen and (min-resolution:2dppx){.image-modal-img{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.dm-page{margin:0 auto;max-width:1200px;min-height:calc(100vh - 140px);padding:20px 16px}.empty-container,.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:40px;margin-bottom:16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.retry-button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;margin-top:16px;padding:10px 20px}.retry-button:hover{background-color:#0056b3}.dm-activity-section{margin-bottom:40px}.dm-activity-section:last-child{margin-bottom:0}.dm-activity-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:12px;margin-bottom:24px;padding:20px 16px;text-align:center}.activity-title{color:#2c3e50;font-size:24px;font-weight:700;margin:0 0 8px;text-shadow:0 1px 2px rgba(0,0,0,.1)}.activity-period{color:#6c757d;font-size:16px;font-weight:500;margin:0}.dm-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}@media (min-width:768px){.dm-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.dm-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:1440px){.dm-grid{grid-template-columns:repeat(5,1fr)}}.dm-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.dm-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.15);transform:translateY(-2px)}.dm-card-image{align-items:center;aspect-ratio:1;background-color:#f8f9fa;cursor:pointer;display:flex;justify-content:center;overflow:hidden;position:relative;width:100%}.dm-card-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.dm-card:hover .dm-card-image img{transform:scale(1.05)}.dm-card-zoom-hint{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:rgba(0,0,0,.6);border-radius:4px;color:#fff;opacity:0;padding:4px;pointer-events:none;position:absolute;right:8px;top:8px;transition:opacity .2s ease}.dm-card:hover .dm-card-zoom-hint{opacity:1}@media (max-width:768px){.dm-card-zoom-hint{opacity:.7}}.dm-card-expiry{background-color:#fff3cd;border-top:1px solid #ffeaa7;padding:12px;text-align:center}.expiry-label{color:#856404;display:block;font-size:12px;font-weight:500;margin-bottom:4px}.expiry-date{color:#d63384;font-size:14px;font-weight:700}@media (max-width:480px){.dm-page{padding:16px 12px}.activity-title{font-size:20px}.activity-period{font-size:14px}.dm-activity-header{padding:16px 12px}.dm-grid{gap:12px}}@supports (-webkit-touch-callout:none){.dm-card,.dm-card-image img{transform:translateZ(0)}}.location-view{background-color:#fff;padding:15px 15px 70px}.location-header{margin-bottom:20px}.location-header h1{color:#c23321;font-size:1.5rem;font-weight:700;margin:0;padding:12px 0 24px;text-align:center}.store-image{border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);height:240px;margin-bottom:20px;overflow:hidden;width:100%}.store-image img{height:100%;object-fit:cover;width:100%}.location-details{display:flex;flex-direction:column;gap:20px;margin-top:10px}.hours-section,.store-info-section{background-color:#f9f9f9;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.1);padding:18px}.info-title{align-items:center;color:#333;display:flex;font-size:1.2rem;font-weight:600;margin:0 0 15px}.info-icon{font-size:1.3rem;margin-right:8px}.address-info{color:#666;font-size:.95rem;line-height:1.5;margin:0;padding-left:28px}.hours-list{display:flex;flex-direction:column;gap:10px;padding-left:28px}.hour-item{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:8px 0}.hour-item:last-child{border-bottom:none}.day{color:#666}.day,.time{font-size:.95rem}.time{color:#333;font-weight:500}@media (min-width:768px){.location-view{margin:0 auto;max-width:768px}.store-image{height:300px}}.search-page{background-color:#f5f5f5;min-height:100vh;padding-bottom:80px}.search-header{background:linear-gradient(135deg,#ff6b35,#f7931e);box-shadow:0 2px 4px rgba(0,0,0,.1);padding:15px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.back-button,.search-header{align-items:center;color:#fff;display:flex}.back-button{background:none;border:none;border-radius:8px;cursor:pointer;justify-content:center;margin-right:15px;padding:8px;transition:background-color .2s}.back-button:hover{background-color:hsla(0,0%,100%,.1)}.search-title{font-size:1.2rem;font-weight:600;margin:0}.search-info{background:#fff;border-bottom:1px solid #eee;margin-bottom:10px;padding:15px 20px}.search-info p{color:#666;font-size:.9rem;margin:5px 0}.search-info strong{color:#333}.loading-spinner{color:#666;font-size:1rem;padding:40px 20px;text-align:center}.error-message{background:#ffebee;border-left:4px solid #c62828;border-radius:8px;color:#c62828;margin:20px;padding:15px 20px}.search-results{padding:0 10px}.product-section{margin-bottom:30px}.section-title{background:#fff;border-left:4px solid #ff6b35;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);color:#333;font-size:1.1rem;font-weight:600;margin:0 0 15px;padding:15px 20px}.products-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);padding:0 10px}.product-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.05);cursor:pointer;overflow:hidden;position:relative;transition:all .3s ease}.product-card:hover{box-shadow:0 4px 15px rgba(0,0,0,.1);transform:translateY(-2px)}.product-image{aspect-ratio:1;background:#f8f8f8;overflow:hidden;position:relative}.product-image img{height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease;width:100%}.product-image img.visible{opacity:1}.image-loading-placeholder{color:#999;font-size:.8rem;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.product-info{padding:12px;position:relative}.product-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#333;display:-webkit-box;font-size:.9rem;font-weight:600;line-height:1.3;margin:0 0 8px;overflow:hidden}.product-price{color:#ff6b35;font-size:1rem;font-weight:700;margin:0}.preorder-badge{background:#2196f3;border-radius:12px;font-weight:600;padding:4px 8px;right:8px;top:8px}.no-query,.no-results{color:#666;padding:60px 20px;text-align:center}.no-query p,.no-results p{font-size:1rem;line-height:1.5;margin:10px 0}@media (max-width:480px){.search-header{padding:12px 15px}.search-title{font-size:1.1rem}.back-button{margin-right:10px}.search-info,.section-title{padding:12px 15px}.section-title{font-size:1rem}.products-grid{gap:8px;padding:0 5px}.product-info{padding:10px}.product-name{font-size:.85rem}.product-price{font-size:.9rem}}@media (min-width:768px){.products-grid{gap:15px;grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.products-grid{grid-template-columns:repeat(4,1fr)}}.cart-page{background-color:#f8f9fa;min-height:100vh;padding-bottom:80px;padding-top:60px}.cart-container{margin:0 auto;max-width:600px;padding:20px}.cart-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;margin-bottom:20px;padding:15px 0}.cart-header h2{color:#333;font-size:1.5rem;margin:0}.cart-header span{color:#6c757d;font-size:.9rem}.empty-cart{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);padding:60px 20px;text-align:center}.empty-cart p{color:#6c757d;font-size:1.1rem;margin:20px 0}.primary-button{background-color:#e74c3c;border-radius:8px;font-size:1rem;font-weight:600;padding:12px 24px;transition:background-color .2s ease}.primary-button:hover{background-color:#c0392b}.cart-items{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);margin-bottom:20px}.cart-item{align-items:center;border-bottom:1px solid #f1f3f4;display:flex;gap:15px;padding:15px}.cart-item:last-child{border-bottom:none}.cart-item-image{border-radius:8px;cursor:pointer;flex-shrink:0;height:80px;overflow:hidden;position:relative;width:80px}.cart-item-image img{height:100%;object-fit:cover;transition:transform .2s ease;width:100%}.cart-item-image:hover img{transform:scale(1.05)}.preorder-badge{background:#ff6b6b;border-radius:4px;color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;position:absolute;right:5px;top:5px}.cart-item-details{cursor:pointer;flex:1 1}.cart-item-name{color:#333;font-size:1rem;font-weight:600;line-height:1.4;margin:0 0 8px}.cart-item-price{color:#e74c3c;font-size:1.1rem;font-weight:700}.cart-item-actions{align-items:center;display:flex;flex-direction:column;gap:10px}.cart-quantity-control{align-items:center;background:#f8f9fa;border-radius:20px;display:flex;gap:8px;padding:4px}.quantity-button{align-items:center;background:#fff;border:none;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.1);color:#333;cursor:pointer;display:flex;font-size:1.2rem;font-weight:700;height:32px;justify-content:center;transition:all .2s ease;width:32px}.quantity-button:hover:not(:disabled){background:#e74c3c;color:#fff}.quantity-button:disabled{cursor:not-allowed;opacity:.5}.quantity-display{color:#333;font-weight:600;min-width:32px;text-align:center}.remove-item-button{transition:all .2s ease}.remove-item-button:hover{background-color:#fee;border-radius:4px}.cart-summary{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);padding:20px}.cart-total{align-items:center;border-bottom:1px solid #dee2e6;color:#333;display:flex;font-size:1.3rem;font-weight:700;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.cart-actions{display:flex;gap:10px;margin-bottom:15px}.secondary-button{flex:1 1;transition:all .2s ease}.secondary-button:hover{background-color:#e9ecef!important;border-color:#adb5bd!important}.primary-button{flex:1 1;transition:all .2s ease}.clear-cart-button{transition:all .2s ease;width:100%}.clear-cart-button:hover{background-color:#fee!important;color:#dc3545!important}@media (max-width:600px){.cart-container{padding:15px}.cart-item{align-items:flex-start;flex-direction:column;gap:10px}.cart-item-image{height:200px;width:100%}.cart-item-details{width:100%}.cart-item-actions{flex-direction:row;justify-content:space-between;width:100%}.cart-actions{flex-direction:column}.cart-header h2{font-size:1.3rem}}.cart-item{animation:slideIn .3s ease-out}.loading{color:#6c757d}.error,.loading{font-size:1.1rem;padding:40px;text-align:center}.error{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);color:#e74c3c}.about-page{background-color:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:800px;min-height:100vh;padding:20px}.about-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px rgba(0,0,0,.1);padding:24px}.about-content h1{border-bottom:3px solid #e74c3c;color:#2c3e50;font-size:28px;padding-bottom:10px;text-align:center}.about-content h1,.about-section{margin-bottom:30px}.about-section h2{border-left:4px solid #e74c3c;color:#34495e;font-size:24px;margin-bottom:20px;padding-left:15px}.subsection{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.subsection h3{align-items:center;color:#2c3e50;display:flex;font-size:18px;margin-bottom:15px}.subsection p{color:#555;font-size:16px;line-height:1.6;margin-bottom:15px}.business-hours,.payment-methods,.preorder-process{list-style:none;margin:0;padding:0}.business-hours li,.payment-methods li,.preorder-process li{border-bottom:1px solid #e9ecef;color:#555;font-size:15px;padding:8px 0}.business-hours li:last-child,.payment-methods li:last-child,.preorder-process li:last-child{border-bottom:none}.preorder-process li strong{color:#e74c3c;font-weight:600}.payment-methods li{padding-left:20px;position:relative}.payment-methods li:before{color:#e74c3c;content:"•";font-size:18px;font-weight:700;left:0;position:absolute}@media (max-width:768px){.about-page{padding:15px}.about-content{padding:20px}.about-content h1{font-size:24px}.about-section h2{font-size:20px}.subsection{padding:15px}.subsection h3{font-size:16px}.business-hours li,.payment-methods li,.preorder-process li,.subsection p{font-size:14px}}@media (prefers-color-scheme:dark){.about-page{background-color:#1a1a1a;color:#fff}.about-content{background:#2d2d2d;color:#fff}.about-content h1,.about-section h2,.subsection h3{color:#fff}.subsection{background:#3a3a3a;border-color:#4a4a4a}.business-hours li,.payment-methods li,.preorder-process li,.subsection p{border-color:#4a4a4a;color:#ccc}}.error-display{align-items:flex-start;animation:slideIn .3s ease;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;max-width:450px;min-width:300px;padding:16px;position:fixed;right:20px;top:20px;z-index:1000}.error-display.error{border-left:4px solid #ff4d4f}.error-display.warning{border-left:4px solid #faad14}.error-display.info{border-left:4px solid #1890ff}.error-icon{flex-shrink:0;margin-right:12px}.error-display.error .error-icon{color:#ff4d4f}.error-display.warning .error-icon{color:#faad14}.error-display.info .error-icon{color:#1890ff}.error-content{flex-grow:1;font-size:14px;line-height:1.5;word-break:break-word}.error-close{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;justify-content:center;margin-left:8px;padding:0}.error-close:hover{color:#666}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:576px){.error-display{left:10px;max-width:none;min-width:auto;right:10px;top:10px}}.image-uploader{background-color:#f9f9f9;border:2px dashed #ccc;border-radius:8px;display:flex;flex-direction:column;gap:16px;margin-bottom:20px;padding:16px;transition:all .3s ease}.image-uploader.highlight{background-color:#f0f7ff;border-color:#4a90e2}.image-preview-container{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.image-preview{border:2px solid transparent;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,.1);height:100px;overflow:hidden;position:relative;transition:all .2s ease;width:100px}.image-preview.thumbnail-selected{border-color:#4a90e2}.image-preview img{height:100%;object-fit:cover;width:100%}.remove-image{background-color:rgba(255,0,0,.7);color:#fff;font-size:14px;font-weight:700;height:20px;right:4px;width:20px}.remove-image,.set-thumbnail{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;justify-content:center;position:absolute;top:4px;z-index:2}.set-thumbnail{background-color:hsla(0,0%,100%,.7);color:#333;height:24px;left:4px;width:24px}.upload-button,.upload-button-container{display:flex;justify-content:center}.upload-button{align-items:center;background-color:#f0f0f0;border:1px solid #ccc;border-radius:4px;color:#333;cursor:pointer;gap:8px;padding:10px 16px;transition:all .2s ease}.upload-button:hover{background-color:#e0e0e0}.image-upload-error{color:#d32f2f;font-size:14px;margin-top:8px}.paste-hint{color:#666;font-size:13px;margin-top:8px;text-align:center}.enhanced-date-picker{position:relative;width:100%}.date-input{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;cursor:pointer;display:flex;font-size:16px;justify-content:space-between;padding:10px;transition:all .2s ease;width:100%}.date-input:hover{border-color:#999}.date-input.open{border-color:#4caf50;box-shadow:0 0 0 2px rgba(76,175,80,.2)}.calendar-icon{color:#666;font-size:18px;pointer-events:none}.dropdown{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);left:0;margin-top:4px;padding:16px;position:absolute;right:0;top:100%;z-index:1000}.quick-selects{grid-gap:8px;border-bottom:1px solid #eee;display:grid;gap:8px;grid-template-columns:repeat(4,1fr);margin-bottom:16px;padding-bottom:16px}.quick-btn{background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:12px;padding:6px 8px;text-align:center;transition:all .2s}.quick-btn:hover{background:#f5f5f5;border-color:#4caf50;color:#4caf50}.calendar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.nav-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:18px;padding:4px 8px;transition:all .2s}.nav-btn:hover{background:#f5f5f5;color:#333}.year-month-selector{align-items:center;display:flex;gap:8px}.month-select,.year-select{background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;padding:4px 8px}.month-select:focus,.year-select:focus{border-color:#4caf50;box-shadow:0 0 0 2px rgba(76,175,80,.2);outline:none}.calendar-grid{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr)}.calendar-header-day{color:#666;font-size:12px;font-weight:700;padding:8px 4px;text-align:center}.calendar-day{align-items:center;aspect-ratio:1;border-radius:4px;cursor:pointer;display:flex;font-size:14px;justify-content:center;position:relative;transition:all .2s}.calendar-day:not(.empty):hover{background:#e8f5e8;color:#2e7d32}.calendar-day.selected{background:#4caf50;color:#fff;font-weight:700}.calendar-day.today{background:#e3f2fd;color:#1976d2;font-weight:700}.calendar-day.selected.today{background:#4caf50;color:#fff}.calendar-day.empty{cursor:default}@media (max-width:480px){.dropdown{left:-10px;padding:12px;right:-10px}.quick-selects{gap:6px;grid-template-columns:repeat(2,1fr)}.quick-btn{font-size:11px;padding:8px 6px}.calendar-day{font-size:13px}.month-select,.year-select{font-size:13px;padding:3px 6px}}@media (prefers-color-scheme:dark){.dropdown{background:#2d2d2d;border-color:#444;color:#fff}.quick-btn{background:#3d3d3d;border-color:#555;color:#fff}.quick-btn:hover{background:#4d4d4d;border-color:#4caf50}.month-select,.year-select{background:#3d3d3d;border-color:#555;color:#fff}.calendar-header-day{color:#bbb}.calendar-day.today{background:#1565c0;color:#fff}}.product-form-container{align-items:center;background-color:rgba(0,0,0,.5);display:flex;height:100%;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;top:0;width:100%;z-index:1000}.product-form{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px rgba(0,0,0,.15);max-height:90vh;max-width:800px;overflow-y:auto;padding:24px;width:100%}.form-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:10px}.form-header h2{color:#333;font-size:1.5rem;margin:0}.icon-button{color:#888;font-size:20px}.icon-button:hover{color:#333}.form-row{gap:16px;margin-bottom:16px}.form-group{flex-basis:calc(50% - 8px);flex-grow:1;flex-shrink:1}.form-group.full-width{flex:1 1 100%}.form-group label{color:#333;margin-bottom:6px}.form-group input[type=date],.form-group input[type=number],.form-group input[type=text],.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:16px;padding:10px;width:100%}.form-group textarea{min-height:100px;resize:vertical}.checkbox-group{padding-top:28px}.checkbox-label input[type=checkbox]{margin-right:8px}.categories-wrapper{display:flex;flex-wrap:wrap;gap:8px}.error-message{color:#e53935;margin-top:4px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:30px}.primary-button{background-color:#4caf50;border-radius:4px;font-size:16px;padding:10px 20px}.primary-button:hover{background-color:#3e9142}.secondary-button{background-color:#f5f5f5;border-radius:4px;font-size:16px;padding:10px 20px}.secondary-button:hover{background-color:#e9e9e9}@media (max-width:767px){.product-form-container{padding:10px}.product-form{max-height:95vh;padding:16px}.form-group{flex:1 1 100%}}.upload-instruction{color:#666;font-size:.9rem;margin-top:8px;text-align:center}.category-grid{grid-gap:8px;background-color:#fff;border:1px solid #ddd;border-radius:4px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));max-height:150px;overflow-y:auto;padding:10px}.category-item{align-items:center;background-color:#f5f5f5;border-radius:4px;cursor:pointer;display:flex;font-size:14px;overflow:hidden;padding:6px 8px;text-overflow:ellipsis;white-space:nowrap}.category-item.selected{background-color:#e3f2fd}.category-item:hover{background-color:#e9e9e9}.category-modal{align-items:center;background-color:rgba(0,0,0,.5);display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.category-modal-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.2);display:flex;flex-direction:column;max-height:90vh;max-width:1000px;overflow-y:auto;width:80%}.category-modal-header{align-items:center;background-color:#d32f2f;border-bottom:1px solid #e0e0e0;border-radius:8px 8px 0 0;color:#fff;display:flex;justify-content:space-between;padding:16px 20px}.category-modal-header h2{font-size:20px;font-weight:600;margin:0}.close-button{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.category-stats{background-color:#f9f9f9;border-bottom:1px solid #e0e0e0;justify-content:space-between;padding:20px}.stat-item{flex:1 1;padding:0 10px;text-align:center}.stat-item h3{color:#d32f2f;font-size:24px;font-weight:700;margin:0}.stat-item p{color:#666;font-size:14px;margin:5px 0 0}.stat-detail{color:#888;font-size:12px}.add-category-form{border-bottom:1px solid #e0e0e0;padding:20px}.add-category-form h3{font-size:16px;font-weight:600;margin:0 0 10px}.input-group{gap:10px}.category-input{border:1px solid #ccc;border-radius:4px;flex:1 1;font-size:15px;padding:10px}.add-button{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;min-width:80px;padding:10px 20px}.add-button:hover{background-color:#388e3c}.add-button:disabled{background-color:#9e9e9e;cursor:not-allowed}.error-message{color:#d32f2f;font-size:14px;margin-top:10px}.category-list-container{flex:1 1;overflow-y:auto;padding:20px}.category-table{text-align:left}.category-table th{background-color:#f5f5f5;border-bottom:2px solid #e0e0e0;padding:12px 15px}.category-table td{border-bottom:1px solid #e0e0e0;padding:12px 15px;vertical-align:middle}.category-name-col{width:25%}.category-desc-col{width:35%}.category-count-col{text-align:center;width:15%}.category-manage-col{width:25%}.category-table tbody tr:hover{background-color:#f5f5f5}.no-categories{color:#757575;padding:30px;text-align:center}.category-actions{display:flex;gap:8px}.cancel-button,.delete-button,.edit-button,.save-button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;padding:6px 12px;transition:background-color .3s}.edit-button{background-color:#2196f3}.edit-button:hover{background-color:#1976d2}.delete-button{background-color:#f44336}.delete-button:hover{background-color:#d32f2f}.delete-button:disabled{background-color:#ffcdd2;cursor:not-allowed}.edit-actions{display:flex;gap:8px}.save-button{background-color:#4caf50;color:#fff}.save-button:hover{background-color:#388e3c}.cancel-button{background-color:#9e9e9e;color:#fff}.cancel-button:hover{background-color:#757575}.edit-category-input{border:1px solid #ccc;border-radius:4px;font-size:14px;padding:6px 8px;width:100%}.category-modal-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.done-button{background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:10px 24px}.done-button:hover{background-color:#388e3c}.done-button:disabled{background-color:#9e9e9e;cursor:not-allowed}.loading-spinner{color:#757575;display:inline-block;margin-right:10px}@media (max-width:768px){.category-modal-content{width:95%}.category-stats{flex-wrap:wrap}.stat-item{flex-basis:50%;margin-bottom:15px}.category-table{font-size:14px}.cancel-button,.delete-button,.edit-button,.feature-button,.save-button{font-size:12px;padding:4px 8px}}.login-container{align-items:center;background-color:#f5f5f5;display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 12px rgba(0,0,0,.1);max-width:400px;padding:2rem;width:100%}.login-title{color:#c7392b;font-size:1.75rem;font-weight:600;margin:0 0 1.5rem;text-align:center}.form-group,.login-form{margin-bottom:1.5rem}.form-group input{border:1px solid #ddd;border-radius:.25rem;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#c7392b;box-shadow:0 0 0 2px rgba(199,57,43,.2);outline:none}.error-message{margin-top:.5rem}.login-button{background-color:#c7392b;border:none;border-radius:.25rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1rem;transition:background-color .2s;width:100%}.login-button:hover{background-color:#ae2f23}.login-button:disabled{background-color:#e0e0e0;color:#757575;cursor:not-allowed}.login-footer{color:#757575;text-align:center}.login-footer p{font-size:.9rem;margin:.5rem 0}.hint{color:#c7392b;font-style:italic}.admin-container{background-color:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.admin-header{background-color:#c7392b;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;padding:.5rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:0 1.5rem}.site-title{font-size:1.5rem;font-weight:600;margin:0}.header-actions{display:flex;gap:.5rem}.admin-main{flex:1 1;margin:0 auto;max-width:1280px;padding:1.5rem;width:100%}.primary-button{align-items:center;background-color:#c7392b;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s}.primary-button:hover{background-color:#ae2f23}.secondary-button{align-items:center;background-color:#f0f0f0;border:1px solid #ddd;border-radius:.25rem;color:#333;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s}.secondary-button:hover{background-color:#e0e0e0}.danger-button{align-items:center;background-color:#dc3545;border:none;border-radius:.25rem;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s}.danger-button:hover{background-color:#c82333}.icon-button{align-items:center;background:none;border:none;border-radius:.25rem;color:inherit;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:background-color .2s}.icon-button:hover{background-color:rgba(0,0,0,.1)}.logout-button{align-items:center;background-color:initial;border:1px solid #fff;border-radius:.25rem;color:#fff;cursor:pointer;display:inline-flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s}.logout-button:hover{background-color:hsla(0,0%,100%,.1)}.activate-button,.deactivate-button,.delete-button,.edit-button{border:none;border-radius:.25rem;cursor:pointer;font-size:.85rem;margin-right:.25rem;padding:.25rem .5rem}.edit-button{background-color:#007bff;color:#fff}.edit-button:hover{background-color:#0069d9}.activate-button{background-color:#28a745;color:#fff}.activate-button:hover{background-color:#218838}.deactivate-button{background-color:#6c757d;color:#fff}.deactivate-button:hover{background-color:#5a6268}.delete-button{background-color:#dc3545;color:#fff}.delete-button:hover{background-color:#c82333}.product-manager{background-color:#fff;border-radius:.5rem;box-shadow:0 2px 4px rgba(0,0,0,.05);margin-bottom:1.5rem;padding:1.5rem}.product-filters{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.filter-group{flex:1 1;min-width:200px}.filter-select,.search-input{border:1px solid #ddd;border-radius:.25rem;font-size:1rem;padding:.5rem;width:100%}.product-table-container{overflow-x:auto}.product-table{border-collapse:collapse;width:100%}.product-table td,.product-table th{border-bottom:1px solid #eee;padding:.75rem;text-align:left}.product-table th{background-color:#f8f9fa;font-weight:600}.product-name-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-thumbnail{border-radius:.25rem;height:50px;object-fit:cover;width:50px}.product-actions{display:flex;gap:.5rem}.status-badge{border-radius:.25rem;display:inline-block;font-size:.85rem;font-weight:500;padding:.25rem .5rem}.status-active{background-color:#e8f5e9;color:#2e7d32}.status-inactive{background-color:#f5f5f5;color:#757575}.status-preorder{background-color:#e3f2fd;color:#1976d2}.status-warning{background-color:#fff3e0;border:1px solid #ffcc02;color:#ef6c00}.expiry-badge{border-radius:.25rem;display:inline-block;font-size:.85rem;padding:.25rem .5rem}.expiring-normal{background-color:#e8f5e9;color:#2e7d32}.expiring-warning{background-color:#fff8e1;color:#f57f17}.expiring-soon{background-color:#ffebee;color:#c62828}.expiring-expired{background-color:#efebe9;color:#6d4c41}.modal,.product-form-container{align-items:center;background-color:rgba(0,0,0,.5);display:flex;height:100%;justify-content:center;left:0;overflow-y:auto;padding:1rem;position:fixed;top:0;width:100%;z-index:1000}.modal-content,.product-form{background-color:#fff;border-radius:.5rem;box-shadow:0 4px 12px rgba(0,0,0,.15);max-height:90vh;max-width:800px;overflow-y:auto;padding:1.5rem;width:100%}.form-header,.modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.form-header h2,.modal-header h2{font-size:1.5rem;font-weight:600;margin:0}.form-row{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.form-group{flex:1 1;min-width:200px}.form-group.full-width{flex:1 0 100%}.form-group label{display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:.25rem;font-size:1rem;padding:.5rem;width:100%}.checkbox-group,.checkbox-label{align-items:center;display:flex}.checkbox-label{cursor:pointer;gap:.5rem;margin-right:1rem}.checkbox-label input[type=checkbox]{width:auto}.form-actions,.modal-footer{border-top:1px solid #eee;display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem}.error-message{color:#dc3545;font-size:.85rem;margin-top:.25rem}.category-stats{display:flex;gap:1rem;margin-bottom:1.5rem}.stat-card{background-color:#f8f9fa;border:1px solid #eee;border-radius:.5rem;flex:1 1;padding:1rem}.stat-card h3{font-size:1rem;margin:0 0 .5rem}.stat-value{font-size:1.5rem;font-weight:600}.add-category-form{margin-bottom:1.5rem}.input-group{display:flex;gap:.5rem}.input-group input{flex:1 1}.category-table{border-collapse:collapse;margin-bottom:1.5rem;width:100%}.category-table td,.category-table th{border-bottom:1px solid #eee;padding:.75rem;text-align:left}.category-table th{background-color:#f8f9fa;font-weight:600}.loading-spinner{align-items:center;color:#c7392b;display:flex;font-size:1.5rem;height:100vh;justify-content:center}@media (max-width:768px){.header-content{align-items:flex-start;flex-direction:column;gap:1rem;padding:1rem}.header-actions{flex-wrap:wrap;width:100%}.admin-main,.product-manager{padding:1rem}.product-table td,.product-table th{padding:.5rem}.modal-content,.product-form{padding:1rem}}.hidden{display:none}.debug-info{background-color:#f0f9ff;border:1px solid #bbdefb;border-radius:4px;font-size:.85rem;margin-bottom:10px;padding:10px}.top-nav{align-items:center;background-color:#e74c3c;box-shadow:0 2px 4px rgba(0,0,0,.1);color:#fff;display:flex;height:50px;justify-content:space-between;padding:env(safe-area-inset-top,10px) 15px 10px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.site-title{font-size:1.2rem;font-weight:700;margin-right:auto}.nav-actions{display:flex;gap:15px}.cart-btn,.search-btn{align-items:center;background:none;border:none;border-radius:8px;color:#fff;cursor:pointer!important;display:flex;justify-content:center;min-height:40px;min-width:40px;padding:8px;position:relative;transition:opacity .2s ease;z-index:10}.cart-btn:hover,.search-btn:hover{background-color:hsla(0,0%,100%,.1);opacity:.8}.cart-btn:active,.search-btn:active{transform:scale(.95)}.cart-badge{align-items:center;animation:cartBadgeAppear .3s ease-out;background:#ff4757;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px rgba(0,0,0,.3);color:#fff;display:flex;font-size:.7rem;font-weight:700;height:18px;justify-content:center;line-height:1;min-width:18px;padding:0 4px;position:absolute;right:-2px;top:-2px}@keyframes cartBadgeAppear{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.search-overlay{animation:slideDown .2s ease-out;background:#fff;border-bottom:1px solid #ddd;left:0;position:absolute;right:0;top:100%;z-index:999}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.search-form{align-items:center;display:flex;gap:10px;padding:15px}.search-input{background:#f8f9fa;border:2px solid #e1e5e9;border-radius:25px;flex:1 1;font-size:1rem;outline:none;padding:12px 15px;transition:all .2s ease}.search-input:focus{background:#fff;border-color:#e74c3c;box-shadow:0 0 0 3px rgba(231,76,60,.1)}.search-submit{background:#e74c3c;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:12px 20px;transition:background-color .2s ease;white-space:nowrap}.search-submit:hover{background:#c0392b}.search-close{align-items:center;background:#f8f9fa;border:2px solid #e1e5e9;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:36px;justify-content:center;line-height:1;transition:all .2s ease;width:36px}.search-close:hover{background:#e9ecef;border-color:#adb5bd;color:#495057}@media (max-width:480px){.search-form{gap:8px;padding:12px}.search-input{font-size:.9rem;padding:10px 12px}.search-submit{font-size:.8rem;padding:10px 16px}.search-close{height:32px;width:32px}}.bottom-nav{background-color:#fff;bottom:0;box-shadow:0 -2px 5px rgba(0,0,0,.1);display:flex;height:60px;justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom,0);position:fixed;right:0;z-index:100}.nav-item{align-items:center;background:none;border:none;color:#666;display:flex;flex:1 1;flex-direction:column;font-size:.7rem;gap:3px;justify-content:center;padding:8px 0}.nav-item.active{color:#e74c3c}.nav-item svg{margin-bottom:2px}@supports (-webkit-touch-callout:none){.top-nav{padding-top:max(10px,env(safe-area-inset-top,10px))}.bottom-nav{padding-bottom:max(0px,env(safe-area-inset-bottom,0px))}}
/*# sourceMappingURL=main.6962643a.css.map*/