:root {
  --ink:#0a0a0a;
  --mut:#6b6b6b;
  --br:#e6e6e6;
  --sel:#e7e7e7;
  --hover:#f7f7f7;
  --sans: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display",
          Inter, "Segoe UI", Roboto, Helvetica, Arial, "Noto Sans", sans-serif;
}

* {
  box-sizing:border-box;
}

html {
  scroll-behavior:smooth;
}

body {
  margin:0;
  color:var(--ink);
  background:#fff;
  font-family:var(--sans);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.wrap {
  max-width:none;
  margin:22px auto;
  padding:0 24px;
}

.h1 {
  margin:4px 0 4px;
  font-family:Montserrat, var(--sans);
  font-weight:800;
  letter-spacing:.02em;
  text-transform:uppercase;
  font-size:clamp(20px, 2.2vw, 34px);
}

.small.muted {
  color:var(--mut);
}

/* Grid rows */
.row {
  display:grid;
  grid-template-columns:minmax(680px,1.6fr) minmax(320px,.6fr);
  gap:28px;
  align-items:start;
  margin:34px 0;
  border-top:1px solid var(--br);
  padding-top:22px;
}

@media (max-width:1100px) {
  .row {
    grid-template-columns:1fr;
  }
}

.viewer {
  border:none;
  background:transparent;
  padding:0;
}

.stage {
  position:relative;
}

/* Canvas */
.stack {
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  border:none;
}

.frame {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  transform:translateX(0);
  transition:none;
  pointer-events:none;
}

.frame img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}

.layers {
  position:absolute;
  inset:0;
  pointer-events:none;
}

.layer {
  position:absolute;
  inset:0;
}

.layer-img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
}

/* Arrows */
.view-arrow {
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:36px;
  height:36px;
  border-radius:6px;
  border:1px solid var(--br);
  background:#fff;
  color:#000;
  cursor:pointer;
  font-size:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 2px 6px rgba(0,0,0,.08);
  z-index:20;
}

.view-arrow.prev {
  left:12px;
}

.view-arrow.next {
  right:12px;
}

.view-arrow.disabled {
  opacity:.65;
}

/* Panel */
.panel {
  position:sticky;
  top:24px;
  padding:0;
  background:#fff;
  font-size:.95rem;
}

.panel-title {
  margin:0 0 12px;
  padding-left:14px;
  transform:translateX(6px);
  font-family:Montserrat, var(--sans);
  font-weight:700;
  letter-spacing:.03em;
  text-transform:uppercase;
  font-size:clamp(16.8px, 1.44vw, 21.6px);
}

/* Option rows */
.row-line {
  position:relative;
  display:flex;
  gap:10px;
  align-items:center;
  padding:10px 12px 10px 18px;
  padding-right:56px;
  border-radius:10px;
  transition:background-color .15s ease, opacity .15s ease;
  cursor:pointer;
  margin-bottom:8px;
  background:transparent;
  font-weight:500;
}

.row-line:hover {
  background:var(--hover);
}

.row-line.is-selected {
  background:var(--sel);
}

.row-line.locked {
  cursor:default;
}

.row-line.locked:hover {
  background:var(--sel);
}

.row-line input[type="radio"],
.row-line input[type="checkbox"] {
  position:absolute;
  opacity:0;
  width:0;
  height:0;
  pointer-events:none;
}

.opt-main {
  display:flex;
  flex-direction:column;
}

.opt-title {
  font-weight:600;
  font-family:var(--sans);
  font-size:.95rem;
}

.opt-caption {
  color:var(--mut);
  font-size:.82rem;
  margin-top:1px;
}

.opt-price {
  margin-left:auto;
  white-space:nowrap;
  font-weight:600;
  color:var(--ink);
  font-family:var(--sans);
}

.opt-price.as-standard {
  color:var(--mut);
  font-weight:500;
}

/* Selection indicator */
.row-line::after {
  content:'';
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  width:20px;
  height:20px;
  border-radius:50%;
  border:2px solid #000;
  background:#fff;
  color:#fff;
  display:inline-block;
  line-height:20px;
  text-align:center;
}

.row-line.is-selected::after {
  content:'✓';
  background:#000;
  color:#fff;
  border-color:#000;
}

/* Loading spinner */
.row-line.loading::after {
  content:'';
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  width:20px;
  height:20px;
  border-radius:50%;
  border:2px solid #000;
  border-top-color:transparent;
  background:transparent;
  animation:spin .7s linear infinite;
}

@keyframes spin {
  100% {
    transform:translateY(-50%) rotate(360deg);
  }
}

.subhead {
  font-weight:700;
  margin:12px 0 8px 18px;
  color:var(--mut);
  text-transform:uppercase;
  letter-spacing:.03em;
  font-size:.82rem;
}

/* Summary */
.foot {
  margin:48px 0;
}

.quote-summary {
  font-family:var(--sans);
}

