/**
 * PCLRC improved properties — search toolbar, grid, table, map, property detail.
 *
 * Preview (list): …/pclrc-parcel-search-preview.php — static …/pclrc-parcel-search-preview.html
 * Preview (detail): …/pclrc-parcel-detail-preview.php — static …/pclrc-parcel-detail-preview.html
 *
 * Embed (pclrc.pps.land): one <link> in the iframe <head> covers list + detail views.
 * <link rel="stylesheet" href="https://pclbdevenvironment.kinsta.cloud/wp-content/themes/Divi-child/assets/css/pclrc-parcel-search.css" />
 *
 * Detail rules use .parcel-views:has(.parcel-detail-main-columns) so listing UI is unchanged.
 *
 * Palette: primary #00558C, page bg #F8F9FA, borders #D1D5DB, body #4B5563
 */






body .entry-content:has(.parcel-views),
body .entry-content:has(.view-toolbar) {
    font-family: var(--font-family-heading, Outfit);
    background-color: #fff;
    margin-left: -1rem;
    margin-right: -1rem;
    max-width: none;
    padding: 0 20px 20px 20px !important;
}

.parcel-list-grid-view.view-show {
    padding: 0px !important;
}

/* Form controls do not inherit font-family reliably across browsers. */
body .entry-content:has(.parcel-views) input,
body .entry-content:has(.parcel-views) select,
body .entry-content:has(.parcel-views) button,
body .entry-content:has(.parcel-views) textarea,
body .entry-content:has(.view-toolbar) input,
body .entry-content:has(.view-toolbar) select,
body .entry-content:has(.view-toolbar) button,
body .entry-content:has(.view-toolbar) textarea {
    font-family: var(--font-family-heading, Outfit);
}

@media (min-width: 981px) {
    body .entry-content:has(.parcel-views),
    body .entry-content:has(.view-toolbar) {
        padding-left: 0;
        padding-right: 0;
        margin-left: 0;
        margin-right: 0;
    }
}

body .entry-content .view-toolbar {
    margin-bottom: 1rem;
}

body .entry-content .view-toolbar form.wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.875rem 1rem;
    margin: 0;
    padding: 1.5rem 1.5rem 1.25rem;
    background: #fff;
    border: 1px solid #d1d5db;
    border-radius: 12px;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

body .entry-content .view-toolbar form.wrap::before {
    content: "Property Search";
    flex: 1 1 100%;
    order: 0;
    margin: 0 0 0.25rem;
    padding: 0;
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.2;
    color: #00558c;
    letter-spacing: -0.02em;
}

body .entry-content .view-toolbar .form-input {
    order: 1;
    flex: 1 1 160px;
    min-width: 0;
    margin: 0;
}

body .entry-content .view-toolbar .filter-button {
    order: 1;
    flex: 0 0 auto;
    margin: 0;
}

body .entry-content .view-toolbar form.wrap::after {
    content: "";
    flex-basis: 100%;
    height: 0;
    order: 2;
    overflow: hidden;
}

