/**
 * Single Service Area Template Styles
 *
 * @package WoundCare_at_Home
 * @since 1.0.0
 */

/* ==========================================================================
   Global
   ========================================================================== */

   #vp-leaflet-map .leaflet-control-attribution.leaflet-control{
    display: none!important;
}

   .vp-site-navigation{
    background: var(--Primary-3);
   }

   .vp-SH-display-2 a{
    color: var(--Primary-primary);
   }

   .vp-SH-display-2 a:hover{
    color: var(--Secondary-1);
   }

   .vp-SH-display-6 a{
    color: var(--Neutral-800);
   }

   .vp-SH-display-6 a:hover{
    color: var(--Primary-primary);
   }

   /* ==========================================================================
   Section 1: Hero
   ========================================================================== */

   .vp-service-hero-inner {
    padding: 0 0 100px 0;
    background: var(--Primary-3);
}

.vp-service-hero-inner .vp-hero-list {
    gap: 6px;
}

.vp-service-hero-inner .vp-hero-list svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.vp-service-hero-inner .vp-max-width {
    max-width: 800px;
    width: 100%;
}

.vp-service-hero-inner .vp-max-width .vp-title-hero svg {
    width: 100%;
}

.vp-service-hero-inner .vp-our-mission-images {
    max-width: 640px;
    width: 100%;
}

.vp-service-hero-inner .vp-our-mission-images img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 0 24px 24px 0;
}

.vp-service-hero-inner .vp-our-mission-card .vp-H5 {
    color: var(--Neutral-600);
}

@media (max-width: 1440px) {
    .vp-service-hero-inner .vp-max-width {
        margin: 0;
    }
}

@media (max-width: 1100px) {
    .vp-service-hero-inner .vp-service-hero .vp-SH-display-1 {
        font-size: var(--32);
        font-weight: 600;
    }
    .vp-service-hero-inner .vp-service-hero {
        gap: var(--36);
    }
}

@media (max-width: 768px) {
    .vp-service-hero-inner .vp-our-mission-images {
        order: 2;
        max-width: 100%;
        padding: 0 var(--16);
        height: auto;
    }
    .vp-service-hero-inner .vp-our-mission-images img {
        border-radius: 20px;
    }
    .vp-service-hero-inner .vp-gap-24.vp-a-i-center {
        gap: var(--12);
    }
    .vp-service-hero-inner .vp-gap-24.vp-a-i-f-start {
        gap: var(--36);
    }
    .vp-service-hero-inner .vp-gap-32.vp-a-i-f-start {
        gap: var(--12);
    }
    .vp-service-hero-inner .vp-gap-8 {
        gap: 6px;
    }
    .vp-service-hero-inner {
        padding: 0 0 60px 0;
    }
}

/* ==========================================================================
   Section 2: Content + Sidebar Section
   ========================================================================== */

.vp-service-content-section {
    padding: 60px 0 200px;
}

.vp-service-content-grid {
    display: flex;
    gap: 84px;
}

/* Main Content */
.vp-service-main-content {
    flex: 1;
}

/* Content Body - Base Styles */
.vp-service-content-body {
    color: var(--Neutral-700);
    font-size: 18px;
    font-weight: 400;
    line-height: 148%;
}

/* Paragraphs */
.vp-service-content-body p {
    margin-bottom: var(--16);
    color: var(--Neutral-700);
    font-size: 18px;
    font-weight: 400;
    line-height: 148%;
}

/* Headings */
.vp-service-content-body h2,
.vp-service-content-body h3,
.vp-service-content-body h4,
.vp-service-content-body h5,
.vp-service-content-body h6 {
    color: var(--Neutral-800);
    font-weight: 600;
    line-height: 1;
    margin-top: 40px;
    margin-bottom: var(--16);
}

.vp-service-content-body h2 {
    font-size: 46px;
}

.vp-service-content-body h2:first-child {
    margin-top: 0;
    line-height: 1;
}

.vp-service-content-body h3 {
    font-size: 24px;
}

.vp-service-content-body h4 {
    font-size: 22px;
}

.vp-service-content-body h5 {
    font-size: 20px;
}

.vp-service-content-body h6 {
    font-size: 18px;
}

/* Unordered List - Dots (default) */
.vp-service-content-body ul {
    color: var(--Neutral-700);
    font-size: 18px;
    font-weight: 400;
    line-height: 148%;
    margin-top: var(--16);
    margin-bottom: var(--16);
    list-style-type: disc;
    margin-left: 34px;
    padding: 0;
}

.vp-service-content-body ul li {
    margin-bottom: 6px;
    padding-left: 8px;
}

