:root {
  --ink:#202020;
  --muted:#62666d;
  --line:#e7e7e7;
  --paper:#fff;
  --soft:#f6f7f8;
  --dark:#0f1d26;
  --dark2:#15252f;
  --accent:#e21a12;
  --accent2:#1e6fb5;
  --radius:8px;
  --shadow:0 18px 45px rgba(0,0,0,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--ink);background:#fff;line-height:1.65;overflow-x:hidden}
.seo-page h1,.seo-page h2,.seo-page h3,.resource-page h1,.resource-page h2,.resource-page h3,.resources-hub h1,.resources-hub h2,.resources-hub h3{font-family:Georgia,"Times New Roman",serif;font-weight:700}
img,video{max-width:100%;height:auto}
a{color:inherit}
.button:focus-visible,.site-nav a:focus-visible,.footer-grid a:focus-visible,.footer-cta a:focus-visible,.faq-list summary:focus-visible,input:focus-visible,textarea:focus-visible,button:focus-visible{outline:3px solid #fff200;outline-offset:3px}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:10000;background:#0f1d26;color:#fff;padding:12px 20px;border-radius:0 0 8px 0;font-weight:900;text-decoration:none}
.skip-link:focus{left:0;top:0;width:auto;height:auto}
.site-header{position:sticky;top:0;left:0;right:0;z-index:20;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px;padding:22px clamp(18px,4vw,64px);background:rgba(15,29,38,.78);-webkit-backdrop-filter:blur(10px) saturate(140%);backdrop-filter:blur(10px) saturate(140%);color:#fff;box-shadow:0 6px 22px rgba(0,0,0,.22)}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){.site-header{background:rgba(15,29,38,.94)}}
.brand img{display:block;width:178px;height:auto}
.site-nav{display:flex;align-items:center;justify-content:center;gap:24px;font-weight:700}
.site-nav a{text-decoration:none}
.nav-group{position:relative}
.nav-menu{position:absolute;top:100%;left:0;display:none;min-width:240px;padding:14px;background:var(--dark);box-shadow:var(--shadow);border-radius:0 0 var(--radius) var(--radius)}
.nav-menu a{display:block;padding:8px 10px;color:#fff}
.nav-group:hover .nav-menu,.nav-group:focus-within .nav-menu{display:block}
.header-contact{display:flex;gap:14px;font-size:14px;white-space:nowrap}
.nav-toggle{display:none}
.home-hero,.page-hero{position:relative;overflow:hidden;color:#fff;background:var(--dark);min-height:680px;display:grid;align-items:center}
.home-hero{min-height:960px;text-align:center}
.hero-video,.hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-shade,.page-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(9,17,23,.52),rgba(9,17,23,.72))}
.home-hero-content,.hero-content{position:relative;z-index:1;width:min(1120px,92vw);margin:auto}
.hero-kicker,.eyebrow{color:#e21a12;font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:14px}
.home-hero .hero-kicker{color:#fff200;font-size:19px}
.page-hero .hero-content>.eyebrow{display:inline-block;margin:0 auto 14px;color:#fff200;font-size:clamp(15px,1.25vw,20px);font-weight:800;line-height:1.25;letter-spacing:.01em;text-transform:capitalize;background:transparent}
.home-hero h1{font-size:clamp(58px,8vw,118px);line-height:.9;margin:16px 0 26px;text-transform:uppercase;letter-spacing:0}
.page-hero h1{font-size:clamp(48px,6vw,86px);line-height:1.02;margin:14px auto 18px;max-width:920px}
.page-hero p{max-width:820px;font-size:20px;margin-left:auto;margin-right:auto}
.quote-card{width:min(760px,94vw);margin:0 auto;padding:34px;border-radius:var(--radius);background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.quote-card h2{margin:0 0 10px;font-size:32px}
.hero-summary{max-width:660px;margin:30px auto 0;font-size:24px;color:rgba(255,255,255,.86)}
.button{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:12px 20px;border-radius:4px;text-decoration:none;font-weight:800;border:1px solid transparent;cursor:pointer}
.button-primary{background:var(--accent);color:#fff}
.button-secondary{background:#fff;color:var(--ink);border-color:#d9d9d9}
.button-phone{background:var(--accent2);color:#fff}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.page-hero .cta-row{justify-content:center}
.section{width:min(1180px,92vw);margin:0 auto;padding:72px 0}
.seo-page main,.resource-page main,.resources-hub main{background:linear-gradient(180deg,#fff 0%,#f7f9fb 42%,#fff 100%)}
.seo-page .section,.resource-page .section,.resources-hub .section{position:relative;isolation:isolate}
.seo-page .section>*:not(.hero-media),.resource-page .section>*:not(.hero-media),.resources-hub .section>*:not(.hero-media){position:relative;z-index:1}
.section-bg-overview:before,.section-bg-detail:before,.section-bg-assessment:before,.section-bg-estimate:before,.section-bg-services:before,.section-bg-process:before,.section-bg-related:before,.section-bg-faq:before,.section-bg-article:before{content:"";position:absolute;top:0;bottom:0;left:50%;width:100vw;transform:translateX(-50%);z-index:-1;pointer-events:none}
.section-bg-overview:before{background:radial-gradient(circle at 12% 12%,rgba(226,26,18,.08),transparent 34%),linear-gradient(135deg,#fff 0%,#f5f8fa 58%,#edf3f7 100%)}
.section-bg-detail:before{background:linear-gradient(180deg,#f7fafc 0%,#fff 100%)}
.section-bg-assessment{color:#fff}
.section-bg-assessment:before{background:linear-gradient(90deg,rgba(15,29,38,.96),rgba(15,29,38,.88)),url("images/roof-inspection-aerial.jpg") center/cover}
.section-bg-assessment h2,.section-bg-assessment h3{color:#fff}
.section-bg-assessment p,.section-bg-assessment li{color:rgba(255,255,255,.92)}
.section-bg-assessment .detail-list li:before{background:#e21a12}
.section-bg-assessment .trust-panel{align-self:start;background:rgba(18,35,45,.9);border-color:rgba(255,255,255,.18);box-shadow:0 22px 58px rgba(0,0,0,.24);backdrop-filter:blur(8px)}
.section-bg-estimate:before{background:linear-gradient(120deg,rgba(245,248,250,.96),rgba(255,255,255,.9)),url("images/roofing-service-cards.webp") center/cover}
.section-bg-estimate{box-shadow:0 24px 70px rgba(15,29,38,.1)}
.section-bg-services:before{background:radial-gradient(circle at 88% 18%,rgba(30,111,181,.1),transparent 31%),linear-gradient(180deg,#fff 0%,#f7fafc 100%)}
.section-bg-process:before{background:linear-gradient(135deg,#fff 0%,#f8fafc 48%,#eef4f7 100%)}
.section-bg-related:before{background:linear-gradient(180deg,#fff 0%,#f6f8fa 100%)}
.section-bg-faq:before{background:radial-gradient(circle at 10% 0%,rgba(226,26,18,.06),transparent 30%),linear-gradient(180deg,#f8fafc 0%,#fff 100%)}
.section-bg-article:before{background:linear-gradient(180deg,#fff 0%,#f7fafc 100%)}
.local-band h2{color:#fff}
.local-band p{color:rgba(255,255,255,.84)}
.local-band .eyebrow{color:#e21a12}
.local-band .area-pills span{background:rgba(255,255,255,.95);border-color:rgba(255,255,255,.34);color:#202020}
.section-intro{max-width:900px;color:#4f5560;font-size:18px}
.two-column{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.9fr);gap:54px;align-items:start}
.section h2{font-size:clamp(34px,4vw,54px);line-height:1.12;margin:8px 0 22px}
.section h3{font-size:24px;line-height:1.25}
.rounded-image{border-radius:var(--radius);box-shadow:var(--shadow)}
.mini-service-grid,.service-list,.quality-grid,.resource-grid,.link-grid{display:grid;gap:18px}
.mini-service-grid{grid-template-columns:repeat(3,1fr);margin-top:18px}
.mini-service-grid a,.link-grid a,.resource-preview a{padding:16px;border:1px solid var(--line);border-radius:var(--radius);text-decoration:none;font-weight:800;background:#fff}
.service-list{grid-template-columns:repeat(3,1fr)}
.service-list a,.quality-grid article,.resource-grid article{display:block;padding:28px;border-radius:var(--radius);background:rgba(255,255,255,.94);box-shadow:var(--shadow);text-decoration:none;border:1px solid rgba(231,231,231,.82)}
.service-list span{display:block;font-size:22px;font-weight:800}
.service-list small{display:block;margin-top:8px;color:var(--muted);line-height:1.45}
.content-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.info-card,.trust-panel,.article-callout{padding:28px;border:1px solid rgba(231,231,231,.88);border-radius:var(--radius);background:rgba(255,255,255,.94);box-shadow:var(--shadow)}
.info-card h3,.trust-panel h3{margin-top:0}
.inspection-depth{align-items:start;padding-top:68px;padding-bottom:68px}
.detail-list,.plain-list{margin:0;padding-left:0;list-style:none}
.detail-list li,.plain-list li{position:relative;margin:12px 0;padding-left:28px;color:var(--muted)}
.detail-list li:before,.plain-list li:before{content:"";position:absolute;left:0;top:.72em;width:8px;height:8px;border-radius:50%;background:var(--accent)}
.trust-panel{background:#0f1d26;color:#fff}
.trust-panel p,.trust-panel li{color:rgba(255,255,255,.9)}
.trust-panel .eyebrow{color:#e21a12}
.section-bg-assessment .detail-list li{color:rgba(255,255,255,.9);font-weight:700}
.section-bg-assessment .trust-panel p{color:rgba(255,255,255,.9)}
.section-bg-assessment .trust-panel .button{margin-top:8px}
.estimate-band{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;background:#f6f7f8;border-radius:var(--radius);padding-left:42px;padding-right:42px}
.estimate-points{display:grid;gap:14px}
.estimate-points p{margin:0;padding:18px;border-left:4px solid var(--accent);background:#fff;border-radius:4px;box-shadow:0 12px 28px rgba(0,0,0,.07)}
.area-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.area-pills span{display:inline-flex;align-items:center;min-height:36px;padding:7px 12px;border-radius:999px;background:#fff;border:1px solid #d9dde1;font-weight:800;color:#202020}
.dark-section{background:linear-gradient(rgba(15,29,38,.94),rgba(15,29,38,.94)),url("images/roofing-hero.webp") center/cover;color:#fff;text-align:center}
.dark-section .section{max-width:980px}
.dark-list p{margin:16px auto;max-width:860px}
.split-cta{display:grid;grid-template-columns:1fr 1fr;background:var(--dark2);color:#fff}
.split-cta>img{width:100%;height:100%;object-fit:cover;filter:brightness(.68)}
.split-cta>div{padding:clamp(44px,7vw,100px)}
.consult-card{display:grid;grid-template-columns:.5fr 1fr;gap:0;background:#000;color:#fff;border-radius:var(--radius);overflow:hidden;padding:0}
.consult-card img{width:100%;height:100%;object-fit:cover;filter:brightness(.58)}
.consult-card div{padding:36px}
.consult-card a{color:#51a8df}
.quality-grid{grid-template-columns:repeat(2,1fr)}
.quality-grid article{display:grid;grid-template-columns:1fr;min-height:140px}
.page-hero{min-height:650px;text-align:center}
.page-hero .hero-content{padding:100px 0}
.local-band{width:100%;max-width:none;background:linear-gradient(90deg,rgba(15,29,38,.94),rgba(15,29,38,.8)),url("images/north-texas-roofing.webp") center/cover;color:#fff;padding:70px clamp(4vw,calc((100vw - 1180px)/2),10vw)}
.local-band>div{max-width:980px;margin:auto}
.contact-panel{padding:28px;border-radius:var(--radius);box-shadow:var(--shadow);background:#fff}
.static-contact-form{display:grid;gap:14px;text-align:left}
.static-contact-form label{display:block;font-weight:800}
.static-contact-form label>input,.static-contact-form label>textarea{display:block;margin-top:6px}
.static-contact-form input,.static-contact-form textarea{width:100%;min-height:42px;border:1px solid #cfd4da;border-radius:4px;padding:10px;font:inherit;font-family:inherit}
.static-contact-form textarea{min-height:96px;resize:vertical}
.static-contact-form input[readonly]{background:#f3f4f6;color:#62666d;cursor:not-allowed}
.static-contact-form .req{color:#e21a12;margin-left:2px;font-weight:900}
.form-required-note{margin:0;font-size:13px;color:#62666d;font-weight:600}
.form-message{margin-top:12px;padding:12px 14px;background:var(--dark);color:#fff;border-radius:4px;font-weight:800}
.form-message.is-success{background:#0d7a3a}
.form-message.is-error{background:#9c1c1c}
.static-form-message{margin-top:12px;padding:12px 14px;background:#0d7a3a;color:#fff;border-radius:6px;font-weight:700;line-height:1.4}
.static-form-message.is-error{background:#9c1c1c}
.check-list{padding-left:0;list-style:none}
.check-list li{position:relative;margin:14px 0;padding-left:34px}
.check-list li:before{content:"✓";position:absolute;left:0;top:0;width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:#e8eef2;color:var(--dark);font-weight:900}
.process-list{counter-reset:step;display:grid;gap:14px;padding:0;list-style:none}
.process-list li{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:18px;border:1px solid var(--line);border-radius:var(--radius)}
.process-list li:before{counter-increment:step;content:counter(step);width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:900;grid-row:span 2}
.process-list span{color:var(--muted)}
.table-wrap{width:100%;overflow-x:auto;margin:26px 0 32px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:0 16px 38px rgba(15,29,38,.08)}
.service-matrix{width:100%;min-width:820px;border-collapse:collapse;text-align:left}
.service-matrix th,.service-matrix td{padding:16px 18px;border-bottom:1px solid var(--line);vertical-align:top}
.service-matrix thead th{background:#0f1d26;color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.04em}
.service-matrix tbody th{width:18%;font-size:18px;color:var(--ink)}
.service-matrix td{color:var(--muted);line-height:1.5}
.service-matrix a{color:var(--accent2);font-weight:900;text-decoration:none}
.service-matrix a:hover,.service-matrix a:focus-visible{text-decoration:underline}
.service-matrix tr:last-child th,.service-matrix tr:last-child td{border-bottom:0}
.faq-section{max-width:980px}
.faq-list{display:grid;gap:12px}
.faq-list details{border:1px solid var(--line);border-radius:var(--radius);padding:18px;background:#fff}
.faq-list summary{cursor:pointer;font-weight:900}
.final-cta{text-align:center;background:linear-gradient(90deg,rgba(15,29,38,.96),rgba(21,37,47,.9)),url("images/roof-installation-aerial.jpg") center/cover;color:#fff;border-radius:var(--radius);padding-left:28px;padding-right:28px;margin-bottom:80px;box-shadow:0 28px 70px rgba(15,29,38,.24)}
.final-cta .cta-row{justify-content:center}
.article-body{max-width:880px}
.article-body section{padding:28px;border:1px solid rgba(231,231,231,.9);border-radius:var(--radius);background:rgba(255,255,255,.94);box-shadow:0 16px 38px rgba(15,29,38,.08);margin:0 0 18px}
.article-expanded{display:grid;gap:34px}
.article-callout{max-width:980px;margin:0 auto}
.muted-callout{background:var(--soft);box-shadow:none}
.resource-detail-columns{width:100%;padding:0}
.resource-grid{grid-template-columns:repeat(2,1fr)}
.site-footer{background:#0b1720;color:#d6dce1}
.footer-cta{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:28px;width:min(1180px,92vw);margin:auto;padding:46px 0 44px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-cta h2{position:relative;font-size:clamp(38px,4.4vw,56px);line-height:1.08;color:#fff;margin:0;max-width:850px;letter-spacing:0}
.footer-swoosh{display:inline-block;width:154px;height:58px;margin-left:16px;vertical-align:middle;border:3px solid #e21a12;border-left-color:transparent;border-bottom-color:transparent;border-radius:50%;transform:rotate(22deg)}
.footer-showcase{width:min(1180px,92vw);margin:auto;padding:40px 0 38px;display:grid;grid-template-columns:minmax(280px,1fr) minmax(245px,.72fr) minmax(360px,1.15fr);gap:30px 44px;align-items:center;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-logo{display:block;width:178px;height:auto;margin:0 0 24px}
.footer-contact-list{display:grid;gap:16px}
.footer-contact-item{display:grid;grid-template-columns:40px minmax(0,1fr);align-items:center;gap:14px;color:#fff;text-decoration:none;font-size:17px;line-height:1.35}
.footer-phone{font-family:Georgia,"Times New Roman",serif;font-size:25px}
.footer-contact-icon,.footer-social-icon{display:inline-grid;place-items:center;color:#e21a12}
.footer-contact-icon{width:40px;height:40px}
.footer-icon-svg{display:block;width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:2.1;stroke-linecap:round;stroke-linejoin:round}
.footer-socials{display:flex;gap:12px;margin-top:22px}
.footer-social-icon{width:40px;height:40px;border:1px solid rgba(255,255,255,.16);border-radius:50%;color:#fff;background:rgba(255,255,255,.03);text-decoration:none;transition:background-color .16s ease,border-color .16s ease,color .16s ease}
a.footer-social-icon:hover,a.footer-social-icon:focus-visible{background:#e21a12;border-color:#e21a12;color:#fff}
.footer-social-icon .footer-icon-svg{width:19px;height:19px;fill:currentColor;stroke:none}
.footer-reference h3{margin:0 0 16px;color:#fff;font-size:18px}
.footer-reference-columns{display:grid;grid-template-columns:1fr 1fr;gap:20px 34px}
.footer-reference a{display:block;color:#d6dce1;text-decoration:none;margin:0 0 12px;font-size:18px;line-height:1.25}
.footer-reference a:hover,.footer-grid a:hover,.footer-bottom a:hover{color:#fff}
.footer-map-card{position:relative;overflow:hidden;height:250px;border-radius:8px;background:#0f1d26;box-shadow:0 18px 48px rgba(0,0,0,.22)}
.footer-map-card iframe{display:block;width:100%;height:100%;border:0;filter:saturate(.92)}
.footer-map-open{position:absolute;top:14px;left:14px;z-index:1;display:inline-flex;align-items:center;min-height:40px;padding:8px 12px;border-radius:3px;background:#fff;color:#0d2c83;text-decoration:none;font-weight:900;box-shadow:0 8px 18px rgba(0,0,0,.2)}
.footer-grid{width:min(1180px,92vw);margin:auto;padding:38px 0 36px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:30px 42px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-grid h3{color:#fff;margin:0 0 16px;font-size:18px;line-height:1.18}
.footer-grid a{display:block;color:#d6dce1;text-decoration:none;margin:7px 0;font-size:15px;line-height:1.35}
.footer-badges{background:#071017;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-badge-grid{width:min(1180px,92vw);margin:auto;padding:24px 0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:26px;align-items:center}
.footer-badge-grid img{display:block;height:clamp(86px,7vw,126px);width:auto;max-width:100%;margin:auto;object-fit:contain}
.footer-bottom{width:100%;margin:0;padding:22px max(4vw,calc((100vw - 1180px)/2));display:flex;justify-content:space-between;gap:18px;color:#9aa3aa;background:#071017}
.footer-bottom a{color:#e21a12;text-decoration:none}
.footer-bottom a:hover,.footer-bottom a:focus-visible{color:#fff;text-decoration:underline}
.footer-bottom span:last-child{display:flex;gap:18px;align-items:center}
.resource-preview,.link-grid{grid-template-columns:repeat(3,1fr)}
@media (max-width:1180px){.content-grid{grid-template-columns:repeat(2,1fr)} .service-list,.quality-grid,.resource-grid,.resource-preview,.link-grid{grid-template-columns:repeat(2,minmax(0,1fr))} .section{padding:56px 0}}
@media (max-width:980px){
  .site-header{grid-template-columns:auto auto;gap:12px;background:rgba(15,29,38,.96)}
  .nav-toggle{display:inline-flex;justify-self:end;background:#fff;color:#111;border:0;border-radius:4px;padding:10px 14px;font-weight:800}
  .site-nav{display:none;grid-column:1/-1;align-items:stretch;justify-content:start;flex-direction:column}
  .site-nav.is-open{display:flex}
  .nav-menu{position:static;display:block;box-shadow:none;background:rgba(255,255,255,.06);margin-top:8px}
  .header-contact{grid-column:1/-1;flex-wrap:wrap}
  .two-column,.split-cta,.consult-card,.content-grid,.estimate-band{grid-template-columns:1fr}
  .home-hero{min-height:860px}
  .service-list,.quality-grid,.resource-grid,.resource-preview,.link-grid,.mini-service-grid{grid-template-columns:1fr}
  .footer-cta{grid-template-columns:1fr;padding:38px 0;gap:20px}
  .footer-cta .button{justify-self:start}
  .footer-showcase{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:28px 30px;padding:34px 0}
  .footer-showcase>.footer-map-card{grid-column:1/-1}
  .footer-reference-columns{grid-template-columns:1fr 1fr}
  .footer-map-card{height:230px}
  .footer-badge-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
  .page-hero p{font-size:18px}
  .estimate-band{padding-left:24px;padding-right:24px}
  .area-pills span{font-size:14px}
  .section{padding:44px 0}
}

/* Call modal — triggered by Schedule Now / Get In Touch / Contact CTAs */
.call-modal{position:fixed;inset:0;z-index:9000;display:none;align-items:center;justify-content:center;padding:clamp(14px,3vw,28px);opacity:0;transition:opacity .18s ease}
.call-modal[hidden]{display:none}
.call-modal.is-open{display:flex;opacity:1}
.call-modal__scrim{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%,rgba(15,29,38,.55),rgba(15,29,38,.78) 60%,rgba(15,29,38,.86));-webkit-backdrop-filter:blur(6px) saturate(140%);backdrop-filter:blur(6px) saturate(140%)}
.call-modal__panel{position:relative;width:min(480px,100%);background:#fff;color:var(--ink);border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.35),0 4px 14px rgba(0,0,0,.18);overflow:hidden;transform:translateY(12px) scale(.985);transition:transform .22s cubic-bezier(.2,.8,.2,1);max-height:calc(100dvh - 28px);display:flex;flex-direction:column}
.call-modal.is-open .call-modal__panel{transform:none}
.call-modal__close{position:absolute;top:10px;right:10px;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.86);color:var(--ink);border:0;border-radius:999px;cursor:pointer;font-size:22px;line-height:1;padding:0;box-shadow:0 2px 6px rgba(0,0,0,.12);z-index:2}
.call-modal__close:hover{background:#fff}
.call-modal__close:focus-visible{outline:3px solid #fff200;outline-offset:2px}
.call-modal__header{position:relative;padding:26px 26px 18px;background:linear-gradient(135deg,var(--dark) 0%,var(--dark2) 55%,#1a3041 100%);color:#fff;overflow:hidden}
.call-modal__header:before{content:"";position:absolute;inset:-40% -20% auto auto;width:280px;height:280px;background:radial-gradient(closest-side,rgba(226,26,18,.32),transparent 70%);pointer-events:none}
.call-modal__eyebrow{position:relative;display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff200;margin:0 0 10px}
.call-modal__title{position:relative;margin:0;font-size:clamp(22px,3.6vw,28px);line-height:1.2;font-family:Georgia,"Times New Roman",serif;font-weight:700}
.call-modal__subtitle{position:relative;margin:6px 0 0;font-size:14.5px;color:rgba(255,255,255,.82);line-height:1.5}
.call-modal__body{padding:22px 26px 8px;overflow:auto}
.call-modal__phone-card{display:block;text-decoration:none;color:#fff;background:var(--accent);background-image:linear-gradient(135deg,#e21a12 0%,#b91009 100%);border-radius:12px;padding:16px 18px;text-align:center;box-shadow:0 10px 24px rgba(226,26,18,.32);transition:transform .15s ease,box-shadow .15s ease}
.call-modal__phone-card:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(226,26,18,.4)}
.call-modal__phone-card:active{transform:translateY(0)}
.call-modal__phone-card:focus-visible{outline:3px solid #fff200;outline-offset:3px}
.call-modal__phone-label{display:block;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:800;opacity:.92}
.call-modal__phone-number{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:6px;font-size:clamp(28px,5.6vw,34px);font-weight:900;letter-spacing:.01em;line-height:1}
.call-modal__phone-icon{flex:0 0 auto;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.18);border-radius:50%}
.call-modal__phone-icon svg{width:14px;height:14px}
.call-modal__phone-cta{display:block;margin-top:6px;font-size:13px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;opacity:.95}
.call-modal__alt{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}
.call-modal__alt-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 12px;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:10px;text-decoration:none;font-weight:700;font-size:14px;line-height:1;transition:border-color .15s ease,background .15s ease,color .15s ease}
.call-modal__alt-btn:hover{border-color:var(--accent2);color:var(--accent2)}
.call-modal__alt-btn:focus-visible{outline:3px solid #fff200;outline-offset:2px}
.call-modal__alt-btn svg{width:15px;height:15px;flex:0 0 auto}
.call-modal__meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px 14px;margin:16px 0 4px;padding:10px 12px;background:var(--soft);border-radius:10px;font-size:12.5px;color:var(--muted);text-align:center}
.call-modal__meta strong{color:var(--ink);font-weight:800}
.call-modal__meta-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#3ad27a;margin-right:4px;vertical-align:middle}
.call-modal__footer{padding:8px 26px 20px;text-align:center}
.call-modal__form-link{display:inline-block;font-size:13.5px;color:var(--muted);text-decoration:none;border-bottom:1px dashed currentColor;padding-bottom:1px}
.call-modal__form-link:hover{color:var(--accent2)}
.call-modal__form-link:focus-visible{outline:3px solid #fff200;outline-offset:3px;border-radius:2px}
body.call-modal-open{overflow:hidden}
@media (max-width:520px){
  .call-modal{padding:0;align-items:flex-end}
  .call-modal__panel{width:100%;max-height:92dvh;border-radius:18px 18px 0 0;transform:translateY(28px)}
  .call-modal.is-open .call-modal__panel{transform:none}
  .call-modal__header{padding:24px 22px 16px}
  .call-modal__body{padding:18px 22px 4px}
  .call-modal__footer{padding:8px 22px 22px}
}
@media (prefers-reduced-motion:reduce){
  .call-modal,.call-modal__panel{transition:none}
}
