/*V 1.9 Depurado y Ordenado*/
/* 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;}

/* Typography */
h1,
h2,
h3,
h4 {font-weight:700;}

/* 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); 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; justify-content: space-between; padding:0; background-color:var(--primary-black); min-height:60px;}
.logo-container {padding:10px 15px; background-color:var(--primary-black); display:flex; justify-content:flex-start; 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:0; justify-content: flex-end;}
.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: #209b41;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;}
.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;}
.phone-button:hover {background-color:var(--primary-green); color:var(--primary-white);}

/* Funcion para cambio de pagina a Lake Havasu*/
.location-switcher {flex-grow: 1; flex-shrink: 1; display: flex; justify-content: center; align-items: center; padding: 0 20px; overflow: hidden;  display: none;}
.location-switcher a {display: flex; align-items: center; font-family: "Montserrat", Arial, sans-serif; color: var(--primary-white); font-size: 18px; font-weight: 700; text-decoration: none; white-space: nowrap; transition: all 0.3s ease;}
.location-switcher a:hover {color: var(--primary-green);  transform: scale(1.05); }
.location-switcher i {color: var(--primary-green); font-size: 18px; margin-right: 10px; animation: spin-3d 3s linear infinite; }
.location-switcher .loc-highlight {color: var(--primary-green); margin: 0 4px; display: inline-block; transition: all 0.3s ease;}
.location-switcher a:hover .loc-highlight {color: var(--primary-white); }

/*  Animación de Giro 3D */
@keyframes spin-3d {
  from {
    transform: rotateY(0deg);
  }
  to {
    transform: rotateY(360deg);
  }
}

/* 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; 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: #209b41;}
.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;}
.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 with Carousel */
.hero {position:relative; color:var(--primary-white); text-align:center; padding:clamp(40px, 6vw, 60px) 20px; width:100%; min-height:35vh; display:flex; align-items:center; justify-content:center; overflow:hidden;}
.hero-carousel {position:absolute; top:0; left:0; width:100%; height:100%; z-index:-1;}
.hero-slide {position:absolute; top:0; left:0; width:100%; height:100%; background-size:cover; background-position:center; background-repeat:no-repeat; opacity:0; transition:opacity 1s ease-in-out;}
.hero-slide.active {opacity:1;}
.hero-slide::before {content:""; position:absolute; top:0; left:0; width:100%; height:100%; background:linear-gradient(rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.7)); z-index:1;}
.hero-content {position:relative; z-index:2; max-width:800px; margin:0 auto; width:100%; text-align:left;}
.hero h1 {font-size:clamp(24px, 6vw, 48px); 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);}

/* Hero Navigation Dots */
.hero-dots {position:absolute; bottom:20px; left:50%; transform:translateX(-50%); display:flex; gap:10px; z-index:3;}
.hero-dot {width:12px; height:12px; border-radius:50%; background-color:rgba(255, 255, 255, 0.5); cursor:pointer; transition:all 0.3s ease;}
.hero-dot.active {background-color:var(--primary-green); transform:scale(1.2);}
.hero-dot:hover {background-color:rgba(255, 255, 255, 0.8);}

/*Hover y Scroll animado para todo la pagina */
.animated-item.scrolled {opacity:1; transform:translateY(0);}
.animated-item.scrolled:hover {transform:translateY(-5px);box-shadow: 0 0 13px 10px rgba(0, 0, 0, 0.15); border-radius: 10px;}
.animated-item.scrolled:hover .service-icon,
.animated-item.scrolled:hover .other-service-icon {transform:translateY(-5px) scale(1.05); box-shadow:0 8px 25px rgba(40, 167, 69, 0.5);}

