/** Shopify CDN: Minification failed

Line 12:0 All "@import" rules must come first

**/
/* ── Hide announcement bar on restoration product pages ── */
.shopify-section-group-header-group .announcement-bar,
.shopify-section-group-header-group [class*="announcement"],
announcement-bar,
[id*="announcement"] { display: none !important; }

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* ══════════════════════════════════════════════════
   RESTORATION FORM STYLES
   Loads after Dawn CSS — wins all specificity battles
   ══════════════════════════════════════════════════ */

.rf-page-wrap, .rf-page-wrap * {
  font-family: 'Space Grotesk',sans-serif !important;
  box-sizing: border-box !important;
}

/* ── TOP ROW ── */
.rf-top-row {
  display: grid !important;
  grid-template-columns: 3fr 2fr !important;
  gap: 0 !important;
  align-items: start !important;
  width: 100% !important;
  padding: 0 0 16px !important;
  margin: 0 !important;
}
.rf-media-col { padding: 16px !important; }
.rf-media-box {
  position: relative !important;
  width: 100% !important;
  padding-bottom: 40% !important;
  height: 0 !important;
  overflow: hidden !important;
  border-radius: 8px !important;
  border: 1.5px solid #DDDDD8 !important;
  background: #EFEFED !important;
  display: block !important;
}
.rf-media-box--placeholder { border: 2px dashed #DDDDD8 !important; background: #EFEFED !important; }
.rf-media-img {
  position: absolute !important; inset: 0 !important;
  width: 100% !important; height: 100% !important;
  object-fit: cover !important; display: block !important;
  max-width: none !important; max-height: none !important;
}
.rf-media-ph-inner {
  position: absolute !important; top: 50% !important; left: 50% !important;
  transform: translate(-50%,-50%) !important; text-align: center !important; width: 80% !important;
}
.rf-media-ph-icon  { font-size: 2rem !important; display: block !important; margin-bottom: 8px !important; }
.rf-media-ph-title { font-size: 16px !important; font-weight: 700 !important; color: #4A4A48 !important; margin: 0 0 4px !important; }
.rf-media-ph-sub   { font-size: 0.78rem !important; color: #888884 !important; margin: 0 !important; }

.rf-details-col { padding: 20px 32px 20px 8px !important; }
.rf-details-brand { font-size: 0.85rem !important; font-weight: 700 !important; letter-spacing: 0.14em !important; text-transform: uppercase !important; color: #888884 !important; margin: 0 0 10px !important; }
.rf-details-title { font-size: 2.4rem !important; font-weight: 800 !important; line-height: 1.1 !important; margin: 0 0 16px !important; color: #1A1A1A !important; }
.rf-details-price { font-size: 2rem !important; font-weight: 700 !important; margin: 0 0 4px !important; color: #1A1A1A !important; }
.rf-details-tax   { font-size: 0.9rem !important; color: #888884 !important; margin: 0 0 20px !important; }
.rf-details-delivery-label { font-size: 16px !important; font-weight: 700 !important; letter-spacing: 0.08em !important; text-transform: uppercase !important; color: #4A4A48 !important; margin-bottom: 12px !important; }
.rf-details-variants { display: flex !important; gap: 10px !important; flex-wrap: wrap !important; margin-bottom: 20px !important; }
.rf-variant-pill {
  padding: 12px 24px !important; border-radius: 40px !important; border: 2px solid #DDDDD8 !important;
  font-size: 1rem !important; font-weight: 600 !important; cursor: pointer !important;
  color: #1A1A1A !important; background: #F8F8F6 !important; display: inline-block !important;
}
.rf-variant-pill--active { background: #1A1A1A !important; color: #F8F8F6 !important; border-color: #1A1A1A !important; }
.rf-top-atc-btn {
  width: 100% !important; padding: 17px !important; background: #1A1A1A !important;
  color: #F8F8F6 !important; border: none !important; border-radius: 6px !important;
  font-size: 1.3rem !important; font-weight: 700 !important; cursor: pointer !important;
  margin-bottom: 10px !important; display: block !important; text-align: center !important;
}
.rf-top-atc-btn:hover { background: #E8C547 !important; color: #1A1A1A !important; }
.rf-top-scroll-hint { font-size: 0.85rem !important; color: #888884 !important; text-align: center !important; margin: 0 !important; }

/* ── MULTI-PAIR DISCOUNT BANNER ── */
.rf-multi-discount-banner {
  width: 100% !important;
  background: #F8F8F6 !important;
  border: 1.5px solid #E8C547 !important;
  border-radius: 8px !important;
  padding: 10px 16px !important;
  margin-bottom: 14px !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  color: #264C21 !important;
  text-align: center !important;
  white-space: nowrap !important;
  letter-spacing: 0.01em !important;
}
.rf-multi-discount-banner strong { font-weight: 700 !important; }

/* ── FORM SECTION ── */
.rf-wrap {
  width: 100% !important;
  background: #F8F8F6 !important;
  padding: 0 16px 16px !important;
  margin-top: 0 !important;
  position: relative !important;
}
/* Green divider line — floats between media row and columns */
.rf-wrap::before {
  content: '' !important;
  display: block !important;
  height: 3px !important;
  background: #E8C547 !important;
  margin: 0 0 16px !important;
  border-radius: 2px !important;
}
.rf-inner {
  display: grid !important;
  grid-template-columns: 1fr 1fr 1fr !important;
  border: 1.5px solid #DDDDD8 !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}
.rf-col {
  padding: 24px 28px 28px !important;
  border-right: 1px solid #DDDDD8 !important;
}
.rf-col:last-child { border-right: none !important; }

/* Column titles — green accent, Syne bold */
.rf-col-title {
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #264C21 !important;
  margin: 0 0 18px !important;
  padding-bottom: 10px !important;
  border-bottom: 1.5px solid #E8C547 !important;
}
.rf-col-opt { font-weight: 400 !important; color: #888884 !important; text-transform: none !important; letter-spacing: 0 !important; font-size: 13px !important; }

/* Labels */
.rf-label {
  display: block !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: #4A4A48 !important;
  margin: 16px 0 6px !important;
}
.rf-required { color: #c0392b !important; }

/* Inputs */
.rf-input {
  width: 100% !important; padding: 11px 13px !important;
  border: 1.5px solid #DDDDD8 !important; border-radius: 7px !important;
  font-size: 1.2rem !important; font-weight: 500 !important; color: #1A1A1A !important; background: #F8F8F6 !important;
  -webkit-appearance: none !important; appearance: none !important;
  height: auto !important; min-height: 0 !important; line-height: 1.4 !important;
}
.rf-input::placeholder { color: #E8C547 !important; font-size: 18px !important; }
.rf-input:focus { border-color: #264C21 !important; outline: none !important; box-shadow: 0 0 0 3px rgba(45,90,39,0.1) !important; }

/* Selects */
.rf-select-wrap { position: relative !important; }
.rf-select-wrap::after {
  content: '▾' !important; position: absolute !important; right: 13px !important;
  top: 50% !important; transform: translateY(-50%) !important;
  pointer-events: none !important; color: #4A4A48 !important; font-size: 16px !important;
}
.rf-select {
  width: 100% !important; padding: 11px 36px 11px 13px !important;
  border: 1.5px solid #DDDDD8 !important; border-radius: 7px !important;
  font-size: 1.2rem !important; font-weight: 500 !important; color: #1A1A1A !important; background: #F8F8F6 !important;
  appearance: none !important; -webkit-appearance: none !important;
  height: auto !important; min-height: 0 !important; cursor: pointer !important;
}
.rf-select:focus { border-color: #264C21 !important; outline: none !important; }

/* Loading message */
.rf-loading-msg { font-size: 16px !important; color: #888884 !important; margin: 0 !important; }

/* Lace slots */
.rf-lace-slot {
  margin-bottom: 18px !important;
  padding-bottom: 18px !important;
  border-bottom: 1px dashed #DDDDD8 !important;
}
.rf-lace-slot:last-of-type { border-bottom: none !important; margin-bottom: 0 !important; }
.rf-lace-slot-label {
  font-size: 0.75rem !important; font-weight: 700 !important;
  letter-spacing: 0.08em !important; text-transform: uppercase !important;
  color: #888884 !important; margin: 0 0 10px !important;
}
.rf-lace-options { display: flex !important; flex-direction: column !important; gap: 9px !important; }

/* Lace buttons */
.rf-lace-btn {
  font-size: 1.2rem !important; font-weight: 500 !important;
  padding: 11px 14px !important; border: 1.5px solid #DDDDD8 !important;
  border-radius: 7px !important; background: #F8F8F6 !important; color: #1A1A1A !important;
  width: 100% !important; display: block !important; text-align: center !important;
  cursor: pointer !important; line-height: 1.3 !important;
  transition: all 0.15s !important;
}
.rf-lace-btn:hover { border-color: #264C21 !important; background: #F8F8F6 !important; }
.rf-lace-btn--active { border-color: #264C21 !important; background: #F8F8F6 !important; color: #264C21 !important; font-weight: 600 !important; }

/* Colour wrap and errors */
.rf-lace-colour-wrap { margin-top: 12px !important; }
.rf-colour-error, .rf-size-error { color: #c0392b !important; font-size: 0.82rem !important; margin-top: 5px !important; }

/* Add another pair button */
.rf-add-pair-btn {
  margin-top: 16px !important; width: 100% !important; padding: 11px 14px !important;
  border: 1.5px dashed #264C21 !important; border-radius: 7px !important;
  background: transparent !important; color: #264C21 !important;
  font-size: 0.92rem !important; font-weight: 600 !important; cursor: pointer !important;
  display: block !important; text-align: center !important;
}
.rf-add-pair-btn:hover { background: #F8F8F6 !important; }

/* ── ADD-ON ROWS — built by JS, override all inline styles ── */
.rf-ao-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 13px 14px !important;
  border: 1.5px solid #DDDDD8 !important;
  border-radius: 8px !important;
  margin-bottom: 10px !important;
  cursor: pointer !important;
  transition: all 0.15s !important;
  background: #F8F8F6 !important;
  font-size: 19px !important;
}
.rf-ao-row:last-of-type { margin-bottom: 0 !important; }
.rf-ao-row--checked {
  border-color: #264C21 !important;
  background: #F8F8F6 !important;
}

/* Dawn root font-size is 10px so use px not rem for inline overrides */
.rf-page-wrap [style*="font-size:18px"] { font-size: 18px !important; }
.rf-page-wrap [style*="font-size:16px"] { font-size: 16px !important; }
/* ── EMAIL NOTICE ── */
.rf-email-notice {
  background: #F8F8F6 !important;
  border: 2px solid #264C21 !important;
  border-radius: 12px !important;
  padding: 12px 20px !important;
  margin-top: 12px !important;
  color: #1A1A1A !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
}
.rf-email-notice strong, .rf-email-notice b { font-weight: 700 !important; }
.rf-email-notice span { font-size: 16px !important; line-height: 1.5 !important; }

/* ── GREEN ADDONS TOTAL BANNER ── */
.rf-totals-addons {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: #264C21 !important;
  color: #F8F8F6 !important;
  padding: 12px 20px !important;
  margin-top: 12px !important;
  border-radius: 12px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
}
[id^="rf-addons-total"] {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  color: #F8F8F6 !important;
}

/* ── DARK NAVY TOTAL ORDER BANNER — single compact line ── */
.rf-totals-order {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: #1a1a2e !important;
  color: #F8F8F6 !important;
  padding: 12px 20px !important;
  margin-top: 8px !important;
  border-radius: 12px !important;
  gap: 16px !important;
}
/* The left div contains strong + breakdown — lay them out in a row */
.rf-totals-order > div {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}
.rf-totals-order strong {
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #F8F8F6 !important;
  white-space: nowrap !important;
}
.rf-breakdown-text {
  margin: 0 !important;
  font-size: 1rem !important;
  opacity: 0.75 !important;
  color: #F8F8F6 !important;
}
[id^="rf-order-total"] {
  font-size: 1.8rem !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  color: #F8F8F6 !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

/* ── BLACK ATC BUTTON ── */
.rf-atc-wrap {
  padding: 12px 0 0 !important;
  background: #F8F8F6 !important;
  border-top: none !important;
  margin-top: 8px !important;
}
.rf-atc-btn {
  width: 100% !important; padding: 17px !important;
  background: #1A1A1A !important; color: #F8F8F6 !important;
  border: none !important; border-radius: 5px !important;
  font-size: 1.3rem !important; font-weight: 700 !important;
  cursor: pointer !important; display: flex !important;
  align-items: center !important; justify-content: center !important;
  letter-spacing: 0.04em !important; transition: background 0.2s !important;
}
.rf-atc-btn:hover { background: #E8C547 !important; color: #1A1A1A !important; }

/* Hidden */
.rf-hidden { display: none !important; }

/* ── ADD ANOTHER PAIR BUTTON ── */
.rf-add-another-pair-btn {
  width: 100% !important;
  margin-top: 20px !important;
  padding: 12px 14px !important;
  border: 2px dashed #264C21 !important;
  border-radius: 8px !important;
  background: transparent !important;
  color: #264C21 !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  font-family: 'Space Grotesk', sans-serif !important;
  cursor: pointer !important;
  display: block !important;
  text-align: center !important;
  letter-spacing: 0.02em !important;
  transition: background 0.15s !important;
}
.rf-add-another-pair-btn:hover { background: #F8F8F6 !important; }

/* ── EXTRA PAIR DETAIL BLOCKS ── */
.rf-extra-pair {
  margin-top: 20px !important;
  padding-top: 18px !important;
  border-top: 2px dashed #DDDDD8 !important;
}
.rf-extra-pair-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 12px !important;
}
.rf-extra-pair-lbl {
  font-size: 13px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: #E8C547 !important;
}
.rf-extra-pair-remove {
  background: none !important;
  border: none !important;
  color: #E8C547 !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  padding: 0 !important;
  font-family: 'Space Grotesk', sans-serif !important;
}
.rf-extra-pair-remove:hover { color: #c0392b !important; }
.rf-extra-pair-fields {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

@media (max-width: 749px) {
  .rf-top-row { grid-template-columns: 1fr !important; }
  .rf-inner   { grid-template-columns: 1fr !important; }
  .rf-col { border-right: none !important; border-bottom: 1px solid #DDDDD8 !important; padding: 18px 14px 20px !important; }
  .rf-col:last-child { border-bottom: none !important; }
  .rf-totals-addons, .rf-totals-order { padding: 12px 16px !important; }
  .rf-email-notice { padding: 12px 14px !important; }
}