.cart-hero { background: linear-gradient(135deg, #0D0D0D 40%, #1a1507 100%); border-bottom: 1px solid var(--border); padding: 60px 0 40px; }
.cart-hero-title { font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 4vw, 48px); font-weight: 300; color: var(--gold-light); }
.cart-hero-title em { color: var(--gold); font-style: italic; }
.cart-steps { display: flex; align-items: center; gap: 0; margin-top: 24px; }
.cart-step { display: flex; align-items: center; gap: 8px; font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted); font-weight: 500; }
.cart-step.active { color: var(--gold); }
.cart-step.active .step-num { background: var(--gold); color: var(--black); border-color: var(--gold); }
.step-num { width: 24px; height: 24px; border-radius: 50%; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 10px; font-family: 'Cormorant Garamond', serif; font-weight: 600; }
.step-divider { width: 32px; height: 1px; background: var(--border); margin: 0 12px; }
.cart-section { padding: 48px 0 80px; }
.cart-table-wrap { background: var(--dark-2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.cart-table-header { display: grid; grid-template-columns: 1fr 100px 120px 80px; gap: 16px; padding: 12px 24px; background: var(--dark-3); border-bottom: 1px solid var(--border); }
.cart-th { font-size: 8px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--text-muted); font-weight: 500; }
.cart-item { display: grid; grid-template-columns: 1fr 100px 120px 80px; gap: 16px; align-items: center; padding: 20px 24px; border-bottom: 1px solid var(--border); }
.cart-item:hover { background: rgba(201,169,110,0.03); }
.cart-item-info { display: flex; align-items: center; gap: 16px; }
.cart-item-thumb { width: 56px; height: 56px; background: var(--dark-3); border: 1px solid var(--border); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; font-size: 24px; }
.cart-item-name { font-size: 13px; color: var(--gold-light); font-weight: 500; margin-bottom: 3px; }
.cart-item-cat { font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-muted); }
.qty-wrap { display: flex; align-items: center; gap: 0; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; width: fit-content; }
.qty-btn { background: transparent; border: none; color: var(--gold); width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; font-size: 14px; cursor: pointer; }
.qty-btn:hover { background: var(--gold-muted); }
.qty-val { width: 36px; text-align: center; font-size: 12px; color: var(--gold-light); border: none; border-left: 1px solid var(--border); border-right: 1px solid var(--border); background: transparent; padding: 4px 0; }
.cart-item-price { font-family: 'Cormorant Garamond', serif; font-size: 18px; color: var(--gold); font-weight: 600; display: block; text-align: right; }
.cart-item-price .price-total { display: block; font-size: 16px; line-height: 1.3; }
.cart-item-price .price-unit { display: block; font-size: 10px; color: var(--text-muted); font-family: 'Montserrat', sans-serif; font-weight: 400; line-height: 1.3; }
.cart-remove-btn { background: transparent; border: none; color: var(--text-muted); cursor: pointer; width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius); }
.cart-remove-btn:hover { color: #e05252; background: rgba(224,82,82,0.08); }
.cart-empty { text-align: center; padding: 80px 24px; }
.cart-empty-icon { font-size: 56px; margin-bottom: 20px; opacity: 0.4; }
.cart-empty-title { font-family: 'Cormorant Garamond', serif; font-size: 28px; color: var(--gold-light); font-weight: 300; margin-bottom: 10px; }
.cart-empty-sub { font-size: 12px; color: var(--text-muted); letter-spacing: 1px; margin-bottom: 28px; }
.order-summary { background: var(--dark-2); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; position: sticky; top: 80px; box-shadow: 0 4px 20px rgba(0,0,0,0.3); }
.order-summary-header { padding: 16px 24px; background: linear-gradient(135deg, var(--dark-3), var(--dark-2)); border-bottom: 1px solid var(--border); }
.order-summary-title { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); font-weight: 600; margin: 0; }
.order-summary-body { padding: 24px; }
.summary-line { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; font-size: 12px; }
.summary-line-label { color: var(--text-muted); letter-spacing: 0.5px; }
.summary-line-val { color: var(--gold-light); font-weight: 500; }
.summary-line-val.gold { font-family: 'Cormorant Garamond', serif; font-size: 16px; color: var(--gold); font-weight: 600; }
.summary-divider { height: 1px; background: linear-gradient(90deg, transparent, var(--border), transparent); margin: 20px 0; }
.summary-total-line { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; padding: 16px; background: rgba(201,169,110,0.1); border-radius: 8px; border: 1px solid var(--border); }
.summary-total-label { font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: var(--gold-light); font-weight: 600; }
.summary-total-val { font-family: 'Cormorant Garamond', serif; font-size: 32px; color: var(--gold); font-weight: 600; line-height: 1; }
.coupon-wrap { margin-top: 16px; padding: 16px; background: var(--dark-3); border-radius: 8px; border: 1px solid var(--border); }
.coupon-label { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted); margin-bottom: 8px; display: block; }
.btn-checkout { background: var(--gold); color: var(--black); border: none; font-family: 'Montserrat', sans-serif; font-size: 10px; letter-spacing: 3px; font-weight: 700; text-transform: uppercase; border-radius: var(--radius); padding: 14px 24px; width: 100%; transition: all var(--transition); cursor: pointer; margin-top: 20px; }
.btn-checkout:hover { background: var(--gold-light); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(201,169,110,0.2); }
.btn-checkout:disabled { opacity: 0.4; cursor: not-allowed; }
.payment-icons { display: flex; justify-content: center; gap: 8px; margin-top: 16px; }
.payment-icon { background: var(--dark-3); border: 1px solid var(--border); border-radius: 3px; padding: 4px 8px; font-size: 9px; letter-spacing: 1px; color: var(--text-muted); text-transform: uppercase; }
.back-link { display: inline-flex; align-items: center; gap: 10px; font-size: 13px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; color: var(--gold-light); text-decoration: none; margin-bottom: 28px; padding: 12px 24px; background: rgba(201,169,110,0.15); border: 1px solid var(--gold); border-radius: 25px; transition: all 0.3s ease; }
.back-link:hover { color: var(--black); background: var(--gold); }
.alert-msg { padding: 10px 16px; border-radius: var(--radius); font-size: 12px; margin-bottom: 20px; }
.alert-msg.success { background: rgba(74, 222, 128, 0.1); color: #4ade80; border: 1px solid rgba(74, 222, 128, 0.3); }
.alert-msg.error { background: rgba(224, 82, 82, 0.1); color: #e05252; border: 1px solid rgba(224, 82, 82, 0.3); }
.coupon-applied { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: rgba(74, 222, 128, 0.1); border: 1px solid rgba(74, 222, 128, 0.3); border-radius: 8px; font-size: 11px; color: #4ade80; }
.coupon-applied button { background: none; border: none; color: #e05252; cursor: pointer; font-size: 14px; padding: 4px 8px; }
.form-select-custom { background: var(--dark-3); border: 1px solid var(--border); color: var(--gold-light); padding: 10px 14px; border-radius: var(--radius); font-size: 13px; width: 100%; }
.form-select-custom:focus { border-color: var(--gold); outline: none; }
.shipping-summary { background: var(--dark-3); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 16px; margin-bottom: 16px; }
.shipping-row { display: flex; justify-content: space-between; align-items: center; font-size: 12px; margin-bottom: 8px; }
.shipping-row:last-child { margin-bottom: 0; }
.shipping-label { color: var(--text-muted); }
.shipping-value { color: var(--gold-light); }
.shipping-value.free { color: #4ade80; }
.payment-methods { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--border); }
.payment-methods form { gap: 12px !important; justify-content: space-between !important; }
.payment-methods form::after { content: ''; flex: 1; }
.payment-method { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--dark-3); border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 8px; cursor: pointer; transition: var(--transition); }
.payment-method:hover { border-color: var(--gold-dark); }
.payment-method.selected { border-color: var(--gold); background: var(--gold-muted); }
.payment-method input { display: none; }
.payment-radio { width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.payment-method.selected .payment-radio { border-color: var(--gold); background: var(--gold); }
.payment-method.selected .payment-radio::after { content: '✓'; font-size: 10px; color: var(--black); }
.payment-icon-method { font-size: 24px; }
.payment-details { flex: 1; }
.payment-name { font-size: 13px; color: var(--gold-light); font-weight: 500; }
.payment-desc { font-size: 11px; color: var(--text-muted); }
.cod-notice { font-size: 10px; color: #fbbf24; margin-top: 4px; }
.payment-btn { background: var(--dark-3); border: 2px solid var(--border); border-radius: 8px; cursor: pointer; transition: all 0.3s; text-align: left; }
.payment-btn.active { background: rgba(201,169,110,0.15); border-color: var(--gold); }
.payment-btn:hover { border-color: var(--gold-dark); }
@media (max-width: 768px) {
    .cart-table-header { display: none; }
    .cart-item { grid-template-columns: 1fr auto; grid-template-rows: auto auto; gap: 12px; padding: 16px; }
    .cart-item-info { grid-column: 1; grid-row: 1; }
    .qty-wrap { grid-column: 1; grid-row: 2; }
    .cart-item-price { grid-column: 2; grid-row: 2; text-align: right; }
    .cart-remove-btn { grid-column: 2; grid-row: 1; justify-self: end; }
    .payment-methods form { display: grid !important; grid-template-columns: 1fr 1fr; gap: 10px !important; }
    .payment-methods form::after { display: none; }
    .payment-btn-large { min-width: unset; width: 100%; padding: 12px 8px; flex-direction: row; justify-content: flex-start; gap: 10px; }
    .payment-btn-large .payment-label { font-size: 11px; }
    .payment-btn-large .payment-desc { font-size: 9px; text-align: left; }
}

.payment-btn-large { background: var(--dark-3); border: 2px solid var(--border); border-radius: 12px; padding: 14px 12px; display: flex; flex-direction: column; align-items: center; gap: 6px; cursor: pointer; transition: all 0.3s; min-width: 85px; }
.payment-btn-large:hover { border-color: var(--gold); background: rgba(201,169,110,0.1); transform: translateY(-2px); }
.payment-btn-large.active { border-color: var(--gold); background: rgba(201,169,110,0.2); }
.payment-btn-large .payment-label { font-size: 11px; color: var(--gold-light); font-weight: 600; }
.payment-btn-large .payment-desc { font-size: 8px; color: var(--text-muted); }
.payment-btn-large.active .payment-label { color: var(--gold); }
