/* ============================================================
   Advertising Calculator — stylesheet v0.4.0
   ============================================================ */

/* ── Design tokens ── */
.acalc {
  --ac-gold:          #f2b632;
  --ac-gold-dark:     #d99e1a;
  --ac-gold-pale:     #fdf5df;
  --ac-gold-border:   #e8c44a;
  --ac-black:         #111111;
  --ac-white:         #ffffff;
  --ac-grey-light:    #f4f5f7;
  --ac-grey-mid:      #dde1e7;
  --ac-grey-text:     #6b7280;
  --ac-text:          #111827;
  --ac-success:       #1a7f37;
  --ac-danger:        #c0392b;

  --ac-thumb-size:    24px;
  --ac-track-h:       6px;
  --ac-track-radius:  99px;

  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--ac-text);
  max-width: 1000px;
  margin: 0 auto;
  font-size: 15px;
}

.acalc[data-acalc-root="1"] * { box-sizing: border-box; }

/* ============================================================
   MAGAZINE TILES
   ============================================================ */

.acalc[data-acalc-root="1"] .acalc__titlesWrap {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 32px;
}

.acalc[data-acalc-root="1"] .acalc__titlesRow {
  display: grid;
  gap: 10px;
}

.acalc[data-acalc-root="1"] .acalc__titlesRow--top    { grid-template-columns: repeat(3, 1fr); }
.acalc[data-acalc-root="1"] .acalc__titlesRow--bottom { grid-template-columns: 1fr 1fr 0.72fr; }

.acalc[data-acalc-root="1"] .acalc__tile {
  position: relative;
  display: block;
  border: 3px solid transparent;
  border-radius: 8px;
  background: #231f20;
  cursor: pointer;
  user-select: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  overflow: hidden;
}

.acalc[data-acalc-root="1"] .acalc__tile:hover { border-color: rgba(242,182,50,0.45); }

.acalc[data-acalc-root="1"] .acalc__tileInput {
  position: absolute;
  inset: 0;
  opacity: 0;
  margin: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
}

.acalc[data-acalc-root="1"] .acalc__tileFace {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 64px;
  padding: 10px 12px;
  color: var(--ac-white);
  text-align: center;
  pointer-events: none;
}

.acalc[data-acalc-root="1"] .acalc__tileSub {
  display: block;
  font-size: 10px;
  font-weight: 400;
  color: var(--ac-gold);
  font-style: italic;
  letter-spacing: 0.2px;
  margin-bottom: 3px;
}

.acalc[data-acalc-root="1"] .acalc__tileMain {
  display: block;
  font-size: clamp(12px, 1.8vw, 17px);
  font-weight: 800;
  line-height: 1.2;
}

.acalc[data-acalc-root="1"] .acalc__tileLogo {
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: 54px;
  object-fit: contain;
  transform: scale(1);
  transition: transform 0.2s ease;
}

/* Selected state */
.acalc[data-acalc-root="1"] .acalc__tile:has(.acalc__tileInput:checked),
.acalc[data-acalc-root="1"] .acalc__tile.is-selected {
  border-color: transparent;
  /* Thick inner border without layout shift */
  box-shadow: inset 0 0 0 4px var(--ac-gold);
}

/* Slight shrink on hover (still centered) */
.acalc[data-acalc-root="1"] .acalc__tile:hover .acalc__tileLogo {
  transform: scale(0.94);
}

/* More shrink when selected (overrides hover) */
.acalc[data-acalc-root="1"] .acalc__tile:has(.acalc__tileInput:checked) .acalc__tileLogo,
.acalc[data-acalc-root="1"] .acalc__tile.is-selected .acalc__tileLogo {
  transform: scale(0.88);
}

/* SAG logo: slightly larger and nudged down */
.acalc[data-acalc-root="1"] .acalc__tileInput[value="SAG"] ~ .acalc__tileFace {
  justify-content: center;
  padding-bottom: 6px;
}
.acalc[data-acalc-root="1"] .acalc__tileInput[value="SAG"] ~ .acalc__tileFace .acalc__tileLogo {
  max-height: 60px;
}

/* Views counter */
.acalc[data-acalc-root="1"] .acalc__views {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--ac-gold);
  border-radius: 8px;
  padding: 10px 14px;
  min-height: 64px;
  text-align: center;
}

.acalc[data-acalc-root="1"] .acalc__viewsNumber {
  font-size: clamp(20px, 3.2vw, 30px);
  font-weight: 900;
  color: var(--ac-black);
  line-height: 1;
  letter-spacing: -0.5px;
}