.vp-service-content-body ul li::marker {
    color: var(--Primary-primary);
    font-size: var(--24);
}

/* Ordered List - Numbers */
.vp-service-content-body ol {
    list-style-type: decimal;
    color: var(--Neutral-700);
    font-size: 18px;
    font-weight: 400;
    line-height: 148%;
    margin-top: var(--16);
    margin-bottom: var(--16);
    margin-left: 25px;
    padding: 0;
}

.vp-service-content-body ol li {
    margin-bottom: 6px;
    padding-left: 8px;
}

.vp-service-content-body ol li::marker {
    color: var(--Primary-primary);
    font-weight: 600;
}

/* Checkmark List - Add class "vp-ul-checked" in editor if needed */
.vp-service-content-body ul.vp-ul-checked {
    list-style: none;
    margin-left: 0;
    padding-top: var(--16);
}

.vp-service-content-body ul.vp-ul-checked li {
    position: relative;
    padding-left: 32px;
    margin-bottom: 6px;
}

.vp-service-content-body ul.vp-ul-checked li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 4px;
    width: 20px;
    height: 20px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M16.6667 5L7.50001 14.1667L3.33334 10' stroke='%238C58DA' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-size: contain;
}

/* Links */
.vp-service-content-body a {
    color: var(--Primary-primary);
    text-decoration: underline;
    transition: opacity 0.3s ease;
}

.vp-service-content-body a:hover {
    color: var(--Secondary-1);
}

/* Strong/Bold */
.vp-service-content-body strong,
.vp-service-content-body b {
    font-weight: 600;
    color: var(--Neutral-800);
}

/* Italic/Emphasis */
.vp-service-content-body em,
.vp-service-content-body i {
    font-style: italic;
}

/* Blockquote */
.vp-service-content-body blockquote {
    border-left: 4px solid var(--Primary-primary);
    padding-left: 24px;
    margin: 24px 0;
    font-style: italic;
    color: var(--Neutral-600);
}

.vp-service-content-body blockquote p {
    margin-bottom: 0;
}

/* Images in content */
.vp-service-content-body img {
    max-width: 100%;
    height: auto;
    border-radius: var(--16);
    margin: 24px 0;
}

/* Figures/Captions */
.vp-service-content-body figure {
    margin: 24px 0;
}

.vp-service-content-body figcaption {
    font-size: 14px;
    color: var(--Neutral-600);
    text-align: center;
    margin-top: 8px;
}

/* Tables */
.vp-service-content-body table {
    width: 100%;
    border-collapse: collapse;
    margin: 24px 0;
}

.vp-service-content-body th,
.vp-service-content-body td {
    padding: 12px 16px;
    border: 1px solid var(--Neutral-300);
    text-align: left;
}

.vp-service-content-body th {
    background: var(--Neutral-200);
    font-weight: 600;
    color: var(--Neutral-800);
}

/* Horizontal Rule */
.vp-service-content-body hr {
    border: none;
    border-top: 1px solid var(--Neutral-300);
    margin: 40px 0;
}

/* Code */
.vp-service-content-body code {
    font-family: monospace;
    background: var(--Neutral-200);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 16px;
}

.vp-service-content-body pre {
    background: var(--Neutral-200);
    padding: 16px;
    border-radius: var(--16);
    overflow-x: auto;
    margin: 24px 0;
}

.vp-service-content-body pre code {
    background: none;
    padding: 0;
}

/* Social Share */
.vp-share {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 40px;
    flex-flow: wrap;
}

.vp-share span {
    color: var(--Neutral-600, #626270);
    font-size: var(--18);
    font-weight: 600;
    margin-right: 8px;
}

.vp-share a {
    display: flex;
    align-items: center;
    justify-content: center;
}

.vp-share a svg {
    width: 22px;
    height: 22px;
}

.vp-share a:hover svg path{
    fill: var(--Secondary-1);
} 

.vp-share a svg{
    width: 32px;
    height: 32px;
}

/* Sticky Sidebar */
.vp-sa-content-section .vp-contact-info {
    flex-shrink: 0;
    position: sticky;
    top: 60px;
    align-self: flex-start;
}

@media (max-width: 768px) {
    .vp-sa-content-section .vp-contact-info {
        position: static;
    }

    .vp-service-content-body h2 {
        font-size: 30px;
    }
}

/* ==========================================================================
   Section 3: Our Services
   ========================================================================== */

   .vp-specializing-inner {
    margin-bottom: 200px;
}

.vp-sa-services .vp-title-inner {
    max-width: 700px;
}

.vp-specializing-inner .vp-title-text p {
    color: var(--Neutral-600);
}

.vp-specializing-inner .vp-services-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: var(--24);
    row-gap: var(--32);
    align-items: stretch;
}