/* Core Services Section */
.services {background-color:var(--primary-white); padding:clamp(40px, 8vw, 80px) 0; width:100%;}
.core-services-grid {display:grid; grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); gap:clamp(20px, 4vw, 30px); max-width:1200px; margin:0 auto; padding:0 20px;}
.core-service-item {background-color:var(--light-gray); padding:clamp(20px, 4vw, 30px); border-radius:8px; box-shadow:0 5px 15px rgba(0, 0, 0, 0.05); text-align:center; transition:transform 0.3s ease, box-shadow 0.3s ease;}
.core-service-item h3 {font-size:clamp(18px, 3vw, 24px); margin-bottom:20px; color:var(--primary-black); text-transform:uppercase;}
.core-service-item ul {text-align:left; max-width:200px; margin:0 auto;}
.core-service-item li {margin-bottom:10px; color:#000000; font-size:clamp(14px, 2vw, 16px); line-height:1.5;}
.service-icon {width:clamp(60px, 10vw, 80px); height:clamp(60px, 10vw, 80px); border-radius:50%; background:linear-gradient(135deg, var(--primary-green), var(--accent-green)); display:flex; align-items:center; justify-content:center; margin:0 auto 20px; box-shadow:0 4px 15px rgba(40, 167, 69, 0.3); transition:all 0.3s ease;}
.service-icon i {font-size:clamp(24px, 4vw, 32px); color:#000000;}

/* 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-black); padding:clamp(40px, 8vw, 80px) 0; width:100%;}
.family-first .section-header h2 {color:var(--primary-white);}
.family-benefits-grid {display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:clamp(15px, 3vw, 20px); margin-top:clamp(30px, 6vw, 40px); padding:0 20px; max-width:1200px; margin-left:auto; margin-right:auto;}
.family-benefit-item {padding:clamp(15px, 3vw, 20px); border-radius:8px; background-color:transparent; box-shadow:none; transition:transform 0.3s ease; display:flex; align-items:center; gap:clamp(10px, 2vw, 15px);}
.family-benefit-item:hover {transform:translateY(-5px);}
.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(14px, 2.5vw, 18px); margin-bottom:10px; color:var(--primary-white); line-height:1.3;}
.benefit-content p {color:#ccc; font-size:clamp(12px, 2vw, 14px); line-height:1.6;}

/* Accredited Section */
.accredited-section {background-color:var(--light-gray); padding:clamp(40px, 8vw, 80px) 0; width:100%;}
.horizontal-logos-carousel {position:relative; max-width:1000px; margin:0 auto; padding:0 20px;}
.carousel-arrow {background:linear-gradient(135deg, var(--primary-green), var(--accent-green)); color:var(--primary-white); border:none; width:clamp(45px, 6vw, 55px); height:clamp(45px, 6vw, 55px); border-radius:50%; font-size:clamp(18px, 2.5vw, 22px); cursor:pointer; display:flex; justify-content:center; align-items:center; box-shadow:0 4px 15px rgba(40, 167, 69, 0.3); transition:all 0.3s ease; position:absolute; top:50%; transform:translateY(-50%); z-index:10;}
.prev-logos {left:0;}
.next-logos {right:0;}
.carousel-arrow:hover {transform:translateY(-50%) scale(1.1); box-shadow:0 6px 20px rgba(40, 167, 69, 0.5);}
.logos-container {position:relative; margin:0 clamp(60px, 10vw, 80px); overflow:hidden; height:clamp(100px, 15vw, 150px);}
.logos-track {display:flex; align-items:center; gap:clamp(15px, 3vw, 30px); transition:transform 0.5s ease; height:100%; padding:20px 0;}
.logo-item {flex-shrink:0; display:flex; align-items:center; justify-content:center; height:clamp(80px, 12vw, 130px); width:clamp(90px, 14vw, 140px); background-color:var(--primary-white); border-radius:8px; box-shadow:0 3px 10px rgba(0, 0, 0, 0.1); transition:all 0.3s ease; padding:8px;}
.logo-item:hover {transform:translateY(-5px); box-shadow:0 8px 20px rgba(0, 0, 0, 0.15);}
.certification-logo {max-width:100%; max-height:100%; object-fit:contain; filter:grayscale(0.3); transition:filter 0.3s ease;}
.logo-item:hover .certification-logo {filter:grayscale(0);}
.logos-track.auto-scroll {animation:scroll-logos 20s linear infinite;}
.logos-track:hover {animation-play-state:paused;}

/* Accreditation Features */
.accreditation-features {display:grid; grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); gap:clamp(20px, 4vw, 30px); max-width:1000px; margin:40px auto 0; padding:0 20px;}
.feature-item {display:flex; align-items:center; justify-content:center; gap:15px; padding:20px; background-color:var(--primary-white); border-radius:8px; box-shadow:0 3px 10px rgba(0, 0, 0, 0.05); transition:transform 0.3s ease;}
.feature-item:hover {transform:translateY(-3px); box-shadow:0 6px 15px rgba(0, 0, 0, 0.1);}
.feature-item i {font-size:clamp(20px, 3vw, 24px); color:var(--primary-green);}
.feature-item h3 {font-size:clamp(12px, 2vw, 14px); color:var(--primary-black); text-align:center; line-height:1.3;}

/* Testimonials Section */
.testimonials-section {background-color:var(--primary-white); padding:clamp(40px, 8vw, 80px) 0; width:100%;}
.testimonials-grid {display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:clamp(20px, 4vw, 30px); max-width:1200px; margin:0 auto; padding:0 20px;}
.testimonial-card {background-color:var(--light-gray); padding:clamp(25px, 4vw, 30px); border-radius:8px; box-shadow:0 5px 15px rgba(0, 0, 0, 0.05); transition:transform 0.3s ease, box-shadow 0.3s ease; display:flex; flex-direction:column;}
.testimonial-card:hover {transform:translateY(-5px); box-shadow:0 8px 20px rgba(0, 0, 0, 0.1);}
.testimonial-header {display:flex; align-items:center; gap:15px; margin-bottom:15px;}
.testimonial-avatar {width:50px; height:50px; border-radius:50%; object-fit:cover; flex-shrink:0;}
.testimonial-author-info {display:flex; flex-direction:column; flex-grow:1;}
.testimonial-author-info h3 {font-size:clamp(16px, 2.5vw, 18px); font-weight:700; color:var(--primary-black); margin:0 0 5px 0; line-height:1.2;}
.testimonial-source {display:flex; align-items:center; gap:8px; font-size:14px; color:#000000;}
.google-logo-icon {color:#1657c0; font-size:18px; display:inline-flex; align-items:center;}
.testimonial-rating {margin-bottom:15px; color:#ffc107; font-size:16px; display:flex; align-items:center; gap:5px;}
.testimonial-text {font-size:clamp(14px, 2vw, 16px); color:rgb(0, 0, 0); line-height:1.6; margin:0; flex-grow:1;}

/* Service Areas with Map Section */
.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); text-transform:uppercase; margin-bottom:clamp(20px, 4vw, 30px);}
.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;}
.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;}

