/* TruStripe quote modal — self-contained, drop-in via quote-modal.js */
.quote-modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:24px}
.quote-modal[aria-hidden="false"]{display:flex}
.quote-modal__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(10,26,20,.6);-webkit-backdrop-filter:blur(6px) saturate(140%);backdrop-filter:blur(6px) saturate(140%);opacity:0;transition:opacity .2s ease}
.quote-modal[aria-hidden="false"] .quote-modal__overlay{opacity:1}
.quote-modal__panel{position:relative;background:#fff;width:100%;max-width:640px;max-height:92vh;border-radius:0;box-shadow:0 30px 80px -20px rgba(10,26,20,.45);display:flex;flex-direction:column;overflow:hidden;transform:scale(.96);opacity:0;transition:transform .2s ease,opacity .2s ease;font-family:'Inter',system-ui,-apple-system,sans-serif;color:#0a1a14}
.quote-modal[aria-hidden="false"] .quote-modal__panel{transform:scale(1);opacity:1}
.quote-modal__close{position:absolute;top:14px;right:14px;z-index:2;width:40px;height:40px;border-radius:999px;border:0;background:rgba(10,26,20,.06);color:#0a1a14;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s}
.quote-modal__close:hover{background:rgba(10,26,20,.12);transform:rotate(90deg)}
.quote-modal__close:focus-visible{outline:2px solid #5cba3a;outline-offset:2px}
.quote-modal__head{padding:36px 36px 20px;border-bottom:1px solid #ece8d8;background:linear-gradient(180deg,#f6f4ec 0%,#fff 100%)}
.quote-modal__eyebrow{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:#1a5d2b;font-weight:600;display:inline-flex;align-items:center;gap:10px}
.quote-modal__eyebrow::before{content:"";width:22px;height:1px;background:#1a5d2b}
.quote-modal__title{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-.02em;font-size:34px;line-height:1.1;margin:10px 0 8px;color:#0f3d24}
.quote-modal__sub{margin:0;color:#3a4a42;font-size:15px;line-height:1.5;max-width:48ch}
.quote-modal__body{padding:24px 36px 32px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
/* The `hidden` HTML attribute must always win over our explicit display rules. */
.quote-modal [hidden]{display:none !important}
.quote-modal__error{background:#fdecec;border:1px solid #f3c2c2;color:#7a1f1f;padding:12px 14px;border-radius:0;margin-bottom:18px;font-size:14px;display:flex;flex-wrap:wrap;gap:6px}
.quote-modal__error a{color:#7a1f1f;text-decoration:underline;font-weight:600}
.quote-modal__form{display:flex;flex-direction:column;gap:16px}
.quote-modal__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.quote-modal__field{display:flex;flex-direction:column;gap:6px;border:0;padding:0;margin:0;min-width:0}
.quote-modal__field label,.quote-modal__field legend{font-size:13px;font-weight:600;color:#0f3d24;letter-spacing:.01em}
.quote-modal__field span[aria-hidden]{color:#5cba3a}
.quote-modal__field input,.quote-modal__field textarea{font:inherit;font-size:16px;color:#0a1a14;background:#faf8f1;border:1.5px solid #d9d4c2;border-radius:0;padding:12px 14px;width:100%;transition:border-color .15s,background .15s,box-shadow .15s}
.quote-modal__field textarea{resize:vertical;min-height:84px;line-height:1.5}
.quote-modal__field input:focus,.quote-modal__field textarea:focus{outline:0;border-color:#5cba3a;background:#fff;box-shadow:0 0 0 4px rgba(92,186,58,.18)}
.quote-modal__field input::placeholder,.quote-modal__field textarea::placeholder{color:#8a978f}
.quote-modal__services legend{margin-bottom:8px}
.quote-modal__grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.quote-modal__check{position:relative;display:flex;align-items:center;gap:10px;padding:11px 13px;border:1.5px solid #d9d4c2;border-radius:0;background:#faf8f1;cursor:pointer;font-size:14px;line-height:1.3;min-height:44px;transition:border-color .15s,background .15s,box-shadow .15s;user-select:none}
.quote-modal__check:hover{border-color:#1a5d2b}
.quote-modal__check input{appearance:none;-webkit-appearance:none;flex:0 0 18px;width:18px;height:18px;border:1.5px solid #b9b4a0;border-radius:5px;background:#fff;cursor:pointer;display:grid;place-content:center;transition:background .15s,border-color .15s;margin:0}
.quote-modal__check input:checked{background:#5cba3a;border-color:#5cba3a}
.quote-modal__check input:checked::after{content:"";width:10px;height:6px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg) translate(1px,-1px)}
.quote-modal__check input:focus-visible{outline:2px solid #5cba3a;outline-offset:2px}
.quote-modal__check.is-checked,.quote-modal__check:has(input:checked){border-color:#5cba3a;background:#f1f9ec;box-shadow:0 0 0 1px #5cba3a inset}
.quote-modal__submit{margin-top:6px;display:inline-flex;align-items:center;justify-content:center;gap:10px;background:#0f3d24;color:#fff;border:0;border-radius:0;padding:15px 26px;font-family:inherit;font-weight:600;font-size:15px;cursor:pointer;box-shadow:0 12px 30px -10px rgba(15,61,36,.5);transition:background .2s,transform .15s,box-shadow .2s;touch-action:manipulation}
.quote-modal__submit:hover:not(:disabled){background:#1a5d2b;transform:translateY(-1px)}
.quote-modal__submit:focus-visible{outline:2px solid #5cba3a;outline-offset:3px}
.quote-modal__submit:disabled{opacity:.7;cursor:wait}
.quote-modal__submit--ghost{background:transparent;color:#0f3d24;border:1.5px solid #d9d4c2;box-shadow:none;margin-top:18px}
.quote-modal__submit--ghost:hover:not(:disabled){background:#f6f4ec;border-color:#0f3d24}
.quote-modal__spinner{display:none;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:qm-spin .7s linear infinite}
.quote-modal__submit[data-loading="true"] .quote-modal__btn-label{opacity:.7}
.quote-modal__submit[data-loading="true"] .quote-modal__spinner{display:inline-block}
@keyframes qm-spin{to{transform:rotate(360deg)}}
.quote-modal__fineprint{margin:4px 0 0;font-size:12.5px;color:#3a4a42;text-align:center}
.quote-modal__success{text-align:center;padding:20px 4px 8px;display:flex;flex-direction:column;align-items:center;gap:6px}
.quote-modal__check-mark{color:#1a5d2b;margin-bottom:8px;animation:qm-pop .35s ease-out both}
.quote-modal__success h3{font-family:'Fraunces',Georgia,serif;font-weight:500;font-size:24px;color:#0f3d24;margin:6px 0 4px;letter-spacing:-.01em}
.quote-modal__success p{margin:0;color:#3a4a42;font-size:14.5px}
@keyframes qm-pop{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}
body.qm-locked{overflow:hidden;touch-action:none}
@media (max-width:600px){
  .quote-modal{padding:0;align-items:stretch}
  .quote-modal__panel{max-width:100%;max-height:100vh;height:100vh;border-radius:0;margin-top:auto}
  .quote-modal__head{padding:28px 22px 18px}
  .quote-modal__title{font-size:28px}
  .quote-modal__body{padding:20px 22px 28px}
  .quote-modal__row{grid-template-columns:1fr}
  .quote-modal__grid{grid-template-columns:1fr}
  .quote-modal__close{top:10px;right:10px}
}
@media (prefers-reduced-motion:reduce){
  .quote-modal__overlay,.quote-modal__panel,.quote-modal__close,.quote-modal__submit{transition:none}
  .quote-modal__check-mark,.quote-modal__spinner{animation:none}
}

/* Sticky mobile CTA bar — bottom-pinned, never changes height on scroll.
   Uses max() so iOS safe-area only widens the padding when it's larger
   than our base 14px, instead of adding on top during scroll. */
.mobile-cta-bar{
  display:none;
  position:fixed !important;
  left:0;right:0;bottom:0;
  width:100%;
  background:#fff;
  border-top:1px solid rgba(0,0,0,.08);
  box-shadow:0 -6px 20px rgba(0,0,0,.10);
  z-index:60;
  padding:14px 14px max(14px, env(safe-area-inset-bottom)) 14px;
  gap:10px;
  box-sizing:border-box;
  align-items:stretch;
  pointer-events:auto;
  -webkit-transform:translateZ(0);
  transform:translateZ(0);
}
.mobile-cta-bar .mcta-btn{
  flex:1 1 0;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px;
  height:54px !important;
  min-height:54px !important;
  max-height:54px !important;
  line-height:1 !important;
  border-radius:0;
  font-family:'Inter',system-ui,sans-serif;
  font-weight:600;
  font-size:15px;
  text-decoration:none;
  border:0;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  touch-action:manipulation;
  white-space:nowrap;
  padding:0 14px;
  box-sizing:border-box;
}
.mobile-cta-bar .mcta-call{background:#fff;color:#0f3d24;border:1.5px solid #0f3d24}
.mobile-cta-bar .mcta-quote{background:#0f3d24;color:#fff}
.mobile-cta-bar .mcta-btn:active{transform:scale(.98)}
.mobile-cta-bar .mcta-btn svg{flex:0 0 18px;width:18px;height:18px}
.mobile-cta-bar .mcta-btn span{line-height:1}
@media (max-width:759.98px){
  .mobile-cta-bar{display:flex}
  /* Body needs to clear: 14 (top pad) + 54 (button) + max(14, safe-area) (bottom pad) + buffer */
  body{padding-bottom:calc(82px + max(14px, env(safe-area-inset-bottom)) + 16px) !important}
  /* Footer doesn't need its own bottom margin if it'd add to that padding */
  footer{padding-bottom:32px}
}

/* ============ DARK MODE OVERRIDES ============ */
.quote-modal__overlay{background:rgba(0,0,0,.65)}
.quote-modal__panel{background:#14271c;border:1px solid rgba(255,255,255,.10);box-shadow:0 30px 80px -20px rgba(0,0,0,.7);color:#f1f5ee}
.quote-modal__close{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.06);color:#f1f5ee}
.quote-modal__close:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.20)}
.quote-modal__head{border-bottom:1px solid rgba(255,255,255,.10);background:linear-gradient(180deg, #0d1a13 0%, #14271c 100%)}
.quote-modal__eyebrow{color:#7ed058}
.quote-modal__eyebrow::before{background:#7ed058}
.quote-modal__title{color:#f1f5ee}
.quote-modal__sub{color:#9bb0a3}
.quote-modal__body{background:#14271c}
.quote-modal__error{background:rgba(220,80,80,.12);border:1px solid rgba(220,80,80,.40);color:#ffb4b4}
.quote-modal__error a{color:#ffd4d4}
.quote-modal__field label,.quote-modal__field legend{color:#f1f5ee}
.quote-modal__field span[aria-hidden]{color:#7ed058}
.quote-modal__field input,.quote-modal__field textarea{color:#f1f5ee;background:#0d1a13;border:1.5px solid rgba(255,255,255,.10)}
.quote-modal__field input:focus,.quote-modal__field textarea:focus{border-color:#5cba3a;background:#0d1a13;box-shadow:0 0 0 4px rgba(92,186,58,.25)}
.quote-modal__field input::placeholder,.quote-modal__field textarea::placeholder{color:#6f8478}
.quote-modal__check{border:1.5px solid rgba(255,255,255,.10);background:#0d1a13;color:#f1f5ee}
.quote-modal__check:hover{border-color:#5cba3a}
.quote-modal__check input{border:1.5px solid rgba(255,255,255,.25);background:#14271c}
.quote-modal__check.is-checked,.quote-modal__check:has(input:checked){border-color:#5cba3a;background:rgba(92,186,58,.12);box-shadow:0 0 0 1px #5cba3a inset;color:#f1f5ee}
.quote-modal__submit{background:#5cba3a;color:#0d1a13;font-weight:700}
.quote-modal__submit:hover:not(:disabled){background:#7ed058}
.quote-modal__submit--ghost{background:rgba(255,255,255,.04);color:#f1f5ee;border:1.5px solid rgba(255,255,255,.10)}
.quote-modal__submit--ghost:hover:not(:disabled){background:rgba(255,255,255,.08);border-color:#5cba3a}
.quote-modal__fineprint{color:#9bb0a3}
.quote-modal__check-mark{color:#7ed058}
.quote-modal__success h3{color:#f1f5ee}
.quote-modal__success p{color:#9bb0a3}
.mobile-cta-bar{background:#0d1a13;border-top:1px solid rgba(255,255,255,.10);box-shadow:0 -6px 20px rgba(0,0,0,.45)}
.mobile-cta-bar .mcta-call{background:#14271c;color:#7ed058;border:1.5px solid rgba(255,255,255,.10)}
.mobile-cta-bar .mcta-quote{background:#5cba3a;color:#0d1a13}