.vp-specializing-inner .vp-services-card {
    max-width: unset;
    width: 100%;
    position: relative;
}



/* Card without image variant */
.vp-specializing-inner .vp-services-card-no-img .vp-services-content {
    border-radius: var(--24);
    max-width: 100%;
    height: 100%;
    min-height: unset;
    box-sizing: border-box;
}

.vp-specializing-inner .vp-services-content {
    border-radius: 0 var(--24) var(--24) var(--24);
    border: 1px solid var(--Neutral-300);
    background: var(--Neutral-100);
    padding: var(--24);
    box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.02);
    width: 100%;
}

.vp-specializing-inner .vp-services-list li {
    color: var(--Neutral-600);
}

.vp-specializing-inner .vp-services-list svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

@media (max-width: 1100px) {
    .vp-specializing-inner .vp-services-cards {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .vp-specializing-inner .vp-services-cards {
        grid-template-columns: 1fr;
    }
}


@media (max-width: 768px) {
    .vp-specializing-inner {
        margin-bottom: 120px;
    }

    .vp-specializing-inner .vp-services-card {
        flex: unset;
        width: 100%;
        max-width: 100%;
    }

    .vp-specializing-inner .vp-services-card-no-img .vp-services-content {
        height: auto;
    }

    .vp-specializing-inner .vp-SH-display-6 {
        font-size: var(--22);
    }

    .vp-specializing-inner .vp-services-list li {
        font-size: 16px;
    }

    .vp-specializing-inner .vp-services-content {
        max-width: 100%;
    }
}

/* ==========================================================================
   Section 4: Why Choose Us
   ========================================================================== */

   .vp-right-car-inner {
    padding: 100px 0;
    gap: 94px;
    background: var(--Neutral-100);
}

.vp-right-car-inner .vp-right-car-info {
    gap: 32px 24px;
}

.vp-right-car-inner .vp-title-text .vp-text-200-regular {
    color: var(--Neutral-600);
}

.vp-right-car-inner .vp-right-car-bg {
    background: var(--Primary-3);
    border-radius: var(--24);
    max-width: 384px;
    height: 500px;
    width: 100%;
    position: absolute;
    z-index: -1;
}

.vp-right-car-inner .vp-right-car-images {
    z-index: 1;
    position: relative;
    display: grid;
    max-width: 620px;
    gap: var(--40);
    align-items: center;
    justify-items: center;
}

.vp-right-car-inner .vp-right-car-image:first-child {
    grid-row: 1 / span 1;
    grid-column: 1 / span 1;
}

.vp-right-car-inner .vp-right-car-image:last-child {
    grid-row: 2 / span 1;
    grid-column: 1 / span 1;
    justify-content: end;
}

.vp-right-car-inner .vp-right-car-image:nth-last-child(2) {
    grid-row: 1 / span 2;
    grid-column: 2 / span 1;
    align-items: center;
}

.vp-right-car-inner .vp-right-car {
    max-width: 670px;
    width: 100%;
}

.vp-right-car-inner .vp-right-car-card {
    max-width: 308px;
    width: 100%;
}

@media (max-width: 1385px) {
    .vp-right-car-inner {
        gap: 60px;
    }
    
    .vp-right-car-inner .vp-right-car-images {
        max-width: 500px;
    }
}

@media (max-width: 1233px) {
    .vp-right-car-inner .vp-right-car-images {
        max-width: 450px;
    }
    
    .vp-right-car-inner {
        gap: 40px;
    }
}

@media (max-width: 1165px) {
    .vp-right-car-inner .vp-right-car-images {
        max-width: 400px;
    }
    
    .vp-right-car-inner .vp-right-car-card {
        max-width: 280px;
    }
}

@media (max-width: 1060px) {
    .vp-right-car-inner .vp-right-car-card {
        max-width: 250px;
    }
    
    .vp-right-car-inner .vp-right-car-card .vp-H5 {
        font-size: 16px;
        line-height: 137%;
    }
}

@media (max-width: 924px) {
    .vp-right-car-inner {
        padding: 60px 0;
    }
    
    .vp-right-car-inner .vp-right-car-card {
        max-width: 100%;
    }
    
    .vp-right-car-inner .vp-right-car-card .vp-H5 {
        font-size: 16px;
        line-height: 137%;
    }
    
    .vp-right-car-btn {
        flex-direction: column;
    }
    
    .vp-right-car-inner .vp-right-car-info {
        gap: var(--24);
    }
}

@media (max-width: 768px) {
    .vp-right-car-inner .vp-right-car-images {
        order: 2;
    }
    
    .vp-right-car-inner .vp-title-text .vp-text-200-regular {
        text-align: center;
    }
    
    .vp-right-car-image img {
        border-radius: 24px;
    }
    
    .vp-right-car-inner .vp-right-car-images {
        max-width: 650px;
        padding: 0 var(--16);
    }
    
    .vp-right-car-inner .vp-right-car-bg {
        height: 65%;
        max-width: 62%;
    }
    
    .vp-right-car-inner .vp-right-car-images {
        gap: var(--30) 15px;
    }
}

/* ==========================================================================
   Section 5: Areas We Serve Map
   ========================================================================== */

   .vp-service-maps-inner {
    padding: 100px 0 200px;
}

.vp-service-maps-inner .vp-service-maps-form {
    max-width: 400px;
    width: 100%;
}

/* City Search */
.vp-city-search-wrapper {
    position: relative;
}

.vp-city-search-wrapper input {
    width: 100%;
    padding: 16px 20px;
    border-radius: var(--16);
    border: 1px solid var(--Neutral-400);
    background: var(--Neutral-100);
    box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.02);
    outline: none;
    font-size: 16px;
}