.acalc[data-acalc-root="1"] .acalc__viewsLabel {
  font-size: 11px;
  font-weight: 600;
  color: rgba(0,0,0,0.6);
  margin-top: 4px;
  white-space: nowrap;
}

/* ============================================================
   SLIDERS
   ============================================================ */

.acalc[data-acalc-root="1"] .acalc__sliders {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px 48px;
  margin-bottom: 32px;
}

.acalc[data-acalc-root="1"] .acalc__fieldLabel {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 20px;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

/* Outer wrapper: extra bottom padding holds the tick labels */
.acalc[data-acalc-root="1"] .acalc__sliderWrap {
  position: relative;
  padding-bottom: 32px;
}

/* ── The track ── */
.acalc[data-acalc-root="1"] .acalc__range {
  -webkit-appearance: none;
  appearance: none;
  display: block;
  width: 100%;
  height: var(--ac-track-h);
  border-radius: var(--ac-track-radius);
  outline: none;
  cursor: pointer;
  /* --range-pct is updated by JS on every input event */
  background: linear-gradient(
    to right,
    var(--ac-gold)      0%,
    var(--ac-gold)      var(--range-pct, 0%),
    var(--ac-grey-mid)  var(--range-pct, 0%),
    var(--ac-grey-mid)  100%
  );
  transition: background 0.05s;
}

/* ── Thumb (WebKit) ── */
.acalc[data-acalc-root="1"] .acalc__range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width:  var(--ac-thumb-size);
  height: var(--ac-thumb-size);
  border-radius: 50%;
  background: var(--ac-white);
  border: 3px solid var(--ac-gold);
  /* Center the thumb on the track */
  margin-top: calc((var(--ac-track-h) - var(--ac-thumb-size)) / 2);
  box-shadow: 0 2px 8px rgba(0,0,0,0.18), 0 0 0 0 rgba(242,182,50,0);
  cursor: grab;
  transition: transform 0.12s ease, box-shadow 0.12s ease;
}
.acalc[data-acalc-root="1"] .acalc__range::-webkit-slider-thumb:hover,
.acalc[data-acalc-root="1"] .acalc__range:focus::-webkit-slider-thumb {
  transform: scale(1.22);
  box-shadow: 0 3px 12px rgba(0,0,0,0.2), 0 0 0 5px rgba(242,182,50,0.25);
}
.acalc[data-acalc-root="1"] .acalc__range:active::-webkit-slider-thumb {
  cursor: grabbing;
  transform: scale(1.15);
}

/* ── Thumb (Firefox) ── */
.acalc[data-acalc-root="1"] .acalc__range::-moz-range-thumb {
  width:  var(--ac-thumb-size);
  height: var(--ac-thumb-size);
  border-radius: 50%;
  background: var(--ac-white);
  border: 3px solid var(--ac-gold);
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
  cursor: grab;
  transition: transform 0.12s ease;
}
.acalc[data-acalc-root="1"] .acalc__range::-moz-range-thumb:hover { transform: scale(1.22); }
.acalc[data-acalc-root="1"] .acalc__range:active::-moz-range-thumb { cursor: grabbing; }

/* Remove default Firefox track styling */
.acalc[data-acalc-root="1"] .acalc__range::-moz-range-track {
  height: var(--ac-track-h);
  border-radius: var(--ac-track-radius);
  background: transparent;
}

/* ── Tick container ── */
.acalc[data-acalc-root="1"] .acalc__ticks {
  position: absolute;
  bottom: 0;
  left:  0;
  right: 0;
  height: 24px;
  pointer-events: none;
}

/* Individual tick */
.acalc[data-acalc-root="1"] .acalc__tick {
  position: absolute;
  top: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  color: var(--ac-grey-text);
  font-weight: 500;
  white-space: nowrap;
  line-height: 1;
  /* Center the label on the snap point */
  transform: translateX(-50%);
}

.acalc[data-acalc-root="1"] .acalc__tick[data-edge="left"]  { transform: translateX(0); }
.acalc[data-acalc-root="1"] .acalc__tick[data-edge="right"] { transform: translateX(-100%); }

/* Tick notch line */
.acalc[data-acalc-root="1"] .acalc__tick::before {
  content: "";
  display: block;
  width: 1px;
  height: 7px;
  background: var(--ac-grey-mid);
}

