/**
 * FR Register — Frontend base styles (uses CSS vars from wp_head injection)
 */

.fr-directory-wrap { max-width: 1200px; margin: 0 auto; }
.fr-directory-filters { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; padding: 16px; background: var(--fr-bg-light, #F4F6F9); border: 1px solid var(--fr-border, #E8ECF1); border-radius: 8px; }
.fr-directory-filters select,
.fr-directory-filters input[type="search"] {
  padding: 8px 12px;
  border: 1px solid var(--fr-border, #E8ECF1);
  border-radius: 4px;
  font-family: var(--fr-font-body, sans-serif);
  color: var(--fr-primary, #0D1B2A);
  background-color: #fff;
}
.fr-directory-filters select option {
  color: #0D1B2A;
  background-color: #fff;
}
/* Divi dark sections often force white text on selects — keep directory filters readable */
.et_pb_section .fr-directory-filters select,
.et_pb_section .fr-directory-filters input[type="search"] {
  color: #0D1B2A !important;
  background-color: #fff !important;
}
.et_pb_section .fr-directory-filters select option {
  color: #0D1B2A !important;
  background-color: #fff !important;
}
.fr-btn-primary { display: inline-block; padding: 10px 20px; background: var(--fr-accent, #E8930A); color: var(--fr-primary, #0D1B2A); font-weight: 700; text-decoration: none; border: none; border-radius: 6px; cursor: pointer; font-family: var(--fr-font-body, sans-serif); }
.fr-btn-primary:hover { background: var(--fr-accent-hover, #F5A623); }
.fr-directory-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.fr-listing-card { background: #fff; border: 1px solid var(--fr-border, #E8ECF1); border-radius: 8px; overflow: hidden; transition: border-color 0.2s; }
.fr-listing-card:hover { border-color: var(--fr-accent, #E8930A); }
.fr-listing-card--featured { border-color: var(--fr-accent, #E8930A); box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.fr-listing-card-link { display: block; padding: 20px; text-decoration: none; color: inherit; }
.fr-listing-title { font-family: var(--fr-font-heading, sans-serif); font-size: 18px; font-weight: 800; color: var(--fr-primary, #0D1B2A); text-transform: uppercase; margin: 0 0 8px; }
.fr-listing-excerpt { font-size: 14px; color: var(--fr-text, #4A5768); margin: 0 0 12px; line-height: 1.5; }
.fr-tier-pill { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 700; }
.fr-badge-verified { display: inline-block; padding: 3px 8px; border-radius: 100px; font-size: 11px; font-weight: 600; background: var(--fr-success-lt, #EBF7F1); color: var(--fr-success, #1A7A4A); margin-left: 6px; }
.fr-get-listed-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 20px; }
.fr-tier-card-front { background: #fff; border: 1px solid var(--fr-border, #E8ECF1); border-radius: 8px; padding: 28px 24px; text-align: center; }
.fr-tier-card-front.is-popular { border-color: var(--fr-accent, #E8930A); border-width: 2px; }
.fr-tier-price { font-size: 36px; font-weight: 800; color: var(--fr-primary, #0D1B2A); font-family: var(--fr-font-heading, sans-serif); }
.fr-account-panel { background: var(--fr-bg-light, #F4F6F9); border: 1px solid var(--fr-border, #E8ECF1); border-radius: 8px; padding: 24px; margin-bottom: 20px; }
.fr-section-title { font-family: var(--fr-font-heading, sans-serif); font-size: 14px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; color: var(--fr-primary, #0D1B2A); margin: 0 0 16px; }
.fr-ver-message { display: none; padding: 12px 16px; border-radius: 6px; margin-bottom: 16px; }
.fr-ver-message.fr-success { background: var(--fr-success-lt, #EBF7F1); color: var(--fr-success, #1A7A4A); }
.fr-ver-message.fr-error { background: #FEF2F2; color: #DC2626; }

/* FM registration (client account guest) */
.fr-fm-register__hero {
    background: var(--fr-primary, #0D1B2A);
    padding: 64px 24px 56px;
}
.fr-fm-register__grid {
    max-width: 1180px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
}
.fr-fm-register__title {
    font-family: var(--fr-font-heading, sans-serif);
    font-size: clamp(32px, 4vw, 48px);
    font-weight: 900;
    text-transform: uppercase;
    color: #fff;
    line-height: 1.1;
    margin: 0 0 16px;
}
.fr-fm-register__title span { color: var(--fr-accent, #E8930A); }
.fr-fm-register__lead {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.65);
    line-height: 1.7;
    margin: 0 0 28px;
}
.fr-fm-register__benefits {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.fr-fm-register__benefits li {
    display: flex;
    gap: 14px;
    align-items: flex-start;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.55);
}
.fr-fm-register__benefits strong {
    display: block;
    font-family: var(--fr-font-heading, sans-serif);
    font-size: 15px;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: 2px;
}
.fr-fm-register__benefit-icon {
    width: 40px;
    height: 40px;
    border-radius: 8px;
    background: rgba(232, 147, 10, 0.15);
    border: 1px solid rgba(232, 147, 10, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.fr-fm-register__card {
    background: #fff;
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.3);
}
.fr-fm-register__card-head h2 {
    font-family: var(--fr-font-heading, sans-serif);
    font-size: 28px;
    font-weight: 900;
    text-transform: uppercase;
    color: var(--fr-primary, #0D1B2A);
    margin: 0 0 6px;
}
.fr-fm-register__card-head p {
    font-size: 13px;
    color: var(--fr-muted, #9BA8B5);
    margin: 0 0 24px;
}
.fr-fm-register__signin {
    margin: 20px 0 0;
    padding-top: 20px;
    border-top: 1px solid var(--fr-border, #E8ECF1);
    text-align: center;
    font-size: 13px;
    color: var(--fr-muted, #9BA8B5);
}
.fr-fm-register__signin a {
    color: var(--fr-accent, #E8930A);
    font-weight: 600;
    text-decoration: none;
}
.fr-checkout-cta { text-align: center; }
.fr-checkout-cta__lead {
    font-size: 15px;
    color: var(--fr-text, #4A5768);
    margin: 0 0 16px;
    line-height: 1.5;
}
.fr-checkout-cta__steps {
    list-style: none;
    margin: 0 0 24px;
    padding: 0;
    text-align: left;
}
.fr-checkout-cta__steps li {
    font-size: 14px;
    color: var(--fr-text, #4A5768);
    padding: 8px 0 8px 28px;
    position: relative;
    border-bottom: 1px solid var(--fr-border, #E8ECF1);
}
.fr-checkout-cta__steps li:last-child { border-bottom: 0; }
.fr-checkout-cta__steps li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: var(--fr-success, #1A7A4A);
    font-weight: 700;
}
.fr-checkout-cta__btn {
    display: block;
    width: 100%;
    text-align: center;
    padding: 14px 20px !important;
    font-size: 16px !important;
}
.fr-checkout-cta__note {
    margin: 14px 0 0;
    font-size: 12px;
    color: var(--fr-muted, #9BA8B5);
}
.fr-checkout-fallback { margin: 0; text-align: center; }
.fr-fm-register .pmpro_checkout h3,
.fr-fm-register .pmpro_checkout_section h3 {
    font-family: var(--fr-font-heading, sans-serif) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    color: var(--fr-primary, #0D1B2A) !important;
}
.fr-fm-register .pmpro_checkout input[type="text"],
.fr-fm-register .pmpro_checkout input[type="email"],
.fr-fm-register .pmpro_checkout input[type="password"],
.fr-fm-register .pmpro_checkout select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--fr-border, #E8ECF1);
    border-radius: 6px;
    font-size: 14px;
}
.fr-fm-register .pmpro_checkout input[type="submit"],
.fr-fm-register .pmpro_btn-submit-checkout {
    width: 100%;
    padding: 13px 20px !important;
    background: var(--fr-accent, #E8930A) !important;
    color: var(--fr-primary, #0D1B2A) !important;
    border: none !important;
    border-radius: 6px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    cursor: pointer;
}
@media (max-width: 900px) {
    .fr-fm-register__grid { grid-template-columns: 1fr; }
}

/* Unclaimed listing banner */
.fr-unclaimed-banner {
    display: flex;
    align-items: center;
    gap: 16px;
    background: #FFF8EC;
    border: 2px solid var(--fr-accent, #E8930A);
    border-radius: 8px;
    padding: 20px 24px;
    margin-bottom: 28px;
}
.fr-unclaimed-banner__icon {
    font-size: 28px;
    flex-shrink: 0;
}
.fr-unclaimed-banner__text {
    flex: 1;
}
.fr-unclaimed-banner__text strong {
    display: block;
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--fr-accent, #E8930A);
    margin-bottom: 4px;
}
.fr-unclaimed-banner__text p {
    margin: 0;
    font-size: 15px;
    color: var(--fr-text, #4A5768);
}
.fr-unclaimed-banner__cta {
    flex-shrink: 0;
    white-space: nowrap;
}
@media (max-width: 600px) {
    .fr-unclaimed-banner { flex-direction: column; align-items: flex-start; }
}

/* Trade chips (homepage / marketing) */
.fr-trades-grid {
    display: grid;
    gap: 12px;
}
a.fr-trade-chip,
div.fr-trade-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    border: 1px solid var(--fr-border, #E8ECF1);
    border-radius: 6px;
    padding: 12px 16px;
    font-size: 13px;
    font-weight: 500;
    color: var(--fr-primary, #0D1B2A);
    text-decoration: none;
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
    cursor: pointer;
}
a.fr-trade-chip:hover,
div.fr-trade-chip:hover {
    border-color: var(--fr-accent, #E8930A);
    box-shadow: 0 2px 16px rgba(13, 27, 42, 0.12);
    transform: translateY(-2px);
}
.fr-trade-icon {
    width: 28px;
    height: 28px;
    border-radius: 4px;
    background: var(--fr-primary, #0D1B2A);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 14px;
}

/* Marketing / content pages (for-contractors, how-it-works, etc.) */
.fr-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--fr-accent, #E8930A);
    margin-bottom: 12px;
}
.fr-eyebrow::before {
    content: '';
    width: 24px;
    height: 2px;
    background: var(--fr-accent, #E8930A);
    border-radius: 2px;
    display: inline-block;
    flex-shrink: 0;
}
.fr-stat { display: flex; flex-direction: column; gap: 4px; }
.fr-stat-num {
    font-family: var(--fr-font-heading, sans-serif);
    font-size: 36px;
    font-weight: 800;
    color: var(--fr-accent, #E8930A);
    line-height: 1;
}
.fr-stat-label { font-size: 13px; color: rgba(255, 255, 255, 0.45); }
.fr-btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    color: #fff;
    font-family: var(--fr-font-body, sans-serif);
    font-weight: 600;
    font-size: 15px;
    padding: 14px 28px;
    border-radius: 6px;
    border: 1.5px solid rgba(255, 255, 255, 0.25);
    text-decoration: none;
    transition: all 0.2s;
}
.fr-btn-outline:hover {
    border-color: var(--fr-accent, #E8930A);
    color: var(--fr-accent, #E8930A);
    background: rgba(232, 147, 10, 0.06);
}
.fr-btn-outline-dark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    color: var(--fr-primary, #0D1B2A);
    font-family: var(--fr-font-body, sans-serif);
    font-weight: 600;
    font-size: 15px;
    padding: 14px 28px;
    border-radius: 6px;
    border: 1.5px solid #C8D0D8;
    text-decoration: none;
    transition: all 0.2s;
}
.fr-btn-outline-dark:hover {
    border-color: var(--fr-accent, #E8930A);
    color: var(--fr-accent, #E8930A);
}
.fr-btn-navy {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--fr-primary, #0D1B2A);
    color: #fff;
    font-family: var(--fr-font-body, sans-serif);
    font-weight: 600;
    font-size: 15px;
    padding: 14px 28px;
    border-radius: 6px;
    text-decoration: none;
}
.fr-btn-navy:hover { background: var(--fr-primary-mid, #1A2E44); }

/* Marketing pages — full width + grid layouts */
body.fr-plugin-page #sidebar,
body.fr-fullwidth-page.et_right_sidebar #sidebar,
body.fr-fullwidth-page.et_left_sidebar #sidebar {
    display: none !important;
}
body.fr-plugin-page #left-area,
body.fr-plugin-page #content-area .container,
body.fr-fullwidth-page.et_right_sidebar #left-area,
body.fr-fullwidth-page.et_left_sidebar #left-area {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
    padding-top: 0 !important;
}
body.fr-plugin-page #content-area .container::before,
body.fr-plugin-page #content-area .container::after,
body.fr-fullwidth-page #content-area .container::before,
body.fr-fullwidth-page #content-area .container::after {
    display: none;
}
body.fr-plugin-page .fr-marketing-wrap {
    width: 100%;
    max-width: 100%;
    clear: both;
}
.fr-marketing-two-col {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 24px !important;
    width: 100% !important;
}
.fr-marketing-three-col {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 24px !important;
    width: 100% !important;
}
.fr-marketing-four-col {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0 !important;
    width: 100% !important;
}
.fr-marketing-two-col > .fr-track-panel,
.fr-marketing-two-col > div {
    float: none !important;
    width: auto !important;
    max-width: none !important;
}
.fr-marketing-four-col > .fr-how-step {
    display: block !important;
    flex-direction: unset !important;
}
@media (max-width: 980px) {
    .fr-marketing-four-col {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 24px !important;
    }
}
@media (max-width: 767px) {
    .fr-marketing-two-col,
    .fr-marketing-three-col,
    .fr-marketing-four-col {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
}

/* Claim page */
.fr-claim-page { max-width: 640px; margin: 0 auto; }
.fr-claim-search-form { display: flex; flex-direction: column; gap: 12px; margin-top: 16px; }
.fr-claim-search-input { padding: 12px 14px; border: 1px solid var(--fr-border, #E8ECF1); border-radius: 6px; font-size: 16px; }
.fr-claim-results { list-style: none; margin: 20px 0; padding: 0; }
.fr-claim-result { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 16px; border: 1px solid var(--fr-border, #E8ECF1); border-radius: 8px; margin-bottom: 12px; }
.fr-claim-result__info { display: flex; flex-direction: column; gap: 4px; }
.fr-claim-sent { text-align: center; padding: 32px 0; }

/* Divi: full-width for FR plugin pages (hide sidebar) */
body.fr-fullwidth-page.et_right_sidebar #sidebar,
body.fr-fullwidth-page.et_left_sidebar #sidebar {
    display: none !important;
}
body.fr-fullwidth-page.et_right_sidebar #left-area,
body.fr-fullwidth-page.et_left_sidebar #left-area {
    width: 100% !important;
    float: none !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
}
body.fr-fullwidth-page #content-area .container::before,
body.fr-fullwidth-page #content-area .container::after {
    display: none;
}
body.fr-fullwidth-page .fr-fm-register__hero {
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
    width: 100vw;
    max-width: 100vw;
}

body.fr-plugin-page .entry-title,
body.fr-plugin-page .main_title,
body.fr-plugin-page #left-area > h1:first-child {
    display: none !important;
}

/* Legacy directory (/find-contractors/) */
@keyframes fr-spin { to { transform: rotate(360deg); } }

.fr-directory-legacy__hero {
    background: #0D1B2A;
    padding: 48px 0 40px;
}
.fr-directory-legacy__inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 48px;
}
.fr-directory-legacy__title {
    font-family: var(--fr-font-heading, 'Barlow Condensed', sans-serif);
    font-size: clamp(36px, 5vw, 56px);
    font-weight: 900;
    text-transform: uppercase;
    color: #fff;
    line-height: 1;
    margin: 0 0 12px;
}
.fr-directory-legacy__lead {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.55);
    max-width: 560px;
    line-height: 1.65;
    margin: 0;
}
.fr-directory-legacy__filters {
    background: #1A2E44;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    position: sticky;
    top: 0;
    z-index: 100;
}
.fr-directory-legacy__filter-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
    padding: 16px 0;
}
.fr-directory-legacy__search-wrap {
    flex: 1;
    min-width: 200px;
}
.fr-directory-legacy__input,
.fr-directory-legacy__select,
#fr-search-keyword,
#fr-filter-trade,
#fr-filter-state,
#fr-filter-tier {
    padding: 10px 14px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 6px;
    color: #fff;
    font-family: var(--fr-font-body, 'DM Sans', sans-serif);
    font-size: 14px;
    outline: none;
    box-sizing: border-box;
    color-scheme: light;
}
.fr-directory-legacy__input {
    width: 100%;
}
.fr-directory-legacy__select,
#fr-filter-trade,
#fr-filter-state,
#fr-filter-tier {
    min-width: 130px;
}
/* Dropdown options — must override Divi white-on-white */
#fr-filter-trade option,
#fr-filter-state option,
#fr-filter-tier option,
.fr-directory-legacy__select option,
select#fr-filter-trade option,
select#fr-filter-state option,
select#fr-filter-tier option {
    color: #0D1B2A !important;
    background-color: #fff !important;
}
.fr-directory-legacy__verified {
    display: flex;
    align-items: center;
    gap: 8px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 13px;
    cursor: pointer;
    white-space: nowrap;
}
.fr-directory-legacy__count {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.4);
    white-space: nowrap;
    margin-left: auto;
}
.fr-directory-legacy__results {
    background: #F4F6F9;
    min-height: 600px;
    padding: 32px 0 64px;
}
.fr-directory-legacy__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}
.fr-directory-legacy__loading,
.fr-directory-legacy__empty {
    text-align: center;
    padding: 80px 0;
    color: #9BA8B5;
}
.fr-directory-legacy__spinner {
    width: 40px;
    height: 40px;
    border: 3px solid #E8930A;
    border-top-color: transparent;
    border-radius: 50%;
    animation: fr-spin 0.8s linear infinite;
    margin: 0 auto 16px;
}
.fr-contractor-card {
    background: #fff;
    border-radius: 10px;
    border: 1px solid #E8ECF1;
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.2s;
    display: flex;
    flex-direction: column;
}
.fr-contractor-card:hover {
    box-shadow: 0 8px 32px rgba(13, 27, 42, 0.12);
    transform: translateY(-2px);
}
.fr-card-top { padding: 20px 20px 16px; flex: 1; }
.fr-card-footer {
    padding: 14px 20px;
    border-top: 1px solid #E8ECF1;
    background: #F4F6F9;
}
.fr-logo-box {
    width: 52px;
    height: 52px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--fr-font-heading, 'Barlow Condensed', sans-serif);
    font-size: 20px;
    font-weight: 900;
    flex-shrink: 0;
    overflow: hidden;
}
.fr-tier-premium { background: #E8930A; color: #0D1B2A; border: 2px solid #E8930A; }
.fr-tier-standard { background: #1A2E44; color: #E8930A; border: 2px solid #1A2E44; }
.fr-tier-basic { background: #E8ECF1; color: #4A5768; border: 2px solid #E8ECF1; }
.fr-badge-sm {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 100px;
}
.fr-badge-premium-sm { background: rgba(232, 147, 10, 0.12); color: #B86D00; border: 1px solid rgba(232, 147, 10, 0.3); }
.fr-badge-standard-sm { background: rgba(26, 46, 68, 0.08); color: #1A2E44; border: 1px solid rgba(26, 46, 68, 0.2); }
.fr-badge-basic-sm { background: #F4F6F9; color: #9BA8B5; border: 1px solid #E8ECF1; }
.fr-badge-verified-sm { background: rgba(26, 122, 74, 0.1); color: #1A7A4A; border: 1px solid rgba(26, 122, 74, 0.25); }
.fr-directory-legacy__card-head { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 14px; }
.fr-directory-legacy__card-meta { flex: 1; min-width: 0; }
.fr-directory-legacy__badges { margin-bottom: 6px; }
.fr-directory-legacy__card-title {
    font-family: var(--fr-font-heading, 'Barlow Condensed', sans-serif);
    font-size: 18px;
    font-weight: 800;
    text-transform: uppercase;
    color: #0D1B2A;
    line-height: 1.2;
    margin: 0 0 4px;
}
.fr-directory-legacy__card-tagline {
    font-size: 12px;
    color: #9BA8B5;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.fr-directory-legacy__stars { color: #E8930A; font-size: 13px; }
.fr-directory-legacy__rating { font-weight: 700; color: #0D1B2A; font-size: 13px; }
.fr-directory-legacy__reviews { font-size: 12px; color: #9BA8B5; }
.fr-directory-legacy__trade-chip {
    font-size: 11px;
    font-weight: 500;
    padding: 3px 8px;
    border-radius: 4px;
    background: #F4F6F9;
    border: 1px solid #E8ECF1;
    color: #4A5768;
}
.fr-directory-legacy__trade-row { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 10px; }
.fr-directory-legacy__states { font-size: 12px; color: #4A5768; }
.fr-directory-legacy__profile-btn {
    display: block;
    text-align: center;
    background: #0D1B2A;
    color: #fff;
    padding: 10px 16px;
    border-radius: 6px;
    font-family: var(--fr-font-heading, 'Barlow Condensed', sans-serif);
    font-size: 15px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-decoration: none;
    transition: background 0.2s;
}
.fr-directory-legacy__profile-btn:hover { background: #E8930A; color: #0D1B2A; }
.fr-directory-legacy__empty h3 {
    font-family: var(--fr-font-heading, 'Barlow Condensed', sans-serif);
    font-size: 28px;
    font-weight: 800;
    text-transform: uppercase;
    color: #0D1B2A;
    margin: 0 0 8px;
}
.fr-directory-legacy__empty-icon { font-size: 48px; margin-bottom: 16px; }

@media (max-width: 980px) {
    .fr-directory-legacy__grid { grid-template-columns: repeat(2, 1fr); }
    .fr-directory-legacy__inner { padding: 0 24px; }
}
@media (max-width: 640px) {
    .fr-directory-legacy__grid { grid-template-columns: 1fr; }
}
