/* -----------------------
   Partners Filters Section
------------------------- */
.partners-filters {
    background: #a7c1b0; /* soft green background */
    padding: 20px;
    border-radius: 10px;
    margin-bottom: 30px;
}

/* Filters row layout */
.filters-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 20px;
    width: 100%;
    justify-content: space-between;
}

/* Individual filter columns */
.filter-search {
    width: 50%;
}

.filter-expertise {
    width: 20%;
}

.filter-col.buttons {
    display: flex;
    gap: 10px;
    align-self: flex-end;
    width: 25%;
    align-items: flex-end;
    justify-content: space-between;
}

/* Labels and inputs */
.filter-col label {
    display: block;
    font-weight: 500;
    margin-bottom: 5px;
}

.filter-col input,
.filter-col select {
    padding: 10px 10px !important;
    border-radius: 6px !important;
    width: 100% !important;
    background: white !important;
}
.filter-col select {
    appearance: none; /* Remove default styling */
    -webkit-appearance: none; /* For Safari */
    -moz-appearance: none; /* For Firefox */
}

/* Buttons */
.partners-btn-apply {
    background: #d7de70;
    border: none;
    padding: 8px 20px !important;
    height: 43px;
    cursor: pointer;
    font-weight: 600;
    font-size: 13px !important;
}

/* -----------------------
   Tablet: 2-row layout
------------------------- */
@media (max-width: 1024px) and (min-width: 641px) {
    .filters-row {
        align-items: stretch;
    }

    /* Row 1: search takes full width */
    .filter-search {
        width: 100% !important;
    }

    /* Row 2: expertise + buttons side by side */
    .filter-row-second {
        display: flex;
        gap: 20px;
        justify-content: space-between;
    }

    .filter-expertise {
        flex: 1;
    }

    .filter-col.buttons {
        flex: 1;
        display: flex;
        gap: 10px;
        justify-content: space-around;
        align-items: flex-end;
    }
}


/* -----------------------
   Mobile: stacked layout
------------------------- */
@media (max-width: 640px) {
    .filters-row {
        flex-direction: column;
        align-items: stretch;
    }
    .filter-search,
    .filter-expertise,
    .filter-col.buttons {
        width: 100% !important;
        margin-right: 0;
    }
    .filter-col.buttons {
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
        justify-content: stretch;
    }
    .partners-btn-apply {
        width: 100%;
    }
}


/* Partner Grid */
.partners-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

@media (max-width: 1024px) {
    .partners-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .partners-grid {
        grid-template-columns: 1fr;
    }
}
.partner-card {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transition: transform .2s ease;
}
.partner-card:hover {
    transform: translateY(-4px);
}
.partner-card-inner {
    display: flex;
    gap: 15px;
    padding: 20px;
    align-items: flex-start;
}

.website-location {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: flex-start;
}

.partner-website, .partner-location {
    display: flex;
    gap: 2px;
}
.partners-logo img {
    width: 60px !important;
    height: 60px !important;
    border-radius: 10% !important;
    object-fit: cover !important;
}
.partner-details {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.partner-name {
    margin: 0;
    font-weight: 600;
}
.partner-website,
.partner-location {
    font-size: 0.9rem;
    color: #555;
    margin: 2px 0;
}
.partner-tags {
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.partners-tag {
    background: #456152 !important;
    color: #fff !important;
    padding: 6px 30px !important;
    border-radius: 16px !important;
    font-size: 0.8rem !important;
}

.partner-website .icon,
.partner-location .icon,
.partner-website .dashicons,
.partner-location .dashicons {
    margin-right: 6px;
    vertical-align: middle;
}


.partners-directory-wrapper {
    margin-left: 0 !important;
    margin-right: 0 !important;
    max-width: 100% !important;
    padding-bottom: 40px;
    margin-top: 40px;
}

/* Partner header */
.pd-partner-header {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 20px;
}
.pd-partner-logo img {
    width: 60px;
    height: 60px;
    object-fit: contain;
    border-radius: 6px;
}
.pd-partner-info h2 {
    margin: 0;
    font-size: 20px;
}
.pd-partner-links {
    display: flex;
    gap: 15px;
    font-size: 14px;
    color: #555;
}

/* Sections */
.pd-section {
    background: #f9f9f9;
    border-radius: 8px;
    padding: 15px;
    margin-bottom: 15px;
}
.pd-section h4 {
    margin: 0 0 10px;
    font-size: 16px;
    font-weight: 600;
}
.pd-modal-expertise span,
.pd-modal-benefits span {
    display: inline-block;
    background: #3b5d50;
    color: #fff;
    padding: 4px 10px;
    border-radius: 12px;
    font-size: 13px;
    margin: 3px 5px 0 0;
}