/* Active tick */
.acalc[data-acalc-root="1"] .acalc__tick.is-active {
  color: var(--ac-black);
  font-weight: 800;
  font-size: 12px;
}
.acalc[data-acalc-root="1"] .acalc__tick.is-active::before {
  width:  2px;
  height: 9px;
  background: var(--ac-gold-dark);
}

/* ============================================================
   RESULT PANEL
   ============================================================ */

.acalc[data-acalc-root="1"] .acalc__panel {
  background: var(--ac-grey-light);
  border: 1px solid var(--ac-grey-mid);
  border-radius: 14px;
  padding: 16px 18px 10px;
  box-shadow: 0 6px 28px rgba(0,0,0,0.07);
}

/* ── Discount + Price row ── */
.acalc[data-acalc-root="1"] .acalc__panelTop {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  align-items: start;
  margin-bottom: 14px;
}

.acalc[data-acalc-root="1"] .acalc__discounts {
  justify-self: end;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-width: 0;
  align-items: flex-end;
}

.acalc[data-acalc-root="1"] .acalc__discountBridge {
  align-self: stretch;
  margin: 0;
  padding: 0;
  font-size: 11px;
  line-height: 1.15;
  font-weight: 600;
  color: var(--ac-grey-text);
  text-align: center;
  letter-spacing: 0.01em;
}

.acalc[data-acalc-root="1"] .acalc__panelStat {
  display: grid;
  grid-template-columns: max-content minmax(92px, max-content);
  align-items: center;
  gap: 10px;
}

.acalc[data-acalc-root="1"] .acalc__panelStatLabel {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.1;
  white-space: normal;
  text-align: right;
}

.acalc[data-acalc-root="1"] .acalc__panelStat--onlinePrompt {
  grid-template-columns: 1fr;
  justify-items: end;
}

.acalc[data-acalc-root="1"] .acalc__panel .acalc__panelStat--onlinePrompt .acalc__panelStatLabel {
  font-size: 19px;
  font-weight: 800;
  letter-spacing: 0;
  color: #b14404;
  max-width: 240px;
  white-space: normal;
}

/* Harden against theme overrides on live site */
.acalc[data-acalc-root="1"] button.acalc__bookBtn {
  font-family: inherit;
  font-size: 16px;
  line-height: 1;
  text-transform: none;
  letter-spacing: 0;
}

.acalc[data-acalc-root="1"] .acalc__bookWrap {
  position: relative;
  width: 100%;
}

.acalc[data-acalc-root="1"] .acalc__tooltip {
  position: absolute;
  right: 0;
  bottom: calc(100% + 10px);
  max-width: 320px;
  background: rgba(17,24,39,0.95);
  color: #fff;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.25;
  box-shadow: 0 12px 28px rgba(0,0,0,0.25);
}
.acalc[data-acalc-root="1"] .acalc__tooltip::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 100%;
  border: 7px solid transparent;
  border-top-color: rgba(17,24,39,0.95);
}

.acalc[data-acalc-root="1"] .acalc__views {
  font-family: inherit;
  padding: 10px 14px;
  min-height: 64px;
}

.acalc[data-acalc-root="1"] .acalc__viewsNumber {
  font-size: clamp(20px, 3.2vw, 30px);
  line-height: 1;
}

.acalc[data-acalc-root="1"] .acalc__badge {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background: var(--ac-gold);
  color: var(--ac-black);
  font-size: 18px;
  font-weight: 900;
  padding: 4px 10px;
  border-radius: 5px;
  letter-spacing: 0.2px;
}

.acalc[data-acalc-root="1"] .acalc__priceBox {
  align-self: start;
  display: flex;
  justify-content: center;
  min-width: 260px;
  justify-self: center;
}

.acalc[data-acalc-root="1"] .acalc__priceBox .acalc__badge {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-width: 210px;
  min-height: 80px;
  padding: 4px 7px 4px;
  gap: 1px;
  line-height: 1;
}

.acalc[data-acalc-root="1"] .acalc__priceValue {
  font-size: 40px;
  font-weight: 900;
  line-height: 1;
}

.acalc[data-acalc-root="1"] .acalc__priceInlineLabel {
  font-size: 18px;
  font-weight: 800;
  line-height: 1.2;
  text-align: center;
}

.acalc[data-acalc-root="1"] .acalc__callCol {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 200px;
  justify-self: center;
}

.acalc[data-acalc-root="1"] .acalc__callUsBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 9px 14px;
  border-radius: 5px;
  background: #231f20;
  color: #fff;
  font-weight: 800;
  font-size: 18px;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 10px 24px rgba(0,0,0,0.16);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  line-height: 1;
  text-align: center;
}

