/* Cart Page */ .cart-page { padding: 40px 0; min-height: calc(100vh - 300px); } .cart-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 40px; padding-bottom: 20px; border-bottom: 1px solid var(--border-color); } .cart-header h1 { font-size: 28px; font-weight: 700; color: var(--text-color); } .return-link { color: var(--primary-color); text-decoration: none; font-size: 14px; transition: color 0.3s ease; } .return-link:hover { color: var(--primary-dark); text-decoration: underline; } /* Cart Content */ .cart-content { display: grid; grid-template-columns: 1fr; gap: 40px; } /* Cart Table */ .cart-table { width: 100%; border-collapse: collapse; } .cart-table thead { border-bottom: 1px solid var(--border-color); } .cart-table th { text-align: left; padding: 15px 10px; font-size: 12px; font-weight: 600; color: var(--text-light); text-transform: uppercase; letter-spacing: 0.5px; } .cart-table th:first-child { width: 50%; } .cart-table th:nth-child(2) { width: 15%; text-align: center; } .cart-table th:nth-child(3) { width: 20%; text-align: center; } .cart-table th:nth-child(4) { width: 15%; text-align: right; } .cart-table tbody tr { border-bottom: 1px solid var(--border-color); } .cart-table td { padding: 30px 10px; } /* Product Column */ .cart-product { display: flex; gap: 20px; align-items: center; } .cart-product-image { width: 100px; height: 100px; border-radius: 8px; overflow: hidden; flex-shrink: 0; border: 1px solid var(--border-color); } .cart-product-image img { width: 100%; height: 100%; object-fit: cover; } .cart-product-info { flex: 1; } .cart-product-name { font-size: 16px; font-weight: 600; color: var(--text-color); margin-bottom: 8px; line-height: 1.4; } .cart-product-name a { color: var(--text-color); text-decoration: none; transition: color 0.3s ease; } .cart-product-name a:hover { color: var(--primary-color); } .cart-product-remove { display: inline-flex; align-items: center; gap: 5px; color: var(--text-light); font-size: 14px; cursor: pointer; border: none; background: none; padding: 0; transition: color 0.3s ease; } .cart-product-remove:hover { color: var(--danger-color); } /* Price Column */ .cart-price { text-align: center; font-size: 16px; font-weight: 600; color: var(--text-color); } /* Quantity Column */ .cart-quantity { text-align: center; } .quantity-selector { display: inline-flex; align-items: center; border: 1px solid var(--border-color); border-radius: 4px; overflow: hidden; } .quantity-selector button { width: 36px; height: 36px; background-color: transparent; border: none; font-size: 18px; cursor: pointer; transition: background-color 0.3s ease; } .quantity-selector button:hover { background-color: var(--bg-gray); } .quantity-selector input { width: 50px; height: 36px; border: none; border-left: 1px solid var(--border-color); border-right: 1px solid var(--border-color); text-align: center; font-size: 14px; font-weight: 600; } /* Total Column */ .cart-total-price { text-align: right; font-size: 18px; font-weight: 700; color: var(--text-color); } /* Cart Summary */ .cart-summary { background-color: var(--bg-gray); padding: 30px; border-radius: 8px; height: fit-content; } .cart-summary h3 { font-size: 18px; font-weight: 700; margin-bottom: 20px; color: var(--text-color); } .summary-row { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; font-size: 14px; } .summary-row.discount { color: var(--primary-color); } .summary-row.discount .discount-label { font-size: 12px; display: block; margin-top: 4px; } .summary-row.total { padding-top: 15px; margin-top: 15px; border-top: 1px solid var(--border-color); font-size: 18px; font-weight: 700; } .summary-row.total .price { font-size: 24px; } .shipping-notice { font-size: 13px; color: var(--text-light); margin-bottom: 20px; text-align: center; } .btn-checkout { width: 100%; padding: 16px; font-size: 16px; font-weight: 700; border-radius: 8px; margin-top: 20px; } /* Shipping Calculator */ .shipping-calculator { margin: 30px 0; padding: 30px; background-color: #fff; border: 1px solid var(--border-color); border-radius: 8px; } .shipping-calculator h3 { font-size: 18px; font-weight: 700; margin-bottom: 20px; color: var(--text-color); } .shipping-form { display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 15px; align-items: end; } .shipping-form select, .shipping-form input { padding: 12px 16px; border: 1px solid var(--border-color); border-radius: 4px; font-size: 14px; } .shipping-form select:focus, .shipping-form input:focus { outline: none; border-color: var(--primary-color); } .btn-calculate { padding: 12px 24px; background-color: var(--primary-color); color: #fff; border: none; border-radius: 4px; font-size: 14px; font-weight: 600; cursor: pointer; transition: background-color 0.3s ease; } .btn-calculate:hover { background-color: var(--primary-dark); } /* Empty Cart */ .cart-empty { text-align: center; padding: 80px 20px; } .cart-empty p { font-size: 18px; color: var(--text-light); margin-bottom: 30px; } /* Recommendations Section */ .recommendations-section { margin-top: 60px; padding-top: 60px; border-top: 1px solid var(--border-color); } .recommendations-section h2 { font-size: 24px; font-weight: 700; margin-bottom: 30px; color: var(--text-color); text-align: center; } .recommendations-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; } .recommendation-card { background-color: #fff; border-radius: 8px; overflow: hidden; transition: all 0.3s ease; border: 1px solid var(--border-color); } .recommendation-card:hover { transform: translateY(-4px); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1); } .recommendation-image { width: 100%; aspect-ratio: 1; overflow: hidden; position: relative; } .recommendation-image img { width: 100%; height: 100%; object-fit: cover; } .recommendation-badge { position: absolute; top: 10px; left: 10px; background-color: var(--primary-color); color: #fff; padding: 4px 10px; border-radius: 4px; font-size: 12px; font-weight: 600; } .recommendation-info { padding: 20px; } .recommendation-category { font-size: 12px; color: var(--text-light); text-transform: uppercase; margin-bottom: 8px; } .recommendation-name { font-size: 14px; font-weight: 600; color: var(--text-color); margin-bottom: 12px; line-height: 1.4; } .recommendation-rating { display: flex; align-items: center; gap: 5px; margin-bottom: 12px; font-size: 12px; } .stars { color: #ffc107; } .recommendation-price { display: flex; align-items: baseline; gap: 10px; margin-bottom: 15px; } .price-current { font-size: 18px; font-weight: 700; color: var(--primary-color); } .price-original { font-size: 14px; color: var(--text-light); text-decoration: line-through; } .recommendation-add-btn { width: 100%; padding: 10px; background-color: var(--text-color); color: #fff; border: none; border-radius: 4px; font-size: 14px; font-weight: 600; cursor: pointer; transition: all 0.3s ease; } .recommendation-add-btn:hover { background-color: var(--primary-color); } /* Responsive */ @media (max-width: 1024px) { .recommendations-grid { grid-template-columns: repeat(3, 1fr); } .shipping-form { grid-template-columns: 1fr; } } @media (max-width: 768px) { .cart-page { padding: 20px 0; } .cart-header h1 { font-size: 24px; } /* Convert table to cards on mobile */ .cart-table { display: block; } .cart-table thead { display: none; } .cart-table tbody, .cart-table tr, .cart-table td { display: block; width: 100%; } .cart-table tr { margin-bottom: 30px; padding: 20px; background-color: var(--bg-gray); border-radius: 8px; border: none; } .cart-table td { padding: 10px 0; text-align: left !important; } .cart-table td:before { content: attr(data-label); display: block; font-size: 12px; font-weight: 600; color: var(--text-light); margin-bottom: 5px; text-transform: uppercase; } .cart-quantity, .cart-total-price { text-align: left !important; } .quantity-selector { display: flex; } .recommendations-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; } } @media (max-width: 480px) { .recommendations-grid { grid-template-columns: 1fr; } .cart-product { flex-direction: column; align-items: flex-start; } .cart-product-image { width: 100%; height: auto; aspect-ratio: 1; } }