/**
 * WP Medical Directory v2.0 — Frontend Styles
 * Production-grade visual styling. WCAG 2.1 AA compliant.
 * @package WP Medical Directory
 */

:root {
    --wpmd-color-primary: #1a5276;
    --wpmd-color-primary-dark: #0e3650;
    --wpmd-color-primary-light: #d4e6f1;
    --wpmd-color-primary-bg: #eaf2f8;
    --wpmd-color-text: #1e293b;
    --wpmd-color-text-muted: #475569;
    --wpmd-color-text-light: #64748b;
    --wpmd-color-link: #1a5276;
    --wpmd-color-link-hover: #0e3650;
    --wpmd-color-bg: #ffffff;
    --wpmd-color-bg-subtle: #f8fafc;
    --wpmd-color-bg-section: #f1f5f9;
    --wpmd-color-border: #e2e8f0;
    --wpmd-color-border-strong: #94a3b8;
    --wpmd-color-focus: #2563eb;
    --wpmd-color-focus-shadow: rgba(37,99,235,0.3);
    --wpmd-color-success: #166534;
    --wpmd-color-success-bg: #dcfce7;
    --wpmd-color-success-border: #86efac;
    --wpmd-color-info: #1e40af;
    --wpmd-color-info-bg: #dbeafe;
    --wpmd-color-info-border: #93c5fd;
    --wpmd-color-error: #991b1b;
    --wpmd-color-warning-bg: #fef3c7;
    --wpmd-color-warning-text: #78350f;
    --wpmd-space-xs: 0.25rem;
    --wpmd-space-sm: 0.5rem;
    --wpmd-space-md: 1rem;
    --wpmd-space-lg: 1.5rem;
    --wpmd-space-xl: 2rem;
    --wpmd-space-2xl: 3rem;
    --wpmd-text-xs: 0.75rem;
    --wpmd-text-sm: 0.875rem;
    --wpmd-text-base: 1rem;
    --wpmd-text-lg: 1.125rem;
    --wpmd-text-xl: 1.25rem;
    --wpmd-text-2xl: 1.5rem;
    --wpmd-text-3xl: 2rem;
    --wpmd-radius-sm: 0.375rem;
    --wpmd-radius-md: 0.5rem;
    --wpmd-radius-lg: 0.75rem;
    --wpmd-radius-xl: 1rem;
    --wpmd-shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --wpmd-shadow-md: 0 4px 6px -1px rgba(0,0,0,0.07), 0 2px 4px -2px rgba(0,0,0,0.05);
    --wpmd-shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.08), 0 4px 6px -4px rgba(0,0,0,0.04);
    --wpmd-focus-width: 3px;
    --wpmd-focus-offset: 2px;
    --wpmd-touch-min: 44px;
}