.acalc[data-acalc-root="1"] .acalc__callUsBtnNumber {
  font-weight: 900;
  opacity: 0.95;
}

@media (min-width: 1024px) {
  .acalc[data-acalc-root="1"] .acalc__callUsBtn {
    font-size: 19px;
  }
}

.acalc[data-acalc-root="1"] .acalc__callUsBtn svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.acalc[data-acalc-root="1"] .acalc__callUsBtn:hover {
  transform: translateY(-1px);
  box-shadow:
    inset 0 0 0 2px var(--ac-gold),
    0 14px 30px rgba(0,0,0,0.22);
  background: #2f2a2b;
}

.acalc[data-acalc-root="1"] .acalc__callUsBtn:active {
  transform: translateY(0);
  box-shadow: 0 10px 24px rgba(0,0,0,0.16);
}

.acalc[data-acalc-root="1"] .acalc__callUsBtn:focus-visible {
  outline: 3px solid rgba(242,182,50,0.65);
  outline-offset: 2px;
}

.acalc[data-acalc-root="1"] .acalc__bookBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 8px 14px;
  border-radius: 5px;
  background: var(--ac-gold);
  color: var(--ac-black);
  font-weight: 800;
  font-size: 16px;
  font-family: inherit;
  border: 1px solid var(--ac-gold-border);
  box-shadow: 0 8px 20px rgba(0,0,0,0.1);
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
  line-height: 1;
  text-align: center;
}

.acalc[data-acalc-root="1"] .acalc__bookBtnIcon svg {
  width: 18px;
  height: 18px;
  display: block;
}

.acalc[data-acalc-root="1"] .acalc__bookBtn:hover {
  transform: translateY(-1px);
  box-shadow:
    inset 0 0 0 2px rgba(35,31,32,0.35),
    0 12px 26px rgba(0,0,0,0.14);
  background: var(--ac-gold-dark);
  color: var(--ac-white);
}

.acalc[data-acalc-root="1"] .acalc__bookBtn:active {
  transform: translateY(0);
  box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

.acalc[data-acalc-root="1"] .acalc__bookBtn:focus-visible {
  outline: 3px solid rgba(35,31,32,0.55);
  outline-offset: 2px;
}

/* call number moved into the button */

/* CTA row removed */

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 820px) {
  .acalc[data-acalc-root="1"] .acalc__titlesRow--bottom {
    grid-template-columns: 1fr 1fr;
  }
  .acalc[data-acalc-root="1"] .acalc__views {
    grid-column: 1 / -1;
    flex-direction: row;
    justify-content: center;
    gap: 10px;
    min-height: auto;
    padding: 10px 20px;
  }
  .acalc[data-acalc-root="1"] .acalc__viewsLabel { margin-top: 0; font-size: 13px; }
  .acalc[data-acalc-root="1"] .acalc__sliders { grid-template-columns: 1fr; gap: 28px; }
  .acalc[data-acalc-root="1"] .acalc__panelStatLabel { font-size: 17px; }
  .acalc[data-acalc-root="1"] .acalc__badge { font-size: 17px; }
  .acalc[data-acalc-root="1"] .acalc__priceValue { font-size: 40px; }
  .acalc[data-acalc-root="1"] .acalc__panelStat { grid-template-columns: 1fr minmax(80px, max-content); }
}