.vp-city-search-wrapper input:focus {
    border-color: var(--Primary-primary);
}

.vp-city-suggestions {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--Neutral-100);
    border: 1px solid var(--Neutral-300);
    border-radius: var(--12);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
    margin-top: 4px;
    max-height: 300px;
    overflow-y: auto;
    z-index: 100;
    display: none;
}

.vp-city-suggestion {
    padding: 12px 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: background 0.2s ease;
}

.vp-city-suggestion:hover {
    background: var(--Primary-3);
}

.vp-city-suggestion.vp-no-match {
    color: var(--Neutral-500);
    cursor: default;
}

.vp-city-suggestion.vp-no-match:hover {
    background: transparent;
}

/* Map Container */
.vp-service-maps-inner .vp-service-maps-city {
    border-radius: var(--24);
    border: 1px solid var(--Neutral-300);
    min-height: 500px;
    overflow: hidden;
    z-index: 1;
}

/* Custom Marker */
.vp-map-marker {
    background: transparent !important;
    border: none !important;
}

.vp-map-marker svg {
    filter: drop-shadow(0 2px 6px rgba(140, 88, 218, 0.3));
    transition: transform 0.2s ease;
}

.vp-map-marker-active svg {
    transform: scale(1.25);
}

/* Custom Popup - Matching Design */
.vp-custom-popup .leaflet-popup-content-wrapper {
    background: var(--Neutral-100);
    border-radius: 20px;
    border: 1px solid var(--Primary-primary);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    padding: 0;
}

.vp-custom-popup .leaflet-popup-content {
    margin: 0;
    min-width: 120px;
}

.vp-custom-popup .leaflet-popup-tip {
    display: none;
}

.vp-map-popup-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 12px;
    text-decoration: none; 
}

.vp-map-popup-card img {
    width: 100%;
    height: 60px;
    border-radius: 12px;
    object-fit: cover;
}

.vp-map-popup-city {
    color: var(--Neutral-800);
    font-size: 16px;
    font-weight: 700;
    line-height: 1;
    text-align: center;
}

.vp-map-popup-card:hover span{
    color: var(--Primary-primary);
}

@media (max-width: 768px) {
    .vp-service-maps-inner {
        padding: 60px 0 120px;
    }
    
    .vp-service-maps-inner .vp-max-width {
        gap: 32px;
    }
    
    .vp-service-maps-inner .vp-service-maps-form {
        max-width: 100%;
    }
    
    .vp-service-maps-inner .vp-service-maps-city {
        min-height: 350px;
    }
}

/* ========================================
   FAQs Section
   ======================================== */
   .vp-faqs-section {
    background: var(--Neutral-100);
    padding: 100px 0;
}

.vp-faqs-section .vp-title {
    display: grid;
    align-items: center;
    text-align: center;
    margin: 0 auto;
}

.vp-faqs-desc {
    color: var(--Neutral-600);
    text-align: center;
    font-size: 18px;
    font-weight: 400;
    line-height: 148%;
    width: 53%;
    margin: 24px auto 44px;
}

.vp-faqs-section .vp-acc-items-grid {
    display: flex;
    flex-direction: column;
    gap: 16px;
    max-width: 816px;
    width: 100%;
    margin: 0 auto;
}

/* Individual FAQ Item */
.vp-faqs-section .vp-faq-item {
    width: 100%;
    overflow: hidden;
    background: #fff;
    border-radius: var(--24, 24px);
    border: 1px solid var(--Neutral-300);
}