/* Skip link */
.wpmd-skip-link { position: absolute; top: -100px; left: 0; z-index: 100000; padding: var(--wpmd-space-md) var(--wpmd-space-lg); background: var(--wpmd-color-primary-dark); color: #fff; font-size: var(--wpmd-text-base); font-weight: 600; text-decoration: none; border: var(--wpmd-focus-width) solid var(--wpmd-color-focus); border-radius: 0 0 var(--wpmd-radius-md) 0; transition: top 0.2s ease; }
.wpmd-skip-link:focus { top: 0; outline: none; }

/* SR only */
.wpmd-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Focus indicators */
.wpmd-directory :focus-visible, .wpmd-directory a:focus-visible, .wpmd-directory button:focus-visible, .wpmd-directory input:focus-visible, .wpmd-directory select:focus-visible, .wpmd-directory textarea:focus-visible, .wpmd-directory [tabindex]:focus-visible { outline: var(--wpmd-focus-width) solid var(--wpmd-color-focus); outline-offset: var(--wpmd-focus-offset); box-shadow: 0 0 0 calc(var(--wpmd-focus-width) + 2px) var(--wpmd-color-focus-shadow); }
#wpmd-main { outline: none; }

/* Directory wrapper */
.wpmd-directory { color: var(--wpmd-color-text); font-size: var(--wpmd-text-base); line-height: 1.65; max-width: 1100px; width: 100%; box-sizing: border-box; margin: 0 auto 30px; padding: var(--wpmd-space-xl) var(--wpmd-space-lg); }
.wpmd-directory a { color: var(--wpmd-color-link); text-decoration: none; font-weight: 500; transition: color 0.15s; }
.wpmd-directory a:hover { color: var(--wpmd-color-link-hover); text-decoration: underline; }

/* Headings */
.wpmd-directory h1 { font-size: var(--wpmd-text-3xl); font-weight: 700; line-height: 1.2; letter-spacing: -0.02em; color: var(--wpmd-color-text); margin: 0 0 var(--wpmd-space-sm); }
.wpmd-directory h2 { font-size: var(--wpmd-text-2xl); font-weight: 700; line-height: 1.3; color: var(--wpmd-color-primary-dark); margin: var(--wpmd-space-xl) 0 var(--wpmd-space-sm); padding-bottom: var(--wpmd-space-xs); border-bottom: 2px solid var(--wpmd-color-primary-light); }
.wpmd-directory h3 { font-size: var(--wpmd-text-xl); font-weight: 600; line-height: 1.4; margin: var(--wpmd-space-lg) 0 var(--wpmd-space-sm); }

/* Sections */
.wpmd-directory section { margin-bottom: var(--wpmd-space-lg); }
.wpmd-directory section ul:not([class]) { padding-left: var(--wpmd-space-lg); margin: 0; }
.wpmd-directory section ul:not([class]) > li { padding: var(--wpmd-space-xs) 0; line-height: 1.5; }

/* Entity header */
.wpmd-entity-header { display: flex; gap: var(--wpmd-space-lg); align-items: flex-start; padding: var(--wpmd-space-lg); margin-bottom: var(--wpmd-space-lg); background: var(--wpmd-color-bg-subtle); border: 1px solid var(--wpmd-color-border); border-radius: var(--wpmd-radius-xl); box-shadow: var(--wpmd-shadow-sm); }
.wpmd-entity-header__image img { width: 100%; max-width: 200px; aspect-ratio: 1; object-fit: cover; border-radius: var(--wpmd-radius-lg); border: 3px solid #fff; box-shadow: var(--wpmd-shadow-md); background: #fff; }
.wpmd-entity-header__content { flex: 1; min-width: 0; }
.wpmd-entity-header__credentials { color: var(--wpmd-color-text-light); font-weight: 400; }
.wpmd-entity-header__specialty { font-size: var(--wpmd-text-lg); color: var(--wpmd-color-primary); font-weight: 500; margin: var(--wpmd-space-xs) 0 var(--wpmd-space-sm); }
@media (max-width: 600px) { .wpmd-entity-header { flex-direction: column; align-items: center; text-align: center; } }

/* Status badges */
.wpmd-status-badges { display: flex; flex-wrap: wrap; gap: var(--wpmd-space-sm); margin: var(--wpmd-space-md) 0 var(--wpmd-space-xs); }
.wpmd-badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 14px; font-size: var(--wpmd-text-sm); font-weight: 600; border-radius: 100px; }
.wpmd-badge--accepting { background: var(--wpmd-color-success-bg); color: var(--wpmd-color-success); border: 1px solid var(--wpmd-color-success-border); }
.wpmd-badge--accepting::before { content: "\2713"; font-weight: 700; }
.wpmd-badge--pcp { background: var(--wpmd-color-primary-bg); color: var(--wpmd-color-primary-dark); border: 1px solid var(--wpmd-color-primary-light); }
.wpmd-badge--pcp::before { content: "\2665"; font-size: 0.8em; }
.wpmd-badge--telehealth { background: var(--wpmd-color-info-bg); color: var(--wpmd-color-info); border: 1px solid var(--wpmd-color-info-border); }
.wpmd-badge--telehealth::before { content: "\25C9"; font-size: 0.7em; }

/* Card meta */
.wpmd-card__meta { color: var(--wpmd-color-text-muted); font-size: var(--wpmd-text-sm); margin: var(--wpmd-space-xs) 0; }
.wpmd-card__meta a { font-weight: 600; position: relative; z-index: 1; } /* above .wpmd-card__link::after overlay */

/* Address / NAP block */
.wpmd-address-block, .wpmd-nap-block { background: var(--wpmd-color-bg-subtle); border-left: 4px solid var(--wpmd-color-primary); padding: 16px 20px; margin: 16px 0; border-radius: 0 var(--wpmd-radius-md) var(--wpmd-radius-md) 0; }
.wpmd-address-block dt, .wpmd-nap-block dt { font-weight: 700; font-size: var(--wpmd-text-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--wpmd-color-text-muted); margin-top: var(--wpmd-space-sm); }
.wpmd-address-block dt:first-child, .wpmd-nap-block dt:first-child { margin-top: 0; }
.wpmd-address-block dd, .wpmd-nap-block dd { margin: var(--wpmd-space-xs) 0 0; }
.wpmd-address-block a, .wpmd-nap-block a { font-weight: 600; }

/* Hours */
.wpmd-hours-list { list-style: none; padding: 0; margin: 0; }
.wpmd-hours-list li { display: flex; justify-content: space-between; max-width: 380px; padding: var(--wpmd-space-sm) 0; border-bottom: 1px solid var(--wpmd-color-border); }
.wpmd-hours-list li:last-child { border-bottom: none; }
.wpmd-hours-list .day { font-weight: 600; }

/* Search results — grouped by CPT */
.wpmd-search-results-type-heading {
    font-size: var(--wpmd-text-xl);
    font-weight: 700;
    color: var(--wpmd-color-primary-dark);
    margin: var(--wpmd-space-xl) 0 var(--wpmd-space-sm);
    padding-bottom: var(--wpmd-space-xs);
    border-bottom: 2px solid var(--wpmd-color-primary-light);
    display: flex;
    align-items: baseline;
    gap: var(--wpmd-space-sm);
}
.wpmd-search-results-type-count {
    font-size: var(--wpmd-text-sm);
    font-weight: 500;
    color: var(--wpmd-color-text-muted);
}

/* Card grid */
.wpmd-card-grid { display: grid; grid-template-columns: 1fr; gap: var(--wpmd-space-md); margin: var(--wpmd-space-lg) 0; padding: 0; width: 100%; box-sizing: border-box; min-width: 0; align-items: start; }
@media (min-width: 600px) { .wpmd-card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .wpmd-card-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 900px) { .wpmd-card-grid.wpmd-card-grid--2col { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .wpmd-card-grid.wpmd-card-grid--4col { grid-template-columns: repeat(4, 1fr); } }
/* Tighter padding on 4-col cards to give content more room */
@media (min-width: 900px) { .wpmd-card-grid--4col .wpmd-card { padding: 14px 16px; } .wpmd-card-grid--4col .wpmd-card__image { margin: -14px -16px 10px; } .wpmd-card-grid--4col .wpmd-card__placeholder { margin: -14px -16px 10px; width: calc(100% + 32px); } .wpmd-card-grid--4col .wpmd-card__title { font-size: var(--wpmd-text-base); } }
.wpmd-shortcode.wpmd-directory { max-width: none; padding-left: 0; padding-right: 0; }

/* Cards */
.wpmd-card { position: relative; display: flex; flex-direction: column; padding: 20px 24px; background: var(--wpmd-color-bg); border: 1px solid var(--wpmd-color-border); border-radius: var(--wpmd-radius-lg); box-shadow: var(--wpmd-shadow-sm); transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s; }
.wpmd-card:hover { box-shadow: var(--wpmd-shadow-lg); border-color: var(--wpmd-color-primary-light); transform: translateY(-2px); }
.wpmd-card__title { font-size: var(--wpmd-text-lg); font-weight: 600; margin: 0 0 var(--wpmd-space-xs); line-height: 1.3; }
.wpmd-card__title a { text-decoration: none; color: var(--wpmd-color-text); }
.wpmd-card__title a:hover { color: var(--wpmd-color-primary); }
.wpmd-card__link::after { content: ""; position: absolute; inset: 0; border-radius: var(--wpmd-radius-lg); }
.wpmd-card__specialty { font-size: var(--wpmd-text-sm); color: var(--wpmd-color-primary); font-weight: 500; margin: 0 0 var(--wpmd-space-sm); }
.wpmd-card__phone { font-size: var(--wpmd-text-sm); color: var(--wpmd-color-text-muted); margin-top: auto; padding-top: var(--wpmd-space-sm); }
.wpmd-card__phone a { font-weight: 600; }
.wpmd-card .wpmd-badge { font-size: var(--wpmd-text-xs); padding: 2px 10px; margin-top: var(--wpmd-space-sm); align-self: flex-start; }

/* Lateral link modules */
.wpmd-lateral-module { margin: var(--wpmd-space-xl) 0; }
.wpmd-lateral-module__title { font-size: var(--wpmd-text-xl); font-weight: 700; color: var(--wpmd-color-primary-dark); margin: 0 0 var(--wpmd-space-md); padding-bottom: var(--wpmd-space-sm); border-bottom: 2px solid var(--wpmd-color-primary-light); }

/* Breadcrumbs */
.wpmd-breadcrumbs { margin-bottom: var(--wpmd-space-lg); font-size: var(--wpmd-text-sm); color: var(--wpmd-color-text-light); }
.wpmd-breadcrumbs ol { display: flex; flex-wrap: wrap; gap: var(--wpmd-space-xs); list-style: none; margin: 0; padding: 0; }
.wpmd-breadcrumbs li:not(:last-child)::after { content: "\203A"; margin-left: var(--wpmd-space-xs); color: var(--wpmd-color-border-strong); }
.wpmd-breadcrumbs a { font-weight: 500; }

/* Map */
.wpmd-map-embed { border-radius: var(--wpmd-radius-lg); overflow: hidden; margin: var(--wpmd-space-lg) 0; border: 1px solid var(--wpmd-color-border); }
.wpmd-map-embed iframe { display: block; width: 100%; height: 300px; border: 0; }

/* Lunch notice */
.wpmd-lunch-notice { background: var(--wpmd-color-primary-bg); border: 1px solid var(--wpmd-color-primary-light); border-radius: var(--wpmd-radius-md); padding: var(--wpmd-space-md) var(--wpmd-space-lg); margin: var(--wpmd-space-md) 0; font-size: var(--wpmd-text-sm); color: var(--wpmd-color-primary-dark); }

/* Accessibility badges */
.wpmd-accessibility-badges { display: flex; flex-wrap: wrap; gap: var(--wpmd-space-sm); margin: var(--wpmd-space-md) 0; }
.wpmd-accessibility-badge { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; font-size: var(--wpmd-text-sm); color: var(--wpmd-color-text-muted); background: var(--wpmd-color-bg-subtle); border: 1px solid var(--wpmd-color-border); border-radius: 100px; }

/* Info list */
.wpmd-info-list { margin: var(--wpmd-space-md) 0; }
.wpmd-info-list dt { font-weight: 700; font-size: var(--wpmd-text-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--wpmd-color-text-muted); margin-top: var(--wpmd-space-md); }
.wpmd-info-list dt:first-child { margin-top: 0; }
.wpmd-info-list dd { margin: var(--wpmd-space-xs) 0 0; }

/* Forms */
.wpmd-form { background: var(--wpmd-color-bg-subtle); border: 1px solid var(--wpmd-color-border); border-radius: var(--wpmd-radius-xl); padding: var(--wpmd-space-xl); margin: var(--wpmd-space-xl) 0; }
.wpmd-form__field { display: flex; flex-direction: column; gap: var(--wpmd-space-xs); margin-bottom: var(--wpmd-space-lg); }
.wpmd-form__label { font-weight: 600; font-size: var(--wpmd-text-sm); }
.wpmd-form__label .wpmd-required { color: var(--wpmd-color-error); margin-left: 2px; }
.wpmd-form__help { font-size: var(--wpmd-text-sm); color: var(--wpmd-color-text-light); margin: 0; }
.wpmd-form__error { font-size: var(--wpmd-text-sm); color: var(--wpmd-color-error); margin: 0; font-weight: 600; }
.wpmd-form__input, .wpmd-form__select, .wpmd-form__textarea { min-height: var(--wpmd-touch-min); padding: var(--wpmd-space-sm) var(--wpmd-space-md); font-size: var(--wpmd-text-base); color: var(--wpmd-color-text); background: #fff; border: 1.5px solid var(--wpmd-color-border-strong); border-radius: var(--wpmd-radius-md); width: 100%; box-sizing: border-box; transition: border-color 0.15s, box-shadow 0.15s; }
.wpmd-form__input:focus, .wpmd-form__select:focus, .wpmd-form__textarea:focus { border-color: var(--wpmd-color-primary); box-shadow: 0 0 0 3px rgba(26,82,118,0.15); }
.wpmd-form__textarea { min-height: 120px; resize: vertical; }
.wpmd-form__field--invalid .wpmd-form__input, .wpmd-form__field--invalid .wpmd-form__select, .wpmd-form__field--invalid .wpmd-form__textarea { border-color: var(--wpmd-color-error); }
.wpmd-button { display: inline-flex; align-items: center; justify-content: center; gap: var(--wpmd-space-sm); min-height: var(--wpmd-touch-min); padding: var(--wpmd-space-sm) var(--wpmd-space-xl); font-size: var(--wpmd-text-base); font-weight: 600; color: #fff; background: var(--wpmd-color-primary); border: 2px solid var(--wpmd-color-primary); border-radius: var(--wpmd-radius-md); cursor: pointer; text-decoration: none; transition: background 0.15s, box-shadow 0.15s; }
.wpmd-button:hover { background: var(--wpmd-color-primary-dark); border-color: var(--wpmd-color-primary-dark); color: #fff; box-shadow: var(--wpmd-shadow-md); }
.wpmd-button--secondary { color: var(--wpmd-color-primary); background: #fff; }
.wpmd-button--secondary:hover { color: #fff; background: var(--wpmd-color-primary); }

/* PHI warning */
.wpmd-phi-warning { margin: var(--wpmd-space-lg) 0; padding: var(--wpmd-space-md) var(--wpmd-space-lg); background: var(--wpmd-color-warning-bg); color: var(--wpmd-color-warning-text); border: 1px solid #fbbf24; border-radius: var(--wpmd-radius-md); font-size: var(--wpmd-text-sm); }
.wpmd-phi-warning strong { display: block; margin-bottom: var(--wpmd-space-xs); }

/* Search shell styles live in search.css to avoid conflicts. */

/* No results */
.wpmd-no-results { text-align: center; padding: var(--wpmd-space-xl); color: var(--wpmd-color-text-muted); font-style: italic; }

/* List layout (layout="list" shortcode attribute) */
.wpmd-provider-list--contributors { margin-left: 1.25rem; }
.wpmd-provider-list__item { margin-bottom: 0.35rem; }

/* Provider card phone */
.wpmd-card__phone { font-size: var(--wpmd-text-sm, 0.875rem); margin: 4px 0 0; }
.wpmd-card__phone a { color: var(--wpmd-color-primary, #1a5276); text-decoration: none; font-weight: 500; }
.wpmd-card__phone a:hover { text-decoration: underline; }

/* Provider card network badges */
.wpmd-card__networks { display: flex; flex-wrap: wrap; gap: 4px; margin: 8px 0 0; }
.wpmd-badge--network { font-size: 11px; padding: 3px 8px; border-radius: 10px; background: #f1f5f9; color: #475569; border: 1px solid #e2e8f0; text-decoration: none; line-height: 1.3; }
.wpmd-badge--network:hover { opacity: 0.85; text-decoration: none; }

/* Compact card layout (layout="compact" shortcode attribute) */
.wpmd-compact-card { background: #fff; border: 1px solid var(--wpmd-color-border, #e5e7eb); border-radius: var(--wpmd-radius-md, 8px); padding: 16px 20px; }
.wpmd-compact-card__name { font-size: var(--wpmd-text-lg, 1.125rem); font-weight: 600; color: var(--wpmd-color-primary, #1a5276); text-decoration: none; display: block; margin-bottom: 4px; }
.wpmd-compact-card__name:hover { text-decoration: underline; }
.wpmd-compact-card__specialty { font-size: var(--wpmd-text-sm, 0.875rem); color: var(--wpmd-color-text-muted, #6b7280); margin-bottom: 10px; }
.wpmd-compact-card__address { font-size: var(--wpmd-text-sm, 0.875rem); color: var(--wpmd-color-text, #374151); line-height: 1.5; margin-bottom: 6px; }
.wpmd-compact-card__phone { font-size: var(--wpmd-text-sm, 0.875rem); }
.wpmd-compact-card__phone a { color: var(--wpmd-color-primary, #1a5276); text-decoration: none; font-weight: 500; }
.wpmd-compact-card__phone a:hover { text-decoration: underline; }

/* Empty state */
.wpmd-empty-state { text-align: center; padding: var(--wpmd-space-2xl) var(--wpmd-space-md); color: var(--wpmd-color-text-muted); }

/* Pagination */
.wpmd-pagination { margin: var(--wpmd-space-xl) 0; text-align: center; }
.wpmd-pagination .page-numbers { display: inline-flex; gap: var(--wpmd-space-xs); list-style: none; padding: 0; margin: 0; }
.wpmd-pagination .page-numbers li a, .wpmd-pagination .page-numbers li span { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 var(--wpmd-space-sm); border: 1px solid var(--wpmd-color-border); border-radius: var(--wpmd-radius-md); font-size: var(--wpmd-text-sm); font-weight: 600; color: var(--wpmd-color-text); background: #fff; text-decoration: none; transition: all 0.15s; }
.wpmd-pagination .page-numbers li a:hover { background: var(--wpmd-color-primary-bg); border-color: var(--wpmd-color-primary-light); color: var(--wpmd-color-primary); }
.wpmd-pagination .page-numbers li span.current { background: var(--wpmd-color-primary); border-color: var(--wpmd-color-primary); color: #fff; }

/* ─── Enhanced entity page layouts ─────────────────────────── */

/* Two-column profile layout for Provider pages with photo */
@media (min-width: 768px) {
    .wpmd-entity-header.has-image {
        display: grid;
        grid-template-columns: 200px 1fr;
        gap: var(--wpmd-space-xl);
        align-items: start;
    }
    .wpmd-entity-header.has-image .wpmd-entity-header__image {
        position: sticky;
        top: var(--wpmd-space-xl);
    }
}

/* Quick actions bar — phone + appointment CTA */
.wpmd-quick-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--wpmd-space-sm);
    margin-top: var(--wpmd-space-md);
    padding-top: var(--wpmd-space-md);
    border-top: 1px solid var(--wpmd-color-border);
}
.wpmd-quick-actions a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 18px;
    border-radius: var(--wpmd-radius-md);
    font-size: var(--wpmd-text-sm);
    font-weight: 600;
    text-decoration: none;
    transition: all 0.15s;
}
.wpmd-quick-actions .wpmd-cta-phone {
    background: var(--wpmd-color-bg-section);
    color: var(--wpmd-color-text);
    border: 1px solid var(--wpmd-color-border);
}
.wpmd-quick-actions .wpmd-cta-phone:hover {
    background: var(--wpmd-color-primary-bg);
    border-color: var(--wpmd-color-primary-light);
}
.wpmd-quick-actions .wpmd-cta-appointment {
    background: var(--wpmd-color-primary);
    color: #fff;
    border: 1px solid var(--wpmd-color-primary);
}
.wpmd-quick-actions .wpmd-cta-appointment:hover {
    background: var(--wpmd-color-primary-dark);
}

/* Tag pill lists — transform ul into wrapped tag layout for
   conditions, procedures, insurance, languages, service area */
.wpmd-directory section ul.wpmd-tag-list,
.wpmd-directory .wpmd-tag-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    list-style: none;
    padding: 4px 0;
    margin: var(--wpmd-space-sm) 0;
}
.wpmd-tag-list li {
    display: inline-flex;
    align-items: center;
    padding: 7px 22px;
    background: var(--wpmd-color-primary-bg);
    border: 1px solid var(--wpmd-color-primary-light);
    border-radius: 100px;
    font-size: var(--wpmd-text-sm);
    color: var(--wpmd-color-primary-dark);
    font-weight: 500;
    line-height: 1.3;
    white-space: nowrap;
}
.wpmd-tag-list li:hover {
    background: var(--wpmd-color-primary-light);
    border-color: var(--wpmd-color-primary);
}

/* Section panels — grouped content blocks */
.wpmd-section-panel {
    background: var(--wpmd-color-bg-subtle);
    border: 1px solid var(--wpmd-color-border);
    border-radius: var(--wpmd-radius-lg);
    padding: var(--wpmd-space-lg) var(--wpmd-space-xl);
    margin: var(--wpmd-space-lg) 0;
}
.wpmd-section-panel h2 {
    margin-top: 0;
    border-bottom: none;
    padding-bottom: 0;
}

/* Two-column section grid for side-by-side content */
@media (min-width: 768px) {
    .wpmd-two-col {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--wpmd-space-xl);
    }
}

/* Education / certification entries — structured list */
.wpmd-structured-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.wpmd-structured-list li {
    padding: var(--wpmd-space-md) 0;
    border-bottom: 1px solid var(--wpmd-color-border);
    line-height: 1.5;
}
.wpmd-structured-list li:last-child {
    border-bottom: none;
}
.wpmd-structured-list .wpmd-entry-primary {
    font-weight: 600;
    color: var(--wpmd-color-text);
}
.wpmd-structured-list .wpmd-entry-secondary {
    font-size: var(--wpmd-text-sm);
    color: var(--wpmd-color-text-muted);
}

/* Insurance accepted — pill grid */
.wpmd-insurance-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    list-style: none;
    padding: 0;
}
.wpmd-insurance-list li {
    padding: 6px 16px;
    background: #fff;
    border: 1px solid var(--wpmd-color-border);
    border-radius: var(--wpmd-radius-md);
    font-size: var(--wpmd-text-sm);
    font-weight: 500;
}

/* Appointment form CTA section */
.wpmd-appointment-cta {
    background: var(--wpmd-color-primary-bg);
    border: 1px solid var(--wpmd-color-primary-light);
    border-radius: var(--wpmd-radius-xl);
    padding: var(--wpmd-space-xl);
    margin: var(--wpmd-space-2xl) 0;
}
.wpmd-appointment-cta h2 {
    color: var(--wpmd-color-primary-dark);
    margin-top: 0;
    border-bottom: none;
}

/* Content prose — bio/description blocks */
.wpmd-directory .wpmd-prose {
    font-size: var(--wpmd-text-base);
    line-height: 1.75;
    color: var(--wpmd-color-text);
    max-width: 70ch;
}
.wpmd-directory .wpmd-prose p {
    margin: 0 0 var(--wpmd-space-md);
}

/* NPI verification link styling */
.wpmd-npi-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    background: var(--wpmd-color-bg-section);
    border: 1px solid var(--wpmd-color-border);
    border-radius: var(--wpmd-radius-sm);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: var(--wpmd-text-sm);
    font-weight: 600;
    text-decoration: none;
}
.wpmd-npi-link:hover {
    background: var(--wpmd-color-primary-bg);
    border-color: var(--wpmd-color-primary-light);
}

/* Archive page header */
.wpmd-archive-header {
    margin-bottom: var(--wpmd-space-2xl);
    padding-bottom: var(--wpmd-space-xl);
    border-bottom: 2px solid var(--wpmd-color-primary-light);
}
.wpmd-archive-header h1 {
    color: var(--wpmd-color-primary-dark);
}
.wpmd-archive-header p {
    color: var(--wpmd-color-text-muted);
    font-size: var(--wpmd-text-lg);
    max-width: 60ch;
}

/* Active filter subtitle on archive pages */
.wpmd-archive-subtitle {
    font-size: var(--wpmd-text-lg);
    font-weight: 600;
    color: var(--wpmd-color-primary);
    margin: 0 0 var(--wpmd-space-md);
}

/* Card image thumbnails — only applies when image is present */
.wpmd-card__image {
    margin: -20px -24px 12px;
    overflow: hidden;
    border-radius: var(--wpmd-radius-lg) var(--wpmd-radius-lg) 0 0;
    /* Force consistent height — prevents portrait photos from blowing out the card */
    aspect-ratio: 1;
    position: relative;
}
.wpmd-card__image img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; position: absolute; top: 0; left: 0; }

/* Placeholder when no image is set */
.wpmd-card__placeholder {
    margin: -20px -24px 10px;
    /* Explicit width so the placeholder always spans edge-to-edge regardless
     * of browser differences in align-self:stretch + negative-margin handling.
     * 100% = card content width = border_width - 48px, so +48px = border_width. */
    width: calc(100% + 48px);
    aspect-ratio: 1;
    height: auto;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--wpmd-radius-lg) var(--wpmd-radius-lg) 0 0;
}
.wpmd-card__placeholder svg { width: 32px; height: 32px; opacity: 0.2; display: block; }
.wpmd-card__placeholder--provider { background: linear-gradient(135deg, var(--wpmd-color-primary-bg) 0%, var(--wpmd-color-primary-light) 100%); color: var(--wpmd-color-primary); }
.wpmd-card__placeholder--location { background: #f0fdf4; color: #86efac; }
.wpmd-card__placeholder--brand { background: linear-gradient(135deg, var(--wpmd-color-bg-section) 0%, var(--wpmd-color-border) 100%); color: var(--wpmd-color-text-muted); }

/* Card type badge (e.g. "Urgent Care", "Medical Clinic") */
.wpmd-card__type {
    display: inline-block;
    font-size: var(--wpmd-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--wpmd-color-primary);
    margin-bottom: var(--wpmd-space-xs);
}

/* ─── Responsive refinements ──────────────────────────────── */
@media (max-width: 600px) {
    .wpmd-directory { padding: var(--wpmd-space-md); }
    .wpmd-entity-header { padding: var(--wpmd-space-lg); }
    .wpmd-directory h1 { font-size: var(--wpmd-text-2xl); }
    .wpmd-directory h2 { font-size: var(--wpmd-text-xl); }
    .wpmd-section-panel { padding: var(--wpmd-space-md); }
    .wpmd-address-block, .wpmd-nap-block { padding: var(--wpmd-space-md); }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) { .wpmd-directory *, .wpmd-directory *::before, .wpmd-directory *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; } .wpmd-skip-link { transition: none; } }

/* High contrast */
@media (forced-colors: active) { .wpmd-card, .wpmd-form__input, .wpmd-form__select, .wpmd-form__textarea, .wpmd-button, .wpmd-badge, .wpmd-entity-header { border: 2px solid CanvasText; } .wpmd-button { background: ButtonFace; color: ButtonText; } }

/* Print */
@media print { .wpmd-skip-link, .wpmd-search-shell, .wpmd-lateral-module, .wpmd-form, .wpmd-button { display: none; } .wpmd-directory { max-width: 100%; padding: 0; color: #000; } .wpmd-entity-header { background: none; border: none; box-shadow: none; } .wpmd-card { box-shadow: none; break-inside: avoid; } }

/* ─── Load More ────────────────────────────────────────────────────── */

.wpmd-load-more-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--wpmd-space-md);
    margin: var(--wpmd-space-xl) 0;
    padding-top: var(--wpmd-space-lg);
    border-top: 1px solid var(--wpmd-color-border);
}

.wpmd-load-more-status {
    font-size: var(--wpmd-text-sm);
    color: var(--wpmd-color-text-muted);
    margin: 0;
}

.wpmd-load-more-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: var(--wpmd-touch-min);
    min-width: 160px;
    padding: var(--wpmd-space-sm) var(--wpmd-space-xl);
    font-size: var(--wpmd-text-base);
    font-weight: 600;
    color: var(--wpmd-color-primary);
    background: var(--wpmd-color-bg);
    border: 2px solid var(--wpmd-color-primary);
    border-radius: var(--wpmd-radius-md);
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
    font-family: inherit;
}

.wpmd-load-more-btn:hover {
    background: var(--wpmd-color-primary);
    color: #fff;
}

.wpmd-load-more-btn:focus-visible {
    outline: var(--wpmd-focus-width) solid var(--wpmd-color-focus);
    outline-offset: var(--wpmd-focus-offset);
    box-shadow: 0 0 0 calc(var(--wpmd-focus-width) + 2px) var(--wpmd-color-focus-shadow);
}

.wpmd-load-more-btn:disabled {
    opacity: 0.65;
    cursor: not-allowed;
    /* Keep border/color so layout doesn't shift while loading */
}

.wpmd-load-more-error {
    display: block;
    font-size: var(--wpmd-text-sm);
    color: var(--wpmd-color-error);
    margin-top: var(--wpmd-space-xs);
}

@media (prefers-reduced-motion: reduce) {
    .wpmd-load-more-btn { transition: none; }
}