@media (max-width: 560px) {
  /* Make the whole titles area one 2-col grid so we can fill gaps */
  .acalc[data-acalc-root="1"] .acalc__titlesWrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .acalc[data-acalc-root="1"] .acalc__titlesRow { display: contents; }

  /* Place SAG into the "empty" tile spot on mobile */
  .acalc[data-acalc-root="1"] .acalc__tile:has(.acalc__tileInput[value="SAG"]) {
    grid-column: 2;
    grid-row: 2;
  }

  /* Place the views box where SAG used to be */
  .acalc[data-acalc-root="1"] .acalc__views {
    grid-column: 2;
    grid-row: 3;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    padding: 10px 14px;
  }
  .acalc[data-acalc-root="1"] .acalc__viewsLabel { margin-top: 0; font-size: 11px; white-space: normal; }

  /* Push PG down so views sits beside PG */
  .acalc[data-acalc-root="1"] .acalc__tile:has(.acalc__tileInput[value="PG"]) {
    grid-column: 1;
    grid-row: 3;
  }

  .acalc[data-acalc-root="1"] .acalc__panelTop          { grid-template-columns: 1fr; gap: 16px; }
  .acalc[data-acalc-root="1"] .acalc__discounts         { width: 100%; justify-self: stretch; align-items: stretch; }
  .acalc[data-acalc-root="1"] .acalc__panelStat         { grid-template-columns: 1fr minmax(72px, max-content); }
  .acalc[data-acalc-root="1"] .acalc__panelStatLabel    { font-size: 19px; }
  .acalc[data-acalc-root="1"] .acalc__badge             { font-size: 22px; padding: 5px 10px; }
  .acalc[data-acalc-root="1"] .acalc__priceBox          { width: 100%; min-width: 0; justify-content: stretch; }
  .acalc[data-acalc-root="1"] .acalc__priceBox .acalc__badge { width: 100%; min-width: 0; min-height: 96px; padding: 8px 10px 7px; }
  .acalc[data-acalc-root="1"] .acalc__priceValue        { font-size: 34px; }
  .acalc[data-acalc-root="1"] .acalc__priceInlineLabel  { font-size: 16px; }
  .acalc[data-acalc-root="1"] .acalc__callCol           { align-items: stretch; min-width: 0; justify-self: stretch; }
  .acalc[data-acalc-root="1"] .acalc__callUsBtn         { width: 100%; font-size: 18px; }
}

/* ============================================================
   STAGES (calc / enquiry / thanks) + fade transitions
   ============================================================ */

.acalc[data-acalc-root="1"] .acalc__stage {
  opacity: 1;
  transition: opacity 0.28s ease;
}
.acalc[data-acalc-root="1"] .acalc__stage[hidden] {
  display: none;
}
.acalc[data-acalc-root="1"] .acalc__stage--leaving {
  opacity: 0;
  pointer-events: none;
}
.acalc[data-acalc-root="1"] .acalc__stage--entering {
  opacity: 0;
}

.acalc[data-acalc-root="1"] .acalc__stageHeading {
  margin: 0 0 18px;
  font-size: 26px;
  font-weight: 800;
  color: var(--ac-text);
  text-align: center;
}

/* ============================================================
   STAGE 2 — Order summary + enquiry form
   ============================================================ */

.acalc[data-acalc-root="1"] .acalc__orderSummary {
  background: var(--ac-grey-light);
  border: 1px solid var(--ac-grey-mid);
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 22px;
  display: block;
  box-shadow: 0 6px 22px rgba(0,0,0,0.05);
}

.acalc[data-acalc-root="1"] .acalc__orderCols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 28px;
}

.acalc[data-acalc-root="1"] .acalc__orderCol {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.acalc[data-acalc-root="1"] .acalc__orderItem {
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 10px;
  align-items: baseline;
  padding: 9px 0;
  border-bottom: 1px dashed rgba(0,0,0,0.07);
  font-size: 15px;
}
.acalc[data-acalc-root="1"] .acalc__orderItem:last-child {
  border-bottom: none;
}
.acalc[data-acalc-root="1"] .acalc__orderItem--pinBottom {
  margin-top: auto;
  padding-top: 14px;
}
.acalc[data-acalc-root="1"] .acalc__orderLabel {
  font-weight: 800;
  color: var(--ac-black);
  white-space: normal;
}
.acalc[data-acalc-root="1"] .acalc__orderValue {
  font-weight: 500;
  color: var(--ac-text);
  text-align: left;
  word-break: break-word;
}
.acalc[data-acalc-root="1"] .acalc__orderItem--emphasis .acalc__orderLabel,
.acalc[data-acalc-root="1"] .acalc__orderItem--emphasis .acalc__orderValue {
  font-size: 18px;
  font-weight: 800;
  color: var(--ac-black);
}

.acalc[data-acalc-root="1"] .acalc__enquiryForm {
  background: var(--ac-white);
  border: 1px solid var(--ac-grey-mid);
  border-radius: 12px;
  padding: 18px 18px 16px;
  box-shadow: 0 6px 22px rgba(0,0,0,0.05);
}

.acalc[data-acalc-root="1"] .acalc__formGrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 18px;
}