.quote-table {
  width:100%;
  border-collapse:collapse;
  font-variant-numeric:tabular-nums;
}

.quote-table th,
.quote-table td {
  padding:10px 6px;
  font-family:var(--sans);
}

.quote-table thead td {
  padding:12px 6px;
  border-bottom:1px solid var(--br);
  font-family:Montserrat, var(--sans);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.02em;
}

.quote-table tbody tr {
  border-bottom:1px solid var(--br);
}

.quote-table .price {
  text-align:right;
  white-space:nowrap;
  font-weight:600;
}

.quote-table .price.standard {
  color:var(--mut);
}

.quote-table tfoot .sep td {
  height:8px;
  border-bottom:1px solid var(--br);
  padding:0;
}

.quote-table tfoot tr {
  border-bottom:1px solid var(--br);
}

.quote-table tfoot tr.grand td {
  font-size:1.05rem;
  font-weight:800;
  font-family:Montserrat, var(--sans);
}

/* Group headers in summary */
.quote-table .grp td {
  padding-top:16px;
  font-weight:800;
  font-family:Montserrat, var(--sans);
  text-transform:uppercase;
  letter-spacing:.02em;
  color:#222;
  background:#fafafa;
}

.quote-table .subgrp td {
  padding-top:8px;
  font-weight:700;
  color:#444;
  font-family:var(--sans);
}

/* Below summary */
.eta {
  margin:12px 0 10px;
  color:var(--mut);
}

.actions {
  display:flex;
  gap:12px;
  flex-wrap:nowrap;
}

.btn {
  padding:14px 20px;
  border:none;
  border-radius:10px;
  background:#111;
  color:#fff;
  cursor:pointer;
  font-weight:700;
  letter-spacing:.02em;
  font-size:1rem;
  white-space:nowrap;
  font-family:var(--sans);
  flex:1 1 0;
  text-align:center;
}

.btn.btn-pay {
  background:#2c2c2c;
}

.btn.btn-pay:hover {
  background:#222;
}

.btn:hover {
  filter:brightness(.95);
}

/* Sticky Total */
.sticky-total {
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:50;
  width:360px;
  max-width:calc(100vw - 48px);
  background:#111;
  color:#fff;
  border-radius:10px;
  padding:12px 14px;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-weight:700;
  letter-spacing:.02em;
  transition:opacity .18s ease, transform .18s ease;
  font-family:Montserrat, var(--sans);
}

.sticky-total {
  width:360px;
  max-width:calc(100vw - 48px);
  background:#111;
  color:#fff;
  border-radius:10px;
  padding:12px 14px;
  box-shadow:0 6px 18px rgba(0,0,0,.18);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-weight:700;
  letter-spacing:.02em;
  transition:opacity .18s ease, transform .18s ease;
  font-family:Montserrat, var(--sans);
}

.sticky-total.hidden {
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
}

.sticky-total .summary-btn {
  background:#fff;
  color:#000;
  border:1px solid transparent;
  border-radius:8px;
  padding:8px 12px;
  cursor:pointer;
  font-weight:700;
  font-size:.9rem;
  letter-spacing:.02em;
}

.sticky-total .summary-btn:hover {
  background:#f2f2f2;
}

.sticky-total .summary-btn:focus {
  outline:none;
  border-color:#bbb;
}

/* Divider before summary */
.full-divider {
  border:none;
  border-top:1px solid var(--br);
  margin:34px -24px 0;
}

/* Alignment helpers */
.opt-caption:empty {
  display:none;
}

.row-line.no-caption .opt-main {
  justify-content:center;
}

/* Collage */
.collage-wrap {
  max-width:1200px;
  margin:0 auto;
  padding:0 16px;
}

.collage-title {
  margin:0 0 12px;
  font-family:Montserrat, var(--sans);
  font-weight:700;
  letter-spacing:.03em;
  text-transform:uppercase;
  font-size:clamp(16px, 1.6vw, 22px);
}

.collage {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.collage-item {
  position:relative;
  width:100%;
  background:#f3f3f3;
}

.collage-item .collage-base,
.collage-item .collage-layers .layer-img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.collage-item .collage-layers {
  position:absolute;
  inset:0;
  pointer-events:none;
}

/* Layout: 1 full, 2 half, 3 half, 4 full */
.collage .item-1 {
  grid-column:1 / -1;
  aspect-ratio:1/1;
}

.collage .item-2 {
  grid-column:auto;
  aspect-ratio:1/1;
}

.collage .item-3 {
  grid-column:auto;
  aspect-ratio:1/1;
}

.collage .item-4 {
  grid-column:1 / -1;
  aspect-ratio:1/1;
}

/* HubSpot polish */
#hs-form-st5 .hsfc-Step__Content {
  padding:0 !important;
}