/* FAQ Question Button */
.vp-faqs-section .vp-faq-question {
    width: 100%;
    background: var(--Neutral-100, #fff);
    border: none;
    padding: 20px 24px;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    border-radius: var(--24, 24px);
    color: var(--Neutral-800);
    font-family: inherit;
    font-size: 20px;
    font-weight: 600;
    line-height: 140%;
    text-align: left; 
}

.vp-faqs-section .vp-faq-question span:first-child {
    flex: 1;
}

.vp-faqs-section .vp-faq-question:hover {
    color: var(--Primary-primary);
    border-color: var(--Neutral-400);
}

.vp-faqs-section .vp-faq-question:focus {
    outline: 2px solid var(--Primary-primary);
    outline-offset: 2px;
}

.vp-faqs-section .vp-faq-question:focus:not(:focus-visible) {
    outline: none;
}

/* Arrow Button */
.vp-faqs-section .vp-faq-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1px solid var(--Neutral-300);
    background: #fff;
    color: var(--Primary-primary);
    transition: all 0.3s ease;
    flex-shrink: 0;
}

.vp-faqs-section .vp-faq-arrow svg {
    transition: transform 0.3s ease;
    width: 20px;
    height: 20px;
}

/* Arrow Hover State */
.vp-faqs-section .vp-faq-question:hover .vp-faq-arrow {
    background-color: var(--Primary-primary);
    border-color: var(--Primary-primary);
    color: #fff;
}

/* FAQ Answer */
.vp-faqs-section .vp-faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out;
}

.vp-faqs-section .vp-faq-answer-inner {
    padding: 16px 24px 24px;
}

.vp-faqs-section .vp-faq-answer-inner p {
    margin: 0 0 12px;
    color: var(--Neutral-600);
    font-size: 18px;
    font-weight: 400;
    line-height: 160%;
}

.vp-faqs-section .vp-faq-answer-inner p:last-child {
    margin-bottom: 0;
}

/* Active/Open State */
.vp-faqs-section .vp-faq-item.active {
    border-radius: var(--24, 24px);
    box-shadow: 0 4px 20px 0 rgba(0, 0, 0, 0.08);
}

.vp-faqs-section .vp-faq-item.active .vp-faq-question {
    color: var(--Primary-primary);
    border: none;
    border-radius: 24px 24px 0 0;
    box-shadow: none;
    background: #fff;
}

.vp-faqs-section .vp-faq-item.active .vp-faq-answer { 
    transition: max-height 0.4s ease-in;
}

.vp-faqs-section .vp-faq-item.active .vp-faq-arrow {
    background-color: var(--Primary-primary);
    border-color: var(--Primary-primary);
    color: #fff;
}

.vp-faqs-section .vp-faq-item.active .vp-faq-arrow svg {
    transform: rotate(180deg);
}

.vp-faqs-btn {
    display: flex;
    justify-content: center;
    margin-top: 44px;
}

/* Responsive */
@media (max-width: 768px) {
    .vp-faqs-section {
        padding: 60px 0;
    }

    .vp-faqs-desc {
        width: 100%;
        font-size: var(--16);
        margin-bottom: 20px;
    }

    .vp-faqs-section .vp-faq-question {
        font-size: 16px;
        padding: 16px;
        gap: 12px;
        border-radius: 16px;
    }

    .vp-faqs-section .vp-faq-item {
        border-radius: 16px;
    }

    .vp-faqs-section .vp-faq-item.active .vp-faq-question {
        border-radius: 16px 16px 0 0;
    }

    .vp-faqs-section .vp-faq-arrow {
        min-width: 36px;
        width: 36px;
        height: 36px;
    }

    .vp-faqs-section .vp-faq-arrow svg {
        width: 16px;
        height: 16px;
    }

    .vp-faqs-section .vp-faq-answer-inner {
        padding: 12px 16px 16px;
    }

    .vp-faqs-section .vp-faq-answer-inner p {
        font-size: 16px;
    }

    .vp-faqs-btn {
        width: 100%;
    }

    .vp-faqs-btn a {
        width: 100%;
    }
}

/* ========================================
   Reviews Section
   ======================================== */
   .vp-service-reviews {
    padding: 100px 0;
}

.vp-service-reviews .vp-max-width {
    position: relative;
}

.vp-reviews-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 44px;
}

.vp-reviews-header .vp-title {
    max-width: 640px;
}

.vp-reviews-nav {
    display: flex;
    gap: 12px;
}

.vp-reviews-nav-mobile {
    display: none;
    gap: 12px;
    justify-content: center;
    margin-top: 32px;
}

.vp-reviews-slider {
    width: 100%;
}