/* Footer */
footer {background-color:var(--primary-black); color:var(--primary-white); padding:clamp(40px, 8vw, 60px) 0 20px; width:100%;}
.footer-logo-section {text-align:center; margin-bottom:clamp(30px, 6vw, 40px); padding:0 20px;}
.footer-logo {max-width:clamp(250px, 30vw, 400px); 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);}
.footer-section ul li {margin-bottom:8px;}
.column ul {display:flex; flex-wrap:wrap;}
.column ul li {width:48%; margin:0 1% 8px;}
.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);}
.visually-hidden {position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;}
.footer-copyright {width: 100%; padding: 25px 0 15px 0; margin-top: 30px; border-top: 1px solid #333; text-align: center; font-size: 14px; color: #999;}
.footer-copyright p {margin: 0; padding: 0; line-height: 1.5;}

/* Responsive y Breakpoints */
@media (min-width: 1201px) and (max-width: 1330px) {
  .location-switcher a,
  .location-switcher i {font-size: 16px;}
}

@media (max-width:1200px) {.header-right {gap:10px;}
 .find-us,
 .google-reviews,
 .phone-button {padding:6px 12px; font-size:13px;}
}

@media (min-width:1151px) and (max-width:1156px) {.desktop-nav a {font-size:12px;}}
@media (min-width: 1151px) {.location-switcher {display: flex;}}
@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;}
 .service-areas-content {grid-template-columns:1fr; gap:30px;}
 .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;}
}

@media (min-width: 992px) and (max-width: 1200px) {
  .location-switcher a,
  .location-switcher i {font-size: 14px;}
}

@media (min-width: 992px) and (max-width: 1150px) {.location-switcher {display: flex; }
.mobile-menu-phone-container {margin-left: 0 !important;}}

