 /**
 * Footer Styles - All Variations
 * 
 * Style 1: Info Blocks Columns (Silent Escapes / Seren Sarasota)
 * Style 2: Columns with Dividers (McGuire Digital)
 * Style 3: Dark with Wave Graphic (North Pier)
 * Style 4: Light Minimal with Logo Top (The Gaspar)
 * 
 * Each style is scoped with .footer-style-N to avoid conflicts
 */

/* ==========================================================
   BASE FOOTER LAYOUT
   Structural foundation used by all footer styles.
   Colors will be converted to var(--custom-properties) in
   the CSS custom properties pass.
   ========================================================== */
footer {
  background: var(--color-footer-bg);
}
footer .row {
  padding: 0 10px;
}
footer .footer-info {
  margin-bottom: 80px;
  max-width: 600px;
  color: #5d5f5f;
}
@media (max-width: 1024px) {
  footer .footer-info {
    margin-bottom: 50px;
  }
}
@media (max-width: 768px) {
  footer .footer-info {
    margin-bottom: 40px;
  }
}
@media (max-width: 480px) {
  footer .footer-info {
    margin-bottom: 30px;
  }
}
footer .footer-info h1, footer .footer-info h2, footer .footer-info h3, footer .footer-info h4, footer .footer-info h5, footer .footer-info h6, footer .footer-info p {
  color: #5d5f5f;
}
footer .footer-info *:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
}
footer .logo-footer-box {
  margin-bottom: 50px;
}
@media (max-width: 1024px) {
  footer .logo-footer-box {
    margin-bottom: 50px;
  }
}
@media (max-width: 768px) {
  footer .logo-footer-box {
    margin-bottom: 30px;
    text-align: center;
  }
}
@media (max-width: 480px) {
  footer .logo-footer-box {
    margin-bottom: 20px;
  }
}
footer .logo-footer {
  width: 222px;
  height: 133px;
  transition: all 0.3s ease;
  display: inline-block;
}
footer .logo-footer img {
  width: 100%;
}
footer .logo-footer:hover {
  opacity: 0.7;
}
@media (max-width: 768px) {
  footer .footer-menu-box {
    flex-basis: 100%;
    margin-bottom: 30px;
  }
}
@media (max-width: 768px) {
  footer .footer-menu {
    margin-bottom: 25px;
    flex-basis: 100%;
    text-align: center;
  }
}
footer .footer-menu nav {
  padding-right: 50px;
  margin-right: 50px;
  border-right: 1px solid #070606;
}
@media (max-width: 1240px) {
  footer .footer-menu nav {
    padding-right: 40px;
    margin-right: 40px;
  }
}
@media (max-width: 1024px) {
  footer .footer-menu nav {
    padding-right: 30px;
    margin-right: 30px;
  }
}
@media (max-width: 768px) {
  footer .footer-menu nav {
    margin: 0 auto 15px;
    padding: 0;
    border: none;
    flex-basis: 100%;
  }
}
footer .footer-menu nav ul li {
  margin-bottom: 15px;
  line-height: .65;
}
footer .footer-menu nav ul li:last-child {
  margin-bottom: 0;
}
footer .footer-menu nav ul > li > a {
  display: inline-block;
  color: #070606;
  letter-spacing: 1.2px;
  font-family: var(--font-heading);
  font-size: 13px;
  line-height: 1.2;
  font-weight: 400;
  text-transform: uppercase;
  position: relative;
  transition: all 0.3s ease;
}
footer .footer-menu nav ul > li > a:before {
  bottom: 0;
  left: 0;
  content: "";
  position: absolute;
  height: 1px;
  width: 0;
  background: #070606;
  transition: all 0.3s ease;
}
footer .footer-menu nav ul > li > a:hover:before {
  width: 100%;
}
footer .copyright-box {
  text-align: center;
  font-family: var(--font-heading);
  font-weight: 300;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
footer .footer-bottom-box {
  margin-bottom: 100px;
}
@media (max-width: 1024px) {
  footer .footer-bottom-box {
    margin-bottom: 50px;
  }
}
@media (max-width: 768px) {
  footer .footer-bottom-box {
    margin-bottom: 40px;
  }
}
@media (max-width: 480px) {
  footer .footer-bottom-box {
    margin-bottom: 30px;
  }
}
footer .footer-contact {
  padding-right: 50px;
  margin-right: 50px;
  border-right: 1px solid #070606;
}
@media (max-width: 1240px) {
  footer .footer-contact {
    padding-right: 40px;
    margin-right: 40px;
  }
}
@media (max-width: 1024px) {
  footer .footer-contact {
    padding-right: 30px;
    margin-right: 30px;
  }
}
@media (max-width: 768px) {
  footer .footer-contact {
    padding: 0;
    margin: 0 auto 20px;
    border: 0;
    text-align: center;
    flex-basis: 100%;
  }
}
footer .footer-contact p {
  padding-bottom: 0;
  margin-bottom: 14px;
  line-height: 1.1;
  font-size: 14px;
  font-family: var(--font-heading);
  font-weight: 400;
  letter-spacing: 0.6px;
}
footer .footer-contact a {
  position: relative;
  color: #070606;
  letter-spacing: 1.2px;
  font-family: var(--font-heading);
  font-size: 14px;
  line-height: 1.2;
  font-weight: 400;
  padding-bottom: 2px;
  display: inline-block;
  transition: all 0.3s ease;
}
footer .footer-contact a:before {
  bottom: 0;
  left: 0;
  content: "";
  position: absolute;
  height: 1px;
  width: 0;
  background: #070606;
  transition: all 0.3s ease;
}
footer .footer-contact a:hover:before {
  width: 100%;
}
footer .footer-contact *:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
}
@media (max-width: 768px) {
  footer .soc-items {
    justify-content: center;
    flex-basis: 100%;
  }
}
footer .soc-items a {
  font-size: 28px;
  color: #514a4e;
  margin-left: 18px;
  transition: all 0.3s ease;
}
@media (max-width: 768px) {
  footer .soc-items a {
    margin: 0 0px;
  }
}
footer .soc-items a:hover {
  color: #000;
}
@media (max-width: 768px) {
  footer .footer-contact-box {
    flex-basis: 100%;
  }
}
footer .btn {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 2px;
  border: 1px solid #070606;
  color: #070606;
  line-height: 1;
  background: transparent;
  border-radius: 0;
  padding: 12px 22px;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  footer .btn {
    margin: 0 auto;
  }
}
footer .btn:hover {
  border: 1px solid #fff;
  color: #fff;
}