.vp-reviews-slider .swiper {
    position: unset;
}

.vp-review-card {
    padding: var(--40) var(--32);
    box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.02);
    background: var(--Neutral-100);
    border: 1px solid var(--Neutral-300);
    border-radius: var(--24);
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.vp-review-text {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.vp-review-text p {
    color: var(--Neutral-600);
}

.vp-stars {
    display: flex;
    gap: 4px;
    padding-left: 2px;
}

.vp-review-author {
    display: flex;
    gap: 8px;
    align-items: center;
}

.vp-review-author img {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    object-fit: cover;
}

.vp-review-author p {
    color: var(--Primary-primary);
}

.vp-author-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

/* Swiper Disabled State */
.swiper-button-prev-review.swiper-button-disabled,
.swiper-button-next-review.swiper-button-disabled {
    opacity: 0.35;
    cursor: auto;
    pointer-events: none;
}

/* Avatar Initial */
.vp-avatar-initial {
    width: 50px;
    height: 50px;
    min-width: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    font-weight: 600;
    text-transform: uppercase;
}

@media (max-width: 768px) {
    /* Reviews */
    .vp-service-reviews {
       padding: 60px 0;
   }

   .vp-reviews-header {
       flex-direction: column;
       align-items: center;
       text-align: center;
   }

   .vp-reviews-nav.arrow-desk {
       display: none;
   }

   .vp-reviews-nav-mobile {
       display: flex;
   }

   .vp-review-card {
       padding: var(--36) var(--24);
   }

   .vp-review-card {
       font-size: var(--18);
   }

   .vp-review-author h5 {
       font-size: var(--16);
       line-height: 148%;
   }

   .vp-author-info {
       gap: 0;
   }
}

/* ==========================================================================
   Healthcare Partners Section
   ========================================================================== */
   .vp-our-qualifications-inner {
    margin: 0 0 100px;
}

.vp-our-qualifications-inner .vp-our-qualifications-card {
    max-width: 384px;
    width: 100%;
    padding: var(--24) var(--16);
    border-radius: var(--24);
    border: 1px solid var(--Neutral-300);
    background: var(--Neutral-100);
    box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.02);
    text-align: center;
}

.vp-our-qualifications-inner .vp-our-qualifications-date {
    gap: 6px;
}

.vp-italic{
    font-style: italic;
    margin-top: 12px;
}

.vp-our-qualifications-cards{
    align-items: stretch;
}

@media (max-width: 768px) {
    .vp-our-qualifications-inner {
        margin-bottom: 0;
    }
    
    .vp-our-qualifications-inner .vp-SH-display-6 {
        font-size: var(--22);
    }
    
    .vp-our-qualifications-inner .vp-our-qualifications-card {
        gap: var(--16);
    }
}

/* ==========================================================================
   Form Styles
   ========================================================================== */

   /* Sticky Sidebar */
/* Sticky Sidebar */
.vp-service-sidebar {
    flex-shrink: 0;
}

.vp-sidebar-form-wrapper {
    position: sticky;
    top: 24px;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    padding-right: 8px;
    padding-bottom: 24px;
}

/* Custom scrollbar for sidebar */
.vp-sidebar-form-wrapper::-webkit-scrollbar {
    width: 6px;
}

.vp-sidebar-form-wrapper::-webkit-scrollbar-track {
    background: var(--Neutral-200);
    border-radius: 3px;
}

.vp-sidebar-form-wrapper::-webkit-scrollbar-thumb {
    background: var(--Primary-2);
    border-radius: 3px;
}

.vp-sidebar-form-wrapper::-webkit-scrollbar-thumb:hover {
    background: var(--Primary-primary);
}

.vp-sidebar-form-wrapper .vp-title-inner {
    margin: 0 0 12px;
    text-align: left;
    max-width: 360px;
} 

.wpforms-field-limit-text,
.wpforms-hidden{
    display: none!important;
}

   .vp-sidebar-form-wrapper .vp-form {
    border-radius: var(--24);
    border: 1px solid var(--Neutral-300);
    background: var(--Neutral-100);
    padding: var(--32) var(--24);
    max-width: 440px;
}