#hs-form-st5 .hs-button,
#hs-form-st5 input[type="submit"] {
  background:#111 !important;
  color:#fff !important;
  border:none !important;
  border-radius:10px !important;
  padding:14px 20px !important;
  font-weight:700 !important;
  letter-spacing:.02em !important;
  font-size:1rem !important;
  font-family:var(--sans) !important;
  width:100% !important;
  cursor:pointer;
}

#hs-form-st5 .hs-button:hover,
#hs-form-st5 input[type="submit"]:hover {
  filter:brightness(.95) !important;
}

#hs-form-st5 .hs-button:focus-visible,
#hs-form-st5 input[type="submit"]:focus-visible {
  outline:2px solid #bbb !important;
  outline-offset:2px;
}

/* Match "Save your Build" heading to Summary */
#quoteForm .collage-title {
  margin:48px 20px 12px; /* same top/bottom spacing as Summary */
}

.location-toggle {
  display:flex;
  align-items:center;
  gap:6px;
  margin:6px 0 4px;
  font-size:.8rem;
  color:var(--mut);
}

.location-toggle span {
  text-transform:uppercase;
  letter-spacing:.12em;
  font-weight:600;
  font-size:.7rem;
}

.location-toggle button,
.sticky-total .summary-btn {
  padding:4px 10px;
  border-radius:999px;
  border:1px solid var(--br);
  background:#fff;
  color:var(--ink);
  font-size:.72rem;
  cursor:pointer;
}

.location-toggle button.is-active {
  background:#111;
  color:#fff;
  border-color:#111;
}

/* Mobile tweaks */
@media (min-width:1100px) {
  .collage .item-1,
  .collage .item-2,
  .collage .item-3,
  .collage .item-4 {
    aspect-ratio:auto;
    min-height:320px;
  }

  .collage-item .collage-base,
  .collage-item .collage-layers .layer-img {
    object-fit:contain;
    position:absolute;
    inset:0;
  }
}

@media (max-width:768px) {
  .viewer {
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
  }

  .stack {
    aspect-ratio:4/3;
  }

  .frame img,
  .layer-img {
    object-fit:cover;
  }

  .view-arrow {
    top:auto;
    bottom:12px;
    transform:none;
  }

  .view-arrow.prev {
    left:8px;
  }

  .view-arrow.next {
    right:8px;
  }

  .panel {
    font-size:.92rem;
  }

  .opt-title {
    font-size:.92rem;
  }

  .opt-caption {
    font-size:.8rem;
  }

  /* .sticky-total{left:0;right:0;bottom:0;width:100%;max-width:none;border-radius:0;padding:14px 16px} */

  .actions {
    gap:10px;
    flex-wrap:nowrap;
  }

  .btn {
    padding:14px 12px;
  }

  .quote-table {
    font-size:13px !important;
  }
}

/* Optional motion polish */
.stage.cover-mode .frame {
  will-change:transform;
}

.stage.cover-mode .frame.covering {
  box-shadow:-18px 0 28px rgba(0,0,0,.10);
}

@media (prefers-reduced-motion:reduce) {
  .stage.cover-mode .frame {
    transition:none !important;
  }
}

/* Make sticky "Summary" match Location pill buttons */
/* .sticky-total .summary-btn{
  padding:4px 10px;
  border-radius:999px;
  border:1px solid var(--br);
  background:#fff;
  color:var(--ink);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  line-height:1;
  white-space:nowrap;
  box-shadow:none;
} */

.sticky-total .summary-btn:hover {
  background:var(--hover);
}

.sticky-total .summary-btn:active {
  transform:translateY(1px);
}

.sticky-total .summary-btn:focus-visible {
  outline:2px solid #bbb;
  outline-offset:2px;
}



/* Location prompt modal */
.location-modal {
  position:fixed;
  inset:0;
  z-index:60;
  display:none;
  align-items:center;
  justify-content:center;
  font-family:var(--sans);
}

.location-modal.is-visible {
  display:flex;
}

.location-modal__backdrop {
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
}

.location-modal__dialog {
  position:relative;
  background:#fff;
  border-radius:14px;
  padding:20px 22px 18px;
  max-width:320px;
  width:calc(100% - 48px);
  box-shadow:0 18px 40px rgba(0,0,0,.25);
  text-align:center;
}

.location-modal__dialog h2 {
  margin:0 0 8px;
  font-family:Montserrat, var(--sans);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.03em;
  text-transform:uppercase;
}

.location-modal__text {
  margin:0 0 16px;
  font-size:.85rem;
  color:var(--mut);
}

.location-modal__buttons {
  display:flex;
  gap:10px;
  justify-content:center;
}

.location-modal__buttons button {
  flex:1 1 0;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--br);
  background:#fff;
  color:var(--ink);
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
}

.location-modal__buttons button[data-location-choice="AU"] {
  background:#111;
  color:#fff;
  border-color:#111;
}

.location-modal__buttons button:hover {
  filter:brightness(.95);
}

.location-modal__buttons button:active {
  transform:translateY(1px);
}