/**
 * Footer Style 1 - Info Blocks Columns (Seren Sarasota)
 * SVG background with white text
 */

/* Scoped to .footer-style-1 to avoid conflicts with other footer styles */

.footer-style-1 footer {
  background-image: url('https://serensarasota.wpenginepowered.com/wp-content/uploads/2026/01/Seren-Background-1.svg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
}

/* All text white */
.footer-style-1 footer,
.footer-style-1 footer p,
.footer-style-1 footer span,
.footer-style-1 footer li,
.footer-style-1 footer address {
  color: #ffffff;
}

/* Links white with hover state */
.footer-style-1 footer a {
  color: #ffffff;
  transition: opacity 0.3s ease;
}

.footer-style-1 footer a:hover {
  color: #ffffff;
  opacity: 0.7;
}

/* Footer info section */
.footer-style-1 .footer-info,
.footer-style-1 .footer-info p {
  color: #ffffff;
}

/* Navigation menus */
.footer-style-1 .footer-menu nav ul li a {
  color: #ffffff;
}

.footer-style-1 .footer-menu nav ul li a:hover {
  color: #ffffff;
  opacity: 0.7;
}

/* Footer contact */
.footer-style-1 .footer-contact,
.footer-style-1 .footer-contact p,
.footer-style-1 .footer-contact a {
  color: #ffffff;
}

/* Social icons */
.footer-style-1 .soc-items a {
  color: #ffffff;
}

.footer-style-1 .soc-items a:hover {
  color: #ffffff;
  opacity: 0.7;
}

/* Copyright */
.footer-style-1 .copyright-box,
.footer-style-1 .copyright-box p,
.footer-style-1 .copyright-box span,
.footer-style-1 .copyright-box a {
    color: #ffffff;
    font-family: var(--font-heading);
    font-size: 10px;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 1px;
    padding-bottom: 15px;
    padding-top: 5px;
}

/* Logo left-aligned with nav - DESKTOP */
.footer-style-1 .logo-footer-box {
  text-align: left !important;
  margin-bottom: 0 !important;
  display: flex !important;
  align-items: center !important;
}

/* Enlarge Seren logo by 15% */
.footer-style-1 .logo-footer {
  width: 210px !important;
  height: auto !important;
}

.footer-style-1 .logo-footer img {
  width: 100% !important;
  height: auto !important;
}

/* Footer Logos Top - Seren logo left, PTM logo right - DESKTOP */
.footer-style-1 .footer-logos-top {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  width: 100% !important;
  margin-bottom: 70px !important;
}

/* PTM Partners Logo - top right - BIGGER SIZE */
.footer-style-1 .ptm-logo-box {
  text-align: right !important;
  display: block !important;
  margin-top: -5px !important;
}

.footer-style-1 .ptm-logo {
  width: 184px !important;
  height: auto !important;
}

.footer-style-1 .ptm-logo-link:hover {
  opacity: 0.7;
}

/* Copyright Row - Partner logos + Copyright on same line */
.footer-style-1 .copyright-row {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  width: 100% !important;
  margin-top: 60px !important;
  padding-bottom: 25px !important;
}

/* Left partner logos group - Strang + Kimsey together */
.footer-style-1 .partner-logos-left {
  display: flex !important;
  align-items: center !important;
  gap: 30px !important;
  flex-shrink: 0 !important;
  margin-top: -20px !important;
}

/* Right partner logos group */
.footer-style-1 .partner-logos-right {
  display: flex !important;
  align-items: center !important;
  gap: 30px !important;
  flex-shrink: 0 !important;
  margin-top: -24px !important;
}

/* Copyright in center - takes remaining space */
.footer-style-1 .copyright-row .copyright-box {
  flex-grow: 1 !important;
  text-align: center !important;
  padding-bottom: 0 !important;
  margin: 0 !important;
}

/* Partner Logos - VISIBLE with proper sizing */
.footer-style-1 .partner-logo {
  display: block !important;
  flex-shrink: 0 !important;
}

.footer-style-1 .partner-logo a {
  display: block !important;
}

.footer-style-1 .partner-logo img {
  display: block !important;
  width: auto !important;
  opacity: 1 !important;
  transition: opacity 0.3s ease !important;
}

.footer-style-1 .partner-logo a:hover img {
  opacity: 0.7 !important;
}

/* Strang Design - smaller */
.footer-style-1 .partner-logo-strang img {
  height: 10px !important;
  min-height: 10px !important;
}

/* Kellogg & Kimsey - smaller */
.footer-style-1 .partner-logo-kimsey img {
  height: 11px !important;
  min-height: 11px !important;
}

/* Robbins - larger */
.footer-style-1 .partner-logo-robbins img {
  height: 18px !important;
  min-height: 18px !important;
}

/* RangeWater */
.footer-style-1 .partner-logo-rangewater img {
  height: 32px !important;
  min-height: 18px !important;
}

/* Vertical divider rules - white - DESKTOP */
.footer-style-1 footer .footer-menu nav {
  border-right: 1px solid #ffffff;
}

/* Override 01-base.css ul margin that causes left offset */
.footer-style-1 ul,
.footer-style-1 ol,
.footer-style-1 footer ul,
.footer-style-1 footer ol {
  margin: 0 !important;
  margin-left: 0 !important;
  padding: 0 !important;
}

.footer-style-1 footer .footer-contact {
  border-right: 1px solid #ffffff;
}

/* Link underline hover effect - white */
.footer-style-1 footer .footer-menu nav ul > li > a:before,
.footer-style-1 footer .footer-contact a:before {
  background: #ffffff;
}

/* Button styling for dark background */
.footer-style-1 footer .btn {
  color: #ffffff;
  border-color: #ffffff;
  font-weight: 400;
  padding: 8px 20px;
}

.footer-style-1 footer .btn:hover {
  background-color: #ffffff;
  color: var(--color-primary);
}

/* Footer bottom box - reduce bottom margin for Style 1 */
.footer-style-1 .footer-bottom-box {
  margin-bottom: 60px !important;
}

/* Copyright row stacks earlier due to partner logos width */
@media (max-width: 1150px) {
  .footer-style-1 .copyright-row {
    flex-direction: column !important;
    align-items: center !important;
    gap: 9px !important;
    margin-top: 30px !important;
    padding-bottom: 20px !important;
  }

  .footer-style-1 .partner-logos-left {
    flex-direction: row !important;
    justify-content: center !important;
    margin-top: 0 !important;
  }

  .footer-style-1 .partner-logos-right {
    justify-content: center !important;
    margin-top: 0 !important;
  }

  .footer-style-1 .copyright-row .copyright-box {
    order: 3 !important;
    margin-top: 10px !important;
  }

  .footer-style-1 .partner-logos-left {
    order: 1 !important;
  }

  .footer-style-1 .partner-logos-right {
    order: 2 !important;
  }
}

/* ==========================================================================
   TABLET AND MOBILE - 1000px and below
   Must come AFTER desktop rules to properly override
   Matches navigation breakpoint
   ========================================================================== */
@media (max-width: 1000px) {
  /* Make row a flex column to control order */
  .footer-style-1 footer > .row {
    display: flex !important;
    flex-direction: column !important;
  }
  
  /* Footer Logos Top - stack vertically on mobile */
  .footer-style-1 .footer-logos-top {
    flex-direction: column !important;
    align-items: center !important;
    order: 1 !important;
    margin-bottom: 20px !important;
  }
  
  /* Logo centered with no padding */
  .footer-style-1 .logo-footer-box {
    text-align: center !important;
    padding-left: 0 !important;
    margin-bottom: 20px !important;
    justify-content: center !important;
  }
  
  /* PTM Logo - 20% larger on mobile, centered below Seren logo */
  .footer-style-1 .ptm-logo-box {
    text-align: center !important;
    display: block !important;
    margin-bottom: 20px !important;
    margin-top: 0 !important;
  }
  
  .footer-style-1 .ptm-logo {
    width: 144px !important;
  }
  
  /* Copyright row - partner logos stacked, disclaimer at bottom */
  .footer-style-1 .copyright-row {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 9px !important;
    margin-top: 5px !important;
    margin-bottom: 0 !important;
    order: 5 !important;
    padding-bottom: 20px !important;
  }
  
  /* Partner logos left - Strang & Kimsey STACKED vertically */
  .footer-style-1 .partner-logos-left {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 18px !important;
    order: 1 !important;
    margin-top: 0 !important;
  }
  
  /* Partner logos right (RangeWater + Robbins) - stacked like left */
  .footer-style-1 .partner-logos-right {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 18px !important;
    order: 2 !important;
    margin-top: 8px !important;
  }
  
  /* Copyright/Disclaimer - move to bottom of copyright row */
  .footer-style-1 .copyright-row .copyright-box {
    order: 3 !important;
    flex-basis: 100% !important;
    text-align: center !important;
    margin-top: 15px !important;
    margin-bottom: 0 !important;
  }
  
  /* Partner logo sizing on mobile - SMALLER */
  .footer-style-1 .partner-logo-strang img {
    height: 9px !important;
    min-height: 9px !important;
  }
  
  .footer-style-1 .partner-logo-kimsey img {
    height: 10px !important;
    min-height: 10px !important;
  }
  
  .footer-style-1 .partner-logo-robbins img {
    height: 17px !important;
    min-height: 14px !important;
  }

  .footer-style-1 .partner-logo-rangewater img {
    height: 32px !important;
    min-height: 26px !important;
  }
  
  /* Footer info */
  .footer-style-1 .footer-info {
    order: 3 !important;
  }
  
  /* Footer bottom box - contains nav and contact */
  .footer-style-1 .footer-bottom-box {
    order: 4 !important;
    margin-bottom: 20px !important;
    flex-direction: column !important;
    align-items: center !important;
  }
  
  /* HIDE vertical divider rules completely */
  .footer-style-1 footer .footer-menu nav {
    border: none !important;
    border-right: none !important;
    padding-right: 0 !important;
    margin-right: 0 !important;
    margin-left: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
  }
  
  .footer-style-1 footer .footer-contact {
    border: none !important;
    border-right: none !important;
    padding-right: 0 !important;
    margin-right: 0 !important;
  }
  
  /* Remove gap between the two nav groups - stack as one continuous list */
  .footer-style-1 footer .footer-menu {
    display: block !important;
    text-align: center !important;
    margin-bottom: 0 !important;
  }
  
  .footer-style-1 footer .footer-menu nav {
    display: block !important;
    width: 100% !important;
    flex-basis: 100% !important;
  }
  
  .footer-style-1 footer .footer-menu nav ul {
    text-align: center !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  
  .footer-style-1 footer .footer-menu nav ul li {
    margin-bottom: 12px !important;
    text-align: center !important;
  }
  
  /* Keep consistent spacing even on last items */
  .footer-style-1 footer .footer-menu nav:first-child ul li:last-child {
    margin-bottom: 12px !important;
  }
  
  .footer-style-1 footer .footer-menu nav:last-child ul li:last-child {
    margin-bottom: 0 !important;
  }
  
  .footer-style-1 footer .footer-menu-box {
    display: block !important;
    text-align: center !important;
    margin-bottom: 0 !important;
    width: 100% !important;
  }
  
  /* INQUIRE button */
  .footer-style-1 footer .footer-menu-box .btn {
    display: inline-block !important;
    margin: 30px auto 0 !important;
    width: auto !important;
    min-width: 100px !important;
    padding: 13px 36px !important;
  }
  
  /* Contact box */
  .footer-style-1 footer .footer-contact-box {
    display: block !important;
    text-align: center !important;
    margin-top: 25px !important;
    width: 100% !important;
  }
  
  .footer-style-1 footer .footer-contact {
    text-align: center !important;
    margin: 0 auto 15px !important;
    padding: 0 !important;
  }
  
  /* Social icons */
  .footer-style-1 footer .soc-items {
    justify-content: center !important;
    margin-top: 15px !important;
  }
  
  .footer-style-1 footer .soc-items a {
    margin-left: 0 !important;
  }
  
  /* Bottom padding on footer */
  .footer-style-1 footer {
    padding-top: 45px !important;
    padding-bottom: 20px !important;
  }


/**
 * Footer Style 2 - Columns with Dividers (McGuire Digital)
 * EXACT original CSS - do not modify
 */

/* Scoped to .footer-style-2 to avoid conflicts with other footer styles */

@media (max-width: 1024px) {
  .footer-style-2 footer {
    text-align: center;
  }
}
.footer-style-2 footer .copyright {
  background: var(--color-footer-bg);
  padding: 15px 0;
  text-align: center;
}
.footer-style-2 footer .copyright span {
  font-family: "Poppins", sans-serif;
  color: #202020;
  font-size: 12px;
  letter-spacing: .25px;
  font-weight: 300;
}
.footer-style-2 footer .copyright p,
.footer-style-2 footer .copyright span p {
  font-family: "Poppins", sans-serif !important;
  color: #202020 !important;
  font-size: 12px !important;
  font-weight: 300 !important;
  margin: 0 !important;
  padding: 0 !important;
  letter-spacing: .25px !important;
  line-height: 1.4 !important;
}
.footer-style-2 footer > .row1375 {
  width: 1920px;
  max-width: 100%;
  padding: 30px 0;
}
@media (max-width: 767px) {
  .footer-style-2 footer > .row1375 {
    padding: 0 0 30px;
  }
}
.footer-style-2 footer > .row1375 > .flex {
  flex-basis: 25%;
  position: relative;
  padding: 20px;
}
@media (max-width: 1024px) {
  .footer-style-2 footer > .row1375 > .flex {
    flex-basis: 100%;
    padding: 0 20px 0;
  }
}
.footer-style-2 footer > .row1375 > .flex:before {
  content: "";
  width: 1px;
  height: 100%;
  background: #4a4a4a;
  position: absolute;
  top: 0;
  right: 0;
}
@media (max-width: 1024px) {
  .footer-style-2 footer > .row1375 > .flex:before {
    display: none;
  }
}
.footer-style-2 footer > .row1375 > .flex:last-child::before {
  display: none;
}
@media (max-width: 1024px) {
  .footer-style-2 footer > .row1375 .brochure {
    padding: 0 65px 30px;
  }
}
@media (max-width: 1024px) {
  .footer-style-2 footer .main_nav_wrap {
    margin: 10px 0 20px;
  }
}
.footer-style-2 footer .main_nav_wrap .main_nav {
  margin: 0;
  padding: 0 0 0 40px;
}
@media (max-width: 1024px) {
  .footer-style-2 footer .main_nav_wrap .main_nav {
    padding: 0 0 0 0;
  }
}
.footer-style-2 footer .main_nav_wrap .main_nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-style-2 footer .main_nav_wrap .main_nav ul li {
  display: block;
  text-align: left;
  margin: 0;
}
.footer-style-2 footer .main_nav_wrap .main_nav ul li a {
  padding: 5px 0;
  display: block;
  color: #102342;
  font-family: "Poppins", sans-serif;
  font-size: 14px;
  text-decoration: none;
}
@media (max-width: 1024px) {
  .footer-style-2 footer .main_nav_wrap .main_nav ul li a {
    text-align: center;
    display: block;
    font-size: 14px;
  }
}
.footer-style-2 footer .address-footer {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
}
.footer-style-2 footer .address-footer > div {
  margin-bottom: 10px;
  width: 100%;
}
@media (max-width: 1024px) {
  .footer-style-2 footer .address-footer > div {
    margin-bottom: 20px;
  }
}
.footer-style-2 footer .address-footer > div p {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-size: 10px;
  line-height: 1.3;
  padding-bottom: 0;
  color: #102342;
  margin: 0;
}
@media (max-width: 1024px) {
  .footer-style-2 footer .address-footer > div p {
    font-size: 12px;
  }
}
.footer-style-2 footer .address-footer > div p a {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-size: 12px;
  line-height: 1.5;
  padding-bottom: 0;
  color: #102342;
  text-decoration: none;
}
.footer-style-2 footer .address-footer > div p a:hover {
  color: #4a4a4a;
}
.footer-style-2 footer .brochure {
  display: flex;
  align-items: center;
}
.footer-style-2 footer .brochure img {
  padding: 0 20px;
  max-width: 80px;
}
@media (max-width: 1024px) {
  .footer-style-2 footer .brochure img {
    padding: 0 0;
  }
}
.footer-style-2 footer .footer-title {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 15px;
  color: #4a4a4a;
  display: block;
  margin-bottom: 10px;
}
.footer-style-2 .social-icons {
  cursor: pointer;
  display: inline-block;
  font-size: 0;
  text-align: center;
}
@media (max-width: 1024px) {
  .footer-style-2 .social-icons {
    width: 100%;
  }
}
.footer-style-2 .social-icons a {
  display: inline-block;
  position: relative;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
  font-size: 20px;
  margin: 0 10px;
  width: 20px;
  height: 20px;
  background: transparent;
  border-radius: 5px;
  color: #102342;
}
.footer-style-2 .social-icons a:first-child {
  margin-left: 0;
}
.footer-style-2 .social-icons a:last-child {
  margin-right: 0;
}
.footer-style-2 .social-icons a i {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  color: #fff;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.footer-style-2 .social-icons a:hover {
  color: #4a4a4a;
}
.footer-style-2 .social-icons a:hover i {
  color: #4a4a4a;
}

/**
 * Footer Style 3 - Dark with Wave Graphic (North Pier Ocean Villas)
 * EXACT CSS from Customizer with !important for master theme overrides
 */

/* Scoped to .footer-style-3 to avoid conflicts with other footer styles */

/* Wave Logo positioning */
.footer-style-3 .wave-logo3 {
  width: 200px;
  position: absolute;
  right: 19%;
  bottom: 170px;
}

@media (max-width: 1800px) {
  .footer-style-3 .wave-logo3 {
    width: 200px;
    right: 19%;
    bottom: 160px;
  }
}

@media (max-width: 1600px) {
  .footer-style-3 .wave-logo3 {
    width: 190px;
    right: 16%;
    bottom: 130px;
  }
}

@media (max-width: 1400px) {
  .footer-style-3 .wave-logo3 {
    width: 180px;
    right: 13%;
    bottom: 120px;
  }
}

@media (max-width: 1230px) {
  .footer-style-3 .wave-logo3 {
    width: 170px;
    right: 10%;
    bottom: 100px;
  }
}

@media (max-width: 1030px) {
  .footer-style-3 .wave-logo3 {
    width: 160px;
    right: 7%;
    bottom: 50px;
  }
}

@media (max-width: 900px) {
  .footer-style-3 .wave-logo3 {
    width: 150px;
    right: 6%;
    bottom: 50px;
  }
}

@media (max-width: 767px) {
  .footer-style-3 .wave-logo3 {
    width: 140px;
    right: 5%;
    bottom: 50px;
  }
}

@media (max-width: 575px) {
  .footer-style-3 .wave-logo3 {
    width: 130px;
    right: 4%;
    bottom: 40px;
  }
}

@media (max-width: 455px) {
  .footer-style-3 .wave-logo3 {
    width: 120px;
    right: 3%;
    bottom: 40px;
  }
}

@media (max-width: 370px) {
  .footer-style-3 .wave-logo3 {
    width: 110px;
    right: 2%;
    bottom: 30px;
  }
}

/* Burger icon */
.footer-style-3 .burger-icon img {
  width: 24px;
  height: auto;
  display: block;
}

/* Footer base - CRITICAL OVERRIDES */
.footer-style-3 footer {
  padding: 5px 0 40px !important;
  background-image: url("/wp-content/uploads/2025/04/Paper-Background.jpg") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  background-color: #2d2d2d !important;
}

/* Subfooter */
.footer-style-3 .subfooter {
  background-image: url("/wp-content/uploads/2025/04/Paper-Background.jpg") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  padding-top: 20px;
  padding-bottom: 20px;
}

.footer-style-3 .subfooter .row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

@media (max-width: 767px) {
  .footer-style-3 .subfooter .row {
    flex-direction: column;
    text-align: center;
  }
}

.footer-style-3 .subfooter-logo {
  max-width: 150px;
}

@media (max-width: 767px) {
  .footer-style-3 .subfooter-logo {
    margin-bottom: 20px;
  }
}

.footer-style-3 .subfooter-text {
  flex: 1;
  padding: 0 30px;
}

@media (max-width: 767px) {
  .footer-style-3 .subfooter-text {
    padding: 0;
    margin-bottom: 20px;
  }
}

.footer-style-3 .subfooter-text p {
  color: #fff !important;
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
}

/* Footer row */
.footer-style-3 footer > .row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
}

@media (max-width: 767px) {
  .footer-style-3 footer > .row {
    flex-direction: column;
    text-align: center;
  }
}

/* Footer columns */
.footer-style-3 .footer-col {
  flex: 1;
  padding: 20px;
  min-width: 200px;
}

@media (max-width: 767px) {
  .footer-style-3 .footer-col {
    flex: 100%;
    padding: 15px 20px;
  }
}

/* Footer headings */
.footer-style-3 .footer-heading {
  color: #fff !important;
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 15px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Footer links */
.footer-style-3 footer a {
  color: #fff !important;
  text-decoration: none;
  transition: opacity 0.3s ease;
}

.footer-style-3 footer a:hover {
  opacity: 0.7;
}

/* Footer nav */
.footer-style-3 footer nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer-style-3 footer nav ul li {
  margin-bottom: 8px;
}

.footer-style-3 footer nav ul li a {
  color: #fff !important;
  font-size: 14px;
}

/* Footer contact info */
.footer-style-3 .footer-contact p {
  color: #fff !important;
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 10px;
}

.footer-style-3 .footer-contact a {
  color: #fff !important;
}

/* Social icons */
.footer-style-3 .soc-items {
  display: flex;
  gap: 15px;
}

@media (max-width: 767px) {
  .footer-style-3 .soc-items {
    justify-content: center;
  }
}

.footer-style-3 .soc-items a {
  color: #fff !important;
  font-size: 20px;
}

/* Copyright */
.footer-style-3 .copyright-box {
  width: 100%;
  text-align: center;
  padding-top: 20px;
  margin-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.2);
}

.footer-style-3 .copyright-box p {
  color: #fff !important;
  font-size: 12px;
  margin: 0;
}


/**
 * Footer Style 4 - Light Minimal with Logo Top (The Gaspar)
 * EXACT original CSS - do not modify
 */

/* Scoped to .footer-style-4 to avoid conflicts with other footer styles */

.footer-style-4 footer {
  background-color: #f5f5f0;
  padding: 60px 0 40px;
}

@media (max-width: 1024px) {
  .footer-style-4 footer {
    padding: 40px 0 30px;
  }
}

.footer-style-4 footer .row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
}

@media (max-width: 1024px) {
  .footer-style-4 footer .row {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
}

.footer-style-4 footer .logo-footer-box {
  flex-basis: 100%;
  text-align: center;
  margin-bottom: 40px;
}

.footer-style-4 footer .logo-footer img {
  max-width: 200px;
  height: auto;
}

@media (max-width: 768px) {
  .footer-style-4 footer .logo-footer img {
    max-width: 150px;
  }
}

.footer-style-4 footer .footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 30px;
}

@media (max-width: 1024px) {
  .footer-style-4 footer .footer-links {
    flex-direction: column;
  }
}

.footer-style-4 footer .footer-links-1 {
  border-right: 1px solid rgba(0,0,0,0.2);
  padding-right: 40px;
  margin-right: 40px;
}

@media (max-width: 1600px) {
  .footer-style-4 footer .footer-links-1 {
    padding-right: 30px;
    margin-right: 30px;
  }
}

@media (max-width: 1024px) {
  .footer-style-4 footer .footer-links-1 {
    padding-right: 0px;
    margin-right: 0px;
    border: none;
  }
}
.footer-style-4 footer .footer-links-2 {
  border-right: 1px solid rgba(0,0,0,0.2);
  padding-right: 40px;
  margin-right: 40px;
}
@media (max-width: 1600px) {
  .footer-style-4 footer .footer-links-2 {
    margin-right: 30px;
  }
}
@media (max-width: 1024px) {
  .footer-style-4 footer .footer-links-2 {
    padding-right: 0px;
    margin-right: 0px;
    border: none;
  }
}
.footer-style-4 footer .footer-links-3 {
  margin-right: 50px;
}
@media (max-width: 1024px) {
  .footer-style-4 footer .footer-links-3 {
    padding-right: 0px;
    margin-right: 0px;
  }
}
.footer-style-4 footer .footer-info-items {
  margin-bottom: 40px;
}
@media (max-width: 1024px) {
  .footer-style-4 footer .footer-info-items {
    flex-basis: 100%;
    margin-bottom: 0;
  }
}
.footer-style-4 footer .footer-info-items .text {
  color: #1a2b49;
}
.footer-style-4 footer .footer-info-items .text a {
  color: #1a2b49;
}
.footer-style-4 footer .footer-info-items .text a:hover {
  color: #777777;
}
.footer-style-4 footer .footer-info-items .text p {
  color: #1a2b49;
  padding-bottom: 15px;
  line-height: 1;
  font-size: 14px;
  letter-spacing: 2px;
}
@media (max-width: 768px) {
  .footer-style-4 footer .footer-info-items .text p {
    letter-spacing: 1px;
    font-size: 14px;
  }
}
.footer-style-4 footer .footer-info-items .text p strong {
  font-weight: 500;
}
.footer-style-4 footer .footer-info-items .text *:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
}
@media (max-width: 1024px) {
  .footer-style-4 footer .footer-info-items .text *:last-child {
    padding-bottom: 10px;
  }
}
.footer-style-4 footer .footer-info-items .footer-info-item {
  border-right: 1px solid rgba(0,0,0,0.2);
  padding-right: 40px;
  margin-right: 40px;
}
@media (max-width: 1600px) {
  .footer-style-4 footer .footer-info-items .footer-info-item {
    padding-right: 30px;
    margin-right: 30px;
  }
}
@media (max-width: 1024px) {
  .footer-style-4 footer .footer-info-items .footer-info-item {
    padding-right: 0px;
    margin-right: 0px;
    flex-basis: 100%;
    border: none;
    text-align: center;
    margin-bottom: 20px;
  }
}
.footer-style-4 footer .footer-info-items .footer-info-item:last-child {
  border-right: 0;
  padding-right: 0;
  margin-right: 0;
}
@media (max-width: 600px) {
  .footer-style-4 footer .footer-info-items .footer-info-item:last-child {
    margin-bottom: 0px;
  }
}
.footer-style-4 footer .copyright {
  text-align: center;
  color: #1a2b49;
  font-size: 14px;
  text-transform: uppercase;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 1px;
}
@media (max-width: 768px) {
  .footer-style-4 footer .copyright {
    letter-spacing: 1px;
  }
}
.footer-style-4 footer .copyright span {
  margin: 0 8px;
}
@media (max-width: 768px) {
  .footer-style-4 footer .copyright span {
    margin: 0 8px;
  }
}
.footer-style-4 footer .footer-links-items {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  justify-content: center;
  margin-bottom: 20px;
  font-family: "fontawesome-brands";
}
@media (max-width: 1024px) {
  .footer-style-4 footer .footer-links-items {
    flex-basis: 100%;
  }
}
.footer-style-4 footer .footer-links-items .footer-links-item {
  margin: 5px;
  font-size: 26px;
  color: #1a2b49;
  display: block;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -ms-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.footer-style-4 footer .footer-links-items .footer-links-item:hover {
  color: #777777;
}
.footer-style-4 footer .button.transparent {
  font-size: 14px;
  background: transparent;
  border: 1px solid #1a2b49;
  color: #1a2b49;
  padding: 10px 25px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
}
.footer-style-4 footer .button.transparent:hover {
  background: #1a2b49;
  color: #fff;
}

/* ==========================================================================
   CUSTOMIZER CSS - The Gaspar Site Styles
   ========================================================================== */

/* Form Styles */
.footer-style-4 .gform_title {
  display: none;
}

@media (max-width: 420px) {
  .footer-style-4 #field_2_12,
  .footer-style-4 #field_2_7,
  .footer-style-4 #field_2_9,
  .footer-style-4 #field_2_14,
  .footer-style-4 #field_2_13 {
    margin-top: -27px;
  }
  .footer-style-4 #field_2_13 {
    margin-bottom: 16px;
  }
}