.vp-sidebar-form-wrapper .vp-form input,
.vp-sidebar-form-wrapper .vp-form select,
.vp-sidebar-form-wrapper .vp-form textarea {
    border-radius: var(--16);
    border: 1px solid var(--Neutral-400, #D0D0DB);
    background: var(--Neutral-100, #FFF);
    box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.02);
    padding: var(--16);
    width: 100%;
    font-family: var(--font-family-onest);
    font-size: 18px;
    font-weight: 500;
    line-height: 140%;
}

.vp-sidebar-form-wrapper .vp-form textarea {
    min-height: 140px;
    resize: vertical;
}

.vp-sidebar-form-wrapper .vp-form select {
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M9.57086 14.7091L4.98086 10.1191C4.7946 9.93174 4.69006 9.67829 4.69006 9.41411C4.69006 9.14992 4.7946 8.89647 4.98086 8.70911C5.07382 8.61538 5.18442 8.54098 5.30628 8.49021C5.42814 8.43945 5.55884 8.41331 5.69086 8.41331C5.82287 8.41331 5.95357 8.43945 6.07543 8.49021C6.19729 8.54098 6.30789 8.61538 6.40086 8.70911L10.9809 13.3091C11.0738 13.4028 11.1844 13.4772 11.3063 13.528C11.4281 13.5788 11.5588 13.6049 11.6909 13.6049C11.8229 13.6049 11.9536 13.5788 12.0754 13.528C12.1973 13.4772 12.3079 13.4028 12.4009 13.3091L16.9809 8.70911C17.1678 8.5208 17.422 8.41449 17.6873 8.41355C17.9527 8.41261 18.2076 8.51713 18.3959 8.70411C18.5842 8.89108 18.6905 9.14521 18.6914 9.41057C18.6924 9.67593 18.5878 9.9308 18.4009 10.1191L13.8109 14.7091C13.2484 15.2709 12.4859 15.5865 11.6909 15.5865C10.8959 15.5865 10.1334 15.2709 9.57086 14.7091Z' fill='%23626270'/%3E%3C/svg%3E") no-repeat right 16px center;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 48px;
}

.vp-sidebar-form-wrapper .vp-form input::placeholder,
.vp-sidebar-form-wrapper .vp-form select,
.vp-sidebar-form-wrapper .vp-form textarea::placeholder {
    color: var(--Neutral-600, #626270);
    font-family: var(--font-family-onest);
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height: 140%;
} 

.vp-sidebar-form-wrapper .vp-form-check label {
    color: var(--Neutral-600);
    cursor: pointer;
}

/* ==========================================================================
   WPForms Styling
   ========================================================================== */

   .wpforms-field{
    margin-bottom: 12px;
   }

   .gm-form .wpforms-field-label {
    font-weight: 700;
    font-size: var(--18);
    line-height: 148%;
}

.gm-form .wpforms-field-large {
    margin-top: 6px;
}

.gm-form input:focus,
.gm-form select:focus,
.gm-form textarea:focus {
    border-color: var(--Primary-primary) !important; 
}

.gm-form .wpforms-field-layout-rows .wpforms-layout-row {
    margin-bottom: 24px;
}

#wpforms-error-noscript,
.wpforms-label-hide {
    display: none !important;
}

.wpforms-submit.gm-submit-form {
    border: none;
    cursor: pointer;
    display: inline-flex;
    padding: var(--20);
    justify-content: center;
    align-items: center;
    gap: var(--12);
    border-radius: var(--12);
    box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.12);
    flex-shrink: 0;
    height: var(--64);
    background: var(--Primary-primary);
    color: var(--Neutral-100);
    transition: background 0.3s ease;
    font-weight: 700;
    font-size: var(--18);
    line-height: 148%;
    margin-top: 12px;
    width: 100%;
}

.wpforms-submit.gm-submit-form:hover {
    background: var(--Secondary-1);
    box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.16);
}

.gm-form .wpforms-error {
    color: #DC2B2B;
}

.gm-form .wpforms-confirmation-container {
    color: #11845B;
    font-weight: 500;
    font-size: 20px;
}

/* Select with value selected (valid) */
.wpforms-container select:valid {
    color: var(--Neutral-800) !important;
    font-weight: 500;
}

/* Privacy Checkbox */
.gm-form .gm-privacy {
    margin-top: 24px;
}

.gm-form .gm-privacy fieldset {
    border: none;
}

.gm-form .gm-privacy ul li {
    display: flex;
    gap: 12px;
}

.gm-form .gm-privacy ul li input {
    width: 20px;
    height: 20px;
    min-width: 20px;
    border-radius: 6px;
    border: 1px solid var(--Neutral-500);
    background: var(--Neutral-100);
    appearance: none;
    -webkit-appearance: none;
    padding: 0;
    cursor: pointer;
}

.gm-form .gm-privacy ul li input[type="checkbox"]:checked {
    background-color: var(--Primary-primary);
    border-color: var(--Primary-primary);
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 8l3 3 5-6' stroke='white' stroke-width='2'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
}

.gm-form .gm-privacy ul li a {
    text-decoration: underline;
    color: #8c59da;
}

