:root{--primary-color:#667eea;--secondary-color:#ff6b6b;--bg-color:#f5f5f5;--card-bg:#ffffff;--text-color:#333}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background:var(--bg-color);color:var(--text-color)}.container{max-width:900px;margin:0 auto;padding:20px}.header{text-align:center;font-size:2rem;font-weight:700;color:var(--primary-color)}.category-section,.header{margin-bottom:30px}.category-title{font-size:1.5rem;font-weight:700;margin-bottom:15px;border-bottom:2px solid var(--primary-color);padding-bottom:5px}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.product-card{background:var(--card-bg);border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.08);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer;position:relative}.product-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px rgba(0,0,0,.12)}.product-image{width:100%;height:150px;display:flex;align-items:center;justify-content:center;background:#eee}.product-image.emoji-image{font-size:5rem;background:linear-gradient(135deg,#ffeaa7,#fdcb6e)}.product-image.real-image{background-size:cover;background-position:50%;background-repeat:no-repeat}.product-info{padding:15px}.product-name{font-size:1.1rem;font-weight:600;margin-bottom:5px}.product-description{font-size:.9rem;color:#666;margin-bottom:10px;min-height:40px}.product-footer{display:flex;justify-content:space-between;align-items:center}.product-price{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.product-card.out-of-stock{cursor:not-allowed}.product-card.out-of-stock .product-image,.product-card.out-of-stock .product-info{opacity:.5;filter:grayscale(80%)}.stock-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:12px}.stock-overlay span{background:rgba(0,0,0,.7);color:white;padding:8px 15px;border-radius:20px;font-size:.9rem;font-weight:600}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:white;border-radius:12px;max-width:450px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 30px rgba(0,0,0,.2);display:flex;flex-direction:column}.modal-close{position:absolute;top:10px;right:10px;background:#eee;border:none;border-radius:50%;width:32px;height:32px;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10}.modal-image{font-size:5rem;text-align:center;background:linear-gradient(135deg,#ffeaa7,#fdcb6e);padding:20px}.modal-title{font-size:1.5rem;font-weight:700;text-align:center;padding:20px 20px 0}.modal-description{font-size:.9rem;color:#666;text-align:center;padding:0 20px 20px}.modal-options{padding:0 20px;flex-grow:1;overflow-y:auto}.option-group{margin-bottom:20px}.option-group h4{font-size:1rem;font-weight:600;margin-bottom:10px;border-bottom:1px solid #eee;padding-bottom:5px}.option-item label{display:flex;align-items:center;padding:8px 0;cursor:pointer}.option-item input{margin-right:10px;width:18px;height:18px;accent-color:var(--primary-color)}.option-name{flex-grow:1;font-size:.95rem}.option-price{font-size:.9rem;font-weight:500;color:var(--primary-color)}.note-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;font-family:inherit;font-size:.9rem;min-height:60px;resize:vertical}.modal-footer{justify-content:space-between;padding:20px;border-top:1px solid #eee;background:#f9f9f9;border-radius:0 0 12px 12px;margin-top:auto}.modal-footer,.quantity-selector{display:flex;align-items:center}.quantity-selector button{width:32px;height:32px;border:2px solid var(--primary-color);background:white;color:var(--primary-color);border-radius:50%;font-size:1.2rem;font-weight:700;cursor:pointer}.quantity-selector span{font-size:1.2rem;font-weight:600;padding:0 15px;min-width:40px;text-align:center}.add-to-cart-btn{background:var(--primary-color);color:white;border:none;border-radius:20px;padding:12px 20px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.add-to-cart-btn:hover{background:#5568cc}.cart-fab{position:fixed;bottom:30px;right:30px;background:var(--primary-color);color:white;border-radius:30px;padding:15px 20px;font-size:1.5rem;box-shadow:0 5px 15px rgba(0,0,0,.3);cursor:pointer;display:flex;align-items:center;z-index:998}.cart-fab-count{background:var(--secondary-color);border-radius:50%;font-size:.8rem;font-weight:700;padding:2px 6px;position:absolute;top:-5px;left:-5px}.cart-fab-total{font-size:1rem;font-weight:600;margin-left:10px}.cart-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:center;justify-content:center}.cart-modal-content{background:white;border-radius:12px;max-width:500px;width:90%;max-height:90vh;display:flex;flex-direction:column}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #eee}.cart-close{background:none;border:none;font-size:1.5rem;cursor:pointer}.cart-items-list{overflow-y:auto;flex-grow:1;padding:10px 20px;max-height:60vh}.cart-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f0f0f0}.cart-item-info{display:flex;flex-direction:column;flex-grow:1}.cart-item-info small{font-size:.85rem;color:#555}.cart-item-info small em{color:#888;font-style:italic}.cart-item-controls{display:flex;align-items:center;gap:10px}.quantity-selector-cart button{width:24px;height:24px;border:1px solid #ccc;background:#f9f9f9;border-radius:50%;cursor:pointer}.quantity-selector-cart span{padding:0 8px;font-size:.9rem;font-weight:600}.cart-remove{background:#ffcccc;border:none;color:#b00;border-radius:4px;padding:4px 8px;font-size:.8rem;cursor:pointer}.cart-footer{display:flex;justify-content:space-between;align-items:center;padding:20px;border-top:1px solid #eee;background:#f9f9f9}.checkout-btn{background:var(--primary-color);color:white;border:none;border-radius:20px;padding:10px 20px;font-size:1rem;font-weight:600;cursor:pointer}.checkout-page form{display:grid;grid-template-columns:1.5fr 1fr;gap:30px}.checkout-page .cart-fab{display:none}.checkout-form h3,.checkout-summary h3{font-size:1.2rem;font-weight:600;margin-bottom:15px;padding-bottom:5px;border-bottom:1px solid #eee}.checkout-form input,.checkout-form textarea{width:100%;padding:12px;margin-bottom:15px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;font-family:inherit}.checkout-form textarea{min-height:80px;resize:vertical}.option-group-checkout label{display:flex;align-items:center;padding:10px;border:1px solid #ddd;border-radius:8px;margin-bottom:10px;cursor:pointer}.option-group-checkout label:has(input:checked){border-color:var(--primary-color);background:#f8f0ff}.option-group-checkout input{width:auto;margin:0 10px 0 0}.checkout-summary{background:var(--card-bg);border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.05);padding:20px;position:sticky;top:20px;max-height:90vh;display:flex;flex-direction:column}.cart-items-list-checkout{overflow-y:auto;flex-grow:1;max-height:300px;border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:15px}.cart-item-checkout{display:flex;align-items:center;gap:10px;padding:8px 0}.item-qty{font-weight:600}.item-details{flex-grow:1;display:flex;flex-direction:column}.item-details small{font-size:.85rem;color:#555}.item-price{font-weight:500;white-space:nowrap}.checkout-total{font-size:.95rem;margin-top:auto;padding-top:10px}.total-row{display:flex;justify-content:space-between;margin-bottom:8px}.total-row.discount{color:var(--secondary-color);font-weight:600}.total-row.final{font-size:1.2rem;font-weight:700;border-top:1px solid #ddd;padding-top:10px;margin-top:5px}.error-message{color:var(--secondary-color);font-size:.9rem;text-align:center;padding:10px;background:#fff0f0;border-radius:8px;margin-top:10px}.place-order-btn{background:var(--primary-color);color:white;border:none;border-radius:8px;padding:15px;font-size:1.1rem;font-weight:600;cursor:pointer;width:100%;margin-top:20px}.place-order-btn:disabled{background:#ccc;cursor:not-allowed}.voucher-input-group{display:flex;margin-top:15px;margin-bottom:15px}.voucher-input-group button:disabled{background:#f5f5f5;cursor:not-allowed;color:#aaa}@media (max-width:768px){.container{padding:10px}.products-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.checkout-page form{grid-template-columns:1fr}.checkout-summary{position:relative;top:0}.cart-fab{bottom:15px;right:15px;padding:12px 15px}.cart-modal-content,.modal-content{width:100%;margin:10px}}