.footer-style-4 #gform_submit_button_2 {
  font-family: "Josefin Sans", serif;
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 2.1px;
  line-height: 2;
  border: 0.5px solid #000 !important;
}

.footer-style-4 #gform_submit_button_2:hover {
  color: #fff !important;
  background-color: #000 !important;
}

/* Button Styles */
.footer-style-4 .button:hover {
  color: #fff !important;
  background-color: #000 !important;
}

.footer-style-4 .gaspar-button {
  border: 0.5px solid #000;
  letter-spacing: 2.1px;
  line-height: 2;
  padding: 12px 17px 12px 14px;
  font-family: "Josefin Sans", serif;
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
}

.footer-style-4 .gaspar-button:hover {
  color: #fff !important;
  background-color: #000;
}

/* Background Pattern */
@media (max-width: 1024px) {
  .footer-style-4 .background-pattern {
    margin-top: -5vh !important;
    margin-bottom: -5vh !important;
    height: 20vh !important;
  }
}

@media (max-width: 768px) {
  .footer-style-4 div.background-image:nth-child(9),
  .footer-style-4 div.background-image:nth-child(6),
  .footer-style-4 div.background-image:nth-child(7) {
    margin-top: 0px !important;
    margin-bottom: 0px !important;
  }
}

.footer-style-4 .background-pattern {
  margin-top: -7vh;
  margin-bottom: -7vh;
}