/* ==========================================================================
   Responsive - Tablet
   ========================================================================== */
@media (max-width: 1024px) {
    .vp-sidebar-form-wrapper .vp-contact {
        padding: 30px 0 60px;
    }

    .vp-sidebar-form-wrapper .vp-contact-bg-1 {
        right: -7%;
    }

    .vp-sidebar-form-wrapper .vp-form {
        padding: var(--32) var(--24);
    }
}

/* ==========================================================================
   Responsive - Mobile
   ========================================================================== */
@media (max-width: 768px) {
    .contact-page .vp-site-navigation {
        padding: 32px 16px 36px;
    }

    .contact-page .vp-site-navigation .vp-max-width {
        padding: 0;
    }

    .vp-sidebar-form-wrapper .vp-form {
        padding: var(--32) var(--24);
    }

    .vp-sidebar-form-wrapper .vp-contact-bg-1 {
        right: -19px;
    }

    .vp-sidebar-form-wrapper .vp-form input,
    .vp-sidebar-form-wrapper .vp-form select,
    .vp-sidebar-form-wrapper .vp-form textarea {
        font-size: var(--16);
        padding: var(--16);
    }

    .vp-sidebar-form-wrapper .vp-form textarea {
        min-height: 98px;
    }

    .vp-contact-form .vp-d-flex.vp-f-d-column.vp-a-i-f-start.vp-gap-24 {
        gap: var(--32);
    }

    .vp-contact-form .vp-d-flex .vp-d-flex.vp-f-d-column-mob {
        gap: var(--12);
    }

    .vp-sidebar-form-wrapper .vp-hero-email,
    .vp-sidebar-form-wrapper .vp-hero-call {
        max-width: 100%;
        padding: var(--12) var(--20);
        gap: 8px;
    }

    .vp-sidebar-form-wrapper .vp-contact-info-more .vp-btn-simple-two-large span:first-child {
        border-right: none;
        padding-right: 0;
    }

    .vp-contact-form .vp-contact-info-more .vp-d-flex .vp-d-flex.vp-f-d-column-mob {
        gap: 8px;
    }

    .vp-sidebar-form-wrapper {
        position: static;
        max-height: none;
        overflow-y: visible;
    }
}

@media (max-width: 700px) {
    .vp-sidebar-form-wrapper .vp-contact-bg-1 {
        right: -16px;
        border-radius: 0;
    }
}

@media (max-width: 600px) {
    .gm-form .wpforms-field-layout-rows .wpforms-layout-row {
        margin-bottom: 12px;
        gap: 12px;
    }
}

/* ========================================
   Mobile Sticky CTA Button
   ======================================== */
   .vp-sticky-cta {
    position: fixed;
    bottom: -80px;
    left: 0;
    right: 0;
    z-index: 999;
    padding: 16px;
    background: linear-gradient(0deg, rgba(255, 255, 255, 0.95) 70%, rgba(255, 255, 255, 0) 100%);
    display: none;
    transition: bottom 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.vp-sticky-cta.is-visible {
    bottom: 0;
}

.vp-sticky-cta-btn {
    display: flex;
    width: 100%;
    padding: 18px 24px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border: none;
    border-radius: 16px;
    background: var(--Primary-primary, #8C58DA);
    box-shadow: 0 8px 24px rgba(140, 88, 218, 0.35);
    color: #fff;
    font-family: var(--font-family-onest);
    font-size: 18px;
    font-weight: 700;
    line-height: 140%;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
}

.vp-sticky-cta-btn:hover {
    background: var(--Secondary-1, #7B4BC4);
    box-shadow: 0 10px 28px rgba(140, 88, 218, 0.45);
    transform: translateY(-2px);
}

.vp-sticky-cta-btn:active {
    transform: translateY(0);
}

/* Only show on mobile */
@media (min-width: 999px) {
    .vp-sticky-cta {
        display: none !important;
    }
}

/* ========================================
   Responsive Styles
   ======================================== */
   @media (max-width: 998px) {
    .vp-service-content-grid {
        flex-direction: column-reverse;
        gap: 60px;
    }

    .vp-service-sidebar {
        position: static;
        max-height: 100%;
    }

    .vp-sidebar-form-wrapper .vp-form {
        min-width: 100%;
    } 
    .vp-sidebar-form-wrapper .vp-form{
        max-width: 100%;
    }
    .vp-sticky-cta {
        display: block;
    }
    
    /* Add padding to last section before footer */
    .vp-single-service-area .vp-sa-partners,
    .vp-single-service-area .vp-service-reviews:last-of-type {
        padding-bottom: 160px;
    }
}