/* Linen — Cart */
.cart-head { text-align: center; margin-bottom: var(--sp-9); }
.cart-head .eyebrow { margin-bottom: var(--sp-3); }
.cart-title {
  font-family: var(--font-display);
  font-size: clamp(34px, 5vw, 52px);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.cart-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--sp-9);
  align-items: flex-start;
}
@media (max-width: 900px) {
  .cart-grid { grid-template-columns: 1fr; }
}

/* Items */
.cart-items { display: flex; flex-direction: column; gap: var(--sp-3); }
.cart-item {
  display: grid;
  grid-template-columns: 96px 1fr auto;
  gap: var(--sp-5);
  align-items: center;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.cart-item:hover { border-color: var(--rose-200); box-shadow: var(--sh-xs); }
.cart-item-img {
  width: 96px;
  height: 96px;
  border-radius: var(--r-md);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cart-item-letter {
  font-family: var(--font-display);
  font-style: normal;
  font-size: 56px;
  color: rgba(255, 255, 255, 0.7);
}
.cart-item-info { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.cart-item-cat { font-family: var(--font-en); font-size: 10px; color: var(--rose-600); font-weight: 700; letter-spacing: 0.10em; text-transform: uppercase; }
.cart-item-name { font-family: var(--font-display); font-size: var(--fs-lg); color: var(--ink-900); font-weight: 500; }
.cart-item-name:hover { color: var(--rose-600); }
.cart-item-price { font-weight: 700; color: var(--ink-900); font-variant-numeric: tabular-nums; }
.cart-item-actions { display: flex; align-items: center; gap: var(--sp-3); }

.cart-qty {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  background: var(--paper-2);
  border-radius: var(--r-pill);
  padding: 5px var(--sp-3);
}
.cart-qty button {
  width: 26px;
  height: 26px;
  font-size: 16px;
  color: var(--ink-700);
}
.cart-qty button:hover { color: var(--rose-500); }
.cart-qty span { font-weight: 600; font-variant-numeric: tabular-nums; min-width: 18px; text-align: center; }

.cart-item-remove {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: var(--ink-500);
  transition: color var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease);
}
.cart-item-remove:hover { color: var(--rose-600); background: var(--rose-50); }

/* Summary */
.cart-summary {
  background: var(--paper-2);
  border-radius: var(--r-xl);
  padding: var(--sp-7);
  position: sticky;
  top: 100px;
}
.cart-summary h3 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 500;
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--line);
}
.cart-summary-row {
  display: flex;
  justify-content: space-between;
  padding: var(--sp-2) 0;
  color: var(--ink-700);
  font-size: var(--fs-sm);
}
.cart-summary-row span:last-child { font-weight: 600; color: var(--ink-900); font-variant-numeric: tabular-nums; }
.cart-summary-note {
  font-size: var(--fs-xs);
  color: var(--rose-600);
  background: var(--rose-50);
  padding: 10px 14px;
  border-radius: var(--r-md);
  margin: var(--sp-2) 0;
}
.cart-summary-divider {
  height: 1px;
  background: var(--line);
  margin: var(--sp-4) 0;
}
.cart-summary-total {
  font-size: var(--fs-md);
  padding: var(--sp-3) 0 var(--sp-5);
}
.cart-summary-total span:last-child {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 500;
}

/* Empty */
.cart-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--sp-12) 0;
}
.cart-empty-icon {
  width: 100px;
  height: 100px;
  margin: 0 auto var(--sp-5);
  border-radius: 50%;
  background: var(--paper-2);
  border: 2px dashed var(--line-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 48px;
  color: var(--ink-300);
}
.cart-empty h2 {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 500;
  margin-bottom: var(--sp-3);
}
.cart-empty p { color: var(--ink-500); margin-bottom: var(--sp-7); }

@media (max-width: 560px) {
  .cart-item { grid-template-columns: 72px 1fr; gap: var(--sp-3); }
  .cart-item-img { width: 72px; height: 72px; }
  .cart-item-actions { grid-column: 1 / -1; justify-content: space-between; }
}
