/*V 1.1*/
/* Reset and Base Styles */
* {margin:0; padding:0; box-sizing:border-box; font-family:"Montserrat", Arial, sans-serif;}

body {background-color:#ffffff; color:#333333; line-height:1.6; overflow-x:hidden;}

a {text-decoration:none; color:inherit; transition:all 0.3s ease;}

ul {list-style:none;}

.container {width:100%; max-width:1200px; margin:0 auto; padding:0 20px;}

img {max-width:100%; height:auto;}

/* Color Variables */
:root {--primary-green:#38ed24; --primary-black:#000000; --primary-white:#ffffff; --light-gray:#f8f9fa; --dark-gray:#343a40; --border-color:#e0e0e0; --accent-green:#38ed24;}

/* Section Styles */
section {padding:60px 0; width:100%;}

.section-header {text-align:center; margin-bottom:40px;}

.section-header h2 {font-size:clamp(24px, 4vw, 32px); font-weight:700; margin-bottom:15px; color:var(--primary-black); text-transform:uppercase; line-height:1.2;}

.section-header p {font-size:clamp(14px, 2.5vw, 18px); color:#666; max-width:700px; margin:0 auto; line-height:1.6;}

/* Header Styles */
.main-header {position:sticky; top:0; z-index:1000; box-shadow:0 2px 10px rgba(0, 0, 0, 0.1); width:100%;}

/* Top Header */
.top-header {display:flex; align-items:center; padding:0; background-color:var(--primary-black); min-height:60px;}

.logo-container {padding:10px 15px; background-color:var(--primary-black); display:flex; justify-content:center; align-items:center; flex-shrink:0;}

.logo {max-width:clamp(100px, 15vw, 200px); height:auto;}

.header-right {display:flex; align-items:center; gap:15px; padding:0 15px; flex-shrink:0; margin-left:auto;}

.find-us {display:flex; align-items:center; gap:8px;}

.map-icon {background-color:#4285f4; color:white; width:35px; height:35px; border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:16px;}

.rating-badge {background-color:#34a853; color:white; padding:6px 10px; border-radius:4px; font-weight:bold; font-size:12px;}

.google-reviews {display:flex; align-items:center; gap:8px; color:var(--primary-white);}

.google-reviews i {font-size:20px; color:#4285f4;}

.review-info {display:flex; flex-direction:column; align-items:flex-start;}

.rating {font-size:12px; font-weight:600; color:#ffc107;}

.review-count {font-size:10px; color:#ccc;}

.phone-button {background:transparent; border:2px solid var(--primary-green); color:var(--primary-white); padding:8px 16px; border-radius:20px; font-size:14px; font-weight:600; cursor:pointer; transition:all 0.3s ease; text-transform:uppercase; white-space:nowrap;}

.review-button:hover,
.phone-button:hover {background-color:var(--primary-green); color:var(--primary-white);}

/* Mobile Menu Button and Phone Container */
.mobile-menu-phone-container {display:none; align-items:center; gap:10px; margin-left:auto; padding:0 15px;}

.mobile-menu-btn {display:none; font-size: 24px !important; cursor:pointer; padding:15px;color:var(--primary-white);z-index:1001;}

/* Mobile Phone Button - Always visible on mobile */
.mobile-phone-button {background:transparent; border:2px solid var(--primary-green); color:var(--primary-white); padding:6px 12px; border-radius:15px; font-size:12px; font-weight:600; cursor:pointer; transition:all 0.3s ease; text-transform:uppercase; white-space:nowrap; text-decoration:none;}

.mobile-phone-button:hover {background-color:var(--primary-green); color:var(--primary-white);}

/* Bottom Navigation */
.bottom-nav {background-color:var(--primary-white); border-bottom:1px solid var(--border-color); padding:0;}

.desktop-nav {background-color:var(--primary-white); display:flex; justify-content:center; width:100%;}

.desktop-nav ul {display:flex; justify-content:center; align-items:center; padding:0; margin:0; gap:clamp(15px, 3vw, 40px); max-width:1200px; width:100%; flex-wrap:wrap;}

.desktop-nav li {padding:0;}

.desktop-nav a {color:var(--primary-black); font-weight:600; font-size:clamp(12px, 1.5vw, 13px); transition:color 0.3s; position:relative; text-transform:uppercase; padding:15px 0; display:block; white-space:nowrap;}

.desktop-nav a:hover,
.desktop-nav a.active {color:var(--primary-green);}

.desktop-nav a:after {content:""; position:absolute; width:0; height:3px; bottom:0; left:0; background-color:var(--primary-green); transition:width 0.3s;}

.desktop-nav a:hover:after,
.desktop-nav a.active:after {width:100%;}

/* Mobile Navigation */
.mobile-nav-container {display:none; position:fixed; top:0; right:-100%; width:100%; height:100%; background-color:var(--primary-black); z-index:1000; transition:right 0.3s ease; overflow-y:auto;}

.mobile-nav-container.active {right:0;}

.mobile-nav-header {display:flex; justify-content:space-between; align-items:center; padding:15px 20px; background-color:var(--primary-black); border-bottom:1px solid rgba(255, 255, 255, 0.1);}

.active-page {color:var(--primary-white); font-weight:600; font-size:16px;}

.close-menu-btn {position:absolute; top:15px; right:15px; font-size:24px; color:var(--primary-white); cursor:pointer; z-index:1002;}

.mobile-nav {background-color:var(--primary-black); height:calc(100% - 50px); overflow-y:auto;}

.mobile-nav ul {display:flex; flex-direction:column; padding:0;}

.mobile-nav li {border-bottom:1px solid rgba(255, 255, 255, 0.1);}

.mobile-nav a {color:var(--primary-white); font-weight:600; display:block; padding:15px 20px; font-size:16px;}

.mobile-nav a:hover,
.mobile-nav a.active {color:var(--primary-green); background-color:rgba(255, 255, 255, 0.05);}

/* Hero Section */
.hero {background:linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)), url("/public/img/ac-services-yuma/air-conditioning-banner.webp")
 no-repeat center center; background-size:cover; color:var(--primary-white); text-align:center; padding:clamp(40px, 6vw, 60px) 20px; position:relative; width:100%; min-height:35vh; display:flex; align-items:center; justify-content:center;}

.hero-content {max-width:800px; margin:0 auto; width:100%;}

.hero h1 {font-size:clamp(24px, 6vw, 48px); font-weight:700; margin-bottom:20px; text-shadow:2px 2px 4px rgba(0, 0, 0, 0.5); line-height:1.2;}

.hero p {font-size:clamp(16px, 3vw, 20px); margin-bottom:30px; text-shadow:1px 1px 2px rgba(0, 0, 0, 0.5); line-height:1.4;}

.cta-button {background:transparent; border:2px solid var(--primary-green); color:var(--primary-white); padding:clamp(12px, 2vw, 15px) clamp(20px, 4vw, 30px); font-size:clamp(14px, 2vw, 16px); font-weight:600; cursor:pointer; border-radius:50px; transition:all 0.3s ease; text-transform:uppercase; box-shadow:0 4px 15px rgba(40, 167, 69, 0.2); min-height:44px;}

.cta-button:hover {background:var(--primary-green); color:var(--primary-white); transform:translateY(-3px); box-shadow:0 6px 20px rgba(40, 167, 69, 0.4);}

/* Combined Section - Mobile First Approach */
.combined-section {background-color:var(--light-gray); padding:20px 0; width:100%;}

.combined-content {max-width:1200px; margin:0 auto; padding:0 15px;}

/* Problem Text */
.problem-text {background-color:var(--primary-white); border-radius:8px; padding:20px; margin-bottom:20px; box-shadow:0 3px 15px rgba(0, 0, 0, 0.1); text-align:center; min-height:526px;}

.problem-text h2 {font-size:18px; font-weight:700; margin-bottom:15px; color:var(--primary-black); text-transform:uppercase; line-height:1.3; text-align:center;}

.problem-text p {font-size:14px; line-height:1.6; color:#555; max-width:100%; text-align:justify;}

.problem-text strong {color:var(--primary-black); font-weight:700;}

.inspection {margin-top:30px;}

/* Shingle Section */
.shingle-section {background-color:var(--primary-white); border-radius:8px; padding:20px; box-shadow:0 3px 15px rgba(0, 0, 0, 0.1);}

.shingle-section .section-header {text-align:center; margin-bottom:10px;}

.shingle-section .section-header h2 {font-size:16px; font-weight:700; margin-bottom:10px; color:var(--primary-black); text-transform:uppercase; line-height:1.3;}

.shingle-section .section-header p {font-size:12px; color:#666; line-height:1.4;}

/* Mobile Visualizer - Completely Redesigned */
.shingle-visualizer {width:100%; margin-bottom:10px;}

.visualizer-main {position:relative; margin-bottom:20px;}

.visualizer-display {width:100%; background-color:#f5f5f5; border-radius:8px; padding:15px; box-shadow:0 2px 10px rgba(0, 0, 0, 0.1);}

/* Mobile:Stack house and detail vertically */
.house-display {width:100%; height:200px; position:relative; margin-bottom:15px; border-radius:6px; overflow:hidden; background-color:#ddd;}

.house-img {position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 0.5s ease;}

.house-img.active {opacity:1;}

.shingle-detail {width:100%; height:120px; position:relative; border-radius:6px; overflow:hidden; background-color:#ddd;}

.detail-img {position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 0.5s ease;}

.detail-img.active {opacity:1;}

/* Material Sets - Hide/Show based on active type */

.none {display:none;}

.material-set.active {display:block;}

.material-options {display:none;}
.material-options.active {display:flex;}

/* Shingle Options - Mobile Optimized */
.shingle-options {position:relative; margin-bottom:20px;}

.options-container {overflow-x:auto; scroll-behavior:smooth; -ms-overflow-style:none; scrollbar-width:none; gap:12px; padding:15px 5px; background-color:#f9f9f9; border-radius:8px;}

.options-container::-webkit-scrollbar {display:none;}

.shingle-option {min-width:80px; max-width:80px; border-radius:8px; overflow:hidden; box-shadow:0 3px 10px rgba(0, 0, 0, 0.15); background-color:var(--primary-white); /* transition:all 0.3s ease; */
 cursor:pointer; flex-shrink:0; height:150px; margin:0px 10px;}

.shingle-option:hover {transform:translateY(-3px); box-shadow:0 6px 20px rgba(0, 0, 0, 0.2);}

.shingle-option.active {border:3px solid var(--primary-green); transform:translateY(-2px);}

.shingle-option img {width:100%; height:60px; object-fit:cover;}

.option-info {padding:0px 6px; text-align:center;}

.option-name {font-size:10px; font-weight:600; color:var(--primary-black); line-height:1.2; margin-bottom:4px;}

.option-favorite {background:none; border:none; color:#999; cursor:pointer; font-size:14px; transition:color 0.3s ease; padding:2px;}

.option-favorite:hover,
.option-favorite.active {color:#ff4757;}

/* Roof Types - Mobile Optimized */
.roof-types {text-align:center;}

.roof-types h3 {margin-bottom:15px; font-size:14px; color:var(--primary-black); font-weight:700; text-transform:uppercase;}

.roof-options {display:flex; justify-content:center; gap:10px; flex-wrap:wrap;}

.roof-option {padding:12px 20px; background-color:var(--light-gray); border-radius:25px; cursor:pointer; transition:all 0.3s ease; box-shadow:0 3px 8px rgba(0, 0, 0, 0.1); display:flex; align-items:center; font-size:15px; font-weight:600; min-height:44px; white-space:nowrap;}

.roof-option i {margin-right:6px; color:var(--primary-green); font-size:14px;}

.roof-option.active {background:linear-gradient(135deg, var(--primary-green), var(--accent-green)); color:var(--primary-white); box-shadow:0 4px 12px rgba(40, 167, 69, 0.4); transform:translateY(-2px);}

.roof-option.active i {color:var(--primary-white);}

.roof-option:hover:not(.active) {transform:translateY(-2px); box-shadow:0 5px 15px rgba(0, 0, 0, 0.15);}

/* Hide arrows on mobile for cleaner look */
.options-arrow {display:none;}

/* Tablet and Desktop Styles */
@media (min-width:768px) {.combined-section {padding:30px 0;}

 .combined-content {display:grid; grid-template-columns:1fr 1fr; gap:30px; padding:0 20px; align-items:start;}

 .problem-text {margin-bottom:0; text-align:left; padding:25px; height:fit-content;}

 .problem-text h2 {font-size:22px; margin-bottom:20px;}

 .problem-text p {font-size:15px; text-align:justify;}

 .shingle-section {padding:25px; height:fit-content;}

 .shingle-section .section-header h2 {font-size:18px;}

 .shingle-section .section-header p {font-size:13px;}

 .visualizer-display {display:flex; gap:15px; padding:15px;}

 .house-display {flex:2; height:160px; margin-bottom:0;}

 .shingle-detail {flex:1; height:160px;}

 .shingle-option {min-width:75px; max-width:75px;}

 .shingle-option img {height:55px;}

 .option-name {font-size:9px;}

 .options-arrow {display:flex; background:linear-gradient(135deg, var(--primary-green), var(--accent-green)); color:var(--primary-white); border:none; width:30px; height:30px; border-radius:50%; font-size:12px; cursor:pointer; justify-content:center; align-items:center; box-shadow:0 2px 8px rgba(40, 167, 69, 0.3); transition:all 0.3s ease; position:absolute; top:50%; transform:translateY(-50%); z-index:2;}

 .options-arrow.prev-options {left:-15px;}

 .options-arrow.next-options {right:-15px;}

 .options-arrow:hover {transform:translateY(-50%) scale(1.1); box-shadow:0 4px 12px rgba(40, 167, 69, 0.5);}

 .options-container {max-width:calc(664px - 60px); margin:0 auto;}
}

@media (min-width:992px) {.problem-text h2 {font-size:24px;}

 .problem-text p {font-size:16px; text-align:justify;}

 .shingle-section .section-header h2 {font-size:20px;}

 .shingle-section .section-header p {font-size:14px;}

 .house-display {height:180px;}

 .shingle-detail {height:180px;}

 .shingle-option {min-width:100px; max-width:100px;}

 .shingle-option img {height:75px;}

 .option-name {font-size:10px;}
}

/* Services Section */
.services {background-color:var(--primary-white); padding:clamp(40px, 8vw, 80px) 0 clamp(20px, 4vw, 40px) 0; width:100%;}

.service-items {display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:clamp(20px, 4vw, 30px); max-width:1200px; margin:0 auto; padding:0 20px;}

.service-items .service-item {display:flex; flex-direction:column; align-items:center; transition:transform 0.3s ease; background-color:transparent; border-radius:0; padding:0;}

.service-items .service-item:hover {transform:translateY(-10px);}

.service-circle {width:clamp(100px, 15vw, 120px); height:clamp(100px, 15vw, 120px); border-radius:50%; display:flex; flex-direction:column; justify-content:center; align-items:center; margin-bottom:20px; background:linear-gradient(135deg, var(--primary-green), var(--accent-green)); color:#000000; box-shadow:0 5px 15px rgba(40, 167, 69, 0.3);}

.service-circle i {font-size:clamp(24px, 4vw, 35px); margin-bottom:5px; color:#000000;}

.service-circle p {font-size:clamp(11px, 2vw, 14px); font-weight:600; text-align:center; line-height:1.2; padding:0 10px;}

.service-box {width:100%; padding:clamp(20px, 4vw, 25px); border-radius:8px; background-color:var(--light-gray); box-shadow:0 5px 15px rgba(0, 0, 0, 0.05); text-align:center; transition:all 0.3s ease;}

.service-box:hover {box-shadow:0 10px 25px rgba(0, 0, 0, 0.1);}

.service-box h3 {font-size:clamp(16px, 3vw, 20px); margin-bottom:15px; color:var(--primary-black); font-weight:700;}

.service-box p {margin-bottom:15px; color:#000000; line-height:1.6; font-size:clamp(13px, 2vw, 15px);}

/* Contact Form Section (Iframe) */
.contact-form-section {background-color:var(--primary-black); color:var(--primary-green); padding:clamp(20px, 3vw, 30px) 0; overflow:hidden;}

.form-grid-container {display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:clamp(30px, 6vw, 60px); max-width:1200px; margin:0 auto; padding:0;}

.form-text-content .form-logo {max-width:100%; height:auto; margin-bottom:30px;}

.form-text-content h2 {font-size:clamp(28px, 5vw, 42px); line-height:1.2; margin-bottom:20px; text-transform:uppercase;}

.form-text-content h2 .highlight {color:var(--primary-green);}

.form-text-content p {font-size:clamp(14px, 2vw, 16px); color:white; line-height:1.7;}

.form-wrapper {border-radius:8px; overflow:hidden; min-height:900px; background-color:#fff; width:100%; box-shadow:0 8px 25px rgba(0, 0, 0, 0.1); position:relative;}

.form-wrapper iframe {width:100% !important; height:100% !important; min-height:900px; border:none !important; border-radius:3px; display:block;}

.form-wrapper .loader {display:flex; align-items:center; justify-content:center; height:200px; color:var(--primary-black); font-size:18px; font-weight:600; background-color:#fff; border-radius:8px; width:100%;}

/* Family First Section */
.family-first {background-color:var(--primary-white); padding:clamp(20px, 4vw, 40px) 0 clamp(40px, 8vw, 80px) 0; width:100%;}

.family-first .section-header p {text-align:left; max-width:900px; margin:0 auto; font-size:clamp(14px, 2.5vw, 16px); line-height:1.8; padding:0 20px;}

.benefits-grid {display:grid; grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:clamp(15px, 3vw, 20px); margin-top:clamp(30px, 6vw, 40px); padding:0 20px; max-width:1200px; margin-left:auto; margin-right:auto;}

.benefit-item {padding:clamp(15px, 3vw, 20px); border-radius:8px; background-color:var(--light-gray); box-shadow:0 3px 10px rgba(0, 0, 0, 0.05); transition:transform 0.3s ease; display:flex; align-items:flex-start; gap:clamp(10px, 2vw, 15px);}

.benefit-item:hover {transform:translateY(-5px); box-shadow:0 8px 20px rgba(0, 0, 0, 0.1);}

.benefit-icon {flex-shrink:0; width:clamp(25px, 4vw, 30px); height:clamp(25px, 4vw, 30px); display:flex; align-items:center; justify-content:center;}

.benefit-icon i {font-size:clamp(20px, 3vw, 24px); color:var(--primary-green);}

.benefit-content {flex:1;}

.benefit-content h3 {font-size:clamp(13px, 2.5vw, 16px); margin-bottom:10px; color:var(--primary-black); font-weight:700; line-height:1.3;}

.benefit-content p {color:#666; font-size:clamp(12px, 2vw, 14px); line-height:1.6;}

/* Recent Projects Section */
.recent-projects {background-color:var(--light-gray); padding:clamp(40px, 8vw, 80px) 0; width:100%;}

.projects-slider {display:flex; align-items:center; justify-content:center; margin-bottom:30px; width:100%; position:relative;}

.slider-arrow {background:linear-gradient(135deg, var(--primary-green), var(--accent-green)); color:var(--primary-white); border:none; width:clamp(35px, 6vw, 45px); height:clamp(35px, 6vw, 45px); border-radius:50%; font-size:clamp(14px, 2.5vw, 18px); cursor:pointer; display:flex; justify-content:center; align-items:center; margin:0 clamp(10px, 2vw, 15px); box-shadow:0 3px 10px rgba(40, 167, 69, 0.3); transition:all 0.3s ease; z-index:2; position:absolute;}

.slider-arrow.prev {left:10px;}

.slider-arrow.next {right:-70px;}

.slider-arrow:hover {transform:scale(1.1); box-shadow:0 5px 15px rgba(40, 167, 69, 0.5);}

.projects-container {display:flex; overflow-x:auto; scroll-behavior:smooth; -ms-overflow-style:none; scrollbar-width:none; gap:clamp(20px, 4vw, 30px); padding:20px clamp(50px, 8vw, 80px); max-width:100%;}

.projects-container::-webkit-scrollbar {display:none;}

.project {min-width:clamp(250px, 40vw, 320px); max-width:clamp(250px, 40vw, 350px); border-radius:8px; overflow:hidden; box-shadow:0 5px 15px rgba(0, 0, 0, 0.1); background-color:var(--primary-white); transition:transform 0.3s ease; flex-shrink:0;}

.project:hover {transform:translateY(-10px); box-shadow:0 10px 25px rgba(0, 0, 0, 0.15);}

.before-after {display:flex; height:clamp(120px, 20vw, 200px);}

.before,
.after {width:50%; position:relative; overflow:hidden;}

.before img,
.after img {width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease;}

.before:hover img,
.after:hover img {transform:scale(1.1);}

.label {position:absolute; bottom:8px; left:8px; background-color:rgba(0, 0, 0, 0.7); color:var(--primary-white); padding:4px 8px; border-radius:4px; font-size:clamp(10px, 1.5vw, 12px); font-weight:600;}

.project-info {padding:clamp(15px, 3vw, 20px);}

.project-info h3 {font-size:clamp(14px, 2.5vw, 18px); margin-bottom:5px; color:var(--primary-black); line-height:1.3;}

.project-info p {color:#666; font-size:clamp(12px, 2vw, 14px);}

/* Service Areas with Map Section - MODIFIED TO MATCH WIREFRAME */
.service-areas-with-map {background-color:var(--primary-black); padding:clamp(40px, 8vw, 80px) 0; width:100%;}

.service-areas-content {display:grid; grid-template-columns:1fr 1.5fr; gap:clamp(30px, 6vw, 50px); align-items:flex-start; max-width:1200px; margin:0 auto; padding:0 20px;}

.service-areas-left h2 {color:var(--primary-green); font-size:clamp(20px, 4vw, 32px); font-weight:700; text-transform:uppercase; margin-bottom:clamp(20px, 4vw, 30px);}

/* NEW:Horizontal list for areas - matching wireframe */
.areas-horizontal-list {display:flex; flex-wrap:wrap; gap:clamp(15px, 3vw, 25px); margin-bottom:20px; align-items:center;}

.area-item {color:var(--primary-white); font-size:clamp(12px, 2vw, 16px); font-weight:600; display:flex; align-items:center; gap:8px; white-space:nowrap;}

.area-item i {color:var(--primary-green); font-size:clamp(12px, 2vw, 16px);}

.areas-description {color:#ccc; font-size:clamp(12px, 2vw, 14px); line-height:1.6;}

/* NEW:Larger map container - matching wireframe */
.map-container-large {background-color:var(--light-gray); border-radius:8px; overflow:hidden; width:100%; height:clamp(300px, 40vw, 500px); box-shadow:0 5px 15px rgba(0, 0, 0, 0.1);}

.map-container-large iframe {width:100%; height:100%; border:0;}

/* Responsive adjustments */
@media (max-width:992px) {.service-areas-content {grid-template-columns:1fr; gap:30px;}
}

@media (max-width:768px) {/* Adjust service areas for mobile */
 .areas-horizontal-list {flex-direction:column; align-items:flex-start; gap:10px;}

 .map-container-large {height:clamp(250px, 35vw, 350px);}
}

@media (max-width:711px) {/* Improve service areas section */
 .areas-horizontal-list {gap:8px;}

 /* Adjust map container */
 .map-container-large {height:clamp(200px, 30vw, 300px);}
}

@media (max-width:576px) {/* Adjust service areas for small screens */
 .areas-horizontal-list {flex-direction:column; gap:5px;}

 .map-container-large {height:clamp(180px, 25vw, 250px);}
}

@media (max-width:480px) {/* Improve areas list */
 .areas-horizontal-list {flex-direction:column; align-items:flex-start;}
 
 /* Adjust map for very small screens */
 .map-container-large {height:clamp(150px, 20vw, 200px);}
}

@media (max-width:360px) {/* Improve map container */
 .map-container-large {height:clamp(120px, 15vw, 150px);}
}

/* Desktop Layout for Service Areas */
@media (min-width:768px) {.service-areas-content {display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px, 5vw, 50px); align-items:start;}
 
 .areas-map {min-height:400px;}
 
 .map-container-service {min-height:400px;}
 
 .map-container-service iframe {min-height:400px;}
}

/* Responsive adjustments for Service Areas */

@media (max-width:992px) {.location-item {font-size:clamp(13px, 2.2vw, 16px);}

 .location-item::before {font-size:clamp(14px, 2.2vw, 18px);}
}

@media (max-width:768px) {.service-areas {padding:clamp(25px, 5vw, 35px) 0;}

 .service-areas .section-header h2 {font-size:clamp(18px, 3.5vw, 24px); margin-bottom:clamp(15px, 3vw, 20px);}

 .location-item {font-size:clamp(12px, 2vw, 14px);}

 .location-item::before {font-size:clamp(13px, 2vw, 16px);}
}

@media (min-width:768px) {.hero h1 {white-space:nowrap;}
}

@media (max-width:576px) {.areas-grid {gap:clamp(12px, 2.5vw, 15px);}

 .location-item {font-size:clamp(11px, 1.8vw, 13px); flex:0 0 calc(50% - 10px); justify-content:center;}

 .location-item::before {font-size:clamp(12px, 1.8vw, 14px);}
}

@media (max-width:480px) {.service-areas .section-header h2 {font-size:clamp(16px, 3vw, 20px);}

 .location-item {font-size:clamp(10px, 1.6vw, 12px); flex:0 0 calc(50% - 8px);}

 .location-item::before {font-size:clamp(11px, 1.6vw, 13px);}
}

@media (max-width:360px) {.location-item {font-size:clamp(9px, 1.4vw, 11px); flex:0 0 calc(50% - 6px);}

 .location-item::before {font-size:clamp(10px, 1.4vw, 12px);}
}

/* FAQ Section */
.faq {background-color:var(--primary-white); padding:clamp(40px, 8vw, 80px) 0; width:100%;}

.faq-container {max-width:800px; margin:0 auto; width:100%; padding:0 20px;}

.faq-item {margin-bottom:15px; border-radius:8px; overflow:hidden; background-color:var(--light-gray); box-shadow:0 3px 10px rgba(0, 0, 0, 0.05); width:100%;}

.faq-question {padding:clamp(15px, 3vw, 20px); cursor:pointer; display:flex; align-items:center; transition:background-color 0.3s ease; min-height:60px;}

.faq-question:hover {background-color:rgba(0, 0, 0, 0.02);}

.faq-arrow {margin-right:clamp(10px, 2vw, 15px); font-size:clamp(14px, 2.5vw, 16px); color:var(--primary-green); transition:transform 0.3s ease; flex-shrink:0; width:20px; height:20px; display:flex; align-items:center; justify-content:center;}

.faq-item.active .faq-arrow i {transform:rotate(45deg);}

.faq-question h3 {font-size:clamp(14px, 2.5vw, 18px); font-weight:600; color:var(--primary-black); line-height:1.3; flex:1;}

.faq-answer {padding:0 clamp(15px, 3vw, 20px) clamp(15px, 3vw, 20px) clamp(45px, 8vw, 55px); background-color:var(--light-gray); color:#666; line-height:1.6; display:none; font-size:clamp(13px, 2vw, 15px);}

.faq-item.active .faq-answer {display:block;}

/* Footer - Updated with black background and white text */
footer {background-color:var(--primary-black); color:var(--primary-white); padding:clamp(40px, 8vw, 60px) 0 20px; width:100%;}

/* Footer Logo Section */
.footer-logo-section {text-align:center; margin-bottom:clamp(30px, 6vw, 40px); padding:0 20px;}

.footer-logo {max-width:clamp(150px, 20vw, 250px); height:auto;}

.footer-content {display:grid; grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); gap:clamp(20px, 4vw, 40px); max-width:1200px; margin:0 auto; padding:0 20px; width:100%;}

.map-container {height:clamp(150px, 25vw, 200px); border-radius:8px; overflow:hidden; margin-bottom:20px; margin-top:20px;}

.map-container iframe {width:100%; height:100%; border:0;}

.footer-section h3 {font-size:clamp(16px, 2.5vw, 18px); margin-bottom:20px; color:var(--primary-white); font-weight:700;}

.footer-section ul li {margin-bottom:8px;}

.footer-section.column ul li {width:100%; margin:0 0 8px;}

.footer-section.column ul {display:grid; grid-template-columns:repeat(2, 1fr); gap:8px;}
 
.footer-section.column ul li {width:100%; margin:0;}

.column ul li {float:left; margin:0px 1%; width:48%;}

.columna {clear:both;}

.footer-section a {color:#ccc; transition:color 0.3s ease; font-size:clamp(12px, 2vw, 14px); line-height:1.5;}

.footer-section a:hover {color:var(--primary-green);}

.licenses {margin-bottom:20px;}

.license-row {display:flex; flex-wrap:wrap; gap:15px; margin-bottom:10px;}

.license-row span {font-size:clamp(12px, 2vw, 14px); color:#ccc;}

.social-media {display:flex; gap:10px; margin-top:15px; margin-bottom:30px; flex-wrap:wrap;}

.social-icon {display:flex; justify-content:center; align-items:center; width:clamp(35px, 6vw, 40px); height:clamp(35px, 6vw, 40px); background-color:rgba(255, 255, 255, 0.1); border-radius:50%; transition:all 0.3s ease; font-size:clamp(14px, 2.5vw, 16px);}

.social-icon:hover {background-color:var(--primary-green); transform:translateY(-3px);}

/* Responsive Breakpoints */
@media (max-width:1200px) {.combined-content {grid-template-columns:1fr;}
 .problem-text {min-height:auto;}

 /* Keep header-right visible b .bottom-navut hide some elements */
 .header-right {gap:10px;}

 /* Hide some elements but keep phone */
 .find-us,
 .google-reviews,
 .review-button {display:none;}

 .phone-button {padding:6px 12px; font-size:13px;}
}

@media (max-width:1150px) {.bottom-nav {display:none;}
 .header-right {display:none;}
 .mobile-menu-phone-container {display:flex;}
 .mobile-menu-btn {display:block;}
 .mobile-nav-container {display:block;}
 .form-grid-container {grid-template-columns:1fr;}
 .form-text-content {text-align:center; margin-bottom:40px;}
 .form-text-content .form-logo {margin:0 auto;}
 .form-wrapper {max-width:600px; margin:0 auto;}
}

/*Icons en Tablets*/
@media (min-width:650px) and (max-width:1024px) {.visualizer-display {display:flex; flex-direction:row;}

 .material-options.active {display:flex; justify-content:center;}
}

@media (max-width:992px) {.bottom-nav {display:none;}

 /* Hide desktop header-right completely */
 .header-right {display:none;}

 /* Show mobile menu and phone container */
 .mobile-menu-phone-container {display:flex;}
 .mobile-menu-btn {display:block;}
 .mobile-nav-container {display:block;}

 .visualizer-display {flex-direction:column; display:block;}
 .house-display {margin-bottom:15px;}
 .options-container {margin:0px auto;}
}

@media (max-width:768px) {.container {padding:0 15px;}
 .areas-grid {grid-template-columns:repeat(2, 1fr);}
 .projects-container {padding:20px 40px;}

 /* Adjust mobile phone button for smaller screens */
 .mobile-phone-button {font-size:11px; padding:5px 10px;}
 .mobile-menu-btn {font-size:18px; padding:8px;}
 .mobile-menu-phone-container {gap:6px; padding:0 8px;}
 .form-wrapper,
 .form-wrapper iframe {min-height:960px;}
}

@media (max-width:576px) {.container {padding:0 10px;}
 .areas-grid {grid-template-columns:1fr; max-width:300px;}
 .projects-container {padding:20px;}
 .slider-arrow {display:none;}
 .options-arrow {display:none;}
 .options-container {max-width:100%; padding:10px 0;}

 /* Further adjust mobile phone button */
 .mobile-phone-button {font-size:10px; padding:4px 8px;}
 .mobile-menu-btn {font-size:16px; padding:6px;}
 .mobile-menu-phone-container {gap:4px; padding:0 6px;}
 .form-wrapper,
 .form-wrapper iframe {min-height:1050px;}
}

@media (max-width:480px) {.service-items {grid-template-columns:1fr; gap:20px;}
 .benefits-grid {grid-template-columns:1fr;}
 .benefit-item {flex-direction:column; align-items:center; text-align:center; gap:10px;}
}

@media (max-width:360px) {.shingle-section {margin:0 10px;}
 .problem-text {padding:0 10px;}
 .cta-button {font-size:13px;}

 /* Smallest screens - minimal phone button */
 .mobile-phone-button {font-size:9px;padding:3px 6px;/* border-radius:8px; */}
 .mobile-menu-btn {font-size:14px; padding:8px;}
 .mobile-menu-phone-container {gap:3px; padding:0 5px;}
}

@media (max-width:320px) {.request {font-size:12px;}
}

