:root{--navy: #173a5e;--navy-dark: #0f2842;--accent: #e0712f;--accent-dark: #c85f22;--ink: #1a1a1a;--muted: #5b6770;--bg: #ffffff;--bg-alt: #f5f5f5;--line: #e2e6ea;--maxw: 1140px;--radius: 8px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:"Source Sans 3",system-ui,-apple-system,sans-serif;font-size:1.0625rem;line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}h1,h2,h3{font-family:Montserrat,system-ui,sans-serif;font-weight:700;line-height:1.15;color:var(--navy);margin:0 0 .6em}h1{font-size:clamp(2rem,5vw,2.85rem)}h2{font-size:clamp(1.6rem,3.5vw,2rem)}h3{font-size:1.3rem}p{margin:0 0 1rem}a{color:var(--accent-dark)}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 1.25rem}.section{padding:4rem 0}.section--alt{background:var(--bg-alt)}.section__lead{max-width:760px;color:var(--muted)}.btn{display:inline-block;padding:.9rem 1.75rem;font-family:Montserrat,sans-serif;font-weight:700;font-size:1rem;border-radius:var(--radius);text-decoration:none;border:2px solid transparent;cursor:pointer;transition:background .15s ease,transform .05s ease}.btn:active{transform:translateY(1px)}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-dark)}.btn--ghost{background:transparent;color:#fff;border-color:#fff}.btn--ghost:hover{background:#ffffff1f}.btn--navy{background:var(--navy);color:#fff}.btn--navy:hover{background:var(--navy-dark)}.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:72px}.nav__brand{font-family:Montserrat,sans-serif;font-weight:800;font-size:1.2rem;color:var(--navy);text-decoration:none;letter-spacing:-.01em}.nav__links{display:flex;align-items:center;gap:1.5rem;list-style:none;margin:0;padding:0}.nav__links a{color:var(--navy);text-decoration:none;font-weight:600}.nav__links a:hover{color:var(--accent-dark)}.nav__phone{white-space:nowrap}.nav__toggle,.nav__toggle-box{display:none}.hero{position:relative;color:#fff;background:linear-gradient(#0f2842e6,#173a5edb),var(--navy) center/cover no-repeat;padding:5.5rem 1.25rem 5rem;text-align:center}.hero--photo{background:linear-gradient(#0f2842e6,#173a5edb),url(/images/hero-tucson-roofing.jpg) center/cover no-repeat}.hero h1{color:#fff;max-width:18ch;margin-inline:auto}.hero .subhead{font-size:1.2rem;opacity:.95;max-width:60ch;margin:0 auto 2rem}.cta-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.trust{background:var(--navy-dark);color:#fff;padding:1.1rem 0}.trust ul{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:1rem 2rem;justify-content:center;font-weight:600;font-size:.98rem}.trust li:before{content:"✓ ";color:var(--accent);font-weight:800}.grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column}.card h3{margin-bottom:.4rem}.card p{color:var(--muted);flex:1}.card a{font-weight:700;text-decoration:none}.citygrid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));list-style:none;padding:0;margin:0}.citygrid a{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:.85rem 1rem;text-decoration:none;font-weight:600;color:var(--navy)}.citygrid a:hover{border-color:var(--accent);color:var(--accent-dark)}.checklist{padding-left:0;list-style:none}.checklist li{padding-left:1.8rem;position:relative;margin-bottom:.5rem}.checklist li:before{content:"✓";position:absolute;left:0;color:var(--accent-dark);font-weight:800}.steps{counter-reset:step;padding-left:0;list-style:none}.steps li{counter-increment:step;padding-left:3rem;position:relative;margin-bottom:1rem}.steps li:before{content:counter(step);position:absolute;left:0;top:0;width:2rem;height:2rem;background:var(--navy);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:Montserrat,sans-serif;font-weight:700}.faq details{border-bottom:1px solid var(--line);padding:1rem 0}.faq summary{font-family:Montserrat,sans-serif;font-weight:600;color:var(--navy);cursor:pointer;font-size:1.1rem}.faq p{margin:.75rem 0 0;color:var(--muted)}.cta-band{background:var(--navy);color:#fff;text-align:center;padding:3.5rem 1.25rem}.cta-band h2{color:#fff}.svc-block{padding:1.25rem 0;border-bottom:1px solid var(--line)}.svc-block h2{margin-bottom:.3rem}.draft-banner{background:#fff4e6;border:1px dashed var(--accent);color:var(--accent-dark);padding:.75rem 1rem;border-radius:var(--radius);font-size:.95rem;margin-bottom:1.5rem}.form{display:grid;gap:.85rem;max-width:520px}.form input,.form textarea{width:100%;padding:.8rem .9rem;border:1px solid var(--line);border-radius:var(--radius);font:inherit}.form textarea{min-height:120px;resize:vertical}.site-footer{background:var(--navy-dark);color:#cdd6df;padding:3rem 0 1.5rem;font-size:.95rem}.footer-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.site-footer h4{color:#fff;font-family:Montserrat,sans-serif;margin:0 0 .75rem}.site-footer ul{list-style:none;margin:0;padding:0}.site-footer li{margin-bottom:.4rem}.site-footer a{color:#cdd6df;text-decoration:none}.site-footer a:hover{color:#fff}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:2rem;padding-top:1.25rem;color:#9fb0bf;font-size:.85rem}.breadcrumb{font-size:.9rem;color:var(--muted);padding:1rem 0 0}.breadcrumb a{color:var(--muted)}@media(max-width:860px){.nav__toggle-box:checked~.nav__links{display:flex}.nav__links{display:none;position:absolute;left:0;right:0;top:72px;flex-direction:column;align-items:flex-start;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:.5rem 1.25rem 1rem}.nav__links li{width:100%;padding:.6rem 0;border-bottom:1px solid var(--line)}.nav__toggle{display:inline-flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.5rem}.nav__toggle span{width:26px;height:3px;background:var(--navy);border-radius:2px}.site-header{position:relative}}
