/* ═══════ Order Stepper V4 ═══════ */
.order-stepper { max-width: 800px; margin: 0 auto; }

.order-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 36px;
}
.order-step-btn {
  background: transparent;
  border: 1px solid #3a3a3a;
  padding: 14px 12px;
  cursor: pointer;
  font-family: "Catamaran", system-ui, sans-serif;
  font-size: 13px;
  color: #7a7a7a;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 500;
  transition: background 140ms, color 140ms, border-color 140ms;
  border-radius: 2px;
  text-align: center;
}
.order-step-btn:hover { color: #fff; border-color: #8a784a; }
.order-step-btn.done { color: #8a784a; border-color: #8a784a; }
.order-step-btn.active { background: #d4b56a; border-color: #d4b56a; color: #1a1304; font-weight: 600; }

.order-panel { display: none; }
.order-panel.active { display: block; }
.order-hidden { display: none !important; }

.order-table-head {
  display: grid;
  grid-template-columns: 1fr 110px 140px 110px;
  gap: 18px;
  padding: 0 0 10px;
  border-bottom: 1px solid #3a3a3a;
  color: #fff;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
}
.order-table-head .c-center { text-align: center; }
.order-table-head .c-right { text-align: right; }

.order-group-head { padding: 24px 0 10px; color: #d4b56a; font-size: 20px; letter-spacing: 0.08em; font-weight: 500; }

.order-row {
  display: grid;
  grid-template-columns: 1fr 110px 140px 110px;
  align-items: center;
  gap: 18px;
  padding: 16px 0;
  border-bottom: 1px solid #2a2a2a;
}
.order-row .prod-label { color: #fff; font-size: 15px; }
.order-row .prod-unit { color: #7a7a7a; font-size: 12px; margin-top: 2px; }
.order-row .mobile-price { display: none; }
.order-row .o-price { color: #d4b56a; font-variant-numeric: tabular-nums; text-align: center; }
.order-row .qty-cell { display: flex; justify-content: center; }
.order-row .line-total { text-align: right; font-variant-numeric: tabular-nums; color: #7a7a7a; }
.order-row .line-total.has-qty { color: #fff; }

.order-stepper .qty-stepper {
  display: inline-flex;
  align-items: stretch;
  background: #e8e3da;
  border-radius: 2px;
  overflow: hidden;
  height: 38px;
}
.order-stepper .qty-stepper > button {
  width: 36px;
  background: transparent;
  border: 0;
  color: #2a2a2a;
  font-size: 18px;
  cursor: pointer;
  font-family: inherit;
  font-weight: 500;
  padding: 0;
  line-height: 1;
}
.order-stepper .qty-stepper > button:hover { background: #d8d2c5; }
.order-stepper .qty-stepper > input {
  width: 48px !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  text-align: center;
  font-variant-numeric: tabular-nums;
  appearance: textfield;
  -moz-appearance: textfield;
  padding: 0 !important;
  font-weight: 500;
  color: #2a2a2a !important;
  font-size: 14px;
}
.order-stepper .qty-stepper > input:focus { background: transparent !important; border-color: transparent !important; }
.order-stepper .qty-stepper > input::-webkit-outer-spin-button,
.order-stepper .qty-stepper > input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.order-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 24px; }
.order-plz-ort { display: grid; grid-template-columns: 100px 1fr; gap: 14px; }

.order-field-label { display: block; font-size: 12px; color: #fff; margin-bottom: 6px; }
.order-section-head { padding: 0 0 14px; color: #d4b56a; font-size: 20px; letter-spacing: 0.08em; font-weight: 500; }

.order-stepper input[type="text"],
.order-stepper input[type="email"],
.order-stepper input[type="tel"],
.order-stepper select,
.order-stepper textarea {
  background: #e8e3da !important;
  color: #2a2a2a !important;
  border: 1px solid transparent !important;
  border-radius: 2px !important;
  padding: 10px 12px !important;
  font-family: "Catamaran", system-ui, sans-serif;
  font-size: 14px;
  box-shadow: none !important;
  transition: background 120ms, border-color 120ms;
  width: 100%;
}
.order-stepper input::placeholder, .order-stepper textarea::placeholder { color: #8a8a8a; }
.order-stepper input:focus, .order-stepper select:focus, .order-stepper textarea:focus {
  background: #f1ece2 !important;
  border-color: #c9a965 !important;
}
.order-stepper select {
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #2a2a2a 50%),
    linear-gradient(135deg, #2a2a2a 50%, transparent 50%) !important;
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50% !important;
  background-size: 5px 5px, 5px 5px !important;
  background-repeat: no-repeat !important;
  padding-right: 32px !important;
}
.order-stepper textarea { resize: vertical; min-height: 90px; font-family: inherit; }

.order-summary-line {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px dashed #2a2a2a;
  font-variant-numeric: tabular-nums;
  align-items: baseline;
}
.order-summary-line .qty-pill { color: #d4b56a; font-weight: 600; }
.order-summary-line .sum-name { color: #fff; }
.order-summary-line .unit-small { color: #7a7a7a; }
.order-summary-line .amt { color: #fff; }

.order-totals-row { display: flex; justify-content: space-between; padding: 4px 0; color: #7a7a7a; font-variant-numeric: tabular-nums; }

.order-total-line {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 18px 0;
  margin-top: 8px;
  border-top: 1px solid #2a2a2a;
}
.order-total-line .label-l { font-size: 20px; letter-spacing: 0.08em; color: #d4b56a; font-weight: 500; }
.order-total-line .total-amt { font-size: 34px; color: #d4b56a; font-variant-numeric: tabular-nums; font-weight: 300; letter-spacing: 0.02em; }

.order-address-card {
  margin-top: 22px;
  background: #141414;
  border: 1px solid #2a2a2a;
  padding: 18px;
  font-size: 14px;
  line-height: 1.6;
}
.order-address-card .caption { color: #fff; margin-bottom: 6px; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; }
.order-address-card .meta { margin-top: 10px; color: #fff; }

.order-footer {
  margin-top: 36px;
  padding-top: 22px;
  border-top: 1px solid #2a2a2a;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.order-footer-total { display: flex; flex-direction: column; gap: 2px; }
.order-footer-total .ey { font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: #8a784a; font-weight: 500; }
.order-footer-total .val { font-size: 24px; color: #d4b56a; font-variant-numeric: tabular-nums; font-weight: 400; letter-spacing: 0.02em; }
.order-footer-actions { display: flex; gap: 10px; }

.order-submit-btn, .order-ghost-btn {
  font-family: "Catamaran", system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  padding: 14px 28px;
  min-width: 180px;
  border-radius: 1px;
  cursor: pointer;
  transition: background 120ms, border-color 120ms, color 120ms;
  text-align: center;
  line-height: 1;
  box-sizing: border-box;
}
.order-submit-btn { background: #d4b56a; color: #1a1304; border: 1px solid #d4b56a; }
.order-submit-btn:hover { background: #e3c577; border-color: #e3c577; }
.order-ghost-btn { background: transparent; color: #fff; border: 1px solid #3a3a3a; }
.order-ghost-btn:hover { border-color: #8a784a; }

@media (max-width: 720px) {
  .order-steps { gap: 4px; margin-bottom: 24px; }
  .order-step-btn { padding: 12px 6px; font-size: 11px; letter-spacing: 0.04em; }
  .order-table-head { display: none; }
  .order-group-head { font-size: 18px; padding: 20px 0 8px; }
  .order-row { grid-template-columns: 1fr auto; gap: 12px; padding: 14px 0; }
  .order-row .o-price { display: none; }
  .order-row .line-total { display: none; }
  .order-row .mobile-price { display: inline; color: #d4b56a; }
  .order-grid-2 { grid-template-columns: 1fr; }
  .order-section-head { font-size: 18px; }
  .order-total-line .total-amt { font-size: 24px; }
  .order-total-line .label-l { font-size: 18px; }
  .order-footer { flex-direction: column; align-items: stretch; gap: 10px; }
  .order-footer-total { flex-direction: row; align-items: baseline; justify-content: space-between; gap: 12px; }
  .order-footer-total .val { font-size: 20px; }
  .order-footer-actions { display: flex; gap: 10px; width: 100%; }
  .order-submit-btn, .order-ghost-btn { padding: 12px 14px; min-width: 0; flex: 1; letter-spacing: 0.16em; }
}