.footer-style-4 .text-image-box-one::before {
  background: url("/wp-content/uploads/2025/05/Birds-Nest-Blue-Pattern-Type4.svg") !important;
}

.footer-style-4 .three-images-spaced::before {
  background: url("/wp-content/uploads/2025/05/Birds-Nest-Blue-35.svg") !important;
}

/* Video Embed */
.footer-style-4 .embed-video {
  max-width: 75%;
  margin: 0 auto;
  position: relative;
  background-image: url('/wp-content/uploads/2025/05/Video-scaled.jpeg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}

.footer-style-4 .embed-video iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  display: block;
  border: none;
}

@media (max-width: 768px) {
  .footer-style-4 .embed-video {
    max-width: 100%;
  }
}

/* One Column Image Left Layout */
.footer-style-4 .one_column_image_left .image_box {
  flex-basis: 50%;
}

.footer-style-4 .one_column_image_left .row {
  width: 2220px;
  max-width: 100%;
}

.footer-style-4 .one_column_image_left.right .row {
  flex-direction: row-reverse;
}

@media (max-width: 1024px) {
  .footer-style-4 .one_column_image_left .image_box {
    flex-basis: 100%;
  }
  .footer-style-4 .btn-arrow {
    font-size: 12px !important;
  }
}

@media (max-width: 1024px) {
  .footer-style-4 .one_column_image_left .text_box {
    flex-basis: 100% !important;
    padding: 5vh 3vh;
  }
}

.footer-style-4 .one_column_image_left .image_box img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.footer-style-4 .one_column_image_left .text_box {
  flex-basis: 50%;
  padding: 4vh 8vh;
}

/* Blockquote Styles */
.footer-style-4 blockquote {
  color: #000;
  font-family: "Josefin Sans";
  font-weight: 300;
  line-height: 1;
  position: relative;
  margin-bottom: 20px;
}

.footer-style-4 blockquote::before {
  content: "";
  position: absolute;
  bottom: 0px;
  left: -40px;
  width: 80px;
  height: 4px;
  background: #c7e0f4;
}

.footer-style-4 blockquote p {
  color: #000 !important;
  font-family: "Josefin Sans" !important;
  font-size: 45px;
  font-weight: 300 !important;
  line-height: 1 !important;
  position: relative !important;
  margin-bottom: 20px !important;
  padding-bottom: 20px !important;
}

@media (max-width: 1024px) {
  .footer-style-4 blockquote p {
    font-size: 35px;
  }
}