.acalc[data-acalc-root="1"] .acalc__formField {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.acalc[data-acalc-root="1"] .acalc__formField--full {
  grid-column: 1 / -1;
}

.acalc[data-acalc-root="1"] .acalc__formLabel {
  font-size: 13px;
  font-weight: 700;
  color: var(--ac-grey-text);
  letter-spacing: 0.02em;
}
.acalc[data-acalc-root="1"] .acalc__req {
  color: var(--ac-danger);
}

.acalc[data-acalc-root="1"] .acalc__formInput {
  width: 100%;
  font: inherit;
  font-size: 15px;
  padding: 10px 12px;
  border: 1px solid var(--ac-grey-mid);
  border-radius: 8px;
  background: var(--ac-white);
  color: var(--ac-text);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.acalc[data-acalc-root="1"] textarea.acalc__formInput {
  resize: vertical;
  min-height: 96px;
}
.acalc[data-acalc-root="1"] .acalc__formInput:focus {
  outline: none;
  border-color: var(--ac-gold);
  box-shadow: 0 0 0 3px rgba(242,182,50,0.25);
}

.acalc[data-acalc-root="1"] .acalc__terms {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 16px 0 6px;
  font-size: 14px;
  color: var(--ac-text);
  cursor: pointer;
}
.acalc[data-acalc-root="1"] .acalc__terms input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  cursor: pointer;
  accent-color: var(--ac-gold-dark);
}
.acalc[data-acalc-root="1"] .acalc__terms a {
  color: var(--ac-gold-dark);
  text-decoration: underline;
}

.acalc[data-acalc-root="1"] .acalc__enquiryError {
  margin: 12px 0 0;
  padding: 10px 12px;
  border-radius: 8px;
  background: #fdecea;
  border: 1px solid #f5c2bc;
  color: #9b2418;
  font-size: 14px;
  font-weight: 600;
}

.acalc[data-acalc-root="1"] .acalc__formActions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}

.acalc[data-acalc-root="1"] .acalc__primaryBtn,
.acalc[data-acalc-root="1"] .acalc__secondaryBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 11px 20px;
  border-radius: 6px;
  font-weight: 800;
  font-family: inherit;
  font-size: 15px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease, color 0.15s ease;
  line-height: 1;
}

.acalc[data-acalc-root="1"] .acalc__primaryBtn {
  background: var(--ac-gold);
  color: var(--ac-black);
  border-color: var(--ac-gold-border);
  box-shadow: 0 8px 18px rgba(0,0,0,0.10);
}
.acalc[data-acalc-root="1"] .acalc__primaryBtn:hover {
  background: var(--ac-gold-dark);
  color: var(--ac-white);
  transform: translateY(-1px);
}
.acalc[data-acalc-root="1"] .acalc__primaryBtn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.acalc[data-acalc-root="1"] .acalc__secondaryBtn {
  background: var(--ac-white);
  color: var(--ac-text);
  border-color: var(--ac-grey-mid);
}
.acalc[data-acalc-root="1"] .acalc__secondaryBtn:hover {
  background: var(--ac-grey-light);
}

.acalc[data-acalc-root="1"] .acalc__enquiryForm.is-submitting .acalc__primaryBtn::after {
  content: "…";
  margin-left: 6px;
}

/* ============================================================
   STAGE 3 — Thank you
   ============================================================ */

.acalc[data-acalc-root="1"] .acalc__stage--thanks {
  text-align: center;
  padding: 20px 18px 18px;
  background: var(--ac-grey-light);
  border: 1px solid var(--ac-grey-mid);
  border-radius: 14px;
  box-shadow: 0 6px 28px rgba(0,0,0,0.07);
}
.acalc[data-acalc-root="1"] .acalc__thanksLead {
  margin: 0 0 24px;
  font-size: 17px;
  color: var(--ac-text);
}
.acalc[data-acalc-root="1"] .acalc__thanksContact {
  font-size: 16px;
  color: var(--ac-grey-text);
}
.acalc[data-acalc-root="1"] .acalc__contactLink {
  color: var(--ac-gold-dark);
  font-weight: 800;
  text-decoration: underline;
  cursor: pointer;
}
.acalc[data-acalc-root="1"] .acalc__contactLink:hover {
  color: var(--ac-black);
}


/* ============================================================
   STAGES — small screen tweaks
   ============================================================ */

@media (max-width: 560px) {
  .acalc[data-acalc-root="1"] .acalc__formGrid {
    grid-template-columns: 1fr;
  }
  .acalc[data-acalc-root="1"] .acalc__orderCols {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .acalc[data-acalc-root="1"] .acalc__formActions {
    flex-direction: column-reverse;
  }
  .acalc[data-acalc-root="1"] .acalc__primaryBtn,
  .acalc[data-acalc-root="1"] .acalc__secondaryBtn {
    width: 100%;
  }
}
