/* =============================================================
 * Redesign 2026 — Agents layer
 * Scope: /agents listing (real-estate.agents view + agents.item partial)
 *        + /agents/{username} profile page (real-estate.agent view).
 * Loaded AFTER the directory + shortcodes layers so it can build on
 * rd-section, rd-page-hero, and rd-* tokens.
 * ============================================================= */

/* ── /agents page hero ─────────────────────────────── */
.rd-page-hero {
    background: linear-gradient(180deg, var(--color-cream, #f6f1e6) 0%, #fff 100%);
    padding: 88px 32px 56px;
    position: relative;
}
.rd-page-hero__inner {
    max-width: 1080px;
    margin: 0 auto;
    text-align: center;
}
.rd-page-hero__eyebrow {
    font-size: 12px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--color-warm, #a8845a);
    font-weight: 600;
    margin: 0 0 12px;
}
.rd-page-hero__title {
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-size: clamp(36px, 4.5vw, 60px);
    font-weight: 600;
    line-height: 1.1;
    color: var(--color-accent, #1f2c58);
    margin: 0 0 16px;
}
.rd-page-hero__lede {
    font-size: 17px;
    line-height: 1.55;
    color: var(--color-text-secondary-light, #5a5f6b);
    max-width: 640px;
    margin: 0 auto;
}

/* ── Agents grid + card ─────────────────────────────── */
.rd-section--agents-listing {
    padding-top: 56px;
}
.rd-agents-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
}
.rd-agents-card {
    background: #fff;
    border: 1px solid var(--color-rule, #e6e1d6);
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .25s ease, box-shadow .25s ease;
}
.rd-agents-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(20, 30, 60, .1);
}
.rd-agents-card__thumb {
    display: block;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--color-cream, #f6f1e6);
}
.rd-agents-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.rd-agents-card__body {
    padding: 20px 22px 22px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
}
.rd-agents-card__eyebrow {
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--color-warm, #a8845a);
    font-weight: 600;
}
.rd-agents-card__name {
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-size: 22px;
    line-height: 1.2;
    font-weight: 600;
    margin: 0;
}
.rd-agents-card__name a { color: inherit; }
.rd-agents-card__name a:hover { color: var(--color-accent, #1f2c58); }
.rd-agents-card__contact {
    list-style: none;
    margin: 4px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 13px;
    color: var(--color-text-secondary-light, #5a5f6b);
}
.rd-agents-card__contact li {
    display: flex;
    align-items: center;
    gap: 8px;
}
.rd-agents-card__contact li i {
    color: var(--color-warm, #a8845a);
    flex-shrink: 0;
}
.rd-agents-card__contact a {
    color: inherit;
    text-decoration: none;
}
.rd-agents-card__contact a:hover { color: var(--color-accent, #1f2c58); }
.rd-agents-card__contact--gated li a {
    color: var(--color-text-secondary-light, #5a5f6b);
    font-style: italic;
    cursor: pointer;
}
.rd-agents-card__footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
    padding-top: 14px;
    border-top: 1px solid var(--color-rule, #e6e1d6);
}
.rd-agents-card__count {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--color-text-secondary-light, #5a5f6b);
    font-weight: 500;
}
.rd-agents-card__count i {
    color: var(--color-warm, #a8845a);
}
.rd-agents-card__cta {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-warm, #a8845a);
}
.rd-agents-card__cta:hover { color: var(--color-accent, #1f2c58); }

.rd-agents-pagination {
    display: flex;
    justify-content: center;
    margin-top: 48px;
}
.rd-agents-pagination .pagination {
    display: inline-flex;
    gap: 6px;
    list-style: none;
    padding: 0;
    margin: 0;
}
/* Richard 2026-05-29: numbers off-centre + inconsistent prev/next colours
   (legacy .{skin}-skin .pagination li:first-child/last-child a paint them
   blue/grey). Uniform navy cells, digit flex-centred; !important overrides
   the legacy skin backgrounds. */
.rd-agents-pagination .page-item .page-link {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 10px;
    border: 1px solid var(--color-rule, #e6e1d6);
    background: #fff !important;
    color: var(--color-accent, #1f2c58) !important;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    line-height: 1;
}
.rd-agents-pagination .page-item.active .page-link {
    background: var(--color-accent, #1f2c58) !important;
    border-color: var(--color-accent, #1f2c58);
    color: #fff !important;
}
.rd-agents-pagination .page-item.disabled .page-link {
    color: var(--color-text-secondary-light, #5a5f6b) !important;
    opacity: .5;
}

.rd-agents-empty {
    text-align: center;
    padding: 80px 24px;
}
.rd-agents-empty .rd-h2 {
    color: var(--color-accent, #1f2c58);
    margin-bottom: 12px;
}
.rd-agents-empty p {
    color: var(--color-text-secondary-light, #5a5f6b);
    font-size: 17px;
}

@media (max-width: 992px) {
    .rd-agents-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .rd-page-hero { padding: 64px 20px 40px; }
    .rd-agents-grid { grid-template-columns: 1fr; }
}

/* =============================================================
 * /agents/{username} profile page
 * ============================================================= */

.rd-agent-profile {
    max-width: 1280px;
    margin: 0 auto;
    padding: 64px 32px 32px;
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 48px;
    align-items: start;
}
.rd-agent-profile__hero {
    display: flex;
    gap: 32px;
    align-items: flex-start;
}
.rd-agent-profile__avatar {
    flex-shrink: 0;
    width: 160px;
    height: 160px;
    border-radius: 999px;
    overflow: hidden;
    background: var(--color-cream, #f6f1e6);
    border: 1px solid var(--color-rule, #e6e1d6);
}
.rd-agent-profile__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.rd-agent-profile__head { flex: 1; }
.rd-agent-profile__eyebrow {
    font-size: 12px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--color-warm, #a8845a);
    font-weight: 600;
    margin: 0 0 10px;
}
.rd-agent-profile__name {
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-size: clamp(32px, 4vw, 48px);
    font-weight: 600;
    line-height: 1.1;
    color: var(--color-accent, #1f2c58);
    margin: 0 0 12px;
}
.rd-agent-profile__lede {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-text-secondary-light, #5a5f6b);
    margin: 0 0 20px;
}
.rd-agent-profile__stats {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
}
.rd-agent-profile__stat-num {
    font-family: var(--font-display, 'Cormorant Garamond', serif);
    font-size: 32px;
    font-weight: 600;
    color: var(--color-accent, #1f2c58);
}
.rd-agent-profile__stat-label {
    font-size: 14px;
    color: var(--color-text-secondary-light, #5a5f6b);
}

.rd-agent-profile__contact {
    background: var(--color-cream, #f6f1e6);
    border-radius: 12px;
    padding: 28px;
    position: sticky;
    top: 96px;
}
.rd-agent-profile__contact-list {
    list-style: none;
    padding: 0;
    margin: 16px 0 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
    font-size: 15px;
}
.rd-agent-profile__contact-list li {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--color-text-secondary-light, #5a5f6b);
}
.rd-agent-profile__contact-list li i {
    color: var(--color-warm, #a8845a);
    flex-shrink: 0;
    font-size: 18px;
}
.rd-agent-profile__contact-list li a {
    color: inherit;
}
.rd-agent-profile__contact-list li a:hover { color: var(--color-accent, #1f2c58); }
.rd-agent-profile__contact-list--gated li a {
    color: var(--color-text-secondary-light, #5a5f6b);
    font-style: italic;
    cursor: pointer;
}

/* ── Listings tabs + grid ──────────────────────────── */
.rd-section--agent-listings {
    padding-top: 24px;
}
.rd-agent-profile__listings-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 24px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.rd-agent-profile__listings-head .rd-h2 {
    margin: 0;
}
.rd-agent-profile__sort {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 220px;
}
.rd-agent-profile__sort .rd-input {
    height: 40px;
}

.rd-agent-profile__tabs.nav {
    display: flex;
    gap: 6px;
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
    border-bottom: 1px solid var(--color-rule, #e6e1d6);
    flex-wrap: wrap;
}
.rd-agent-profile__tab .nav-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 18px;
    color: var(--color-text-secondary-light, #5a5f6b);
    font-weight: 600;
    font-size: 14px;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
}
.rd-agent-profile__tab .nav-link.active {
    color: var(--color-accent, #1f2c58);
    border-bottom-color: var(--color-warm, #a8845a);
}
.rd-agent-profile__tab-count {
    font-size: 12px;
    color: var(--color-warm, #a8845a);
}

.rd-agent-profile__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

.rd-agent-profile__empty {
    text-align: center;
    padding: 64px 16px;
    color: var(--color-text-secondary-light, #5a5f6b);
    font-style: italic;
}

@media (max-width: 992px) {
    .rd-agent-profile { grid-template-columns: 1fr; gap: 32px; }
    .rd-agent-profile__contact { position: static; }
    .rd-agent-profile__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .rd-agent-profile { padding: 48px 20px 24px; }
    .rd-agent-profile__hero { flex-direction: column; gap: 20px; }
    .rd-agent-profile__avatar { width: 120px; height: 120px; }
    .rd-agent-profile__grid { grid-template-columns: 1fr; }
}