body .entry-content .view-toolbar .view-button {
    order: 3;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin: 0;
    padding: 0.625rem 0.875rem;
    min-height: 44px;
    border-radius: 8px;
    border: 1px solid transparent;
    background: #f3f4f6;
    color: #6b7280;
    text-decoration: none;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

body .entry-content .view-toolbar .view-button svg {
    width: 1.125rem;
    height: 1.125rem;
    fill: currentColor;
    flex-shrink: 0;
}

body .entry-content .view-toolbar .view-button span {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

body .entry-content .view-toolbar .view-button:hover,
body .entry-content .view-toolbar .view-button:focus-visible {
    background: #e5e7eb;
    color: #00558c;
}

body .entry-content .view-toolbar .view-button.active {
    background: #e0f0f7;
    color: #00558c;
    border-color: #b8d4e6;
}

body .entry-content .view-toolbar .form-input label {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    margin: 0;
    font-size: 0.75rem;
    font-weight: 700;
    color: #4b5563;
    line-height: 1.2;
}

body .entry-content .view-toolbar .form-input input[type="text"],
body .entry-content .view-toolbar .form-input input:not([type]),
body .entry-content .view-toolbar .form-input select {
    width: 100% !important;
    max-width: 100%;
    margin: 0;
    padding: 0.5rem 0.75rem;
    font-size: 0.9375rem;
    line-height: 1.4;
    color: #1f2937;
    background: #fff;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    box-sizing: border-box;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body .entry-content .view-toolbar .form-input input:focus,
body .entry-content .view-toolbar .form-input select:focus {
    outline: none;
    border-color: #00558c;
    box-shadow: 0 0 0 3px rgba(0, 85, 140, 0.15);
}

body .entry-content .view-toolbar .filter-button.search-button,
body .entry-content .view-toolbar button.filter-button {
    padding: 0.625rem 1.25rem;
    min-height: 44px;
    border: none;
    border-radius: 8px;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor: pointer;
    background: #00558c;
    color: #fff;
    transition: background-color 0.2s ease, opacity 0.2s ease;
}

body .entry-content .view-toolbar .filter-button:hover,
body .entry-content .view-toolbar .filter-button:focus-visible {
    background: #004670;
}

body .entry-content .parcel-views {
    margin-top: 0.5rem;
}

@media (min-width: 1000px) {
/* Scope to the list container only — ids like parcel-list-grid-view-*-button also start with this prefix. */
    body .entry-content .parcel-list-view.parcel-list-grid-view[id^="parcel-list-grid-view"] {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 1.5rem;
        row-gap: 4rem;
        align-items: stretch;
    }
}

@media (max-width: 1200px) {
    body .entry-content .parcel-list-view.parcel-list-grid-view[id^="parcel-list-grid-view"] {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 600px) {
    body .entry-content .parcel-list-view.parcel-list-grid-view[id^="parcel-list-grid-view"] {
        grid-template-columns: 1fr;
    }
}

/* Property card — matches comp: padded container, rounded image, spec row, address, status, VIEW PROPERTY CTA */
body .entry-content .parcel-card {
    display: flex;
    flex-direction: column;
    height: 100% !important;
    min-height: 500px ! IMPORTANT;
    margin: 0;
    padding: 1.25rem;
    overflow: hidden;
    background: #fff;
    border-radius: 10px;
    border: 1px solid #d1d5db;
    box-shadow: 0 2px 10px rgba(15, 23, 42, 0.06);
}

body .entry-content .parcel-card > div:first-child {
    margin: 0;
    padding: 0;
    width: 100%;
    min-width: 0;
}

body .entry-content .parcel-card .parcel-image {
    display: block;
    width: 100%;
    overflow: hidden;
    border-radius: 8px;
}

body .entry-content .parcel-card .parcel-image img {
    display: block;
    width: 100%;
    max-width: 100%;
    height: 200px;
    object-fit: cover;
    object-position: center;
}

body .entry-content .parcel-card > p {
    margin: 0;
    padding: 0;
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.2;
    color: #00558c;
}

/* Spec row: parcel ID link only (default listing markup) */
body .entry-content .parcel-card > p:first-of-type {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    padding: 0.75rem 0 0.875rem;
    margin: 0;
    margin-top: 0.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: #4b5563;
    background: #fff;
    border: none;
    border-bottom: 1px solid #e5e7eb;
}

body .entry-content .parcel-card > p:first-of-type a {
    color: #374151;
    text-decoration: none;
    font-weight: 700;
    letter-spacing: 0.01em;
}

body .entry-content .parcel-card > p:first-of-type a:hover {
    color: #00558c;
    text-decoration: underline;
    text-underline-offset: 2px;
}

body .entry-content .parcel-card > p:nth-of-type(2) {
    padding-top: 1.25rem;
}

body .entry-content .parcel-card > p:nth-of-type(2)::first-line {
    font-size: clamp(1.125rem, 2.4vw, 1.375rem);
    font-weight: 700;
    color: #00558c;
    line-height: 1.3;
    letter-spacing: -0.01em;
}

body .entry-content .parcel-card > p:nth-of-type(3),
body .entry-content .parcel-card > p:nth-of-type(4) {
    padding-top: 0.75rem;
    font-size: 0.9375rem;
    line-height: 1.5;
}

body .entry-content .parcel-card > p:nth-of-type(4) {
    margin-top: 0.25rem;
}

body .entry-content .parcel-card .parcel-card-label {
    font-weight: 700;
    color: #374151;
}

body .entry-content .parcel-card .parcel-card-value {
    font-weight: 400;
    color: #4b5563;
}

body .entry-content .parcel-card::after {
    content: "View property \2197";
    display: block;
    margin-top: auto;
    padding-top: 0;
    padding-bottom: 0;
    text-transform: uppercase;
    color: #00558c;
    text-decoration: underline;
    text-decoration-color: #00558c;
    text-decoration-thickness: 2px;
    text-underline-offset: 5px;
    font-size: 1rem;
    font-weight: 600;
    line-height: 125%;
    letter-spacing: 0.02rem;
    margin-top: 1rem;
}

body .entry-content .parcel-list-view:not(.parcel-list-grid-view) {
    margin-top: 0.5rem;
}

body .entry-content .parcel-list-view .bootstrap-table .table {
    border-collapse: separate;
    border-spacing: 0;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
    font-size: 0.9375rem;
}

body .entry-content .parcel-list-view .bootstrap-table .table thead th {
    background: #f3f4f6;
    color: #00558c;
    font-weight: 700;
    font-size: 0.8125rem;
    text-transform: none;
    border-bottom: 1px solid #e5e7eb;
    padding: 0.75rem 1rem;
}

body .entry-content .parcel-list-view .bootstrap-table .table tbody td {
    padding: 0.75rem 1rem;
    border-color: #e5e7eb;
    vertical-align: middle;
    color: #374151;
}

body .entry-content .parcel-list-view .bootstrap-table .table tbody tr:hover {
    background: #f9fafb;
}

body .entry-content .parcel-list-view .bootstrap-table .table tbody td a {
    color: #00558c;
    font-weight: 600;
    text-decoration: none;
}

body .entry-content .parcel-list-view .bootstrap-table .table tbody td a:hover {
    text-decoration: underline;
}

body .entry-content #map {
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #e5e7eb;
    min-height: 420px;
}

/* -------------------------------------------------------------------------
 * Property detail page (iframe markup with .parcel-detail-main-columns).
 * Scoped so .parcel-list-view / .view-toolbar layouts are unaffected.
 * ------------------------------------------------------------------------- */

body .entry-content .parcel-views:has(.parcel-detail-main-columns) {
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-header {
    margin: 0 0 1.25rem;
    padding: 0 0 1.25rem;
    border-bottom: 1px solid #e5e7eb;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-header::before {
    content: "Property Details";
    display: block;
    margin: 0 0 1rem;
    font-size: 1.125rem;
    font-weight: 700;
    color: #00558c;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-header p {
    margin: 0;
    white-space: pre-line;
    font-size: 1.125rem;
    font-weight: 700;
    color: #00558c;
    line-height: 1.35;
    letter-spacing: -0.02em;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-header p::first-line {
    font-size: clamp(1.75rem, 4vw, 2.375rem);
    line-height: 1.15;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading {
    margin: 0 0 1.75rem;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem 1.5rem;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links > a:first-child {
    color: #00558c;
    font-weight: 600;
    font-size: 0.9375rem;
    text-decoration: none;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links > a:first-child:hover,
body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links > a:first-child:focus-visible {
    text-decoration: underline;
    text-underline-offset: 3px;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links > a:first-child p {
    margin: 0;
    display: inline;
    font: inherit;
    color: inherit;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links a.link-button.alt {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.625rem 1.25rem;
    min-height: 44px;
    border-radius: 8px;
    border: none;
    background: #00558c;
    color: #fff;
    font-size: 0.8125rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background-color 0.2s ease;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links a.link-button.alt:hover,
body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-detail-heading-links a.link-button.alt:focus-visible {
    background: #004670;
    color: #fff;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-main-columns {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 1fr);
    gap: 2rem 2.5rem;
    align-items: start;
    margin-bottom: 2rem;
}

@media (max-width: 900px) {
    body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-main-columns {
        grid-template-columns: 1fr;
    }

    body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-images-wrapper {
        order: -1;
    }
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .property-details.grid {
    display: grid;
    grid-template-columns: minmax(0, 42%) minmax(0, 1fr);
    column-gap: 1.25rem;
    row-gap: 0;
    margin: 0;
    width: 100%;
    min-width: 0;
}

/*
 * Rows share one height per pair; label + value must stretch (not align-self: center)
 * or border-bottom on each cell sits at different Y when one column is taller.
 */
body .entry-content .parcel-views:has(.parcel-detail-main-columns) .property-details.grid > .parcel-detail-label {
    margin: 0;
    padding: 0.75rem 0;
    font-size: 0.8125rem;
    font-weight: 700;
    color: #374151;
    line-height: 1.4;
    border-bottom: 1px solid #e5e7eb;
    align-self: stretch;
    display: flex;
    align-items: flex-start;
    min-height: 0;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .property-details.grid > .parcel-detail-value {
    margin: 0;
    padding: 0.75rem 0;
    font-size: 0.9375rem;
    font-weight: 400;
    color: #4b5563;
    line-height: 1.5;
    text-align: left;
    border-bottom: 1px solid #e5e7eb;
    white-space: pre-line;
    align-self: stretch;
    min-height: 0;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .property-details.grid > a {
    margin: 0;
    padding: 0.75rem 0;
    font-size: 0.9375rem;
    font-weight: 600;
    color: #00558c;
    text-align: left;
    text-decoration: none;
    border-bottom: 1px solid #e5e7eb;
    align-self: stretch;
    justify-self: stretch;
    display: flex;
    align-items: flex-start;
    max-width: 100%;
    word-break: break-word;
    min-height: 0;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .property-details.grid > a:hover,
body .entry-content .parcel-views:has(.parcel-detail-main-columns) .property-details.grid > a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 2px;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-images-wrapper {
    min-width: 0;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-main-image {
    border-radius: 10px;
    overflow: hidden;
    background: #f3f4f6;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-main-image img {
    display: block;
    width: 100%;
    height: auto;
    max-height: min(520px, 70vh);
    object-fit: cover;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-images-wrapper .mySwiper {
    margin-top: 1rem;
}

/* Thumbnail strip: works with Swiper or plain markup (preview / no-JS). */
body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-images-wrapper .mySwiper .swiper-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-images-wrapper .thumbnail {
    flex: 0 0 auto;
    width: 88px;
    height: 66px;
    overflow: hidden;
    border-radius: 6px;
    border: 1px solid #e5e7eb;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) .parcel-detail-images-wrapper .thumbnail img {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 6px;
    object-fit: cover;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) #parcel-detail-map {
    margin-top: 0.5rem;
}

body .entry-content .parcel-views:has(.parcel-detail-main-columns) #parcel-detail-map #map {
    min-height: 360px;
}