/* =====================================================================
   L.A. ELITE — QUOTE TOOL  ·  STYLESHEET (single source of truth)
   LIGHT register — built to live natively inside elitewindowcleaning.net:
   warm cream + gold, GFS Didot display, DM Sans body, airy + sharp.
   One source of truth. No layered overwrites, no band-aids, no dead code.
   ===================================================================== */

:root{
  /* Site DNA: cream #f0ede8 · gold #b8935a · GFS Didot · DM Sans */
  --cream:      #f0ede8;
  --cream-hi:   #f6f3ee;
  --cream-lo:   #e7e2d8;
  --gold:       #b8935a;
  --gold-lt:    #d4ae80;
  --gold-deep:  #936f3f;
  --ink:        #1d1b17;   /* primary text */
  --text:       #1d1b17;
  --text-soft:  rgba(29,27,23,0.64);
  --text-faint: rgba(29,27,23,0.42);
  --line:       rgba(184,147,90,0.28);
  --line-2:     rgba(184,147,90,0.55);
  --glow:       184,147,90;

  /* Card surfaces — clean warm white that lifts off the cream page */
  --surf-1:     #ffffff;
  --surf-2:     #fbf9f5;
  --hi:         #2a2620;   /* top stop of the gilded total numeral */
  --field-bg:   linear-gradient(180deg, #fffefb, #f7f3ec);
  --chip-bg:    linear-gradient(180deg, #ffffff, #f6f2ea);

  --serif: "GFS Didot", Georgia, serif;
  --sans:  "DM Sans", system-ui, sans-serif;
  --ease:  cubic-bezier(0.16,1,0.3,1);
  --spring: cubic-bezier(0.34,1.56,0.64,1);

  /* Soft warm elevation — cards float on cream with a real, sharp top edge */
  --edge: inset 0 1px 0 #ffffff, 0 1px 2px rgba(40,30,12,0.05), 0 14px 34px -12px rgba(50,38,15,0.18);
  --edge-hi: inset 0 1px 0 #ffffff, 0 2px 4px rgba(40,30,12,0.06), 0 22px 48px -14px rgba(50,38,15,0.24);
  /* tighter, crisper lift for SMALL controls so they visibly pop off the card */
  --pop: inset 0 1px 0 #ffffff, 0 1px 2px rgba(40,30,12,0.10), 0 6px 14px -4px rgba(50,38,15,0.30);
}

*{ box-sizing: border-box; margin: 0; padding: 0; }
html{ scroll-behavior: smooth; }

/* No default (blue) focus ring on click; a refined gold ring for keyboard users only */
:focus:not(:focus-visible){ outline: none; }
:focus-visible{ outline: 2px solid var(--gold-deep); outline-offset: 2px; border-radius: 4px; }

body{
  font-family: var(--sans);
  color: var(--text);
  background:
    radial-gradient(circle, rgba(184,147,90,0.05) 1px, transparent 1.5px) 0 0 / 22px 22px,
    linear-gradient(180deg, var(--cream-hi) 0%, var(--cream) 38%, var(--cream-lo) 100%);
  background-attachment: fixed;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  line-height: 1.55;
  position: relative;
  overflow-x: hidden;
}

/* Faint warm wash — subtle light, never heavy on cream */
body::before{
  content:""; position: fixed; inset: -20%; z-index: 0; pointer-events: none;
  background:
    radial-gradient(55% 50% at 50% -4%, rgba(var(--glow),0.11) 0%, transparent 55%),
    radial-gradient(40% 44% at 14% 8%,  rgba(var(--glow),0.08) 0%, transparent 60%),
    radial-gradient(46% 46% at 88% 96%, rgba(var(--glow),0.06) 0%, transparent 60%);
}

/* Clean-glass gleam — a couple of wide, rigid diagonal light streaks (window-pane sheen, never droplets) */
body::after{
  content:""; position: fixed; inset: 0; z-index: 1; pointer-events: none; mix-blend-mode: screen;
  background:
    linear-gradient(106deg, transparent 14%, rgba(255,255,255,0.05) 20%, transparent 24.5%, transparent 63%, rgba(255,255,255,0.035) 69%, transparent 73%),
    linear-gradient(106deg, transparent 41%, rgba(255,255,255,0.025) 44%, transparent 46.5%);
}

/* Fine paper grain — texture, not noise */
.qt-grain{
  position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: 0.035; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.qt{ position: relative; z-index: 2; max-width: 820px; margin: 0 auto; padding: clamp(1.25rem,3vw,1.75rem) clamp(1rem,3vw,2rem) clamp(1.5rem,3vw,2.25rem); }

/* ---------- Header (sticky — the running total stays with you) ---------- */
.qt-head{ position: sticky; top: 0; z-index: 20; isolation: isolate;
  background:
    radial-gradient(120% 90% at 50% -22%, rgba(255,250,242,0.12) 0%, transparent 55%),         /* soft top sheen — lifts the band */
    radial-gradient(110% 150% at 16% 125%, rgba(48,43,37,0.38) 0%, transparent 58%),            /* deepening, lower-left — the wavy fade */
    radial-gradient(95% 120% at 86% -10%, rgba(184,147,90,0.10) 0%, transparent 55%),            /* faint warm gold cast */
    linear-gradient(180deg, #777169 0%, #6c665d 52%, #5d5850 100%);                              /* warm taupe-gray — the color from the header */
  -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px);
  box-shadow: 0 16px 38px -28px rgba(0,0,0,0.55); }
/* wood-grain ridges + fine grain — soft-light on the dark band so it textures rather than muddies */
.qt-head::before{ content:""; position: absolute; inset: 0; z-index: -1; pointer-events: none; opacity: 0.16; mix-blend-mode: soft-light;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='340' height='150'%3E%3Cfilter id='w'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.014 0.52' numOctaves='3' seed='7' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23w)'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 340px 100%, 170px 170px; background-repeat: repeat-x, repeat; }
.qt-head__inner{ position: relative; max-width: none; margin: 0 auto; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 1rem;
  padding: clamp(0.85rem,2vw,1.2rem) clamp(1rem,3vw,2rem) 0.9rem; }
/* full-width gold streak where the header meets the page */
.qt-head::after{ content:""; position: absolute; left: 0; bottom: 0; height: 1px; width: 100%;
  background: linear-gradient(90deg, transparent, var(--line-2) 16%, var(--gold) 50%, var(--line-2) 84%, transparent); }
.qt-head__left{ justify-self: start; display: flex; flex-direction: column; align-items: center; gap: 0.22rem; }
/* framed on a light medallion so it reads as a seal and lifts off the dark band */
.qt-head__logo{ height: clamp(50px, 6.6vw, 66px); width: auto; display: block; margin-bottom: 0.3rem; padding: 0.5rem 0.72rem; border-radius: 13px;
  background: linear-gradient(180deg, #fcf9f4 0%, #efeae0 100%);
  border: 1px solid rgba(184,147,90,0.42);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.6), 0 7px 18px -8px rgba(0,0,0,0.55); }
.qt-head__co{ display: flex; flex-direction: column; align-items: flex-start; gap: 2px; }
.qt-head__co1{ font-family: var(--serif); font-size: clamp(1.25rem,2.3vw,1.55rem); color: #f7f3ec; line-height: 1; letter-spacing: 0.01em; white-space: nowrap;
  text-shadow: 0 1px 1px rgba(0,0,0,0.45), 0 0 22px rgba(184,147,90,0.18); }
.qt-head__co2{ font-size: 0.5rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-lt); white-space: nowrap;
  text-shadow: 0 1px 2px rgba(0,0,0,0.5); }
.qt-head__center{ display: flex; flex-direction: column; align-items: center; gap: 0.3rem; }
.qt-head__eyebrow{ display: flex; align-items: center; justify-content: center; gap: 0.55rem; white-space: nowrap; font-size: 0.58rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--gold-lt); text-shadow: 0 1px 2px rgba(0,0,0,0.5); }
.qt-head__eyebrow::before, .qt-head__eyebrow::after{ content:""; height: 1px; width: clamp(16px,4vw,30px); background: linear-gradient(90deg, transparent, var(--line-2)); }
.qt-head__eyebrow::after{ background: linear-gradient(90deg, var(--line-2), transparent); }
.qt-head__title{ font-family: var(--serif); font-size: clamp(1.3rem,2.5vw,1.7rem); letter-spacing: 0.01em; text-align: center; line-height: 1.05;
  background: linear-gradient(180deg, #fdfaf4 0%, var(--gold-lt) 55%, var(--gold) 100%); -webkit-background-clip: text; background-clip: text; color: transparent;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,0.5)) drop-shadow(0 0 16px rgba(184,147,90,0.20)); }

/* Quiet live running total */
.qt-running{ justify-self: end; display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 0.5rem 1.5rem; border: 1px solid var(--line); border-radius: 14px;
  background: var(--surf-1); box-shadow: var(--edge); text-align: center; }
.qt-running__lbl{ font-size: 0.52rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--text-faint); }
.qt-running__val{ font-family: var(--serif); font-size: 1.45rem; line-height: 1; color: var(--gold-deep); }
.qt-running__range{ font-size: 0.62rem; letter-spacing: 0.04em; color: var(--text-soft); }

/* ---------- Single-column guided flow ---------- */
.qt-flow{ display: block; }

/* ---------- Cards ---------- */
.card{
  position: relative;
  background: linear-gradient(180deg, var(--surf-1) 0%, var(--surf-2) 100%);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: clamp(1rem,2.2vw,1.45rem);
  box-shadow: var(--edge), 0 34px 64px -44px rgba(70,64,56,0.5);   /* soft taupe ambient — ties the boxes to the header */
  margin-bottom: 1.1rem;
  opacity: 0; transform: translateY(14px);
  animation: rise 0.7s var(--ease) forwards;
}
.card:nth-child(2){ animation-delay: 0.08s; }
.card::before{ content:""; position: absolute; inset: 0 0 auto 0; height: 1px; border-radius: 16px 16px 0 0; opacity: 0.7;
  background: linear-gradient(90deg, transparent, var(--gold-lt) 30%, var(--gold-lt) 70%, transparent); }
.card:last-child{ margin-bottom: 0; }
@keyframes rise{ to{ opacity: 1; transform: none; } }

.sec-title{ display: flex; align-items: center; justify-content: center; gap: 0.65rem; font-family: var(--serif); font-size: clamp(1.05rem,2vw,1.3rem); margin-bottom: 1.05rem; letter-spacing: 0.01em;
  background: linear-gradient(180deg, #2c2620 0%, #574a3a 100%); -webkit-background-clip: text; background-clip: text; color: transparent;
  filter: drop-shadow(0 1px 1px rgba(255,255,255,0.5)) drop-shadow(0 2px 3px rgba(40,30,12,0.2)); }
/* symmetric flourish — a thin gold rule on each side of the centered title */
.sec-title::before, .sec-title::after{ content:""; height: 1px; width: clamp(18px, 6vw, 54px); background: linear-gradient(90deg, transparent, var(--line-2)); }
.sec-title::after{ background: linear-gradient(90deg, var(--line-2), transparent); }
.sec-title .dot{ display: none; } /* the flourish rules are the accent now */
.sub-title{ display: flex; align-items: center; gap: 0.55rem; font-size: 0.62rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-deep); margin: 1.15rem 0 0.7rem; }
.sub-note{ text-transform: none; letter-spacing: 0.01em; font-weight: 400; font-size: 0.68rem; color: var(--text-faint); }
.dot{ width: 7px; height: 7px; border-radius: 50%; background: radial-gradient(circle at 35% 30%, var(--gold-lt), var(--gold-deep)); box-shadow: 0 0 8px rgba(184,147,90,0.5); flex: 0 0 auto; }
.svc-note{ font-size: 0.73rem; color: var(--text-faint); line-height: 1.6; margin-top: 1rem; text-align: center; max-width: 60ch; margin-left: auto; margin-right: auto; }
.svc-topnote{ text-align: center; font-size: 0.66rem; letter-spacing: 0.03em; font-style: italic; color: var(--text-faint); margin: -0.5rem 0 0.5rem; }

.label{ display: block; font-size: 0.64rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(29,27,23,0.72); margin: 0.9rem 0 0.4rem; }

/* field layout — paired fields sit side by side; full-width ones span both columns */
.fields{ display: grid; grid-template-columns: 1fr 1fr; gap: 0 1.1rem; }
.field-wrap{ grid-column: 1 / -1; text-align: center; }
.field-wrap--half{ grid-column: span 1; }
.field-wrap .label{ margin-top: 0.9rem; }
@media (max-width: 540px){ .field-wrap--half{ grid-column: 1 / -1; } }

/* ---------- Service toggles ---------- */
.svc-row{ display: flex; flex-wrap: wrap; justify-content: space-evenly; gap: 0.6rem; padding: 0 0.5rem; }
.svc{
  font-family: var(--sans); font-weight: 500; font-size: clamp(0.8rem,1.2vw,0.88rem); letter-spacing: 0.04em; color: var(--text-soft);
  padding: 0.5rem 1.15rem; border-radius: 999px;
  background: var(--chip-bg); border: 1px solid var(--line);
  cursor: pointer; transition: color .25s, border-color .25s, transform .25s var(--spring), box-shadow .25s; box-shadow: var(--edge);
}
.svc:hover{ color: var(--ink); border-color: var(--line-2); transform: translateY(-2px); }
.svc:active{ transform: translateY(0); }
.svc[aria-pressed="true"]{
  color: #fff;
  background: linear-gradient(180deg, var(--gold-lt), var(--gold) 60%, var(--gold-deep));
  border-color: var(--gold-deep);
  box-shadow: var(--edge-hi), 0 8px 20px -8px rgba(184,147,90,0.6);
}

/* ---------- Inputs & radios ---------- */
.field{ display: block; width: 100%; max-width: 340px; margin: 0 auto; text-align: center; background: var(--field-bg); color: var(--text); border: 1px solid var(--line); border-radius: 10px; padding: 0.7rem 0.95rem; font-family: var(--sans); font-size: 0.95rem; box-shadow: inset 0 1px 3px rgba(40,30,12,0.07); transition: border-color .2s, box-shadow .2s; }
.field::placeholder{ color: var(--text-faint); }
.field:focus{ outline: none; border-color: var(--gold); box-shadow: inset 0 1px 3px rgba(40,30,12,0.07), 0 0 0 3px rgba(184,147,90,0.18); }
/* highlight a field once it's actually being used */
.field:not(:placeholder-shown){ border-color: var(--gold); background: linear-gradient(180deg, #fffdf8, #fbf6ea); }
/* no scroll spinner on number inputs */
.field[type=number]{ -moz-appearance: textfield; appearance: textfield; }
.field[type=number]::-webkit-outer-spin-button,
.field[type=number]::-webkit-inner-spin-button{ -webkit-appearance: none; margin: 0; }
.radio-row{ display: flex; gap: 0.65rem; flex-wrap: wrap; }
.radio{ flex: 1 1 0; min-width: 130px; text-align: center; padding: 0.6rem 1rem; border-radius: 9px; background: var(--chip-bg); border: 1px solid var(--line); cursor: pointer; font-family: var(--sans); font-weight: 500; font-size: 0.85rem; letter-spacing: 0.03em; color: var(--text-soft); transition: color .2s, border-color .2s, transform .2s var(--spring); box-shadow: var(--pop); }
.radio:hover{ transform: translateY(-1px); border-color: var(--line-2); color: var(--ink); }
.radio[aria-pressed="true"]{ color: #f7f3ec; border-color: var(--gold-deep);
  background: linear-gradient(180deg, #777169 0%, #6c665d 52%, #5d5850 100%);
  box-shadow: var(--edge-hi), inset 0 1px 0 rgba(255,255,255,0.14); text-shadow: 0 1px 1px rgba(0,0,0,0.4); }

/* ---------- Add-on cards ---------- */
.addons{ display: grid; grid-template-columns: repeat(auto-fit, minmax(225px,1fr)); gap: 0.9rem; }
.addon{
  display: grid; grid-template-columns: 20px minmax(0,1fr); gap: 0.7rem; align-items: start;
  padding: 0.85rem 1rem; border-radius: 12px;
  background: linear-gradient(180deg, #ffffff, #fbf8f3);
  border: 1px solid var(--line); cursor: pointer; transition: border-color .2s, transform .2s var(--spring), box-shadow .25s; box-shadow: var(--edge);
}
.addon:hover{ border-color: var(--line-2); transform: translateY(-2px); }
.addon:has(input:checked){ border-color: var(--gold-deep);
  background: linear-gradient(180deg, #777169 0%, #6c665d 52%, #5d5850 100%);
  box-shadow: var(--edge-hi), inset 0 1px 0 rgba(255,255,255,0.14); }
.addon:has(input:checked) .addon__name{ color: #f7f3ec; }
.addon:has(input:checked) .addon__meta{ color: var(--gold-lt); }
.addon:has(input:checked) .addon__note{ color: rgba(247,243,236,0.72); }
.addon input[type=checkbox]{ -webkit-appearance: none; appearance: none; width: 19px; height: 19px; margin: 1px 0 0; border-radius: 5px;
  border: 1px solid var(--line-2); background: var(--surf-1); box-shadow: var(--pop); cursor: pointer; display: grid; place-items: center; transition: background .15s, border-color .15s; }
.addon input[type=checkbox]::after{ content: '✓'; font-size: 0.7rem; font-weight: 700; color: #fff; opacity: 0; transition: opacity .15s; }
.addon input[type=checkbox]:checked{ background: linear-gradient(180deg, var(--gold-lt), var(--gold)); border-color: var(--gold-deep); }
.addon input[type=checkbox]:checked::after{ opacity: 1; }
.addon__name{ font-weight: 600; font-size: 0.94rem; color: var(--ink); }
.addon__meta{ display: block; font-size: 0.78rem; color: var(--gold-deep); margin-top: 0.22rem; }
.addon__note{ display: block; font-size: 0.74rem; color: var(--text-faint); margin-top: 0.16rem; }

/* Saphir brand lockup inside its add-on cards — gem icon + state-aware wordmark */
.saphir-gem{ height: 1.05em; width: auto; vertical-align: -0.18em; margin-right: 0.34em; filter: drop-shadow(0 1px 1px rgba(0,0,0,0.28)); }
.saphir-mark{ letter-spacing: 0.005em; }
.saphir-mark__a{ color: #3a7bd0; }          /* the brand blue 'a' — pops on light or dark card */
.saphir-mark__plus{ color: var(--gold); font-size: 0.6em; font-weight: 700; vertical-align: super; margin-left: 0.03em; }
.saphir-mark__tm{ font-size: 0.46em; vertical-align: super; letter-spacing: 0; margin-left: 0.05em; opacity: 0.75; }
.addon:has(input:checked) .saphir-mark__a{ color: #6fa8e8; }   /* a touch brighter on the dark selected card */

/* Free Water Test — premium gold ribbon. Fits its box on one line. */
.fwt{
  grid-column: 2; margin-top: 0.75rem;
  display: flex; align-items: center; gap: 0.55rem; width: 100%;
  padding: 0.55rem 0.9rem; border-radius: 9px;
  background: linear-gradient(180deg, rgba(184,147,90,0.18), rgba(184,147,90,0.07));
  border: 1px solid var(--line-2); box-shadow: var(--pop);
}
.fwt__check{ width: 17px; height: 17px; border-radius: 50%; background: radial-gradient(circle at 35% 30%, var(--gold-lt), var(--gold-deep)); color: #fff; display: grid; place-items: center; font-size: 0.62rem; font-weight: 700; flex: 0 0 auto; box-shadow: 0 1px 2px rgba(0,0,0,0.25); }
.fwt__text{ font-size: 0.62rem; letter-spacing: 0.13em; text-transform: uppercase; color: var(--gold-deep); font-weight: 600; white-space: nowrap; }
.fwt__free{ color: var(--ink); }

/* ---------- Estimate summary (the bottom "arrival" reveal) ---------- */
.summary{ background: linear-gradient(180deg, #fffdf8 0%, #fbf6ec 100%); border-color: var(--line-2); margin-top: 0.4rem; }
.summary .amount{
  margin-top: 0.3rem; text-align: center;
  font-family: var(--serif); font-size: clamp(1.6rem,3vw,1.9rem); line-height: 1; letter-spacing: -0.005em;
  background: linear-gradient(180deg, var(--hi) 0%, var(--gold-deep) 55%, var(--gold) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.summary .range{ font-size: 0.82rem; color: var(--text-soft); margin-top: 0.45rem; letter-spacing: 0.02em; text-align: center; }
.summary .placeholder{ color: var(--text-faint); font-size: 0.9rem; }
.summary hr{ border: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--line-2), transparent); margin: 1.3rem 0; }
.line{ display: flex; justify-content: space-between; gap: 1rem; font-size: 0.88rem; padding: 0.4rem 0; color: var(--text-soft); }
.line b{ color: var(--ink); font-weight: 600; }
.consult{ margin-top: 0.9rem; padding: 0.85rem 1rem; border-radius: 10px; font-size: 0.82rem; line-height: 1.55; color: var(--ink);
  background: linear-gradient(180deg, rgba(184,147,90,0.14), rgba(184,147,90,0.05)); border: 1px solid var(--line-2); }
.note{ font-size: 0.73rem; color: var(--text-faint); line-height: 1.65; margin-top: 1.1rem; }

/* ---------- Discounts ---------- */
.disc-row{ display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 0.8rem 0; border-bottom: 1px solid var(--line); cursor: pointer; }
.disc-row + .disc-row{ }
.disc-text{ display: flex; flex-direction: column; gap: 2px; }
.disc-name{ font-weight: 600; font-size: 0.95rem; color: var(--ink); }
.disc-sub{ font-size: 0.73rem; color: var(--text-faint); }
.disc-row.is-disabled{ opacity: 0.45; cursor: not-allowed; }
.disc-note{ font-size: 0.73rem; color: var(--text-faint); line-height: 1.6; margin-top: 0.85rem; }
.toggle{ position: relative; flex: 0 0 auto; width: 44px; height: 24px; }
.toggle input{ position: absolute; inset: 0; width: 100%; height: 100%; margin: 0; opacity: 0; cursor: pointer; }
.toggle-track{ position: absolute; inset: 0; border-radius: 999px; background: #e9e2d6; border: 1px solid var(--line); transition: background .2s, border-color .2s; box-shadow: inset 0 1px 3px rgba(40,30,12,0.12); }
.toggle-track::before{ content:""; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 50%; background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,0.25); transition: transform .22s var(--spring); }
.toggle input:checked + .toggle-track{ background: linear-gradient(180deg, var(--gold-lt), var(--gold)); border-color: var(--gold-deep); }
.toggle input:checked + .toggle-track::before{ transform: translateX(20px); }
.line-item-discount b{ color: #4a9e6e; }
.cta{
  display: block; width: 100%; margin-top: 1.1rem; padding: 0.8rem 1rem; cursor: pointer;
  font-family: var(--sans); font-weight: 600; font-size: 0.96rem; letter-spacing: 0.04em; color: #fff;
  border: 1px solid var(--gold-deep); border-radius: 999px;
  background: linear-gradient(180deg, var(--gold-lt), var(--gold) 60%, var(--gold-deep));
  box-shadow: var(--edge-hi), 0 8px 22px -6px rgba(184,147,90,0.55);
  transition: transform 0.25s var(--spring), box-shadow 0.25s;
}
.cta:hover{ transform: translateY(-2px); box-shadow: var(--edge-hi), 0 14px 30px -6px rgba(184,147,90,0.65); }
.cta:active{ transform: translateY(0); }
.cta[disabled]{ opacity: 0.6; cursor: progress; transform: none; box-shadow: var(--edge); }

/* ---------- Send Your Estimate ---------- */
#send{ background: linear-gradient(180deg, #fffdf8 0%, #fbf6ec 100%); border-color: var(--line-2); }
.send-lead{ text-align: center; color: var(--text-soft); font-size: 0.9rem; max-width: 46ch; margin: 0 auto 1.25rem; }
.send-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem 1rem; }
.send-field{ display: flex; flex-direction: column; gap: 0.3rem; text-align: left; }
.send-field__lbl{ font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); padding-left: 0.15rem; }
/* the send card's inputs fill their column and read left-aligned, unlike the centered service fields */
.send-grid .field{ max-width: none; margin: 0; text-align: left; }
.send-grid .field.is-error{ border-color: #c2502f; box-shadow: 0 0 0 3px rgba(194,80,47,0.14); }
@media (max-width: 540px){ .send-grid{ grid-template-columns: 1fr; } }

.consent-row{ display: flex; align-items: flex-start; gap: 0.7rem; margin-top: 1rem; cursor: pointer; }
.consent-row input{ margin-top: 0.18rem; width: 16px; height: 16px; flex: 0 0 auto; accent-color: var(--gold-deep); cursor: pointer; }
.consent-row.is-error .consent-text{ color: #c2502f; }
.consent-text{ font-size: 0.74rem; line-height: 1.6; color: var(--text-soft); }
.consent-text a{ color: var(--gold-deep); text-decoration: underline; text-underline-offset: 2px; }

.send-status{ margin-top: 0.9rem; min-height: 1.1rem; text-align: center; font-size: 0.82rem; letter-spacing: 0.01em; }
.send-status.is-error{ color: #c2502f; }

/* success state — replaces the form contents after a successful send */
.send-done{ text-align: center; padding: 0.6rem 0 0.2rem; }
.send-done__mark{ width: 46px; height: 46px; margin: 0 auto 0.7rem; border-radius: 50%; display: grid; place-items: center; color: #fff; font-size: 1.3rem;
  background: radial-gradient(circle at 35% 30%, var(--gold-lt), var(--gold-deep)); box-shadow: var(--pop); }
.send-done__title{ font-family: var(--serif); font-size: 1.35rem; color: var(--ink); margin-bottom: 0.4rem; }
.send-done__sub{ font-size: 0.88rem; color: var(--text-soft); line-height: 1.6; max-width: 40ch; margin: 0 auto; }

/* ---------- Elite Club showcase ---------- */
#membership{ background: linear-gradient(180deg, #fffdf8 0%, #faf4e8 100%); border-color: var(--line-2); }
.club-lead{ text-align: center; color: var(--text-soft); font-size: 0.92rem; max-width: 44ch; margin: 0 auto 1.2rem; }
.club-benefits{ display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.7rem 0.9rem; max-width: 540px; margin: 0 auto; }
.club-benefit{ display: flex; flex-direction: column; gap: 2px; padding: 0.7rem 0.85rem; border: 1px solid var(--line); border-radius: 11px; background: var(--surf-1); box-shadow: var(--edge); text-align: center; }
.club-benefit__name{ font-weight: 600; font-size: 0.88rem; color: var(--ink); }
.club-benefit__sub{ font-size: 0.72rem; color: var(--text-faint); }
.cta--ghost{ background: linear-gradient(180deg, #fff, #f3ecdf); color: var(--gold-deep); border: 1px solid var(--gold-deep);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 10px 22px -8px rgba(50,38,15,0.5), 0 3px 7px -2px rgba(50,38,15,0.32); max-width: 320px; margin-left: auto; margin-right: auto; text-decoration: none; text-align: center; }
.cta--ghost:hover{ background: linear-gradient(180deg, #fff, #f0e7d6); box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 16px 30px -8px rgba(50,38,15,0.55), 0 4px 9px -2px rgba(50,38,15,0.34); }
.club-foot{ text-align: center; font-size: 0.7rem; color: var(--text-faint); margin-top: 0.7rem; }
@media (max-width: 480px){ .club-benefits{ grid-template-columns: 1fr; } }

/* ---------- Help: "?" markers, floating trigger, slide-in manual ---------- */
.help-mark{ position: absolute; top: 13px; right: 15px; z-index: 4; width: 22px; height: 22px; padding: 0; border-radius: 50%;
  display: inline-grid; place-items: center; font-family: var(--sans); font-weight: 700; font-size: 0.72rem; line-height: 1; cursor: pointer;
  color: var(--gold-deep); background: var(--surf-1); border: 1px solid var(--line-2); box-shadow: var(--pop); transition: color .2s, background .2s, transform .2s var(--spring); }
.help-mark:hover{ color: #fff; background: linear-gradient(180deg, var(--gold-lt), var(--gold)); border-color: var(--gold-deep); transform: translateY(-1px); }
.help-mark--inline{ position: static; width: 17px; height: 17px; font-size: 0.6rem; margin-left: 0.4rem; vertical-align: middle; box-shadow: none; }

.qt-phone-fab{ position: fixed; top: 1rem; left: 1rem; z-index: 40; display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.5rem 0.9rem; border-radius: 999px; font-family: var(--sans); font-size: 0.82rem; font-weight: 600; letter-spacing: 0.01em;
  text-decoration: none; color: var(--ink); background: linear-gradient(180deg, #fff, #f3ecdf); border: 1px solid var(--line-2);
  box-shadow: inset 0 1px 0 #fff, 0 6px 16px -8px rgba(50,38,15,0.5); transition: transform .2s; }
.qt-phone-fab::before{ content: '📞'; font-size: 0.9em; }
.qt-phone-fab:hover{ transform: translateY(-2px); }

.qt-help-btn{ position: fixed; bottom: 1.2rem; right: 1.2rem; z-index: 40; display: inline-flex; align-items: center; gap: 0.45rem;
  padding: 0.55rem 1.1rem 0.55rem 0.7rem; border-radius: 999px; font-family: var(--sans); font-size: 0.8rem; font-weight: 600; letter-spacing: 0.03em;
  color: var(--gold-deep); background: linear-gradient(180deg, #fff, #f3ecdf); border: 1px solid var(--gold-deep);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 10px 22px -8px rgba(50,38,15,0.5), 0 3px 7px -2px rgba(50,38,15,0.32); cursor: pointer; transition: transform .2s var(--spring), box-shadow .2s var(--ease); }
.qt-help-btn::before{ content:'?'; display: inline-grid; place-items: center; width: 19px; height: 19px; border-radius: 50%; background: linear-gradient(180deg, var(--gold-lt), var(--gold)); color: #fff; font-weight: 700; font-size: 0.72rem; }
.qt-help-btn:hover{ transform: translateY(-2px); box-shadow: inset 0 1px 0 rgba(255,255,255,0.9), 0 16px 30px -8px rgba(50,38,15,0.55), 0 4px 9px -2px rgba(50,38,15,0.34); }

.qt-help-panel{ position: fixed; top: 0; right: 0; z-index: 51; height: 100%; width: min(420px, 92vw); --drag: 0px;
  background: linear-gradient(180deg, var(--cream-hi), var(--cream)); border-left: 1px solid var(--line-2);
  box-shadow: -24px 0 60px -24px rgba(40,30,10,0.45); transform: translateX(100%); transition: transform .34s var(--ease); display: flex; flex-direction: column; }
/* open: sit flush right, but offset by however far the customer has dragged it aside */
.qt-help-panel.is-open{ transform: translateX(var(--drag)); }
.qt-help-panel.is-dragging{ transition: none; }   /* follow the finger 1:1 while dragging */

/* grip the customer grabs to slide the panel aside (and pull it back) */
.qt-help-grip{ position: absolute; left: -26px; top: 50%; transform: translateY(-50%); z-index: 2;
  width: 26px; height: 86px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 5px;
  background: linear-gradient(180deg, var(--cream-hi), var(--cream)); border: 1px solid var(--line-2); border-right: none;
  border-radius: 12px 0 0 12px; box-shadow: -8px 0 18px -8px rgba(40,30,10,0.4); cursor: grab; touch-action: none; padding: 0; }
.qt-help-grip:active{ cursor: grabbing; }
.qt-help-grip span{ width: 5px; height: 5px; border-radius: 50%; background: var(--gold-deep); opacity: 0.85; }
.qt-help-head{ display: flex; align-items: center; justify-content: space-between; padding: 1.1rem 1.3rem; border-bottom: 1px solid var(--line); flex: 0 0 auto; }
.qt-help-head__title{ font-family: var(--serif); font-size: 1.2rem;
  background: linear-gradient(180deg, #2c2620 0%, #574a3a 100%); -webkit-background-clip: text; background-clip: text; color: transparent;
  filter: drop-shadow(0 1px 1px rgba(255,255,255,0.5)) drop-shadow(0 2px 3px rgba(40,30,12,0.18)); }
.qt-help-close{ width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--line); background: var(--surf-1); color: var(--text-soft); cursor: pointer; font-size: 0.82rem; transition: color .2s, border-color .2s; }
.qt-help-close:hover{ color: var(--ink); border-color: var(--line-2); }
.qt-help-body{ overflow-y: auto; padding: 0.4rem 1.3rem 2rem; scroll-behavior: smooth; }
.qt-help-topic{ padding: 1.05rem 0; border-bottom: 1px solid var(--line); }
.qt-help-topic:last-child{ border-bottom: none; }
.qt-help-topic h3{ font-family: var(--serif); font-size: 1.05rem; color: var(--gold-deep); margin-bottom: 0.5rem; }
.qt-help-topic p{ font-size: 0.84rem; line-height: 1.62; color: var(--text-soft); margin-bottom: 0.45rem; }
.qt-help-topic p:last-child{ margin-bottom: 0; }
.qt-help-topic p b{ color: var(--ink); font-weight: 600; }
.qt-help-topic.is-flash{ animation: helpFlash 1.4s ease; border-radius: 8px; }
@keyframes helpFlash{ 0%,100%{ background: transparent; } 18%{ background: rgba(184,147,90,0.18); } }

.hidden{ display: none !important; }
.qt-foot{ position: relative; isolation: isolate; margin-top: clamp(1.75rem,3.5vw,2.75rem);
  background:
    radial-gradient(120% 90% at 50% 122%, rgba(255,250,242,0.10) 0%, transparent 55%),         /* soft base sheen */
    radial-gradient(110% 150% at 86% -25%, rgba(48,43,37,0.36) 0%, transparent 58%),            /* deepening near the seam — wavy fade */
    radial-gradient(95% 120% at 14% 110%, rgba(184,147,90,0.10) 0%, transparent 55%),            /* faint warm gold cast */
    linear-gradient(180deg, #5d5850 0%, #6c665d 48%, #777169 100%);                              /* warm taupe-gray — matches header */
  box-shadow: 0 -14px 38px -30px rgba(0,0,0,0.45); }
/* wood-grain ridges + fine grain — matches the header band */
.qt-foot::after{ content:""; position: absolute; inset: 0; z-index: -1; pointer-events: none; opacity: 0.16; mix-blend-mode: soft-light;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='340' height='150'%3E%3Cfilter id='w'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.014 0.52' numOctaves='3' seed='7' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23w)'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 340px 100%, 170px 170px; background-repeat: repeat-x, repeat; }
/* full-width gold streak where the page meets the footer */
.qt-foot::before{ content:""; position: absolute; left: 0; top: 0; height: 1px; width: 100%; z-index: 1;
  background: linear-gradient(90deg, transparent, var(--line-2) 16%, var(--gold) 50%, var(--line-2) 84%, transparent); }
.qt-foot__inner{ position: relative; max-width: 820px; margin: 0 auto; padding: clamp(1rem,2.5vw,1.5rem) clamp(1rem,3vw,2rem); text-align: center; }
/* business contact — the prominent line */
.qt-foot__contact{ display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 0.55rem; font-family: var(--serif); font-size: 0.96rem; letter-spacing: 0.01em; }
.qt-foot__contact a{ color: #f1ece2; text-decoration: none; transition: color .2s; }
.qt-foot__contact a:hover{ color: var(--gold-lt); }
.qt-foot__dot{ color: var(--gold); }
/* DarkInsight credit — the quiet line */
.qt-foot__credit{ margin-top: 0.6rem; font-size: 0.56rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(246,243,238,0.5); }
.qt-foot .qt-ver{ color: var(--gold-lt); }

/* ---------- Preferred date & time (Send section) ---------- */
.sched{ margin: 0.5rem auto 0.2rem; max-width: 460px; width: 100%; text-align: center; }
.sched__h{ font-family: var(--sans); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-soft); margin: 0 0 0.5rem; font-weight: 600; }
.sched__opt{ font-family: var(--sans); font-size: 0.6rem; letter-spacing: 0.03em; color: var(--text-faint); text-transform: none; }
.sched__times{ display: flex; gap: 0.35rem; flex-wrap: wrap; margin-bottom: 0.5rem; }
.sched__time{ flex: 1 1 0; min-width: 92px; text-align: center; cursor: pointer; padding: 0.36rem 0.5rem; border: 1px solid var(--line-2); border-radius: 8px; background: var(--chip-bg); font-family: var(--sans); font-size: 0.74rem; color: var(--text-soft); transition: border-color .2s, box-shadow .2s, color .2s; }
.sched__time input{ position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.sched__time.is-active{ border-color: var(--gold); color: var(--gold-deep); font-weight: 600; box-shadow: var(--pop); }
.sched__mode{ display: inline-flex; gap: 0.2rem; background: var(--cream-lo); border-radius: 999px; padding: 0.18rem; margin: 0 0 0.5rem; }
.sched__modebtn{ cursor: pointer; padding: 0.26rem 0.75rem; border-radius: 999px; font-family: var(--sans); font-size: 0.7rem; color: var(--text-soft); transition: background .2s, color .2s; }
.sched__modebtn input{ position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.sched__modebtn.is-active{ background: #fff; color: var(--gold-deep); font-weight: 600; box-shadow: 0 1px 4px -1px rgba(50,38,15,0.2); }
.sched__dates, .sched__range{ display: flex; gap: 0.45rem; flex-wrap: wrap; justify-content: center; }
.sched__dates[hidden], .sched__range[hidden]{ display: none; }
.sched__date{ display: flex; flex-direction: column; gap: 0.18rem; font-family: var(--sans); font-size: 0.56rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-faint); }
.sched__date input{ font-family: var(--sans); font-size: 0.78rem; text-transform: none; letter-spacing: 0; padding: 0.34rem 0.5rem; border: 1px solid var(--line); border-radius: 8px; background: var(--field-bg); color: var(--text); box-shadow: inset 0 1px 3px rgba(40,30,12,0.07); }
.sched__date input:focus{ outline: none; border-color: var(--gold); box-shadow: inset 0 1px 3px rgba(40,30,12,0.07), 0 0 0 3px rgba(184,147,90,0.18); }

@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
}
