:root{
  --black:#101418;
  --deep:#17202a;
  --green:#239b3d;
  --orange:#f49a1d;
  --orange-dark:#dd7f08;
  --red:#cf2e2e;
  --red-dark:#a61f1f;
  --white:#ffffff;
  --text:#1d2733;
  --muted:#667587;
  --line:#e7ecf0;
  --soft:#f7f9fb;
  --shadow:0 18px 48px rgba(16,20,24,.08);
  --max:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial,Helvetica,sans-serif;
  color:var(--text);
  line-height:1.6;
  background:
    linear-gradient(rgba(0,0,0,.78),rgba(0,0,0,.78)),
    var(--page-bg) center/cover fixed no-repeat;
  background-color:#000000;
}
body.page-home{--page-bg:url('home_bg.jpg')}
body.page-services{--page-bg:url('services_bg.jpg')}
body.page-contact{--page-bg:url('contact_bg.jpg')}
body.page-projects{--page-bg:url('projects_bg.jpg')}
body.page-roofing{--page-bg:url('roofing_bg.jpg')}
body.page-instant-roof-quote{--page-bg:url('satellite_quote_bg.jpg')}
body.page-emergency{--page-bg:url('emergency_bg.jpg');--topbar-start:var(--red);--topbar-end:var(--red-dark)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.topbar{background:linear-gradient(90deg,var(--topbar-start,var(--orange)),var(--topbar-end,var(--orange-dark)));color:#fff;font-size:14px;font-weight:700}
.topbar a{color:#fff}
.wrap,.container,.nav,.footer-wrap{max-width:var(--max);margin:0 auto;padding-left:22px;padding-right:22px}
.topbar .wrap{padding-top:12px;padding-bottom:12px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav{padding-top:14px;padding-bottom:14px;display:flex;justify-content:space-between;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand img{width:64px;height:64px;min-width:64px;min-height:64px;object-fit:cover;border-radius:50%;background:#0d1117;padding:8px;border:4px solid #fff;display:block}
.brand h1{margin:0;font-size:20px;line-height:1.1}
.brand p{margin:5px 0 0;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:1px}
nav{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
nav a.active{color:var(--green);font-weight:700}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:15px 24px;border-radius:999px;font-weight:700;border:none;white-space:nowrap}
.btn-primary,.btn-green{background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;box-shadow:0 10px 24px rgba(244,154,29,.24)}
.btn-outline{background:#fff;color:var(--black);border:2px solid var(--black)}
.btn-outline.active{border-color:var(--green);color:var(--green)}
.btn-emergency{background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;box-shadow:0 10px 24px rgba(207,46,46,.24)}
.cta-row,.inline-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.cta-row{width:100%;max-width:760px}
.cta-row .btn{flex:1;text-align:center}
.hero,.page-hero{background-image:linear-gradient(rgba(255,255,255,.90),rgba(255,255,255,.90)),var(--page-bg);background-position:center;background-size:cover;background-repeat:no-repeat;background-color:transparent;border-bottom:1px solid var(--line)}
.hero{position:relative;overflow:hidden}
.hero .container,.page-hero .container{position:relative;z-index:1;padding-top:60px;padding-bottom:60px;display:grid;grid-template-columns:1.08fr .92fr;gap:38px;align-items:center}
.eyebrow{display:inline-flex;padding:8px 14px;border-radius:999px;background:#eef8f0;border:1px solid #d6ecd9;color:var(--green);font-size:13px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;margin-bottom:18px}
.orange-badge{display:inline-block;background:linear-gradient(135deg,#f49a1d,#dd7f08);color:#fff;padding:12px 24px;border-radius:999px;font-weight:700;margin-bottom:16px;font-size:18px}
.alert-band{display:inline-block;background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;padding:12px 24px;border-radius:999px;font-weight:700;margin-bottom:16px;font-size:18px}
.hero h2,.page-hero h2{margin:0 0 18px;color:var(--green);font-size:56px;line-height:1.02;letter-spacing:-1.6px}
.hero p,.page-hero p{margin:0 0 28px;color:var(--muted);font-size:19px}
.info-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.info-pill,.service,.contact-card,.quote-form,.cta-card,.notice-card{background:#fff;border:1px solid var(--line);border-radius:26px;padding:26px;box-shadow:var(--shadow)}
.notice-card{display:flex;align-items:flex-start;gap:14px;border-left:6px solid var(--orange)}
.notice-card strong{color:var(--green)}
.hero-logo-card,.side-logo{background:transparent;border:none;box-shadow:none;padding:0;display:flex;justify-content:center;align-items:center}
.hero-logo-card img,.side-logo img{width:420px;max-width:100%;height:auto;object-fit:contain;border-radius:24px;background:transparent;padding:0;border:none;box-shadow:none;display:block;margin:0 auto}
section{padding:86px 22px}
.container{max-width:var(--max);margin:0 auto}
.section-head{max-width:860px;margin-bottom:36px}
.mini{color:var(--orange);font-size:13px;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.section-head h3,.service h4,.contact-card h4,.cta-card h4,.quote-form h3{margin:0 0 10px;color:var(--green)}
.section-head h3{font-size:42px;line-height:1.08;letter-spacing:-1px;margin-bottom:12px}
.service h4,.contact-card h4,.cta-card h4{font-size:22px}
.quote-form h3{font-size:34px;margin-bottom:18px}
.section-head p{margin:0;color:#dbe3ec;font-size:18px}
.service p,.contact-card p,.cta-card p{margin:0;color:var(--muted)}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.service-icon{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;font-size:26px;margin-bottom:16px;background:linear-gradient(135deg,#eef8f0,#fff1df)}
.service ul,.checklist{margin:14px 0 0;padding-left:18px}
.service li,.checklist li{margin:0 0 8px}
.quote-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:24px}
.quote-form label{display:block;font-size:14px;font-weight:700;margin:0 0 8px;color:var(--black)}
.quote-form input,.quote-form textarea,.quote-form select{width:100%;padding:14px;border:1px solid #d8dfe6;border-radius:14px;font:inherit;background:#fff}
.quote-form textarea{min-height:120px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.note{font-size:13px;color:var(--muted);margin-top:10px}
.footer{background:var(--black);color:#fff;padding:42px 22px;margin-top:24px}
.footer-wrap{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}
.muted-light{color:#cfd7e0}
.muted{color:var(--muted)}
@media (max-width:1020px){.hero .container,.page-hero .container,.grid-4,.grid-3,.grid-2,.quote-grid,.info-strip{grid-template-columns:1fr 1fr}.hero h2,.page-hero h2{font-size:46px}}
@media (max-width:760px){.nav{flex-direction:column;align-items:flex-start}nav{width:100%}.hero .container,.page-hero .container,.grid-4,.grid-3,.grid-2,.quote-grid,.info-strip,.form-row{grid-template-columns:1fr}.hero h2,.page-hero h2{font-size:35px}.section-head h3{font-size:30px}}



.warranty-section{padding-top:28px;padding-bottom:86px}
.warranty-card{
  background:linear-gradient(135deg,#0c1219,#121a24 56%,#0b1017);
  border:1px solid rgba(255,255,255,.08);
  border-radius:32px;
  padding:30px;
  box-shadow:0 24px 56px rgba(0,0,0,.28);
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:30px;
  align-items:center;
  overflow:hidden;
}
.warranty-card::before{
  content:"";
  position:absolute;
  inset:auto -10% -40% auto;
  width:340px;
  height:340px;
  background:radial-gradient(circle,rgba(244,154,29,.22),rgba(244,154,29,0) 68%);
  pointer-events:none;
}
.warranty-card{position:relative}
.warranty-button-link{display:block}
.warranty-button-link img{
  width:100%;
  max-width:520px;
  border-radius:28px;
  display:block;
  box-shadow:0 20px 40px rgba(0,0,0,.28);
}
.warranty-copy{position:relative;z-index:1}
.warranty-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#fff;
  font-size:13px;
  font-weight:800;
  letter-spacing:.9px;
  text-transform:uppercase;
  margin-bottom:18px;
}
.warranty-card h3{
  margin:0 0 14px;
  color:#fff;
  font-size:42px;
  line-height:1.08;
  letter-spacing:-1px;
}
.warranty-card p{
  margin:0;
  color:#d8e0e9;
  font-size:18px;
}
.warranty-pills{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:22px;
}
.warranty-pill{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.11);
  border-radius:22px;
  padding:18px;
  color:#eff4f8;
}
.warranty-pill strong{
  display:block;
  margin-bottom:6px;
  color:#fff;
  font-size:18px;
}
.btn-outline-light{
  background:transparent;
  color:#fff;
  border:2px solid rgba(255,255,255,.42);
}
.warranty-note{
  margin-top:14px;
  color:#b9c5d1;
  font-size:14px;
}
@media (max-width:1020px){
  .warranty-card{grid-template-columns:1fr}
}
@media (max-width:760px){
  .warranty-card h3{font-size:31px}
  .warranty-pills{grid-template-columns:1fr}
}



/* Enhanced WMC quote form */
.form-section-title{
  margin:24px 0 12px;
  padding-top:4px;
  color:var(--green);
  font-size:15px;
  font-weight:800;
  letter-spacing:.8px;
  text-transform:uppercase;
}
.form-section-title:first-of-type{margin-top:0}
.optional{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
  text-transform:none;
  letter-spacing:0;
}
.quote-form input[type="file"]{
  padding:11px;
  background:#f8fafc;
}
.checkbox-line{
  display:flex !important;
  align-items:flex-start;
  gap:12px;
  margin:12px 0 0 !important;
  color:var(--text) !important;
  font-size:15px !important;
  font-weight:700 !important;
  line-height:1.45;
}
.checkbox-line input{
  width:20px !important;
  height:20px;
  min-width:20px;
  margin-top:2px;
  accent-color:var(--orange);
}
.checkbox-line span{display:block}


.upload-warning{color:#b42318;font-weight:700;}


/* File upload remove buttons */
.file-clear-button{
  margin-top:8px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(180,35,24,.28);
  background:#fff;
  color:#b42318;
  font-size:13px;
  font-weight:800;
  cursor:pointer;
}
.file-clear-button:hover,.file-clear-button:focus{
  background:#fff4f2;
  outline:none;
}
.file-clear-button[hidden]{
  display:none !important;
}


.footer-contact{min-width:180px}
.footer-partner{
  margin-left:auto;
  display:flex;
  align-items:center;
  gap:12px;
  width:300px;
  max-width:100%;
  padding:12px 14px;
  border:1px solid rgba(245,130,11,.45);
  border-radius:18px;
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.03));
  box-shadow:0 18px 34px rgba(0,0,0,.18);
  color:#fff;
  text-decoration:none;
}
.footer-partner:hover{border-color:rgba(245,130,11,.9);transform:translateY(-1px)}
.footer-partner img{
  width:58px;
  height:58px;
  object-fit:contain;
  border-radius:14px;
  background:#0a1017;
  padding:5px;
  flex:0 0 auto;
}
.footer-partner small{display:block;color:#f5820b;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:3px}
.footer-partner strong{display:block;color:#fff;font-size:15px;line-height:1.1}
.footer-partner em{display:block;color:#cfd7e0;font-style:normal;font-size:11px;line-height:1.3;margin-top:3px}
.footer-partner b{display:block;color:#fff;font-size:12px;margin-top:4px}
@media (max-width:760px){.footer-partner{margin-left:0;width:100%}}

/* WMC moving logo intro */
.wmc-intro {
  position: fixed;
  inset: 0;
  z-index: 999999;
  display: grid;
  place-items: center;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 38%, rgba(244, 154, 29, 0.18), transparent 32%),
    linear-gradient(135deg, #060a0f 0%, #111923 52%, #060a0f 100%);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 0.55s ease, visibility 0.55s ease;
}

.wmc-intro::before {
  content: "";
  position: absolute;
  inset: -30%;
  background:
    linear-gradient(110deg, transparent 0%, rgba(255, 255, 255, 0.07) 42%, rgba(255, 255, 255, 0.22) 50%, rgba(255, 255, 255, 0.07) 58%, transparent 100%);
  transform: translateX(-70%) rotate(6deg);
  animation: wmcIntroSweep 1.65s ease-out both;
}

.wmc-intro-stage {
  position: relative;
  width: min(460px, 82vw);
  transform-origin: center center;
  animation: wmcLogoMove 1.85s cubic-bezier(.2,.72,.18,1) forwards;
}

.wmc-intro-stage img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 26px;
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.48);
}

html.wmc-intro-complete .wmc-intro {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

html.wmc-intro-skip .wmc-intro {
  display: none !important;
}

@keyframes wmcLogoMove {
  0% {
    opacity: 0;
    transform: translateY(34px) scale(0.92);
    filter: blur(2px);
  }
  22% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
  68% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateY(-58px) scale(0.72);
  }
}

@keyframes wmcIntroSweep {
  0% { transform: translateX(-78%) rotate(6deg); opacity: 0; }
  35% { opacity: 1; }
  100% { transform: translateX(78%) rotate(6deg); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
  .wmc-intro::before,
  .wmc-intro-stage {
    animation: none;
  }
  .wmc-intro {
    transition: opacity .2s ease, visibility .2s ease;
  }
}

/* WMC mobile-only compact header and menu */
.mobile-menu-toggle,
.mobile-menu-panel,
.mobile-header-actions{
  display:none;
}

@media (max-width:760px){
  .topbar .wrap{
    padding-top:7px;
    padding-bottom:7px;
    font-size:12px;
    line-height:1.25;
    gap:6px;
  }
  .topbar .wrap > div:first-child{
    display:none;
  }

  header{
    z-index:120;
  }
  .nav{
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    padding:8px 14px 6px;
  }
  .brand{
    gap:9px;
    flex:1 1 auto;
    min-width:0;
  }
  .brand img{
    width:46px;
    height:46px;
    min-width:46px;
    min-height:46px;
    padding:5px;
    border-width:3px;
  }
  .brand h1{
    font-size:13px;
    line-height:1.12;
    max-width:210px;
  }
  .brand p{
    margin-top:2px;
    font-size:8.5px;
    line-height:1.2;
    letter-spacing:.45px;
    max-width:210px;
  }

  header nav{
    width:auto;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:0;
    flex:0 0 auto;
    position:relative;
  }
  header nav > a:not(.mobile-menu-link),
  header nav > .cta-row{
    display:none !important;
  }

  .mobile-menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:38px;
    padding:9px 12px;
    border-radius:999px;
    border:1px solid rgba(16,20,24,.16);
    background:#fff;
    color:var(--black);
    font:inherit;
    font-size:13px;
    font-weight:800;
    box-shadow:0 8px 18px rgba(16,20,24,.08);
    cursor:pointer;
    white-space:nowrap;
  }
  .mobile-menu-toggle:focus{
    outline:3px solid rgba(244,154,29,.28);
    outline-offset:2px;
  }
  .mobile-menu-panel{
    position:absolute;
    top:calc(100% + 10px);
    right:0;
    width:min(286px, calc(100vw - 28px));
    padding:10px;
    border:1px solid rgba(16,20,24,.12);
    border-radius:20px;
    background:rgba(255,255,255,.98);
    box-shadow:0 18px 48px rgba(16,20,24,.18);
  }
  .mobile-menu-toggle[aria-expanded="true"] + .mobile-menu-panel{
    display:block;
  }
  .mobile-menu-link{
    display:flex;
    align-items:center;
    justify-content:space-between;
    width:100%;
    padding:12px 13px;
    border-radius:14px;
    color:var(--black);
    font-size:15px;
    font-weight:800;
  }
  .mobile-menu-link::after{
    content:"›";
    color:var(--orange);
    font-size:20px;
    line-height:1;
  }
  .mobile-menu-link:hover,
  .mobile-menu-link:focus,
  .mobile-menu-link.active{
    background:#fff4e5;
    color:var(--green);
    outline:none;
  }

  .mobile-header-actions{
    display:grid;
    grid-template-columns:.9fr 1.25fr 1.15fr;
    gap:6px;
    max-width:var(--max);
    margin:0 auto;
    padding:0 10px 8px;
  }
  .mobile-header-actions .btn{
    min-height:40px;
    padding:7px 6px;
    border-radius:14px;
    font-size:11px;
    line-height:1.12;
    text-align:center;
    white-space:normal;
    box-shadow:0 6px 14px rgba(16,20,24,.10);
  }
  .mobile-header-actions .btn-outline{
    border-width:1.5px;
  }

  .hero .container,
  .page-hero .container{
    padding-top:34px;
  }
}

@media (max-width:390px){
  .brand h1{font-size:12px;max-width:172px}
  .brand p{font-size:7.8px;max-width:172px}
  .mobile-menu-toggle{font-size:12px;padding:8px 10px;min-height:36px}
  .mobile-header-actions .btn{font-size:10.5px;min-height:38px;padding:6px 4px}
}

/* WMC scroll reveal card animations */
.wmc-scroll-reveal {
  opacity: 0;
  transition:
    opacity 0.78s ease,
    transform 0.78s cubic-bezier(.2,.72,.18,1),
    box-shadow 0.28s ease;
  will-change: opacity, transform;
}

.wmc-scroll-reveal.wmc-reveal-left {
  transform: translate3d(-42px, 18px, 0);
}

.wmc-scroll-reveal.wmc-reveal-right {
  transform: translate3d(42px, 18px, 0);
}

.wmc-scroll-reveal.wmc-reveal-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

@media (max-width: 700px) {
  .wmc-scroll-reveal.wmc-reveal-left {
    transform: translate3d(-24px, 14px, 0);
  }
  .wmc-scroll-reveal.wmc-reveal-right {
    transform: translate3d(24px, 14px, 0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .wmc-scroll-reveal,
  .wmc-scroll-reveal.wmc-reveal-left,
  .wmc-scroll-reveal.wmc-reveal-right {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* WMC private instant roof quote engine */
.page-instant-roof-quote .instant-roof-hero .container{align-items:center}
.instant-roof-hero h2{max-width:980px}
.instant-trust-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:24px}
.instant-trust-strip>div{padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);box-shadow:0 12px 28px rgba(0,0,0,.14)}
.instant-trust-strip strong{display:block;color:#fff;font-size:17px;margin-bottom:4px}
.instant-trust-strip span{display:block;color:#e8edf3;font-size:14px;line-height:1.45}
.instant-estimator-section{padding-top:74px}
.instant-section-head{max-width:1060px}
.instant-estimator-grid{display:grid;grid-template-columns:minmax(0,1.38fr) minmax(320px,.82fr);gap:28px;align-items:start}
.roof-estimator-card{padding:30px;border-radius:30px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 26px 70px rgba(15,23,42,.14)}
.roof-estimator-card h3,.roof-lead-form h3{margin:0 0 10px;font-size:31px;line-height:1.12;color:var(--green)}
.instant-card-copy{margin:0 0 20px;color:var(--muted);font-size:16px}
.instant-step-label{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:7px 13px;border-radius:999px;background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;font-size:12px;font-weight:900;letter-spacing:.8px;text-transform:uppercase;margin-bottom:14px}
.instant-form-hint{margin:9px 0 16px;color:var(--muted);font-size:13px;font-weight:700}
.roof-address-autocomplete-shell{position:relative;z-index:22}
.roof-address-autocomplete-shell #roof-address{position:relative;z-index:2}
.roof-address-suggestions{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:35;overflow:hidden;padding:8px;border-radius:20px;background:#fff;border:1px solid rgba(15,23,42,.16);box-shadow:0 24px 54px rgba(15,23,42,.20)}
.roof-address-suggestions[hidden]{display:none}
.roof-address-suggestion{display:flex;align-items:flex-start;gap:12px;width:100%;padding:13px 14px;border:0;border-radius:15px;background:transparent;color:#111827;font:inherit;text-align:left;cursor:pointer;transition:background .18s ease,transform .18s ease}
.roof-address-suggestion:hover,.roof-address-suggestion.is-active{background:linear-gradient(135deg,#fff8ef,#eef8f1);transform:translateX(2px)}
.roof-address-suggestion-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 34px;height:34px;margin-top:1px;border-radius:999px;background:#eef8f1;color:#12633f;font-size:16px;font-weight:900}
.roof-address-suggestion-copy{display:grid;gap:3px;min-width:0}
.roof-address-suggestion-copy strong{display:block;color:#111827;font-size:14px;line-height:1.35;font-weight:950}
.roof-address-suggestion-copy span{display:block;color:#475569;font-size:13px;line-height:1.35;font-weight:700}
.roof-address-suggestion-empty{padding:13px 14px;color:#475569;font-size:13px;line-height:1.45;font-weight:800}
.roof-address-autocomplete-status{min-height:18px;margin:7px 0 0;color:#475569;font-size:12px;line-height:1.45;font-weight:800}
.roof-address-autocomplete-status.is-working{color:#9a5a00}
.roof-address-autocomplete-status.is-success{color:#12633f}
.roof-address-autocomplete-status.is-error{color:#b42318}
.instant-submit-button{margin-top:10px;min-width:230px;justify-content:center}
.instant-status{min-height:24px;margin-top:16px;padding:0;font-weight:800;font-size:14px;line-height:1.5;color:var(--muted)}
.instant-status.is-working{color:#9a5a00}
.instant-status.is-success{color:#12633f}
.instant-status.is-error{color:#b42318}
.roof-quote-results{margin-top:28px;padding:26px;border-radius:28px;background:linear-gradient(180deg,#fff8ef 0%,#fff 100%);border:1px solid rgba(244,130,11,.26);box-shadow:0 18px 42px rgba(17,24,39,.10)}
.roof-result-header h3{margin:0 0 10px;font-size:28px;color:#111827}
.roof-result-header p{margin:6px 0;color:#334155}
.manual-review-result{padding:4px 0 2px}
.roof-package-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:22px}
.roof-package-card{padding:22px;border-radius:24px;background:#fff;border:1px solid rgba(15,23,42,.10);box-shadow:0 14px 30px rgba(15,23,42,.08)}
.roof-package-badge{display:inline-flex;margin-bottom:12px;padding:7px 11px;border-radius:999px;background:#eef8f1;color:#11663f;font-size:12px;font-weight:900;letter-spacing:.6px;text-transform:uppercase}
.roof-package-card h4{margin:0 0 8px;color:#111827;font-size:21px}
.roof-package-price-label{margin:0 0 4px;color:#64748b;font-size:12px;font-weight:900;letter-spacing:.65px;text-transform:uppercase}
.roof-package-price{margin:0 0 12px;color:var(--orange-dark);font-weight:950;font-size:24px;line-height:1.25;letter-spacing:-.4px}
.roof-package-card p{margin:0;color:#475569;font-size:15px;line-height:1.55}
.roof-package-tier{margin:16px 0 6px;color:#11663f;font-size:12px;font-weight:900;letter-spacing:.8px;text-transform:uppercase}
.roof-package-recommended{display:inline-flex;align-items:center;gap:8px;margin:0 0 10px;padding:8px 12px;border-radius:999px;background:linear-gradient(135deg,rgba(244,154,29,.12),rgba(35,155,61,.12));border:1px solid rgba(244,154,29,.22);color:#9a5500;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}
.roof-package-subtitle{margin:0 0 12px;color:#475569;font-size:14px;font-weight:700}
.roof-product-media{position:relative;margin:0 0 14px;border-radius:20px;overflow:hidden;border:1px solid rgba(15,23,42,.08);background:#f8fafc;box-shadow:0 10px 24px rgba(15,23,42,.08)}
.roof-product-media img{display:block;width:100%;height:190px;object-fit:cover}
.roof-product-image-badge{position:absolute;left:12px;bottom:12px;display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(17,24,39,.86);backdrop-filter:blur(4px);color:#fff;font-size:12px;font-weight:900;letter-spacing:.5px;text-transform:uppercase;border:1px solid rgba(255,255,255,.16)}
.roof-product-rating{display:flex;align-items:center;justify-content:center;gap:12px;margin:0 0 14px;padding:12px 14px;border-radius:16px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);text-align:center}
.roof-product-stars{display:inline-flex;align-items:center;justify-content:center;gap:3px;font-size:20px;line-height:1;font-weight:900}
.roof-product-rating-text{display:none}
.roof-product-feature-list{margin:16px 0 0;padding:16px 18px 16px 34px;border-radius:18px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);color:#334155;font-size:14px;line-height:1.6}
.roof-product-feature-list li+li{margin-top:6px}
.roof-result-note{margin-top:18px;padding:16px 18px;border-radius:18px;background:#111827;color:#f8fafc;font-size:15px;line-height:1.6}
.roof-review-system-wrap{margin-top:22px}
.roof-review-system-card{padding:24px;border-radius:26px;background:#fff;border:1px solid rgba(15,23,42,.10);box-shadow:0 14px 30px rgba(15,23,42,.08)}
.roof-review-flat-card{border-left:6px solid var(--orange)}
.roof-review-mixed-card{border-left:6px solid var(--green)}
.roof-review-system-badge{display:inline-flex;margin-bottom:12px;padding:8px 12px;border-radius:999px;background:#111827;color:#fff;font-size:12px;font-weight:900;letter-spacing:.6px;text-transform:uppercase}
.roof-review-system-card h4{margin:0 0 10px;color:#111827;font-size:24px;line-height:1.2}
.roof-review-system-card p{margin:0;color:#475569;font-size:16px;line-height:1.65}
.roof-review-system-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px}
.roof-review-system-grid>div{padding:16px;border-radius:18px;background:#f8fafc;border:1px solid rgba(15,23,42,.08)}
.roof-review-system-grid strong{display:block;margin-bottom:5px;color:#111827;font-size:14px}
.roof-review-system-grid span{display:block;color:#475569;font-size:14px;line-height:1.55}
.gmp-attribution{margin:16px 0 0;font-family:Roboto,Sans-Serif;font-style:normal;font-weight:400;font-size:13px;letter-spacing:normal;white-space:nowrap;color:#5e5e5e}
.roof-lead-form{margin-top:28px;padding-top:28px;border-top:1px solid rgba(15,23,42,.10)}
.instant-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px 18px;margin-bottom:16px}
.instant-legal-note{margin:14px 0 2px;color:var(--muted);font-size:14px;font-weight:700}
.instant-legal-note a{font-weight:900;color:var(--green)}
.instant-consent-line{margin-top:18px !important}
.roof-submit-success{padding:18px 0 8px;scroll-margin-top:118px;outline:none}
.roof-submit-success h3{margin:0 0 12px;color:var(--green);font-size:32px}
.roof-submit-success p{color:#334155;font-size:16px;line-height:1.65}
.instant-side-stack{display:grid;gap:20px}
.instant-info-card{padding:24px;border-radius:28px}
.instant-info-card h4{font-size:24px;margin-bottom:12px}
.instant-checklist{margin-top:14px}
.instant-emergency-card{background:linear-gradient(180deg,#fff3f2 0%,#fff 100%);border:1px solid rgba(180,35,24,.20)}
.instant-how-section{padding-top:74px}
.instant-flow-card{min-height:248px}
.instant-disclaimer-section{padding-top:18px}
.instant-disclaimer-card{border-left:5px solid var(--orange);padding:28px;border-radius:26px}
.instant-disclaimer-card h4{font-size:26px}
.instant-disclaimer-card p{font-size:16px;line-height:1.75}
.legal-page-copy{max-width:980px;margin:0 auto;padding:36px;border-radius:30px;background:#fff;border:1px solid rgba(15,23,42,.08);box-shadow:0 24px 56px rgba(15,23,42,.10)}
.legal-page-copy h3{margin-top:28px;color:var(--green);font-size:24px}
.legal-page-copy h3:first-child{margin-top:0}
.legal-page-copy p,.legal-page-copy li{color:#334155;line-height:1.75;font-size:16px}
.legal-page-copy ul{padding-left:24px}
@media (max-width:1120px){
  .instant-estimator-grid{grid-template-columns:1fr}
  .instant-side-stack{grid-template-columns:repeat(2,minmax(0,1fr))}
  .roof-package-grid{grid-template-columns:1fr}
  .roof-review-system-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .instant-trust-strip,.instant-form-grid,.instant-side-stack{grid-template-columns:1fr}
  .roof-estimator-card{padding:22px;border-radius:24px}
  .roof-estimator-card h3,.roof-lead-form h3,.roof-submit-success h3{font-size:26px}
  .roof-quote-results{padding:20px;border-radius:22px}
  .roof-result-header h3{font-size:24px}
  .instant-submit-button{width:100%;min-width:0}
  .roof-package-price{font-size:22px}
  .gmp-attribution{white-space:normal}
  .legal-page-copy{padding:24px;border-radius:24px}
}



/* WMC precision satellite roof map and measurement workstation */
.roof-map-stage{margin-top:28px;padding-top:28px;border-top:1px solid rgba(15,23,42,.10)}
.roof-map-stage.roof-stage-preparing-selection{visibility:hidden;pointer-events:none}
.roof-property-summary{margin:0 0 18px}
.roof-property-card{display:grid;gap:6px;padding:18px 20px;border-radius:20px;background:linear-gradient(180deg,#eef8f1 0%,#fff 100%);border:1px solid rgba(22,155,98,.22);color:#173326}
.roof-property-card strong{font-size:16px;color:#111827}
.roof-property-card span{font-size:14px;line-height:1.55;color:#365247}
.roof-property-card .gmp-attribution{margin:4px 0 0;font-style:normal}
.roof-map-shell{position:relative;overflow:hidden;margin:18px 0 18px;border-radius:28px;border:1px solid rgba(15,23,42,.12);box-shadow:0 22px 54px rgba(15,23,42,.14);background:#e5e7eb}
.roof-map{width:100%;height:620px;min-height:520px}
.roof-map-status{position:absolute;left:18px;right:18px;bottom:18px;z-index:2;min-height:0;padding:14px 16px;border-radius:18px;background:rgba(17,24,39,.92);color:#fff;font-size:14px;font-weight:800;line-height:1.5;box-shadow:0 16px 30px rgba(0,0,0,.22)}
.roof-map-status.is-working{background:rgba(154,90,0,.94)}
.roof-map-status.is-success{background:rgba(18,99,63,.94)}
.roof-map-status.is-error{background:rgba(180,35,24,.94)}
.roof-tool-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:18px 0}
.roof-tool-grid .btn{width:100%;min-height:50px;padding:12px 10px;justify-content:center;text-align:center;font-size:14px}
.roof-map-guidance{display:grid;gap:10px;margin:14px 0 22px;padding:18px 20px;border-radius:22px;background:#fff8ef;border:1px solid rgba(244,130,11,.22);color:#5a3a13;font-size:14px;line-height:1.6}
.roof-map-guidance strong{color:#111827}
.roof-map-guidance em{font-style:normal;font-weight:900;color:#9a5a00}
.roof-selection-layout{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(300px,.85fr);gap:18px;margin-top:18px}
.roof-selected-list-card,.roof-measurement-card{padding:20px;border-radius:24px;background:#fff;border:1px solid rgba(15,23,42,.10);box-shadow:0 16px 34px rgba(15,23,42,.08)}
.roof-panel-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.roof-panel-heading h4{margin:0;color:#111827;font-size:22px}
.roof-panel-heading span{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:6px 11px;border-radius:999px;background:#eef8f1;color:#11663f;font-size:12px;font-weight:900}
.roof-selected-list{display:grid;gap:14px}
.roof-empty-state{margin:0;padding:16px;border-radius:18px;background:#f8fafc;color:#475569;font-weight:800}
.roof-selection-row{display:grid;grid-template-columns:auto minmax(0,1fr);gap:14px;padding:16px;border-radius:20px;background:#f8fafc;border:1px solid rgba(15,23,42,.10);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}
.roof-selection-row.is-selected{background:#fff8ef;border-color:rgba(244,130,11,.45);box-shadow:0 14px 30px rgba(244,130,11,.14)}
.roof-select-row{align-self:start;min-width:78px;min-height:40px;padding:9px 12px;border:0;border-radius:999px;background:#111827;color:#fff;font:inherit;font-size:13px;font-weight:900;cursor:pointer}
.roof-row-main{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.roof-row-main label{margin:0;color:#334155;font-size:13px;font-weight:900}
.roof-row-main input,.roof-row-main select{margin-top:7px}
.roof-row-metrics{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:9px 12px;padding-top:4px}
.roof-row-metrics span{display:inline-flex;gap:5px;align-items:center;padding:8px 11px;border-radius:999px;background:#fff;border:1px solid rgba(15,23,42,.08);color:#334155;font-size:13px}
.roof-measurement-summary{display:grid;gap:10px}
.roof-measurement-summary>div,.roof-result-measurements>div{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid rgba(15,23,42,.08)}
.roof-measurement-summary>div:last-child,.roof-result-measurements>div:last-child{border-bottom:0}
.roof-measurement-summary strong,.roof-result-measurements strong{color:#334155}
.roof-measurement-summary span,.roof-result-measurements span{color:#111827;font-weight:950;text-align:right}
.roof-measurement-note{margin:16px 0 0;color:#475569;font-size:14px;line-height:1.6;font-weight:700}
.roof-calculate-button{margin-top:22px}
.roof-result-measurements{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 22px;margin:20px 0;padding:18px 20px;border-radius:22px;background:#fff;border:1px solid rgba(15,23,42,.10)}
.roof-result-breakdown{margin:0 0 18px;padding:18px 20px 18px 42px;border-radius:22px;background:#f8fafc;border:1px solid rgba(15,23,42,.08);color:#334155;line-height:1.65}
.roof-result-breakdown li+li{margin-top:8px}
@media (max-width:1120px){
  .roof-selection-layout{grid-template-columns:1fr}
  .roof-tool-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .roof-map{height:520px;min-height:420px}
  .roof-map-status{left:12px;right:12px;bottom:12px;padding:12px 13px;font-size:13px}
  .roof-tool-grid{grid-template-columns:1fr}
  .roof-tool-grid .btn{min-height:46px;font-size:13px}
  .roof-panel-heading{align-items:flex-start;flex-direction:column}
  .roof-selection-row{grid-template-columns:1fr}
  .roof-select-row{justify-self:start}
  .roof-row-main{grid-template-columns:1fr}
  .roof-row-metrics{grid-column:auto}
  .roof-measurement-summary>div,.roof-result-measurements>div{display:grid;gap:5px}
  .roof-result-measurements{grid-template-columns:1fr;padding:16px}
}


/* Premium WMC Roof Intelligence Studio visual upgrade */
.roof-studio-panel{
  position:relative;
  isolation:isolate;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(320px,.88fr);
  gap:22px;
  align-items:center;
  margin:18px 0 22px;
  padding:26px;
  border-radius:30px;
  overflow:hidden;
  background:
    radial-gradient(circle at 8% 10%,rgba(244,154,29,.26),rgba(244,154,29,0) 32%),
    radial-gradient(circle at 92% 16%,rgba(35,155,61,.22),rgba(35,155,61,0) 30%),
    linear-gradient(135deg,#0c1219 0%,#17202a 52%,#0e151d 100%);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 30px 78px rgba(0,0,0,.30);
}
.roof-studio-panel::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(120deg,rgba(255,255,255,.11),rgba(255,255,255,0) 22%),
    repeating-linear-gradient(135deg,rgba(255,255,255,.028) 0 1px,transparent 1px 18px);
  pointer-events:none;
}
.roof-studio-copy{position:relative;z-index:1}
.roof-studio-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:34px;
  padding:8px 14px;
  border-radius:999px;
  color:#fff;
  background:linear-gradient(135deg,rgba(244,154,29,.95),rgba(221,127,8,.95));
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 12px 26px rgba(244,154,29,.22);
  font-size:12px;
  line-height:1;
  font-weight:950;
  letter-spacing:.9px;
  text-transform:uppercase;
}
.roof-studio-copy h4{
  margin:16px 0 10px;
  color:#fff;
  font-size:30px;
  line-height:1.12;
  letter-spacing:-.6px;
}
.roof-studio-copy p{
  margin:0;
  color:#d8e1eb;
  font-size:16px;
  line-height:1.68;
}
.roof-studio-live{
  position:relative;
  z-index:1;
  display:grid;
  gap:12px;
}
.roof-studio-stat{
  display:grid;
  gap:4px;
  padding:16px 18px;
  border-radius:22px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  backdrop-filter:blur(12px);
  box-shadow:0 18px 36px rgba(0,0,0,.18);
}
.roof-studio-stat small{
  color:#c8d3df;
  font-size:12px;
  font-weight:900;
  letter-spacing:.7px;
  text-transform:uppercase;
}
.roof-studio-stat strong{
  color:#fff;
  font-size:25px;
  line-height:1.18;
  letter-spacing:-.35px;
}
.roof-map-shell{
  isolation:isolate;
  margin-top:22px;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.22);
  background:
    linear-gradient(135deg,rgba(244,154,29,.92),rgba(35,155,61,.86),rgba(15,23,42,.96));
  padding:4px;
  box-shadow:
    0 38px 90px rgba(0,0,0,.32),
    0 12px 34px rgba(244,154,29,.16);
}
.roof-map-shell::before{
  content:"";
  position:absolute;
  inset:4px;
  border-radius:30px;
  pointer-events:none;
  z-index:1;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10);
}
.roof-map{
  border-radius:30px;
  height:690px;
  min-height:560px;
}
.roof-map-toolbar{
  position:absolute;
  z-index:3;
  top:20px;
  left:20px;
  right:20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:14px 16px;
  border-radius:22px;
  background:rgba(13,19,27,.88);
  color:#fff;
  border:1px solid rgba(255,255,255,.14);
  backdrop-filter:blur(14px);
  box-shadow:0 20px 46px rgba(0,0,0,.28);
  pointer-events:none;
}
.roof-map-toolbar-title{
  display:flex;
  align-items:center;
  gap:12px;
}
.roof-map-toolbar-title strong{
  display:block;
  color:#fff;
  font-size:15px;
  line-height:1.2;
  font-weight:950;
}
.roof-map-toolbar-title small{
  display:block;
  margin-top:2px;
  color:#ccd6e1;
  font-size:12px;
  font-weight:800;
  letter-spacing:.22px;
}
.roof-map-signal{
  width:14px;
  height:14px;
  border-radius:50%;
  background:linear-gradient(135deg,#f49a1d,#239b3d);
  box-shadow:0 0 0 6px rgba(244,154,29,.18),0 0 24px rgba(244,154,29,.50);
}
.roof-map-toolbar-badges{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
}
.roof-map-toolbar-badges span{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:7px 11px;
  border-radius:999px;
  color:#fff;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  font-size:11px;
  font-weight:950;
  letter-spacing:.55px;
  text-transform:uppercase;
}
.roof-map-status{
  left:24px;
  right:24px;
  bottom:24px;
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(12px);
  box-shadow:0 22px 48px rgba(0,0,0,.32);
}
.roof-command-deck{
  position:relative;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
  margin:22px 0;
  padding:20px;
  border-radius:30px;
  background:
    radial-gradient(circle at 10% 18%,rgba(244,154,29,.14),rgba(244,154,29,0) 34%),
    linear-gradient(135deg,#101820 0%,#18232e 100%);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 26px 66px rgba(0,0,0,.24);
}
.roof-command-group{
  padding:18px;
  border-radius:24px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
}
.roof-command-heading{
  display:grid;
  gap:4px;
  margin-bottom:14px;
}
.roof-command-heading strong{
  color:#fff;
  font-size:18px;
  line-height:1.2;
}
.roof-command-heading span{
  color:#cfd7e0;
  font-size:13px;
  line-height:1.45;
  font-weight:700;
}
.roof-command-deck .roof-tool-grid{
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin:0;
}
.roof-command-deck .roof-tool-grid .btn{
  min-height:54px;
  white-space:normal;
  line-height:1.24;
  border-radius:18px;
  border-width:1.5px;
  box-shadow:0 12px 24px rgba(0,0,0,.16);
}
.roof-command-deck .roof-tool-grid .btn-outline{
  background:rgba(255,255,255,.96);
}
.roof-command-deck .roof-tool-grid .btn-green{
  box-shadow:0 14px 28px rgba(244,154,29,.22);
}
.roof-map-guidance{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  padding:20px 22px;
  background:
    radial-gradient(circle at 96% 12%,rgba(244,154,29,.18),rgba(244,154,29,0) 38%),
    linear-gradient(180deg,#fff8ef 0%,#ffffff 100%);
  box-shadow:0 18px 38px rgba(15,23,42,.08);
}
.roof-selection-layout{
  gap:20px;
}
.roof-selected-list-card,.roof-measurement-card{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  padding:22px;
  background:
    linear-gradient(180deg,#ffffff 0%,#fbfcfd 100%);
}
.roof-selected-list-card::before,.roof-measurement-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  right:0;
  height:5px;
  background:linear-gradient(90deg,var(--orange),var(--green));
}
.roof-panel-heading span{
  box-shadow:0 10px 20px rgba(35,155,61,.10);
}
.roof-empty-state{
  min-height:84px;
  display:flex;
  align-items:center;
  border:1px dashed rgba(15,23,42,.18);
}
.roof-selection-row{
  background:linear-gradient(180deg,#f8fafc 0%,#ffffff 100%);
}
.roof-selection-row.is-selected{
  box-shadow:0 18px 38px rgba(244,130,11,.16);
}
.roof-row-metrics span{
  box-shadow:0 10px 18px rgba(15,23,42,.05);
}
.roof-measurement-summary>div,
.roof-result-measurements>div{
  align-items:center;
}
.roof-measurement-summary span,
.roof-result-measurements span{
  padding:6px 10px;
  border-radius:999px;
  background:#f8fafc;
  border:1px solid rgba(15,23,42,.08);
}
.roof-calculate-button{
  min-height:58px;
  padding-left:32px;
  padding-right:32px;
  box-shadow:0 20px 40px rgba(244,154,29,.24);
}
@media (hover:hover){
  .roof-studio-stat,
  .roof-command-group,
  .roof-selected-list-card,
  .roof-measurement-card{
    transition:transform .24s ease, box-shadow .24s ease, border-color .24s ease;
  }
  .roof-studio-stat:hover,
  .roof-command-group:hover,
  .roof-selected-list-card:hover,
  .roof-measurement-card:hover{
    transform:translateY(-2px);
  }
}
@media (max-width:1120px){
  .roof-studio-panel,
  .roof-command-deck{
    grid-template-columns:1fr;
  }
  .roof-map-toolbar{
    align-items:flex-start;
    flex-direction:column;
  }
  .roof-map-toolbar-badges{
    justify-content:flex-start;
  }
}
@media (max-width:760px){
  .roof-studio-panel{
    padding:20px;
    border-radius:26px;
  }
  .roof-studio-copy h4{
    font-size:25px;
  }
  .roof-studio-stat strong{
    font-size:22px;
  }
  .roof-map-shell{
    padding:3px;
    border-radius:28px;
  }
  .roof-map{
    height:560px;
    min-height:450px;
    border-radius:25px;
  }
  .roof-map-toolbar{
    top:14px;
    left:14px;
    right:14px;
    padding:12px;
    border-radius:18px;
  }
  .roof-map-toolbar-title strong{
    font-size:14px;
  }
  .roof-map-toolbar-badges span{
    font-size:10px;
    min-height:28px;
  }
  .roof-map-status{
    left:16px;
    right:16px;
    bottom:16px;
  }
  .roof-command-deck{
    padding:15px;
    border-radius:26px;
  }
  .roof-command-group{
    padding:15px;
    border-radius:21px;
  }
  .roof-command-deck .roof-tool-grid{
    grid-template-columns:1fr;
  }
  .roof-selected-list-card,.roof-measurement-card{
    padding:18px;
    border-radius:24px;
  }
}
@media (prefers-reduced-motion:reduce){
  .roof-studio-stat,
  .roof-command-group,
  .roof-selected-list-card,
  .roof-measurement-card{
    transition:none !important;
    transform:none !important;
  }
}

/* 2026-05-15 WMC instant estimator readability + emergency card alignment refinement */
.page-instant-roof-quote .instant-trust-strip > div{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(255,255,255,.64);
  box-shadow:0 18px 42px rgba(15,23,42,.20);
  backdrop-filter:blur(8px);
}
.page-instant-roof-quote .instant-trust-strip strong{
  color:var(--green);
}
.page-instant-roof-quote .instant-trust-strip span{
  color:#334155;
  font-weight:750;
}
.page-instant-roof-quote .instant-emergency-card{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-items:start;
  border-left:6px solid #b42318;
}
.page-instant-roof-quote .instant-emergency-card h4,
.page-instant-roof-quote .instant-emergency-card p{
  width:100%;
  margin:0;
}
.page-instant-roof-quote .instant-emergency-card > div{
  margin-top:4px !important;
}
.page-instant-roof-quote .instant-emergency-card .btn{
  max-width:100%;
  justify-content:center;
}
@media (max-width:760px){
  .page-instant-roof-quote .instant-trust-strip > div{
    padding:16px;
  }
  .page-instant-roof-quote .instant-emergency-card{
    padding:22px;
    gap:14px;
  }
  .page-instant-roof-quote .instant-emergency-card .btn{
    width:100%;
  }
}


/* 2026-05-15 WMC smart one-click roof perimeter capture refinement */
.page-instant-roof-quote .roof-tool-grid-outline #roof-start-smart-select{
  grid-column:1 / -1;
  font-size:15px;
  font-weight:950;
  box-shadow:0 18px 36px rgba(35,155,61,.22);
}
.page-instant-roof-quote .roof-map-status.is-working{
  letter-spacing:.05px;
}
@media (max-width:760px){
  .page-instant-roof-quote .roof-tool-grid-outline #roof-start-smart-select{
    grid-column:auto;
  }
}


/* 2026-05-15 WMC hero trust cards entrance refinement */
.page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-reveal{
  opacity:0;
  transition:
    opacity .82s ease,
    transform .82s cubic-bezier(.2,.72,.18,1),
    box-shadow .28s ease;
  will-change:opacity,transform;
}
.page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-left{
  transform:translate3d(-72px,18px,0);
}
.page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-up{
  transform:translate3d(0,28px,0) scale(.985);
}
.page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-right{
  transform:translate3d(72px,18px,0);
}
.page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-visible{
  opacity:1;
  transform:translate3d(0,0,0) scale(1);
}
@media (max-width:700px){
  .page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-left{
    transform:translate3d(-42px,14px,0);
  }
  .page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-up{
    transform:translate3d(0,20px,0) scale(.985);
  }
  .page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-right{
    transform:translate3d(42px,14px,0);
  }
}
@media (prefers-reduced-motion:reduce){
  .page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-reveal,
  .page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-left,
  .page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-up,
  .page-instant-roof-quote .instant-trust-strip > div.wmc-hero-trust-right{
    opacity:1;
    transform:none;
    transition:none;
  }
}

/* WMC contact quote address autocomplete */
.wmc-contact-address-autocomplete-shell{position:relative;z-index:18}
.wmc-contact-address-autocomplete-shell #project-address{position:relative;z-index:2}
.wmc-contact-address-suggestions{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:34;overflow:hidden;padding:8px;border-radius:20px;background:#fff;border:1px solid rgba(15,23,42,.16);box-shadow:0 24px 54px rgba(15,23,42,.20)}
.wmc-contact-address-suggestions[hidden]{display:none}
.wmc-contact-address-suggestion{display:flex;align-items:flex-start;gap:12px;width:100%;padding:13px 14px;border:0;border-radius:15px;background:transparent;color:#111827;font:inherit;text-align:left;cursor:pointer;transition:background .18s ease,transform .18s ease}
.wmc-contact-address-suggestion:hover,.wmc-contact-address-suggestion.is-active{background:linear-gradient(135deg,#fff8ef,#eef8f1);transform:translateX(2px)}
.wmc-contact-address-suggestion-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 34px;height:34px;margin-top:1px;border-radius:999px;background:#eef8f1;color:#12633f;font-size:16px;font-weight:900}
.wmc-contact-address-suggestion-copy{display:grid;gap:3px;min-width:0}
.wmc-contact-address-suggestion-copy strong{display:block;color:#111827;font-size:14px;line-height:1.35;font-weight:950}
.wmc-contact-address-suggestion-copy span{display:block;color:#475569;font-size:13px;line-height:1.35;font-weight:700}
.wmc-contact-address-suggestion-empty{padding:13px 14px;color:#475569;font-size:13px;line-height:1.45;font-weight:800}
.wmc-contact-address-autocomplete-status{min-height:18px;margin:7px 0 0;color:#475569;font-size:12px;line-height:1.45;font-weight:800}
.wmc-contact-address-autocomplete-status.is-working{color:#9a5a00}
.wmc-contact-address-autocomplete-status.is-success{color:#12633f}
.wmc-contact-address-autocomplete-status.is-error{color:#b42318}


/* 2026-05-15 WMC hero trust cards visible side-to-center entrance + mobile alignment lock */
@media (max-width:760px){
  .page-instant-roof-quote .instant-trust-strip{
    width:100%;
    max-width:100%;
    grid-template-columns:1fr;
    justify-items:stretch;
    align-items:stretch;
    gap:12px;
    margin-left:auto;
    margin-right:auto;
  }
  .page-instant-roof-quote .instant-trust-strip > div{
    width:100%;
    max-width:100%;
    min-height:0;
    margin:0;
    display:flex;
    flex-direction:column;
    justify-content:center;
    box-sizing:border-box;
    text-align:left;
  }
}


/* Large WMC Instant Satellite Roof Quote announcement banner */
.instant-roof-announcement-section{padding-top:28px;padding-bottom:28px}
.instant-roof-announcement-card{
  display:grid;
  grid-template-columns:minmax(0,1.65fr) minmax(250px,.85fr);
  gap:28px;
  align-items:center;
  padding:34px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:32px;
  background:
    radial-gradient(circle at 92% 18%,rgba(255,157,0,.22),transparent 34%),
    radial-gradient(circle at 12% 92%,rgba(57,174,66,.20),transparent 40%),
    linear-gradient(135deg,rgba(8,15,25,.96),rgba(17,31,45,.94));
  color:#fff;
  box-shadow:0 28px 70px rgba(0,0,0,.34);
  overflow:hidden;
  position:relative;
}
.instant-roof-announcement-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(110deg,rgba(255,255,255,.08),transparent 42%,rgba(255,255,255,.04));
  pointer-events:none;
}
.instant-roof-announcement-copy,.instant-roof-announcement-actions{position:relative;z-index:1}
.instant-roof-announcement-kicker{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:5px 14px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--orange),var(--orange-dark));
  color:#fff;
  font-size:13px;
  line-height:1.2;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.instant-roof-announcement-card h3{
  margin:14px 0 10px;
  color:#fff;
  font-size:clamp(28px,3.5vw,48px);
  line-height:1.08;
  letter-spacing:-.03em;
}
.instant-roof-announcement-card p{
  margin:0;
  max-width:860px;
  color:rgba(255,255,255,.90);
  font-size:18px;
  line-height:1.55;
}
.instant-roof-announcement-actions{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  justify-content:center;
  gap:16px;
}
.instant-roof-announcement-pill{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  padding:12px 18px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.08);
  color:#fff;
  text-align:center;
  font-size:15px;
  font-weight:800;
  line-height:1.35;
}
.instant-roof-announcement-button{
  width:100%;
  min-height:64px;
  justify-content:center;
  text-align:center;
  font-size:17px;
  font-weight:800;
  box-shadow:0 18px 36px rgba(224,126,0,.28);
}
@media (max-width:900px){
  .instant-roof-announcement-section{padding-top:20px;padding-bottom:20px}
  .instant-roof-announcement-card{grid-template-columns:1fr;gap:20px;padding:24px;border-radius:26px}
  .instant-roof-announcement-card h3{font-size:clamp(25px,7vw,38px)}
  .instant-roof-announcement-card p{font-size:16px}
  .instant-roof-announcement-actions{gap:12px}
  .instant-roof-announcement-pill{min-height:52px;font-size:14px}
  .instant-roof-announcement-button{min-height:58px;font-size:16px}
}

.roof-star{display:inline-block;line-height:1}
.roof-star.is-full{color:#dd7f08}
.roof-star.is-empty{color:rgba(221,127,8,.28)}
.roof-star.is-half{background:linear-gradient(90deg,#dd7f08 50%,rgba(221,127,8,.28) 50%);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}


.roof-analysis-logo-loader{display:flex;align-items:center;gap:18px;margin:18px 0 4px;padding:18px 20px;border-radius:24px;background:linear-gradient(135deg,rgba(17,24,39,.96),rgba(30,41,59,.94));border:1px solid rgba(244,154,29,.34);box-shadow:0 20px 42px rgba(15,23,42,.20);color:#fff;overflow:hidden;position:relative}
.roof-analysis-logo-loader[hidden]{display:none}
/* Visibility safety-net: if the browser is actively locating/preparing the property and an older cached JS path leaves the loader hidden, the disabled submit state still reveals the branded WMC loader. */
.roof-estimator-card:has(#roof-analysis-form button[type="submit"][disabled]) .roof-analysis-logo-loader[hidden],
.roof-estimator-card:has(#roof-analysis-status.is-working) .roof-analysis-logo-loader[hidden]{display:flex !important}
.roof-analysis-logo-loader::before{content:'';position:absolute;inset:0;background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.10) 42%,transparent 72%);transform:translateX(-120%);animation:wmcLoaderSweep 2.2s ease-in-out infinite}
.roof-analysis-logo-motion{position:relative;width:88px;height:88px;min-width:88px;display:grid;place-items:center;z-index:1}
.roof-analysis-logo-ring{position:absolute;inset:0;border-radius:50%;border:3px solid rgba(244,154,29,.25);border-top-color:var(--orange);border-right-color:rgba(35,155,61,.92);animation:wmcLoaderSpin 1.35s linear infinite}
.roof-analysis-logo-motion img{position:relative;width:68px;height:68px;border-radius:20px;object-fit:contain;background:#fff;box-shadow:0 12px 24px rgba(0,0,0,.28);animation:wmcLoaderFloat 1.8s ease-in-out infinite}
.roof-analysis-loader-message{position:relative;z-index:1;display:grid;gap:4px;min-width:0}
.roof-analysis-loader-message strong{font-size:16px;line-height:1.3;color:#fff;letter-spacing:.2px}
.roof-analysis-loader-message span{display:block;color:#e2e8f0;font-size:14px;line-height:1.55}
@keyframes wmcLoaderSpin{to{transform:rotate(360deg)}}
@keyframes wmcLoaderFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-4px) scale(1.04)}}
@keyframes wmcLoaderSweep{0%,20%{transform:translateX(-120%)}70%,100%{transform:translateX(120%)}}
@media (max-width:720px){.roof-analysis-logo-loader{align-items:flex-start;gap:14px;padding:16px}.roof-analysis-logo-motion{width:72px;height:72px;min-width:72px}.roof-analysis-logo-motion img{width:56px;height:56px;border-radius:16px}.roof-analysis-loader-message strong{font-size:15px}.roof-analysis-loader-message span{font-size:13px}}
@media (prefers-reduced-motion:reduce){.roof-analysis-logo-ring,.roof-analysis-logo-motion img,.roof-analysis-logo-loader::before{animation:none}}


/* V58: Keep the mobile satellite roof workspace clear for the customer roof view. */
@media (max-width:760px){
  .page-instant-roof-quote .roof-map-toolbar{
    display:none;
  }
}

@media (max-width:760px){.roof-submit-success{scroll-margin-top:208px}}


/* V263: Move selected roof card into the tool deck and remove the lower Live Measurements panel. */
.roof-measurement-hidden{
  display:none !important;
}
.roof-selected-list-card-inline{
  margin-top:16px;
  padding:14px;
  border-radius:20px;
  background:
    radial-gradient(circle at 8% 0%,rgba(244,154,29,.16),rgba(244,154,29,0) 34%),
    linear-gradient(180deg,#fffdf8 0%,#ffffff 100%);
  border:1px solid rgba(244,130,11,.34);
  box-shadow:0 16px 34px rgba(0,0,0,.16);
}
.roof-command-group .roof-selected-list-card-inline::before{
  height:4px;
  background:linear-gradient(90deg,var(--orange),var(--green));
}
.roof-command-group .roof-selected-list-card-inline .roof-panel-heading{
  margin-bottom:10px;
}
.roof-command-group .roof-selected-list-card-inline .roof-panel-heading h4{
  font-size:16px;
  line-height:1.15;
}
.roof-command-group .roof-selected-list-card-inline .roof-panel-heading span{
  min-height:26px;
  padding:5px 9px;
  font-size:11px;
}
.roof-command-group .roof-selected-list-card-inline .roof-selected-list{
  gap:10px;
}
.roof-command-group .roof-selected-list-card-inline .roof-empty-state{
  min-height:54px;
  padding:12px;
  border-radius:15px;
  font-size:12px;
  line-height:1.45;
}
.roof-command-group .roof-selected-list-card-inline .roof-selection-row{
  grid-template-columns:auto minmax(0,1fr);
  gap:10px;
  padding:12px;
  border-radius:16px;
}
.roof-command-group .roof-selected-list-card-inline .roof-select-row{
  min-width:58px;
  min-height:34px;
  padding:7px 10px;
  font-size:11px;
}
.roof-command-group .roof-selected-list-card-inline .roof-row-main{
  gap:8px;
}
.roof-command-group .roof-selected-list-card-inline .roof-row-main label{
  font-size:11px;
}
.roof-command-group .roof-selected-list-card-inline .roof-row-main input,
.roof-command-group .roof-selected-list-card-inline .roof-row-main select{
  min-height:34px;
  margin-top:5px;
  font-size:12px;
}
.roof-command-group .roof-selected-list-card-inline .roof-row-metrics{
  gap:7px;
  padding-top:0;
}
.roof-command-group .roof-selected-list-card-inline .roof-row-metrics span{
  padding:6px 8px;
  font-size:11px;
}
@media (max-width:760px){
  .roof-command-group .roof-selected-list-card-inline .roof-selection-row{
    grid-template-columns:1fr;
  }
  .roof-command-group .roof-selected-list-card-inline .roof-row-main{
    grid-template-columns:1fr;
  }
}


/* V271: right vertical Satellite Roof Quote button kept; browser/side rail hidden. */
html,body{
  scrollbar-width:none;
  -ms-overflow-style:none;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar{
  width:0 !important;
  height:0 !important;
  display:none !important;
}
.satellite-side-button{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}
.wmc-satellite-vertical-button{
  position:fixed;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  z-index:90;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:172px;
  padding:16px 10px;
  border-radius:18px;
  background:linear-gradient(135deg,var(--orange),var(--orange-dark));
  color:#fff;
  font-size:13px;
  font-weight:900;
  letter-spacing:.35px;
  line-height:1.1;
  text-align:center;
  box-shadow:0 18px 38px rgba(221,127,8,.30);
  border:1px solid rgba(255,255,255,.30);
}
.wmc-satellite-vertical-button:hover,
.wmc-satellite-vertical-button:focus{
  color:#fff;
  filter:brightness(1.04);
  outline:3px solid rgba(244,154,29,.22);
  outline-offset:3px;
}
@media (max-width:760px){
  .wmc-satellite-vertical-button{
    right:8px;
    top:auto;
    bottom:88px;
    transform:none;
    min-height:142px;
    padding:13px 8px;
    border-radius:16px;
    font-size:12px;
  }
}
.satellite-gate-seo-copy{margin:22px 0 0;padding:18px 20px;border-radius:22px;background:rgba(255,255,255,.92);border:1px solid rgba(15,23,42,.10);color:#1f2937;text-align:left;box-shadow:0 16px 34px rgba(15,23,42,.10)}
.satellite-gate-seo-copy h2{margin:0 0 10px;color:#111827;font-size:20px;line-height:1.22}
.satellite-gate-seo-copy p{margin:0;color:#475569;font-size:14px;line-height:1.65;font-weight:700}
.satellite-gate-seo-copy ul{margin:14px 0 0;padding-left:20px;color:#334155;font-size:14px;line-height:1.65;font-weight:800}


/* V279: remove visible Step 3 estimate summary/detail boxes from the customer result view. */
.roof-result-summary-strip,
.roof-result-detail-strip,
.roof-result-summary-pill,
.roof-result-detail-pill,
.roof-result-measurements,
.roof-result-breakdown,
.instant-result-summary-strip,
.instant-result-detail-strip,
.instant-result-measurements,
.instant-result-breakdown{
  display:none !important;
}

.instant-result-panel .roof-result-summary-strip,
.instant-result-panel .roof-result-detail-strip,
.instant-result-panel .roof-result-measurements,
.instant-result-panel .roof-result-breakdown,
.instant-step-card .roof-result-summary-strip,
.instant-step-card .roof-result-detail-strip,
.instant-step-card .roof-result-measurements,
.instant-step-card .roof-result-breakdown{
  display:none !important;
}

/* Keep the result card clean after removing the white/blue measurement boxes. */
.instant-result-panel,
.instant-step-card.result-ready,
.instant-step-card[data-step="3"]{
  overflow:hidden;
}

.roof-package-grid,
.roof-package-grid-spacious{
  margin-top:18px !important;
}

