/* ============================================================
   Love's Window Washing — page layouts for SEO pages
   Builds on styles.css + components.css (shares :root vars).
============================================================ */

/* ---------- Breadcrumb ---------- */
.breadcrumb { font-family: var(--body); font-size: 13px; letter-spacing: 0.01em; }
.breadcrumb ol { list-style: none; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin: 0; padding: 0; }
.breadcrumb li { display: flex; align-items: center; gap: 8px; }
.breadcrumb a { color: inherit; opacity: 0.7; text-decoration: none; }
.breadcrumb a:hover { opacity: 1; text-decoration: underline; }
.breadcrumb li[aria-current] { font-weight: 700; opacity: 0.95; }
.breadcrumb .sep { width: 5px; height: 5px; background: currentColor; transform: rotate(45deg); opacity: 0.5; }

/* ---------- Page hero ---------- */
.page-hero { position: relative; background: var(--cream); color: var(--ink); border-bottom: 4px solid var(--ink); overflow: hidden; padding: 64px 0 64px; text-align: center; }
.page-hero.red { background: var(--red); color: var(--cream); }
.page-hero .ph-sun {
  position: absolute; top: 50%; left: 50%; right: auto;
  width: min(1100px, 150%); height: 280%;
  transform: translate(-50%, -50%);
  background: repeating-conic-gradient(from 0deg at 50% 50%, var(--cream-deep) 0deg 3deg, var(--cream) 3deg 6deg);
  -webkit-mask-image: radial-gradient(closest-side at 50% 50%, #000 18%, transparent 72%);
  mask-image: radial-gradient(closest-side at 50% 50%, #000 18%, transparent 72%);
  opacity: 0.9; pointer-events: none;
}
.page-hero.red .ph-sun {
  background: repeating-conic-gradient(from 0deg at 50% 50%, var(--red-deep) 0deg 3deg, var(--red) 3deg 6deg);
  -webkit-mask-image: radial-gradient(closest-side at 50% 50%, #000 16%, transparent 70%);
  mask-image: radial-gradient(closest-side at 50% 50%, #000 16%, transparent 70%);
  opacity: 0.55;
}
.page-hero .wrap { position: relative; z-index: 2; }
.page-hero .breadcrumb { margin-bottom: 22px; }
.page-hero .breadcrumb ol { justify-content: center; }
.ph-eyebrow { font-family: var(--display); text-transform: uppercase; letter-spacing: 0.12em; font-size: 15px; color: var(--red); display: inline-flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 14px; }
.page-hero.red .ph-eyebrow { color: var(--cream); }
.ph-eyebrow .diamond { width: 9px; height: 9px; }
.page-hero h1 { font-family: var(--display); text-transform: uppercase; font-size: clamp(38px, 6vw, 76px); line-height: 0.9; margin: 0 auto; max-width: 20ch; }
.page-hero h1 .red { color: var(--red); }
.page-hero.red h1 .red { color: var(--cream); text-decoration: underline; text-decoration-thickness: 6px; text-underline-offset: 8px; }
.page-hero .ph-sub { font-size: clamp(17px, 2vw, 21px); line-height: 1.5; max-width: 60ch; margin: 20px auto 0; opacity: 0.9; }
.page-hero .ph-cta { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: center; margin-top: 30px; }
.page-hero .ph-phone { font-family: var(--display); font-size: 24px; color: inherit; }
.page-hero .ph-phone:hover { color: var(--red); }
.page-hero.red .ph-phone:hover { color: var(--cream); opacity: 0.8; }

/* ---------- Quote page static header (non-sticky, borderless) ---------- */
.quote-nav-static { position: static; background: var(--cream); border: none; box-shadow: none; }
.quote-nav-static .nav-inner { display: flex; align-items: center; justify-content: center; height: 96px; }
.quote-nav-static .nav-logo { display: flex; align-items: center; }
.quote-nav-static .nav-logo img { height: 66px; }
@media (max-width: 540px) { .quote-nav-static .nav-inner { height: 78px; } .quote-nav-static .nav-logo img { height: 54px; } }

/* ---------- Centered page hero (no mascot pages) ---------- */.page-hero.center { text-align: center; padding: 64px 0 64px; }
.page-hero.center .ph-sun {
  top: 50%; left: 50%; right: auto;
  width: min(1100px, 150%); height: 280%;
  transform: translate(-50%, -50%);
  background: repeating-conic-gradient(from 0deg at 50% 50%, var(--cream-deep) 0deg 3deg, var(--cream) 3deg 6deg);
  -webkit-mask-image: radial-gradient(closest-side at 50% 50%, #000 18%, transparent 72%);
  mask-image: radial-gradient(closest-side at 50% 50%, #000 18%, transparent 72%);
  opacity: 0.9;
}
.page-hero.center.red .ph-sun {
  background: repeating-conic-gradient(from 0deg at 50% 50%, var(--red-deep) 0deg 3deg, var(--red) 3deg 6deg);
  -webkit-mask-image: radial-gradient(closest-side at 50% 50%, #000 16%, transparent 70%);
  mask-image: radial-gradient(closest-side at 50% 50%, #000 16%, transparent 70%);
  opacity: 0.55;
}
.page-hero.center .breadcrumb ol { justify-content: center; }
.page-hero.center .ph-eyebrow { justify-content: center; }
.page-hero.center h1 { max-width: 20ch; margin-left: auto; margin-right: auto; }
.page-hero.center .ph-sub { margin-left: auto; margin-right: auto; }
.page-hero.center .ph-cta { justify-content: center; }

/* ---------- Generic content ---------- */
.section.tight { padding: 64px 0; }
.prose { max-width: 70ch; }
.prose p { font-size: 17px; line-height: 1.65; margin: 0 0 18px; }
.lead { font-size: 20px !important; line-height: 1.55 !important; font-weight: 500; }
.h2 { font-family: var(--display); text-transform: uppercase; font-size: clamp(28px, 4vw, 46px); line-height: 0.95; margin: 0 0 12px; }
.h2.center { text-align: center; }
.h2 .red { color: var(--red); }
.section.red .h2 .red, .section.red .h2 { color: var(--cream); }
.sub-h { font-size: 18px; line-height: 1.5; opacity: 0.85; max-width: 60ch; margin: 0 0 38px; }
.sub-h.center { text-align: center; margin-left: auto; margin-right: auto; }

/* layout: main + aside */
.twocol { display: grid; grid-template-columns: 1.7fr 1fr; gap: 48px; align-items: start; }
.aside-card { position: sticky; top: 110px; background: var(--cream); border: 3px solid var(--ink); box-shadow: 0 6px 0 rgba(27,27,27,0.25); padding: 26px 24px; }
.section.red .aside-card { background: var(--cream); color: var(--ink); }
.aside-card h3 { font-family: var(--display); text-transform: uppercase; font-size: 24px; margin: 0 0 8px; }
.aside-card p { font-size: 15px; line-height: 1.5; opacity: 0.82; margin: 0 0 18px; }
.aside-card .pill { width: 100%; justify-content: center; margin-bottom: 12px; }
.aside-phone { display: block; text-align: center; font-family: var(--display); font-size: 26px; color: var(--red); }
.aside-list { list-style: none; margin: 18px 0 0; padding: 18px 0 0; border-top: 2px dashed rgba(27,27,27,0.3); display: flex; flex-direction: column; gap: 10px; }
.aside-list li { display: flex; gap: 10px; font-size: 14px; line-height: 1.4; align-items: flex-start; }
.aside-list .tick { flex: none; width: 20px; height: 20px; border-radius: 50%; background: var(--red); color: var(--cream); display: flex; align-items: center; justify-content: center; font-size: 12px; margin-top: 1px; }

/* ---------- Benefit grid ---------- */
.benefit-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.benefit { display: flex; gap: 16px; align-items: flex-start; }
.benefit .b-ic { flex: none; width: 46px; height: 46px; border-radius: 50%; background: var(--red); border: 3px solid var(--ink); box-shadow: 0 3px 0 var(--ink); position: relative; }
.benefit .b-ic::after { content: ""; position: absolute; left: 50%; top: 50%; width: 16px; height: 9px; border-left: 3px solid var(--cream); border-bottom: 3px solid var(--cream); transform: translate(-50%, -65%) rotate(-45deg); }
.benefit h3 { font-family: var(--display); text-transform: uppercase; font-size: 21px; margin: 0 0 5px; line-height: 1; }
.benefit p { font-size: 15px; line-height: 1.5; margin: 0; opacity: 0.84; }
.section.red .benefit p { opacity: 0.92; }

/* ---------- Process steps ---------- */
.process { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; counter-reset: step; }
.step { text-align: center; }
.step .step-n { width: 60px; height: 60px; margin: 0 auto 14px; border-radius: 50%; background: var(--cream); color: var(--red); border: 3px solid var(--ink); box-shadow: 0 4px 0 var(--ink); display: flex; align-items: center; justify-content: center; font-family: var(--display); font-size: 28px; }
.section.red .step .step-n { background: var(--cream); }
.step h3 { font-family: var(--display); text-transform: uppercase; font-size: 19px; margin: 0 0 6px; }
.step p { font-size: 14.5px; line-height: 1.5; margin: 0; opacity: 0.84; }

/* ---------- Includes / checklist ---------- */
.checklist { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 28px; }
.checklist li { display: flex; gap: 12px; align-items: flex-start; font-size: 16px; line-height: 1.45; }
.checklist .tick { flex: none; width: 24px; height: 24px; border-radius: 50%; background: var(--red); color: var(--cream); display: flex; align-items: center; justify-content: center; font-size: 13px; margin-top: 1px; }

/* ---------- Service mini grid (hub + cross-links) ---------- */
.mini-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.mini-card { display: flex; flex-direction: column; background: var(--cream); border: 3px solid var(--ink); box-shadow: 0 6px 0 rgba(27,27,27,0.22); padding: 28px 24px 24px; color: var(--ink); transition: transform 0.15s ease, box-shadow 0.15s ease; text-decoration: none; }
.mini-card:hover { transform: translateY(-5px) rotate(-0.5deg); box-shadow: 0 12px 0 rgba(27,27,27,0.25); }
.mini-card .mc-n { font-family: var(--display); font-size: 15px; color: var(--red); letter-spacing: 0.1em; margin-bottom: 8px; }
.mini-card h3 { font-family: var(--display); text-transform: uppercase; font-size: 26px; line-height: 0.95; margin: 0 0 10px; }
.mini-card h3 .red { color: var(--red); }
.mini-card p { font-size: 15px; line-height: 1.5; margin: 0 0 18px; opacity: 0.82; flex: 1; }
.mini-card .mc-link { font-family: var(--display); text-transform: uppercase; font-size: 14px; letter-spacing: 0.05em; color: var(--red); display: inline-flex; align-items: center; gap: 8px; }
.mini-card .mc-link::after { content: "\2192"; transition: transform 0.15s ease; }
.mini-card:hover .mc-link::after { transform: translateX(4px); }

/* ---------- City grid ---------- */
.city-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.city-card { display: flex; align-items: center; justify-content: space-between; gap: 12px; background: var(--cream); border: 3px solid var(--ink); box-shadow: 0 5px 0 rgba(27,27,27,0.2); padding: 18px 20px; color: var(--ink); text-decoration: none; transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease; }
.city-card:hover { transform: translateY(-3px); box-shadow: 0 9px 0 rgba(27,27,27,0.22); background: #fff; }
.city-card .cc-name { font-family: var(--display); text-transform: uppercase; font-size: 21px; line-height: 1; }
.city-card .cc-sub { font-size: 12px; opacity: 0.6; margin-top: 3px; display: block; letter-spacing: 0.02em; }
.city-card .cc-arrow { font-family: var(--display); color: var(--red); font-size: 22px; flex: none; }

/* ---------- FAQ ---------- */
.faq-list { display: flex; flex-direction: column; gap: 0; max-width: 820px; margin: 0 auto; border-top: 2px solid var(--ink); }
.section.red .faq-list { border-color: var(--cream); }
.faq-item { border-bottom: 2px solid var(--ink); }
.section.red .faq-item { border-color: rgba(250,237,210,0.4); }
.faq-q { width: 100%; text-align: left; display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 22px 4px; font-family: var(--display); text-transform: uppercase; font-size: clamp(18px, 2.2vw, 23px); letter-spacing: 0.01em; color: inherit; cursor: pointer; background: none; border: none; }
.faq-q .faq-ic { flex: none; width: 30px; height: 30px; border-radius: 50%; background: var(--red); color: var(--cream); display: flex; align-items: center; justify-content: center; font-family: var(--display); font-size: 24px; line-height: 1; padding-bottom: 2px; transition: transform 0.2s ease; }
.section.red .faq-q .faq-ic { background: var(--cream); color: var(--red); }
.faq-a { overflow: hidden; height: 0; }
.faq-a-inner { padding-bottom: 4px; }
.faq-a p { font-size: 16px; line-height: 1.6; margin: 0; padding: 0 4px 24px; opacity: 0.86; max-width: 70ch; }

/* ---------- Reviews grid ---------- */
.reviews-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }
.rv-big { background: var(--cream); border: 3px solid var(--ink); box-shadow: 0 6px 0 rgba(27,27,27,0.22); padding: 28px 26px; color: var(--ink); }
.rv-big .rv-stars { display: flex; gap: 3px; color: var(--gold); font-size: 19px; margin-bottom: 12px; }
.rv-big blockquote { margin: 0 0 16px; font-size: 17.5px; line-height: 1.55; font-style: italic; }
.rv-big figcaption { font-family: var(--display); text-transform: uppercase; font-size: 15px; color: var(--red); display: flex; align-items: center; gap: 8px; }
.rv-big figcaption .rv-where { color: var(--ink); opacity: 0.6; font-size: 13px; }

/* ---------- Stats row ---------- */
.stats-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.stat { text-align: center; }
.stat .stat-n { font-family: var(--display); font-size: clamp(40px, 6vw, 64px); line-height: 0.9; color: var(--red); }
.section.red .stat .stat-n { color: var(--cream); }
.stat .stat-l { font-family: var(--display); text-transform: uppercase; font-size: 14px; letter-spacing: 0.06em; margin-top: 6px; opacity: 0.85; }

/* ---------- About ---------- */
.about-split { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
.about-art { display: flex; justify-content: center; }
.about-art img { width: min(360px, 80%); height: auto; filter: drop-shadow(0 12px 22px rgba(27,27,27,0.26)); }
.value-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.value { background: var(--cream); border: 3px solid var(--ink); box-shadow: 0 6px 0 rgba(27,27,27,0.22); padding: 26px 22px; }
.section.red .value { color: var(--ink); }
.value .v-ic { width: 50px; height: 50px; border-radius: 50%; background: var(--red); border: 3px solid var(--ink); margin-bottom: 14px; position: relative; box-shadow: 0 3px 0 var(--ink); }
.value .v-ic::after { content: ""; position: absolute; left: 50%; top: 50%; width: 16px; height: 9px; border-left: 3px solid var(--cream); border-bottom: 3px solid var(--cream); transform: translate(-50%, -65%) rotate(-45deg); }
.value h3 { font-family: var(--display); text-transform: uppercase; font-size: 22px; margin: 0 0 6px; }
.value p { font-size: 15px; line-height: 1.5; margin: 0; opacity: 0.84; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 48px; align-items: start; }
.contact-info { display: flex; flex-direction: column; gap: 22px; }
.contact-row { display: flex; gap: 16px; align-items: flex-start; }
.contact-row .c-ic { flex: none; width: 48px; height: 48px; border-radius: 50%; background: var(--red); border: 3px solid var(--ink); box-shadow: 0 3px 0 var(--ink); display: flex; align-items: center; justify-content: center; color: var(--cream); font-family: var(--display); font-size: 20px; }
.contact-row h3 { font-family: var(--display); text-transform: uppercase; font-size: 18px; margin: 0 0 3px; }
.contact-row a, .contact-row p { font-size: 17px; margin: 0; color: inherit; line-height: 1.4; }
.contact-row a:hover { color: var(--red); }
.contact-card { background: var(--cream); border: 3px solid var(--ink); box-shadow: 0 8px 0 rgba(27,27,27,0.25); padding: 32px 30px; }
.section.red .contact-card { color: var(--ink); }
.contact-card h2 { font-family: var(--display); text-transform: uppercase; font-size: 30px; margin: 0 0 6px; }
.contact-card .cc-sub { font-size: 15px; opacity: 0.8; margin: 0 0 22px; }
.form-stack { display: flex; flex-direction: column; gap: 20px; }
.form-stack .field input, .form-stack .field textarea, .form-row .field input {
  font-family: var(--body); font-size: 16px; padding: 14px 15px; width: 100%;
  background: #fff; color: var(--ink); border: 3px solid var(--ink); border-radius: 10px; outline: none;
  box-shadow: inset 0 2px 4px rgba(27,27,27,0.1); transition: box-shadow 0.15s ease;
}
.form-stack .field textarea { resize: vertical; min-height: 110px; }
.form-stack .field input:focus, .form-stack .field textarea:focus { box-shadow: 0 0 0 4px rgba(121,44,24,0.18), inset 0 2px 4px rgba(27,27,27,0.1); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-card .submit-btn { width: 100%; justify-content: center; margin-top: 4px; }

/* ---------- Compare (commercial vs residential) ---------- */
.compare { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
.compare-col { background: var(--cream); border: 3px solid var(--ink); box-shadow: 0 8px 0 rgba(27,27,27,0.24); padding: 34px 30px; display: flex; flex-direction: column; }
.compare-col.accent { background: var(--red); color: var(--cream); }
.compare-col .cmp-tag { font-family: var(--display); text-transform: uppercase; letter-spacing: 0.1em; font-size: 14px; color: var(--red); margin-bottom: 8px; }
.compare-col.accent .cmp-tag { color: var(--cream); opacity: 0.85; }
.compare-col h2 { font-family: var(--display); text-transform: uppercase; font-size: 34px; margin: 0 0 14px; line-height: 0.95; }
.compare-col > p { font-size: 16px; line-height: 1.55; opacity: 0.86; margin: 0 0 20px; }
.compare-col ul { list-style: none; margin: 0 0 24px; padding: 0; display: flex; flex-direction: column; gap: 11px; flex: 1; }
.compare-col li { display: flex; gap: 11px; font-size: 15.5px; line-height: 1.4; align-items: flex-start; }
.compare-col li .tick { flex: none; width: 22px; height: 22px; border-radius: 50%; background: var(--red); color: var(--cream); display: flex; align-items: center; justify-content: center; font-size: 12px; margin-top: 1px; }
.compare-col.accent li .tick { background: var(--cream); color: var(--red); }
.compare-col .pill { align-self: flex-start; }
.compare-col.accent .pill { background: var(--cream); color: var(--red); }

/* ---------- Inline CTA strip ---------- */
.cta-strip { background: var(--ink); color: var(--cream); border: 3px solid var(--ink); box-shadow: 0 8px 0 rgba(27,27,27,0.3); padding: 40px 36px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 22px; }
.cta-strip > div:last-child { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.cta-strip h2 { font-family: var(--display); text-transform: uppercase; font-size: clamp(24px, 3vw, 36px); margin: 0; line-height: 0.95; }
.cta-strip p { margin: 6px 0 0; opacity: 0.8; font-size: 15px; }

/* ---------- Anchor offset for sticky nav ---------- */
[id] { scroll-margin-top: 96px; }

/* ============================================================
   MULTI-STEP QUOTE WIZARD
============================================================ */
/* centered sunburst behind the whole quote wizard */
.quote-section { position: relative; overflow: hidden; }
.section.quote-section::before { content: none !important; }
.quote-sun {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: min(1100px, 150vw); aspect-ratio: 1; z-index: 0; pointer-events: none;
  background: repeating-conic-gradient(from 0deg, var(--cream-deep) 0deg 3deg, var(--cream) 3deg 6deg);
  -webkit-mask-image: radial-gradient(closest-side, #000 12%, rgba(0,0,0,0.55) 42%, transparent 74%);
  mask-image: radial-gradient(closest-side, #000 12%, rgba(0,0,0,0.55) 42%, transparent 74%);
  opacity: 0.85;
}
.quote-section > .wrap { position: relative; z-index: 1; }
.quote-wizard { max-width: 960px; margin: 0 auto; }
.quote-wizard .breadcrumb { margin-bottom: 34px; }
.ms-form { display: block; }
[hidden] { display: none !important; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ---- horizontal stepper ---- */
.stepper { display: flex; align-items: flex-start; justify-content: center; max-width: 860px; margin: 0 auto; }
.step-node { display: flex; flex-direction: column; align-items: center; gap: 12px; flex: 0 0 auto; width: 92px; text-align: center; }
.step-dot { width: 58px; height: 58px; border-radius: 50%; border: 3px solid var(--red); background-color: var(--cream); color: var(--red); display: flex; align-items: center; justify-content: center; font-family: var(--display); font-size: 26px; transition: transform 0.25s ease, background-color 0.25s ease, color 0.25s ease, box-shadow 0.25s ease; }
.step-node.active .step-dot { background-color: var(--red); color: var(--cream); transform: scale(1.07); box-shadow: 0 8px 18px rgba(27,27,27,0.45); }
.step-node.done .step-dot { background-color: var(--red); color: var(--cream); box-shadow: 0 5px 14px rgba(27,27,27,0.3); }
.step-label { font-family: var(--display); text-transform: uppercase; font-size: 13px; letter-spacing: 0.06em; color: var(--ink); opacity: 0.4; transition: opacity 0.2s ease, color 0.2s ease; }
.step-node.active .step-label, .step-node.done .step-label { opacity: 1; color: var(--red); }
.step-conn { flex: 1 1 auto; min-width: 20px; height: 3px; margin-top: 28px; background: var(--cream-deep); border-radius: 3px; position: relative; }
.step-conn::after { content: ""; position: absolute; inset: 0; width: 0; background: var(--red); border-radius: 3px; transition: width 0.35s ease; }
.step-conn.filled::after { width: 100%; }

/* ---- steps ---- */
.ms-step { border: none; margin: 0; padding: 0; min-width: 0; }
.ms-step[hidden] { display: none; }
.ms-headline { font-family: var(--display); text-transform: uppercase; text-align: center; font-size: clamp(30px, 5vw, 58px); line-height: 0.95; margin: 50px 0 38px; }
.ms-headline .red { color: var(--red); }
.ms-narrow { max-width: 620px; margin: 0 auto; }
.ms-fields { display: flex; flex-direction: column; gap: 20px; }
.ms-fields .field-label { font-family: var(--display); text-transform: uppercase; font-size: 13px; letter-spacing: 0.06em; margin-bottom: 7px; display: block; }
.ms-select { font-family: var(--body); font-size: 16px; padding: 15px 16px; width: 100%; background: #fff; color: var(--ink); border: 3px solid var(--ink); border-radius: 10px; outline: none; box-shadow: inset 0 2px 4px rgba(27,27,27,0.1); }
.ms-opt { font-family: var(--body); text-transform: none; font-weight: 400; opacity: 0.5; font-size: 12px; letter-spacing: 0; }

/* phone with country prefix */
.phone-row { display: flex; gap: 10px; }
.phone-prefix { flex: 0 0 auto; display: flex; align-items: center; justify-content: center; padding: 0 18px; background-color: #fff; border: 3px solid var(--ink); border-radius: 10px; font-family: var(--display); font-size: 18px; box-shadow: inset 0 2px 4px rgba(27,27,27,0.1); }
.phone-row input { flex: 1; min-width: 0; }
/* unify all wizard field backgrounds */
.quote-wizard .field input, .quote-wizard .field textarea, .quote-wizard .ms-select { background-color: #fff; }

/* ---- choice tiles (property + services) ---- */
.choice-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 720px; margin: 0 auto; }
.choice-grid.svc-choices { grid-template-columns: repeat(4, 1fr); max-width: 900px; }
.choice { position: relative; cursor: pointer; }
.choice input { position: absolute; opacity: 0; width: 0; height: 0; }
.choice-box { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; height: 100%; padding: 30px 16px; background-color: #fff; border: 3px solid var(--ink); border-radius: 14px; box-shadow: 0 6px 0 rgba(27,27,27,0.18); transition: transform 0.12s ease, box-shadow 0.12s ease, background-color 0.12s ease; }
.choice:hover .choice-box { transform: translateY(-4px); box-shadow: 0 10px 0 rgba(27,27,27,0.2); }
.choice-ic { width: 44px; height: 44px; color: var(--red); }
.choice-ic svg { width: 100%; height: 100%; display: block; }
.choice-name { font-family: var(--display); text-transform: uppercase; font-size: 16px; text-align: center; line-height: 1.05; }
.choice input:checked + .choice-box { background-color: var(--cream); box-shadow: 0 6px 0 var(--red), inset 0 0 0 3px var(--red); }
.choice input:focus-visible + .choice-box { outline: 3px solid var(--red); outline-offset: 3px; }
/* property step = bigger tiles */
.choice-grid:not(.svc-choices) .choice-box { padding: 50px 22px; }
.choice-grid:not(.svc-choices) .choice-ic { width: 60px; height: 60px; }
.choice-grid:not(.svc-choices) .choice-name { font-size: 24px; }

/* ---- errors ---- */
.ms-err { color: var(--red); font-weight: 700; font-size: 14px; margin: 22px auto 0; display: flex; align-items: center; justify-content: center; gap: 8px; }
.ms-err::before { content: "!"; flex: none; width: 20px; height: 20px; border-radius: 50%; background: var(--red); color: var(--cream); display: inline-flex; align-items: center; justify-content: center; font-family: var(--display); font-size: 14px; }
.ms-err[hidden] { display: none; }

/* ---- footer nav ---- */
.ms-footer { display: flex; align-items: center; justify-content: space-between; gap: 18px; margin-top: 50px; padding-top: 26px; border-top: 2px dashed rgba(27,27,27,0.25); }
.ms-counter { font-family: var(--display); text-transform: uppercase; font-size: 15px; letter-spacing: 0.05em; opacity: 0.7; }
.ms-counter .ms-cur { color: var(--red); }
.ms-actions { display: flex; gap: 12px; align-items: center; }
.pill.ghost { background: transparent; color: var(--red); box-shadow: 0 4px 0 var(--ink); }
.pill.ghost:hover { background: var(--cream-deep); }

@media (max-width: 760px) {
  .choice-grid.svc-choices { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .step-node { width: 64px; }
  .step-dot { width: 46px; height: 46px; font-size: 20px; }
  .step-label { font-size: 10.5px; letter-spacing: 0.02em; }
  .step-conn { margin-top: 22px; }
  .ms-headline { margin: 36px 0 28px; }
  .choice-grid, .choice-grid.svc-choices { grid-template-columns: 1fr 1fr; gap: 12px; }
  .choice-box { padding: 22px 12px; gap: 10px; }
  .choice-grid:not(.svc-choices) .choice-box { padding: 32px 14px; }
  .ms-footer { flex-direction: column-reverse; align-items: stretch; gap: 16px; }
  .ms-actions { justify-content: space-between; flex-wrap: wrap; }
  .ms-actions .pill { flex: 1; justify-content: center; }
  .ms-actions .ms-submit { flex: 1 0 100%; }
  .ms-counter { text-align: center; }
}

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 1000px) {
  .twocol { grid-template-columns: 1fr; gap: 36px; }
  .aside-card { position: static; }
  .process { grid-template-columns: repeat(2, 1fr); gap: 28px; }
  .mini-grid { grid-template-columns: repeat(2, 1fr); }
  .city-grid { grid-template-columns: repeat(2, 1fr); }
  .about-split { grid-template-columns: 1fr; gap: 32px; }
  .about-art { order: -1; }
  .value-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 36px; }
  .stats-row { grid-template-columns: repeat(2, 1fr); gap: 30px; }
}
@media (max-width: 700px) {
  .page-hero { padding: 28px 0 40px; }
  .benefit-grid { grid-template-columns: 1fr; }
  .checklist { grid-template-columns: 1fr; }
  .process { grid-template-columns: 1fr; }
  .mini-grid { grid-template-columns: 1fr; }
  .city-grid { grid-template-columns: 1fr; }
  .reviews-grid { grid-template-columns: 1fr; }
  .compare { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .cta-strip { padding: 30px 22px; }
}

/* ============================================================
   2026 REFRESH
   (1) double-rule dividers  (2) ticket-notch boxes
   (3) two-line header       (4) logo pops out
   (5) zero shadows          (6) capitalized cursive
============================================================ */

/* ---- (5) NO SHADOWS ANYWHERE ---- */
*, *::before, *::after { box-shadow: none !important; text-shadow: none !important; }
.emblem-mascot, .foot-brand img, .foot-brand .foot-logo, .about-art img { filter: none !important; }
/* keep inputs usable without their shadow focus ring */
.field input:focus,
.form-stack .field input:focus,
.form-stack .field textarea:focus,
.ms-select:focus { outline: 3px solid var(--red); outline-offset: 2px; }
.choice input:checked + .choice-box { border-color: var(--red) !important; background-color: var(--cream) !important; }

/* ---- (6) CURSIVE: capitalize so F's (and word-initials) read clearly ---- */
.script { text-transform: capitalize !important; }

/* ---- (1) SECTION DIVIDERS — thin / thick / thin, straddling the boundary;
        gap above shows the upper section color, gap below the lower ---- */
.hero, .page-hero { border-bottom: none !important; }
.section.red::after { content: none !important; }
.section::before,
.section.red::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important; right: 0 !important; top: -12px !important; bottom: auto !important;
  width: auto !important; height: 24px !important;
  transform: none !important;
  background: linear-gradient(to bottom,
    transparent 0 3px, var(--ink) 3px 5px,
    transparent 5px 9px, var(--ink) 9px 15px,
    transparent 15px 19px, var(--ink) 19px 21px,
    transparent 21px 24px) !important;
  background-size: auto !important;
  z-index: 6; pointer-events: none;
}

/* ---- (3) HEADER — two thin equal black lines, broken around the logo ---- */
.nav { border-bottom: none !important; }
.nav::after {
  content: ""; position: absolute; left: 100px; right: 0; bottom: 0; height: 7px;
  z-index: 1; pointer-events: none;
  background: linear-gradient(to bottom,
    var(--ink) 0 2px, transparent 2px 5px,
    var(--ink) 5px 7px);
}

/* ---- (4) LOGO in a circular badge that pops out of the header ---- */
.nav-inner { overflow: visible; }
.nav-logo {
  position: relative; z-index: 6;
  width: 150px; height: 150px; flex: none;
  border-radius: 50%;
  background: var(--cream);
  border: 3px solid var(--ink);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  transform: translateY(28px);
  transform-origin: top center;
}
.nav.scrolled .nav-logo {
  width: 122px; height: 122px;
  transform: translateY(20px);
}
/* left rule runs behind the badge to its center; the circle (z-index 6)
   covers the overlap so both lines appear to touch the curve exactly */
.nav::before {
  content: ""; position: absolute; left: 0; width: 100px; bottom: 0; height: 7px;
  z-index: 1; pointer-events: none;
  background: linear-gradient(to bottom,
    var(--ink) 0 2px, transparent 2px 5px,
    var(--ink) 5px 7px);
}
.nav-logo img { height: auto !important; width: 90% !important; transform: none !important; }

/* ---- (2) TICKET-NOTCH BOXES (concave corners; fill + both rules curve) ---- */
.vframe, .mini-card, .city-card, .rv-big, .value,
.compare-col, .aside-card, .contact-card, .cta-strip, .rev-col {
  --tk-r: 15px;
  --tk-fill: var(--cream);
  --tk-line: var(--ink);
  --tk-inner: rgba(27,27,27,0.42);
  --tk-mask:
    radial-gradient(circle var(--tk-r) at 0 0, #0000 98%, #000) top left / 51% 51% no-repeat,
    radial-gradient(circle var(--tk-r) at 100% 0, #0000 98%, #000) top right / 51% 51% no-repeat,
    radial-gradient(circle var(--tk-r) at 0 100%, #0000 98%, #000) bottom left / 51% 51% no-repeat,
    radial-gradient(circle var(--tk-r) at 100% 100%, #0000 98%, #000) bottom right / 51% 51% no-repeat;
  position: relative;
  isolation: isolate;
  border: none !important;
  background: var(--tk-line) !important;
  -webkit-mask: var(--tk-mask); mask: var(--tk-mask);
}
.vframe::before, .mini-card::before, .city-card::before, .rv-big::before, .value::before,
.compare-col::before, .aside-card::before, .contact-card::before, .cta-strip::before, .rev-col::before {
  content: ""; position: absolute; inset: 3px; z-index: -2; pointer-events: none;
  background: var(--tk-fill);
  -webkit-mask: var(--tk-mask); mask: var(--tk-mask);
}
.vframe::after, .mini-card::after, .city-card::after, .rv-big::after, .value::after,
.compare-col::after, .aside-card::after, .contact-card::after, .cta-strip::after, .rev-col::after {
  content: ""; position: absolute; inset: 7px; z-index: -1; pointer-events: none;
  border: 1.5px solid var(--tk-inner);
  -webkit-mask: var(--tk-mask); mask: var(--tk-mask);
}
/* fill colors for non-cream tickets */
.rev-col { --tk-fill: var(--red); --tk-inner: rgba(250,237,210,0.34); }
.compare-col.accent { --tk-fill: var(--red); --tk-inner: rgba(250,237,210,0.34); }
.cta-strip { --tk-fill: var(--ink); --tk-inner: rgba(250,237,210,0.30); }
.city-card:hover { --tk-fill: #fff; }
/* keep the number badge inside the masked card */
.svc-stamp { margin-top: 0 !important; }
.svc { padding-top: 30px; }
/* keep sticky aside working with a real positioned context */
.aside-card { position: sticky !important; top: 110px; }
@media (max-width: 1000px) {
  .aside-card { position: relative !important; top: auto; }
}

/* ---- mobile: plain logo top-left + hamburger top-right (no circle badge) ---- */
@media (max-width: 1000px) {
  /* drop the circular badge entirely */
  .nav-logo {
    width: auto !important; height: auto !important; flex: none;
    border: none !important; background: transparent !important;
    border-radius: 0 !important; overflow: visible !important;
    transform: none !important; display: flex; align-items: center;
  }
  .nav.scrolled .nav-logo { width: auto !important; height: auto !important; transform: none !important; }
  .nav-logo img { height: 72px !important; width: auto !important; }
  .nav.scrolled .nav-logo img { height: 60px !important; }
  /* single continuous double-line across the whole header bottom */
  .nav::before { display: none !important; }
  .nav::after { left: 0 !important; right: 0 !important; }
}
@media (max-width: 540px) {
  .nav-logo img { height: 62px !important; }
  .nav.scrolled .nav-logo img { height: 52px !important; }
}