@media (max-width: 991px) {.top-header {flex-wrap: wrap; min-height: 0;}
 .location-switcher {display: flex; flex-basis: 100%; order: 3; justify-content: center; background-color: var(--primary-black); padding: 8px 15px; border-top: 1px solid #111; }
 .hero {margin-top: 0;}}

@media (max-width:768px) {.container {padding:0 15px;}
 .mobile-phone-button {font-size:11px; padding:5px 10px;}
 .logos-container {margin:0 clamp(40px, 6vw, 50px);}
 .prev-logos,
 .next-logos,
 .logos-track {gap:clamp(10px, 2vw, 20px);}
 .logo-item {width:clamp(75px, 11vw, 115px); height:clamp(65px, 10vw, 105px); padding:5px;}
 .hero-dots {display:none;}
 .footer-section.column ul li {width:100%; margin:0 0 8px;}
 .videos-grid {grid-template-columns:1fr; gap:20px;}
 .areas-horizontal-list {flex-direction:column; align-items:flex-start; gap:10px;}
 .map-container-large {height:clamp(250px, 35vw, 350px);}
 .tips-carousel {margin:0 clamp(40px, 6vw, 50px);}
 .form-wrapper,
 .form-wrapper iframe {min-height:960px;}
}

@media (max-width:576px) {.container {padding:0 10px;}
 .carousel-arrow {width:35px; height:35px; font-size:14px;}
 .logos-container,
 .tips-carousel {margin:0 40px;}
 .logos-track {gap:clamp(6px, 1vw, 12px);}
 .logo-item {width:clamp(65px, 9vw, 85px); height:clamp(50px, 8vw, 70px); padding:3px;}
 .prev-logos,
 .next-logos,
 .mobile-phone-button {font-size:10px; padding:4px 8px;}
 .hero {padding:30px 15px;}
 .hero h1 {font-size:clamp(20px, 5vw, 24px);}
 .hero p {font-size:clamp(14px, 3vw, 16px);}
 .cta-button {padding:10px 20px; font-size:13px;}
 .section-header h2 {font-size:clamp(20px, 5vw, 24px);}
 .areas-horizontal-list {gap:5px;}
 .map-container-large {height:clamp(180px, 25vw, 250px);}
 .footer-content {grid-template-columns:1fr;}
 .footer-section.column ul {display:grid; grid-template-columns:1fr 1fr; gap:8px;}
 .footer-section.column ul li {width:100%; margin:0;}
 .form-wrapper,
 .form-wrapper iframe {min-height:1050px;}
 .location-switcher a,
 .location-switcher i {font-size: 16px;}
}

@media (max-width:480px) {.core-services-grid,
 .other-services-grid,
 .family-benefits-grid,
 .accreditation-features,
 .videos-grid {grid-template-columns:1fr; gap:20px;}
 .family-benefit-item {flex-direction:row; align-items:flex-start; text-align:left;}
 .logos-track {gap:clamp(5px, 0.8vw, 10px);}
 .logo-item {width:clamp(55px, 8vw, 70px); height:clamp(45px, 7vw, 60px); padding:2px;}
 .areas-horizontal-list {align-items:flex-start;}
 .footer-section.column ul {grid-template-columns:1fr;}
 .map-container-large {height:clamp(150px, 20vw, 200px);}
 .location-switcher a,
 .location-switcher i {font-size: 13px;}
}

@media (max-width:360px) {h1, h2, h3, h4, p, a {word-wrap:break-word; overflow-wrap:break-word; hyphens:auto;}
 .container {padding:0 10px;}
 section {padding:30px 0;}
 .hero {padding:30px 10px; width:100%; overflow:hidden;}
 .hero h1 {font-size:20px; line-height:1.3;}
 .core-service-item,
 .testimonial-card,
 .feature-item,
 .family-benefit-item,
 .footer-logo-section {padding:15px 10px !important;}
 .footer-logo {max-width:200px !important; width:100%; height:auto;}
 .location-switcher {padding:5px 10px; width:100%; box-sizing:border-box;}
 .location-switcher a {font-size:12px; white-space:normal; text-align:center; line-height:1.4; display:block;}
 .core-services-grid, 
 .other-services-grid, 
 .family-benefits-grid, 
 .accreditation-features, 
 .testimonials-grid, 
 .videos-grid, 
 .footer-content {display:flex !important; flex-direction:column !important; width:100% !important; padding:0 !important; gap:15px; margin:0 !important;}
 .family-benefit-item, 
 .core-service-item {width:100% !important; box-sizing:border-box; margin:0 !important; flex-direction:column; align-items:center; text-align:center;}
 .benefit-icon {margin-bottom:10px;}
 .cta-button {font-size:12px; padding:10px 15px; width:100%; box-sizing:border-box;}
 .mobile-phone-button {font-size:9px; padding:3px 6px;}
 .mobile-menu-btn {padding:8px;}
 .logos-container {margin:0 10px;}
 .logos-track {gap:5px;}
 .logo-item {width:60px; height:50px; padding:2px;}
 .map-container-large, 
 .map-container iframe {height:180px; width:100% !important;}
}

@media (max-width:300px) {.container {padding:0 5px !important;}
 .logo-container {padding:5px !important;}
 .logo {max-width:110px !important;}
 .mobile-menu-phone-container {padding:0 2px !important; gap:5px !important;}
 .mobile-phone-button {font-size:9px !important; padding:4px 6px !important;}
 .mobile-menu-btn {padding:5px !important; font-size:20px !important;}
 h1, h2, h3, h4, p, a, span {word-wrap:break-word; overflow-wrap:break-word; hyphens:auto;}
 .hero h1 {font-size:20px !important;}
 .location-switcher {padding:5px !important;}
 .location-switcher a {font-size:10px !important; display:block; text-align:center;}
 .core-service-item, .other-service-item, .family-benefit-item, 
 .feature-item, .video-card, .tip-card {padding:15px 5px !important;}
 .footer-logo {max-width:180px;}
 .map-container, .map-container iframe {height:180px; width:100% !important;}
}