@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@500;600;700;800&display=swap');

:root {
  --navy-950: #0b1f33;
  --navy-900: #102a43;
  --navy-800: #173f5f;
  --blue: #f47a3c;
  --blue-light: #fff0e8;
  --coral: #f47a3c;
  --coral-dark: #d95d22;
  --ink: #17324a;
  --muted: #647585;
  --line: #dfe7ec;
  --cream: #f7f8f7;
  --white: #fff;
  --shadow: 0 24px 60px rgba(5, 39, 58, .12);
  --radius: 10px;
  --container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: "DM Sans", Arial, sans-serif;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
.container { width: min(calc(100% - 40px), var(--container)); margin-inline: auto; }
.section { padding: 110px 0; }
.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; }
.skip-link { position: fixed; z-index: 1000; top: -100px; left: 16px; padding: 10px 16px; background: white; color: var(--navy-900); border-radius: 4px; }
.skip-link:focus { top: 16px; }

.announcement { background: var(--navy-950); color: rgba(255,255,255,.86); font-size: 12px; letter-spacing: .02em; }
.announcement__inner { min-height: 37px; display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.announcement a { color: white; font-weight: 700; }
.pulse { display: inline-block; width: 7px; height: 7px; margin-right: 8px; border-radius: 50%; background: #ffb067; box-shadow: 0 0 0 5px rgba(255,176,103,.13); }

.site-header { position: relative; z-index: 50; background: white; box-shadow: 0 1px 0 rgba(4,35,55,.08); }
.nav-wrap { min-height: 82px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 10px; line-height: 1; }
.brand__mark { width: 43px; height: 43px; flex: 0 0 auto; }
.brand__text { display: flex; flex-direction: column; }
.brand__text strong { font-family: "Manrope", sans-serif; color: var(--navy-900); font-size: 17px; letter-spacing: .055em; }
.brand__text small { margin-top: 5px; color: var(--blue); font-size: 9px; font-weight: 800; letter-spacing: .31em; }
.primary-nav { display: flex; align-items: center; gap: clamp(18px, 2vw, 30px); }
.primary-nav > a:not(.button):not(.nav-phone) { color: #294956; font-size: 13px; font-weight: 700; }
.primary-nav > a:hover { color: var(--blue); }
.nav-phone { display: flex; align-items: center; gap: 8px; font-weight: 700; color: var(--navy-900); font-size: 14px; line-height: 1.2; }
.nav-phone small { display: block; color: var(--muted); font-size: 9px; font-weight: 500; text-transform: uppercase; letter-spacing: .08em; }
.nav-phone__icon { display: grid; place-items: center; width: 31px; height: 31px; color: var(--blue); background: var(--blue-light); border-radius: 50%; font-size: 12px; }
.nav-toggle { display: none; padding: 6px; background: transparent; border: 0; }
.nav-toggle span:not(.sr-only) { display: block; width: 26px; height: 2px; margin: 5px 0; background: var(--navy-900); transition: .2s; }

.button { display: inline-flex; align-items: center; justify-content: center; gap: 18px; min-height: 52px; padding: 0 25px; border: 0; border-radius: 4px; color: white; background: var(--blue); font-size: 13px; font-weight: 800; letter-spacing: .01em; cursor: pointer; transition: transform .2s, background .2s, box-shadow .2s; }
.button:hover { transform: translateY(-2px); box-shadow: 0 12px 25px rgba(4,35,55,.18); }
.button--small { min-height: 43px; padding: 0 18px; font-size: 12px; }
.button--coral { background: var(--coral); }
.button--coral:hover { background: var(--coral-dark); }
.button--navy { background: var(--navy-900); }
.button--full { width: 100%; }
.text-link { display: inline-flex; align-items: center; gap: 12px; color: var(--navy-900); font-size: 13px; font-weight: 800; }
.text-link span { color: var(--blue); }
.text-link--light { color: white; }
.play { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid rgba(255,255,255,.48); border-radius: 50%; }

.hero { position: relative; min-height: 690px; display: flex; align-items: center; color: white; overflow: hidden; background: var(--navy-900) url("assets/images/hero-plumber.jpg") center center / cover no-repeat; }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(2,27,42,.94) 0%, rgba(2,32,48,.80) 35%, rgba(3,38,56,.25) 70%, rgba(3,38,56,.1) 100%); }
.hero__content { position: relative; z-index: 2; padding-top: 15px; padding-bottom: 55px; }
.hero__copy { max-width: 660px; }
.eyebrow { display: flex; align-items: center; gap: 10px; margin: 0 0 20px; color: var(--blue); font-size: 11px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; }
.eyebrow span { width: 27px; height: 2px; background: currentColor; }
.eyebrow--light { color: #ffab73; }
.hero h1, h2 { font-family: "Manrope", sans-serif; letter-spacing: -.045em; line-height: 1.08; }
.hero h1 { margin: 0; font-size: clamp(56px, 7vw, 91px); font-weight: 700; }
.hero h1 em { color: #ff9a60; font-style: normal; }
.hero__lead { max-width: 600px; margin: 28px 0 32px; color: rgba(255,255,255,.83); font-size: 18px; line-height: 1.7; }
.hero__actions { display: flex; align-items: center; gap: 29px; }
.hero__proof { display: flex; gap: 28px; margin-top: 38px; color: rgba(255,255,255,.75); font-size: 11px; }
.hero__proof b { display: inline-grid; place-items: center; width: 17px; height: 17px; margin-right: 6px; color: white; background: rgba(244,122,60,.35); border-radius: 50%; }
.hero__rating { position: absolute; z-index: 3; right: 0; bottom: 0; }
.rating-badge { display: flex; align-items: center; gap: 16px; min-width: 300px; padding: 19px 28px; color: var(--navy-900); background: white; border-radius: 8px 0 0 0; box-shadow: var(--shadow); }
.rating-badge__score { font-family: "Manrope"; font-size: 32px; font-weight: 800; }
.stars { color: #ffb84d; font-size: 14px; letter-spacing: 2px; }
.rating-badge small, .reviews__score small { color: var(--muted); font-size: 10px; }

.trust-strip { position: relative; z-index: 4; background: white; box-shadow: 0 10px 40px rgba(9,50,70,.08); }
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); min-height: 104px; }
.trust-item { display: flex; align-items: center; justify-content: center; gap: 15px; border-right: 1px solid var(--line); }
.trust-item:last-child { border-right: 0; }
.trust-item__icon { display: grid; place-items: center; width: 42px; height: 42px; color: var(--blue); background: var(--blue-light); border-radius: 50%; font-size: 21px; }
.trust-item strong, .trust-item small { display: block; }
.trust-item strong { font-family: "Manrope"; font-size: 13px; }
.trust-item small { color: var(--muted); font-size: 10px; }

.services { background: var(--cream); }
.section-heading { max-width: 680px; margin-bottom: 52px; }
.section-heading--center { margin-inline: auto; text-align: center; }
.section-heading--center .eyebrow { justify-content: center; }
.section-heading h2, .difference h2, .spotlight h2, .reviews h2, .faq h2, .estimate h2 { margin: 0 0 20px; color: var(--navy-900); font-size: clamp(37px, 5vw, 57px); font-weight: 700; }
.section-heading > p:last-child { max-width: 575px; margin: auto; color: var(--muted); font-size: 16px; }
.service-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.service-card { position: relative; min-height: 488px; padding: 38px 29px 30px; overflow: hidden; color: white; background: linear-gradient(180deg, rgba(11,31,51,.98) 0%, rgba(16,42,67,.96) 100%); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius); transition: transform .25s, box-shadow .25s, border-color .25s; }
.service-card:hover { transform: translateY(-7px); border-color: rgba(255,255,255,.16); box-shadow: var(--shadow); }
.service-card--featured { border-top: 4px solid #ff9a60; }
.service-card__number { position: absolute; right: 19px; top: 10px; color: rgba(255,255,255,.16); font-family: "Manrope"; font-size: 65px; font-weight: 800; line-height: 1; }
.service-card__icon { position: relative; display: grid; place-items: center; width: 62px; height: 62px; margin-bottom: 25px; color: var(--blue); background: rgba(255,255,255,.12); border-radius: 50%; }
.service-card__icon svg { width: 32px; }
.service-card h3 { margin: 0 0 13px; color: white; font-family: "Manrope"; font-size: 19px; }
.service-card p { color: rgba(255,255,255,.75); font-size: 13px; line-height: 1.7; }
.service-card ul { min-height: 120px; margin: 20px 0 21px; padding: 18px 0 0; border-top: 1px solid rgba(255,255,255,.12); list-style: none; }
.service-card li { position: relative; padding: 4px 0 4px 18px; color: rgba(255,255,255,.72); font-size: 11px; }
.service-card li::before { content: "✓"; position: absolute; left: 0; color: var(--blue); font-weight: 800; }
.service-card > a { color: white; font-size: 12px; font-weight: 800; }
.service-card > a span { margin-left: 8px; color: var(--blue); }

.difference { overflow: hidden; }
.split { display: grid; grid-template-columns: .95fr 1fr; align-items: center; gap: clamp(60px, 9vw, 125px); }
.image-stack { position: relative; padding: 0 0 45px 24px; }
.image-stack__main { position: relative; z-index: 2; overflow: hidden; border-radius: 7px; box-shadow: var(--shadow); }
.image-stack__main::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 0 1px rgba(255,255,255,.2); }
.image-stack__main img { width: 100%; aspect-ratio: 1 / 1.08; object-fit: cover; }
.image-stack__card { position: absolute; z-index: 3; right: -42px; bottom: 10px; display: flex; align-items: center; gap: 14px; padding: 20px 24px; color: white; background: var(--blue); border-radius: 5px; box-shadow: 0 18px 35px rgba(7,159,197,.25); }
.image-stack__card span { font-family: "Manrope"; font-size: 36px; font-weight: 800; }
.image-stack__card p { margin: 0; padding-left: 14px; border-left: 1px solid rgba(255,255,255,.4); font-size: 10px; line-height: 1.5; text-transform: uppercase; letter-spacing: .08em; }
.image-stack__dots { position: absolute; left: 0; bottom: 0; width: 100px; height: 100px; background-image: radial-gradient(#f4a477 1.5px, transparent 1.5px); background-size: 10px 10px; }
.difference__copy .lead { margin-bottom: 28px; color: var(--muted); font-size: 16px; }
.benefit { display: grid; grid-template-columns: 34px 1fr; gap: 16px; margin: 21px 0; }
.benefit__check { display: grid; place-items: center; width: 29px; height: 29px; color: var(--blue); background: var(--blue-light); border-radius: 50%; font-weight: 800; }
.benefit h3 { margin: 0 0 3px; font-family: "Manrope"; color: var(--navy-900); font-size: 14px; }
.benefit p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.65; }
.difference__copy .button { margin-top: 15px; }

.process { color: white; background: var(--navy-900); }
.section-heading--light h2 { color: white; }
.process-grid { display: grid; grid-template-columns: 1fr 110px 1fr 110px 1fr; align-items: start; text-align: center; }
.process-grid article { max-width: 245px; margin: auto; }
.process-step { position: relative; display: grid; place-items: center; width: 76px; height: 76px; margin: 0 auto 24px; color: #ff9a60; border: 1px solid rgba(255,154,96,.58); border-radius: 50%; font-size: 26px; }
.process-step span { position: absolute; top: -7px; right: -7px; display: grid; place-items: center; width: 26px; height: 26px; color: var(--navy-900); background: #ff9a60; border-radius: 50%; font-size: 9px; font-weight: 800; }
.process-step b { font-weight: 400; }
.process-line { margin-top: 38px; border-top: 1px dashed rgba(255,154,96,.35); }
.process h3 { margin: 0 0 12px; font-family: "Manrope"; font-size: 16px; }
.process article p { margin: 0; color: rgba(255,255,255,.6); font-size: 12px; line-height: 1.7; }

.spotlight { background: var(--cream); }
.spotlight__grid { display: grid; grid-template-columns: .8fr 1.2fr; align-items: center; gap: 90px; }
.spotlight__copy p:not(.eyebrow) { color: var(--muted); }
.spotlight__image { position: relative; }
.spotlight__image img { width: 100%; height: 435px; object-fit: cover; border-radius: 8px; box-shadow: var(--shadow); }
.spotlight__tag { position: absolute; left: -28px; bottom: 28px; padding: 13px 18px; color: var(--navy-900); background: white; border-radius: 4px; box-shadow: 0 12px 30px rgba(4,35,55,.18); font-size: 11px; font-weight: 800; }
.spotlight__tag span { display: inline-grid; place-items: center; width: 20px; height: 20px; margin-right: 7px; color: white; background: var(--blue); border-radius: 50%; }

.reviews__header { display: flex; align-items: end; justify-content: space-between; margin-bottom: 40px; }
.reviews__header h2 { margin-bottom: 0; }
.reviews__score { display: flex; align-items: center; gap: 16px; padding-bottom: 10px; }
.reviews__score > strong { font-family: "Manrope"; color: var(--navy-900); font-size: 42px; }
.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.review-card { padding: 31px; background: var(--cream); border: 1px solid #e4edef; border-radius: 7px; }
.review-card--raised { background: white; box-shadow: var(--shadow); transform: translateY(-10px); }
.review-card blockquote { min-height: 110px; margin: 18px 0 24px; color: #3d5966; font-size: 14px; line-height: 1.75; }
.review-card footer { display: flex; align-items: center; gap: 11px; }
.review-card footer > span { display: grid; place-items: center; width: 38px; height: 38px; color: white; background: var(--blue); border-radius: 50%; font-size: 11px; font-weight: 800; }
.review-card footer strong, .review-card footer small { display: block; }
.review-card footer strong { font-size: 12px; }
.review-card footer small { color: var(--muted); font-size: 9px; }

.faq { background: var(--cream); }
.faq__grid { display: grid; grid-template-columns: .65fr 1.35fr; gap: 90px; }
.faq__grid > div:first-child > p:not(.eyebrow) { max-width: 260px; color: var(--muted); font-size: 13px; }
.accordion details { border-bottom: 1px solid #d5e3e7; }
.accordion summary { position: relative; padding: 22px 44px 22px 0; color: var(--navy-900); font-family: "Manrope"; font-size: 14px; font-weight: 700; cursor: pointer; list-style: none; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary span::before, .accordion summary span::after { content: ""; position: absolute; right: 8px; top: 50%; width: 14px; height: 2px; background: var(--blue); }
.accordion summary span::after { transform: rotate(90deg); transition: .2s; }
.accordion details[open] summary span::after { transform: rotate(0); }
.accordion details p { max-width: 670px; margin: -8px 0 22px; color: var(--muted); font-size: 12px; line-height: 1.75; }

.estimate { padding: 100px 0; color: white; background: var(--navy-900); }
.estimate__grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; align-items: center; }
.estimate h2 { color: white; }
.estimate__copy > p:not(.eyebrow) { max-width: 480px; color: rgba(255,255,255,.65); }
.estimate__contact { display: flex; flex-wrap: wrap; gap: 30px; margin-top: 38px; }
.estimate__contact > div { display: flex; gap: 10px; align-items: center; }
.estimate__contact > div > span { display: grid; place-items: center; width: 35px; height: 35px; color: #ff9a60; background: rgba(255,154,96,.12); border-radius: 50%; }
.estimate__contact p { margin: 0; }
.estimate__contact small, .estimate__contact a { display: block; }
.estimate__contact small { color: rgba(255,255,255,.5); font-size: 9px; text-transform: uppercase; }
.estimate__contact a { font-size: 11px; font-weight: 700; }
.quote-form { padding: 34px; color: var(--ink); background: white; border-radius: 8px; box-shadow: 0 25px 70px rgba(0,0,0,.2); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.quote-form label { display: block; margin-bottom: 14px; color: var(--navy-900); font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; }
.quote-form input, .quote-form select, .quote-form textarea { width: 100%; margin-top: 6px; padding: 13px 14px; color: var(--ink); background: #f8faf9; border: 1px solid #dce7e9; border-radius: 4px; outline: 0; font-size: 12px; text-transform: none; }
.quote-form input:focus, .quote-form select:focus, .quote-form textarea:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(7,159,197,.1); }
.quote-form textarea { resize: vertical; }
.form-note { margin: 9px 0 0; color: #899aa2; font-size: 9px; text-align: center; }
.form-success { margin-top: 12px; padding: 12px; color: #0f604c; background: #e4f7ef; border-radius: 4px; font-size: 11px; text-align: center; }

.site-footer { padding: 70px 0 22px; color: rgba(255,255,255,.55); background: #031e2d; }
.footer-grid { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 60px; padding-bottom: 55px; }
.brand--footer .brand__text strong { color: white; }
.footer-grid > div:first-child p { max-width: 300px; font-size: 12px; }
.footer-grid h3 { margin: 0 0 19px; color: white; font-family: "Manrope"; font-size: 12px; }
.footer-grid a { display: block; margin: 9px 0; font-size: 11px; }
.footer-grid a:hover { color: #ff9a60; }
.footer-grid p { font-size: 11px; }
.footer-bottom { display: flex; justify-content: space-between; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.1); font-size: 9px; }
.footer-bottom span { margin: 0 6px; }
.mobile-call { display: none; }

.reveal { opacity: 0; transform: translateY(25px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 1060px) {
  .primary-nav { gap: 16px; }
  .primary-nav > a:not(.button):not(.nav-phone) { display: none; }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .service-card { min-height: 450px; }
  .process-grid { grid-template-columns: 1fr 60px 1fr 60px 1fr; }
  .spotlight__grid, .estimate__grid { gap: 55px; }
  .footer-grid { gap: 35px; }
}

@media (max-width: 760px) {
  body { padding-bottom: 55px; }
  .container { width: min(calc(100% - 28px), var(--container)); }
  .section { padding: 78px 0; }
  .announcement__inner { justify-content: center; text-align: center; }
  .announcement a { display: none; }
  .nav-wrap { min-height: 70px; }
  .brand__mark { width: 38px; height: 38px; }
  .brand__text strong { font-size: 15px; }
  .nav-toggle { position: relative; z-index: 3; display: block; }
  .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .primary-nav { position: absolute; top: 70px; left: 0; right: 0; display: none; padding: 20px; background: white; box-shadow: 0 20px 35px rgba(4,35,55,.15); }
  .primary-nav.is-open { display: grid; }
  .primary-nav > a:not(.button):not(.nav-phone) { display: block; padding: 4px 8px; font-size: 9px; letter-spacing: .03em; line-height: 1.15; }
  .nav-phone { padding: 8px; }
  .hero { min-height: 680px; align-items: end; background-position: 62% center; }
  .hero__overlay { background: linear-gradient(0deg, rgba(2,27,42,.98) 2%, rgba(2,30,45,.84) 57%, rgba(2,30,45,.3) 100%); }
  .hero__content { padding-bottom: 70px; }
  .hero h1 { font-size: clamp(52px, 17vw, 72px); }
  .hero__lead { margin: 23px 0 27px; font-size: 15px; }
  .hero__actions { align-items: flex-start; flex-direction: column; gap: 19px; }
  .hero__proof { flex-wrap: wrap; gap: 12px 19px; margin-top: 29px; }
  .hero__rating { display: none; }
  .trust-grid { grid-template-columns: 1fr 1fr; padding: 15px 0; }
  .trust-item { justify-content: flex-start; padding: 14px 10px; border-bottom: 1px solid var(--line); }
  .trust-item:nth-child(2) { border-right: 0; }
  .trust-item:nth-child(n+3) { border-bottom: 0; }
  .trust-item__icon { width: 35px; height: 35px; font-size: 16px; }
  .trust-item strong { font-size: 11px; }
  .trust-item small { font-size: 9px; }
  .section-heading { margin-bottom: 38px; }
  .section-heading h2, .difference h2, .spotlight h2, .reviews h2, .faq h2, .estimate h2 { font-size: 39px; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { min-height: auto; }
  .service-card ul { min-height: auto; }
  .split { grid-template-columns: 1fr; gap: 60px; }
  .image-stack { max-width: 520px; padding-left: 0; }
  .image-stack__card { right: -5px; }
  .process-grid { grid-template-columns: 1fr; gap: 45px; }
  .process-line { display: none; }
  .spotlight__grid { display: flex; flex-direction: column-reverse; gap: 45px; }
  .spotlight__image img { height: 350px; }
  .spotlight__tag { left: 12px; }
  .reviews__header { align-items: flex-start; flex-direction: column; gap: 25px; }
  .review-grid { grid-template-columns: 1fr; }
  .review-card--raised { transform: none; }
  .review-card blockquote { min-height: auto; }
  .faq__grid { grid-template-columns: 1fr; gap: 35px; }
  .estimate__grid { grid-template-columns: 1fr; gap: 45px; }
  .quote-form { padding: 25px 20px; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid > div:first-child { grid-column: 1 / -1; }
  .footer-bottom { align-items: flex-start; flex-direction: column; }
  .mobile-call { position: fixed; z-index: 100; left: 0; right: 0; bottom: 0; display: flex; align-items: center; justify-content: center; gap: 9px; height: 55px; color: white; background: var(--coral); box-shadow: 0 -5px 20px rgba(4,35,55,.18); font-size: 13px; font-weight: 800; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
