/**
 * public-components.css — Componentes do Layout Público P8W
 *
 * Ordem de carregamento:
 *   1. design-tokens.css
 *   2. codental-theme.css
 *   3. public-components.css  ← este arquivo
 *
 * Contém: nav, botões, hero, cards, grids, filtros, formulários,
 *         paginação, empty-state, footer, animações.
 * Zero valores hardcoded — tudo via tokens.
 */

/* ============================================================
   RESET PÚBLICO
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--font-family, 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif);
    background: #f8fafc;
    color: var(--text-primary, #0f172a);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

/* ============================================================
   NAVEGAÇÃO PÚBLICA
   ============================================================ */
.pub-nav {
    background: var(--surface-card, #fff);
    border-bottom: 1px solid var(--border-subtle, #e2e8f0);
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(8px);
}
.pub-nav__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}
.pub-nav__logo {
    display: flex;
    align-items: center;
    gap: .625rem;
    text-decoration: none;
    flex-shrink: 0;
}
.pub-nav__logo-icon {
    width: 38px;
    height: 38px;
    background: var(--brand-primary, #0ea5e9);
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1rem;
    flex-shrink: 0;
    transition: opacity var(--transition-fast, 150ms ease);
}
.pub-nav__logo:hover .pub-nav__logo-icon { opacity: .88; }
.pub-nav__logo-name {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text-primary, #0f172a);
    letter-spacing: -.02em;
}
.pub-nav__links {
    display: flex;
    align-items: center;
    gap: 1.75rem;
    list-style: none;
}
.pub-nav__links a {
    font-size: .875rem;
    font-weight: 500;
    color: var(--text-secondary, #475569);
    text-decoration: none;
    transition: color var(--transition-fast, 150ms ease);
    white-space: nowrap;
}
.pub-nav__links a:hover,
.pub-nav__links a.active { color: var(--brand-primary, #0ea5e9); }
.pub-nav__actions {
    display: flex;
    align-items: center;
    gap: .625rem;
    flex-shrink: 0;
}

/* Hamburger */
.pub-nav__hamburger {
    display: none;
    background: none;
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 8px;
    font-size: 1.125rem;
    color: var(--text-secondary, #475569);
    cursor: pointer;
    padding: .4375rem .625rem;
    transition: all var(--transition-fast, 150ms ease);
    line-height: 1;
}
.pub-nav__hamburger:hover,
.pub-nav__hamburger.is-open {
    border-color: var(--brand-primary, #0ea5e9);
    color: var(--brand-primary, #0ea5e9);
}

/* Mobile menu */
.pub-nav__mobile {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows .25s ease;
    background: var(--surface-card, #fff);
    border-top: 1px solid var(--border-subtle, #e2e8f0);
    overflow: hidden;
}
.pub-nav__mobile.is-open { grid-template-rows: 1fr; }
.pub-nav__mobile__inner { overflow: hidden; padding: 0; }
.pub-nav__mobile.is-open .pub-nav__mobile__inner { padding: .75rem 1.25rem 1rem; }

.pub-nav__mobile__links {
    display: flex;
    flex-direction: column;
    gap: .125rem;
    margin-bottom: .75rem;
}
.pub-nav__mobile__links a {
    display: flex;
    align-items: center;
    gap: .625rem;
    padding: .625rem .75rem;
    font-size: .9rem;
    font-weight: 500;
    color: var(--text-secondary, #475569);
    text-decoration: none;
    border-radius: 8px;
    transition: background var(--transition-fast, 120ms ease), color var(--transition-fast, 120ms ease);
}
.pub-nav__mobile__links a:hover,
.pub-nav__mobile__links a.active {
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 8%, transparent);
    color: var(--brand-primary, #0ea5e9);
}
.pub-nav__mobile__links a i { width: 1.125rem; text-align: center; font-size: .875rem; opacity: .7; flex-shrink: 0; }
.pub-nav__mobile__links a:hover i,
.pub-nav__mobile__links a.active i { opacity: 1; }
.pub-nav__mobile__sep { height: 1px; background: var(--border-subtle, #e2e8f0); margin: .375rem 0 .75rem; }
.pub-nav__mobile__actions { display: flex; gap: .625rem; }
.pub-nav__mobile__actions .pub-btn { flex: 1; justify-content: center; }

/* ============================================================
   BOTÕES PÚBLICOS
   ============================================================ */
.pub-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    padding: .5625rem 1.125rem;
    border-radius: 8px;
    font-size: .875rem;
    font-weight: 600;
    font-family: inherit;
    line-height: 1.4;
    text-decoration: none;
    transition: all var(--transition-fast, 150ms ease);
    cursor: pointer;
    border: 1.5px solid transparent;
    white-space: nowrap;
    user-select: none;
    -webkit-user-select: none;
}
.pub-btn:focus-visible {
    outline: 2px solid var(--brand-primary, #0ea5e9);
    outline-offset: 2px;
}
/* Tamanhos */
.pub-btn--sm  { padding: .375rem .875rem; font-size: .8125rem; border-radius: 7px; }
.pub-btn--lg  { padding: .875rem 1.75rem; font-size: 1rem; font-weight: 700; border-radius: 10px; }
.pub-btn--xl  { padding: 1rem 2.25rem; font-size: 1.0625rem; font-weight: 700; border-radius: 12px; }
.pub-btn--full { width: 100%; }
.pub-btn--icon { padding: .5625rem; aspect-ratio: 1; }
.pub-btn--icon.pub-btn--sm { padding: .375rem; }

/* Variantes */
.pub-btn--primary {
    background: var(--brand-primary, #0ea5e9);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.pub-btn--primary:hover {
    filter: brightness(1.08);
    box-shadow: 0 4px 14px color-mix(in srgb, var(--brand-primary, #0ea5e9) 35%, transparent);
    transform: translateY(-1px);
}
.pub-btn--primary:active { transform: translateY(0); filter: brightness(.97); }

.pub-btn--secondary {
    background: var(--brand-secondary, #84cc16);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.pub-btn--secondary:hover {
    filter: brightness(1.08);
    transform: translateY(-1px);
    box-shadow: 0 4px 14px color-mix(in srgb, var(--brand-secondary, #84cc16) 35%, transparent);
}

.pub-btn--ghost {
    background: transparent;
    color: var(--text-secondary, #475569);
    border-color: var(--border-subtle, #e2e8f0);
}
.pub-btn--ghost:hover {
    background: var(--surface-sunken, #f1f5f9);
    color: var(--text-primary, #0f172a);
    border-color: var(--border-color-strong, #cbd5e1);
}
.pub-btn--ghost-light {
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.9);
    border-color: rgba(255,255,255,.2);
}
.pub-btn--ghost-light:hover { background: rgba(255,255,255,.16); }
.pub-btn--danger {
    background: transparent;
    color: var(--color-danger, #dc2626);
    border-color: var(--color-danger, #dc2626);
}
.pub-btn--danger:hover { background: var(--color-danger, #dc2626); color: #fff; }

/* ============================================================
   INPUTS / SELECTS PÚBLICOS
   ============================================================ */
.pub-input,
.pub-select {
    width: 100%;
    padding: .6875rem 1rem;
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 8px;
    font-size: .9375rem;
    font-family: inherit;
    color: var(--text-primary, #0f172a);
    background: var(--surface-card, #fff);
    outline: none;
    transition: border-color var(--transition-fast, 150ms ease), box-shadow var(--transition-fast, 150ms ease);
    line-height: 1.5;
}
.pub-input::placeholder { color: var(--text-muted, #94a3b8); }
.pub-input:focus,
.pub-select:focus {
    border-color: var(--brand-primary, #0ea5e9);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-primary, #0ea5e9) 12%, transparent);
}
.pub-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .875rem center;
    padding-right: 2.5rem;
    cursor: pointer;
}
.pub-input--sm,
.pub-select--sm { padding: .5rem .875rem; font-size: .875rem; border-radius: 7px; }

/* Aplicar select padrão para todos os selects públicos */
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .875rem center;
    padding-right: 2.25rem !important;
    cursor: pointer;
}
select:focus { outline: none; border-color: var(--brand-primary, #0ea5e9) !important; }

/* ============================================================
   LABEL DE SEÇÃO (eyebrow)
   ============================================================ */
.pub-label {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--brand-primary, #0ea5e9);
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 10%, transparent);
    padding: .25rem .75rem;
    border-radius: var(--radius-full, 9999px);
    margin-bottom: 1rem;
}

/* ============================================================
   SEÇÕES
   ============================================================ */
.pub-section { padding: 5rem 1.5rem; }
.pub-section--sm { padding: 3.5rem 1.5rem; }
.pub-section--alt { background: var(--surface-card, #fff); }
.pub-section--dark {
    background: linear-gradient(135deg, var(--color-gray-900, #0f172a) 0%, var(--color-gray-800, #1e293b) 100%);
    color: #fff;
}
.pub-section--teal {
    background: linear-gradient(135deg, #0d9488 0%, #0891b2 100%);
    color: #fff;
}
.pub-container { max-width: 1200px; margin: 0 auto; }
.pub-container--sm { max-width: 800px; margin: 0 auto; }

/* Tipografia de seção */
.pub-heading {
    font-size: 2.25rem;
    font-weight: 700;
    letter-spacing: -.025em;
    color: var(--text-primary, #0f172a);
    line-height: 1.2;
}
.pub-heading--lg { font-size: 2.625rem; }
.pub-heading--sm { font-size: 1.625rem; }
.pub-subheading {
    font-size: 1.0625rem;
    color: var(--text-muted, #64748b);
    margin-top: .75rem;
    line-height: 1.7;
    max-width: 620px;
}
.pub-subheading--wide { max-width: 820px; }
.pub-section--dark .pub-heading,
.pub-section--teal .pub-heading { color: #fff; }
.pub-section--dark .pub-subheading,
.pub-section--teal .pub-subheading { color: rgba(255,255,255,.7); }
.pub-section--dark .pub-label,
.pub-section--teal .pub-label {
    background: rgba(255,255,255,.12);
    color: rgba(255,255,255,.9);
}

/* ============================================================
   HERO PÚBLICO
   ============================================================ */
.pub-hero {
    background: var(--gradient-hero, linear-gradient(135deg, #0f172a 0%, #1e293b 60%, #0f2d44 100%));
    color: #fff;
    padding: 6rem 1.5rem 5rem;
    position: relative;
    overflow: hidden;
}
.pub-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 50% at 70% 50%, color-mix(in srgb, var(--brand-primary, #0ea5e9) 18%, transparent), transparent),
        radial-gradient(ellipse 40% 40% at 20% 80%, rgba(99,102,241,.12), transparent);
    pointer-events: none;
}

/* Hero com banner de imagem (marketplace, rental, etc.) */
.pub-hero--banner {
    background-color: var(--color-gray-900, #0f172a);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.pub-hero--banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--gradient-hero-overlay, linear-gradient(135deg, rgba(15,23,42,.85) 0%, rgba(15,23,42,.70) 50%, rgba(15,23,42,.55) 100%));
    pointer-events: none;
}
.pub-hero--banner .pub-hero__inner { position: relative; z-index: 1; }

/* Hero compacto (catálogos) */
.pub-hero--compact { padding: 4.5rem 1.5rem 3.5rem; }


.pub-hero__inner {
    max-width: 1200px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.pub-hero__inner--2col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.pub-hero__inner--center { text-align: center; max-width: 760px; margin: 0 auto; }
.pub-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background: rgba(255,255,255,.09);
    border: 1px solid rgba(255,255,255,.15);
    color: rgba(255,255,255,.85);
    padding: .375rem 1rem;
    border-radius: var(--radius-full, 9999px);
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .04em;
    margin-bottom: 1.25rem;
}
.pub-hero__title {
    font-size: 2.75rem;
    font-weight: 700;
    letter-spacing: -.03em;
    line-height: 1.15;
    color: #fff;
}
.pub-hero__title mark {
    background: none;
    color: var(--brand-primary, #0ea5e9);
}
.pub-hero__desc {
    font-size: 1.0625rem;
    color: rgba(255,255,255,.72);
    margin-top: 1rem;
    line-height: 1.75;
    max-width: 520px;
}
.pub-hero__actions {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-top: 2rem;
    flex-wrap: wrap;
}
.pub-hero__stats {
    display: flex;
    align-items: center;
    gap: 2rem;
    margin-top: 2.5rem;
    padding-top: 1.75rem;
    border-top: 1px solid rgba(255,255,255,.1);
    flex-wrap: wrap;
}
.pub-hero__stat-value {
    font-size: 1.75rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: -.04em;
    line-height: 1;
}
.pub-hero__stat-label {
    font-size: .75rem;
    color: rgba(255,255,255,.55);
    margin-top: .2rem;
    font-weight: 500;
}

/* Visual box do hero */
.pub-hero__visual {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* ── Hero de página interna ── centralizado, tamanho uniforme ──────── */
.pub-hero--page {
    padding: 4rem 1.5rem 3.25rem;
    text-align: center;
}
.pub-hero--page::before {
    background:
        radial-gradient(ellipse 70% 60% at 50% 100%, color-mix(in srgb, var(--brand-primary, #0ea5e9) 16%, transparent), transparent),
        radial-gradient(ellipse 50% 50% at 50% -20%, rgba(99,102,241,.1), transparent);
}
.pub-hero--page .pub-hero__inner {
    max-width: 760px !important;
    margin: 0 auto !important;
    text-align: center !important;
    display: block !important;
    grid-template-columns: none !important;
}
.pub-hero--page .pub-hero__title { font-size: 2.375rem !important; }
.pub-hero--page .pub-hero__desc {
    max-width: 600px !important;
    margin: .875rem auto 0 !important;
    text-align: center !important;
}
.pub-hero--page .pub-label { margin-bottom: .875rem; }
@media (max-width: 640px) {
    .pub-hero--page .pub-hero__title { font-size: 1.875rem !important; }
}

/* ============================================================
   BARRA DE BUSCA PÚBLICA (hero search)
   ============================================================ */
.pub-search {
    background: rgba(255,255,255,.97);
    border-radius: 14px;
    padding: .875rem 1rem;
    display: flex;
    gap: .625rem;
    flex-wrap: wrap;
    box-shadow: 0 8px 32px rgba(0,0,0,.22);
    max-width: 860px;
    margin: 2rem auto 0;
}
.pub-search input,
.pub-search select {
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 8px;
    padding: .625rem .875rem;
    font-size: .9375rem;
    font-family: inherit;
    color: var(--text-primary, #0f172a);
    background: #fff;
    outline: none;
    transition: border-color var(--transition-fast, 150ms ease);
    flex: 1;
    min-width: 140px;
}
.pub-search input:focus,
.pub-search select:focus { border-color: var(--brand-primary, #0ea5e9); }
.pub-search .pub-btn { flex-shrink: 0; }
@media (max-width: 540px) {
    .pub-search { flex-direction: column; }
    .pub-search input,
    .pub-search select,
    .pub-search .pub-btn { width: 100%; }
}

/* ============================================================
   STAT CARDS PÚBLICOS
   ============================================================ */
.pub-stats {
    background: var(--surface-card, #fff);
    border-bottom: 1px solid var(--border-subtle, #e2e8f0);
    padding: 0;
}
.pub-stats__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
}
.pub-stat {
    flex: 1;
    text-align: center;
    padding: 1.5rem 1.25rem;
    position: relative;
}
.pub-stat + .pub-stat { border-left: 1px solid var(--border-subtle, #e2e8f0); }
.pub-stat__value {
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: -.04em;
    color: var(--brand-primary, #0ea5e9);
    line-height: 1;
    margin-bottom: .3rem;
}
.pub-stat__label { font-size: .8125rem; color: var(--text-muted, #94a3b8); font-weight: 500; }

/* Stat cards em grid (painel) */
.pub-stat-grid { display: grid; gap: 1.25rem; }
.pub-stat-grid--2 { grid-template-columns: repeat(2, 1fr); }
.pub-stat-grid--3 { grid-template-columns: repeat(3, 1fr); }
.pub-stat-grid--4 { grid-template-columns: repeat(4, 1fr); }

.pub-stat-card {
    background: var(--surface-card, #fff);
    border-radius: 16px;
    border: 1px solid var(--border-subtle, #e2e8f0);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(15,23,42,.07));
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.pub-stat-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    margin-bottom: .875rem;
    flex-shrink: 0;
}
.pub-stat-card__label {
    font-size: .6875rem;
    font-weight: 600;
    color: var(--text-muted, #94a3b8);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: .25rem;
}
.pub-stat-card__value {
    font-size: 1.625rem;
    font-weight: 800;
    letter-spacing: -.03em;
    line-height: 1.2;
    color: var(--text-primary, #0f172a);
}
.pub-stat-card__delta {
    font-size: .75rem;
    font-weight: 600;
    margin-top: .375rem;
}
.pub-stat-card__delta--up { color: var(--color-success, #22c55e); }
.pub-stat-card__delta--down { color: var(--color-danger, #ef4444); }

/* Variantes de cor do ícone */
.pub-icon-bg--primary   { background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 12%, transparent); color: var(--brand-primary, #0ea5e9); }
.pub-icon-bg--success   { background: color-mix(in srgb, var(--color-success, #22c55e) 12%, transparent); color: var(--color-success-600, #16a34a); }
.pub-icon-bg--warning   { background: color-mix(in srgb, var(--color-warning, #f59e0b) 12%, transparent); color: var(--color-warning-600, #d97706); }
.pub-icon-bg--danger    { background: color-mix(in srgb, var(--color-danger, #ef4444) 12%, transparent);  color: var(--color-danger-600, #dc2626); }
.pub-icon-bg--info      { background: color-mix(in srgb, var(--color-info, #0ea5e9) 12%, transparent);    color: var(--color-info-700, #0369a1); }
.pub-icon-bg--secondary { background: color-mix(in srgb, var(--brand-secondary, #84cc16) 12%, transparent); color: var(--brand-secondary-d, #65a30d); }
.pub-icon-bg--purple    { background: rgba(168, 85, 247, .12); color: #a855f7; }
.pub-icon-bg--orange    { background: rgba(249, 115, 22, .12); color: #f97316; }
.pub-icon-bg--teal      { background: rgba(20, 184, 166, .12); color: #14b8a6; }
.pub-icon-bg--cyan      { background: rgba(6, 182, 212, .12);  color: #06b6d4; }
.pub-icon-bg--pink      { background: rgba(236, 72, 153, .12); color: #ec4899; }
.pub-icon-bg--amber     { background: rgba(245, 158, 11, .12); color: #f59e0b; }

/* ============================================================
   FILTROS PÚBLICOS
   ============================================================ */
.pub-filters {
    background: var(--surface-sunken, #f1f5f9);
    border-bottom: 1px solid var(--border-subtle, #e2e8f0);
    padding: .875rem 1.5rem;
}
.pub-filters__inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    gap: .625rem;
    flex-wrap: wrap;
    align-items: flex-end;
}
.pub-filters .f-group { display: flex; flex-direction: column; gap: .25rem; }
.pub-filters label { font-size: .6875rem; font-weight: 600; color: var(--text-secondary, #475569); letter-spacing: .04em; text-transform: uppercase; }
.pub-filters input,
.pub-filters select {
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 7px;
    padding: .5rem .875rem;
    font-size: .875rem;
    font-family: inherit;
    color: var(--text-primary, #0f172a);
    background: var(--surface-card, #fff);
    outline: none;
    transition: border-color var(--transition-fast, 150ms ease);
}
.pub-filters input:focus,
.pub-filters select:focus { border-color: var(--brand-primary, #0ea5e9); }

/* Pills de filtro (tipo/categoria) */
.pub-filter-pills {
    display: flex;
    align-items: center;
    gap: .375rem;
    flex-wrap: wrap;
}
.pub-filter-pill {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .3125rem .875rem;
    border-radius: var(--radius-full, 9999px);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    font-size: .8125rem;
    font-weight: 600;
    color: var(--text-secondary, #475569);
    background: var(--surface-card, #fff);
    text-decoration: none;
    transition: all var(--transition-fast, 150ms ease);
    white-space: nowrap;
    cursor: pointer;
}
.pub-filter-pill:hover {
    border-color: color-mix(in srgb, var(--brand-primary, #0ea5e9) 40%, transparent);
    color: var(--brand-primary, #0ea5e9);
}
.pub-filter-pill.active,
.pub-filter-pill--active {
    border-color: var(--brand-primary, #0ea5e9);
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 8%, transparent);
    color: var(--brand-primary, #0ea5e9);
}

/* ============================================================
   GRIDS DE CARDS
   ============================================================ */
.pub-grid { display: grid; gap: 1.25rem; }
.pub-grid--2 { grid-template-columns: repeat(2, 1fr); }
.pub-grid--3 { grid-template-columns: repeat(3, 1fr); }
.pub-grid--4 { grid-template-columns: repeat(4, 1fr); }
.pub-grid--auto { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

/* ============================================================
   CARD DE CATÁLOGO (produto, imóvel, empresa, etc.)
   ============================================================ */
.pub-card {
    background: var(--surface-card, #fff);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 14px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
    transition: border-color var(--transition-normal, 200ms ease),
                box-shadow var(--transition-normal, 200ms ease),
                transform var(--transition-normal, 200ms ease);
}
.pub-card:hover {
    border-color: var(--brand-primary, #0ea5e9);
    box-shadow: 0 8px 28px rgba(0,0,0,.09);
    transform: translateY(-3px);
}
.pub-card__img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    background: var(--surface-sunken, #f1f5f9);
    display: block;
    flex-shrink: 0;
    position: relative;
}
.pub-card__img-placeholder {
    width: 100%;
    height: 200px;
    background: linear-gradient(135deg, var(--color-gray-800, #1e293b), var(--color-gray-700, #334155));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.pub-card__img-placeholder i { font-size: 2rem; color: rgba(255,255,255,.2); }

/* Badges sobre a imagem */
.pub-card__badges {
    position: absolute;
    top: .75rem;
    left: .75rem;
    display: flex;
    gap: .375rem;
    flex-wrap: wrap;
}
.pub-card__badge {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    padding: .2rem .625rem;
    border-radius: var(--radius-full, 9999px);
    font-size: .6875rem;
    font-weight: 700;
    letter-spacing: .02em;
    line-height: 1.4;
}
.pub-card__badge--primary  { background: var(--brand-primary, #0ea5e9); color: #fff; }
.pub-card__badge--success  { background: var(--color-success-600, #16a34a); color: #fff; }
.pub-card__badge--warning  { background: #f59e0b; color: #fff; }
.pub-card__badge--auction  { background: #7c3aed; color: #fff; }
.pub-card__badge--sale     { background: var(--color-danger-600, #dc2626); color: #fff; }
.pub-card__badge--featured { background: #f59e0b; color: #fff; }
.pub-card__badge--new      {
    background: color-mix(in srgb, var(--color-success-500, #22c55e) 14%, transparent);
    color: var(--color-success-600, #16a34a);
    border: 1px solid color-mix(in srgb, var(--color-success-500, #22c55e) 28%, transparent);
}

.pub-card__body {
    padding: 1rem 1.125rem 1.125rem;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: .25rem;
}
.pub-card__cat {
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--brand-primary, #0ea5e9);
    margin-bottom: .125rem;
}
.pub-card__title {
    font-size: .9375rem;
    font-weight: 700;
    color: var(--text-primary, #0f172a);
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pub-card__meta {
    font-size: .8125rem;
    color: var(--text-muted, #94a3b8);
    display: flex;
    align-items: center;
    gap: .375rem;
    flex-wrap: wrap;
    margin-top: .125rem;
}
.pub-card__meta i { font-size: .75rem; }
.pub-card__specs {
    display: flex;
    gap: .625rem;
    flex-wrap: wrap;
    margin-top: .375rem;
}
.pub-card__spec {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    font-size: .75rem;
    color: var(--text-secondary, #475569);
    font-weight: 500;
}
.pub-card__spec i { font-size: .6875rem; color: var(--text-muted, #94a3b8); }
.pub-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: auto;
    padding-top: .75rem;
}
.pub-card__price {
    font-size: 1.125rem;
    font-weight: 800;
    letter-spacing: -.02em;
    color: var(--brand-primary, #0ea5e9);
    line-height: 1.2;
}
.pub-card__price-sub {
    font-size: .75rem;
    color: var(--text-muted, #94a3b8);
    font-weight: 500;
    margin-top: .1rem;
}
.pub-card__arrow {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--surface-sunken, #f1f5f9);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted, #94a3b8);
    font-size: .6875rem;
    transition: all var(--transition-fast, 150ms ease);
    flex-shrink: 0;
}
.pub-card:hover .pub-card__arrow {
    background: var(--brand-primary, #0ea5e9);
    color: #fff;
}

/* Card em modo lista */
.pub-card--list {
    flex-direction: row;
    border-radius: 12px;
}
.pub-card--list .pub-card__img { width: 200px; height: 140px; border-radius: 0; flex-shrink: 0; }
.pub-card--list .pub-card__img-placeholder { width: 200px; height: 140px; flex-shrink: 0; }
.pub-card--list .pub-card__body { padding: 1rem 1.125rem; }

/* ============================================================
   CARD DE PERFIL (corretor, empresa com avatar)
   ============================================================ */
.pub-profile-card {
    background: var(--surface-card, #fff);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 16px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: border-color var(--transition-normal, 200ms ease),
                box-shadow var(--transition-normal, 200ms ease),
                transform var(--transition-normal, 200ms ease);
}
.pub-profile-card:hover {
    border-color: var(--brand-primary, #0ea5e9);
    box-shadow: 0 8px 28px rgba(0,0,0,.09);
    transform: translateY(-2px);
}
.pub-profile-card__head {
    padding: 1.5rem 1.25rem 1rem;
    background: linear-gradient(160deg, color-mix(in srgb, var(--brand-primary, #0ea5e9) 8%, transparent), transparent);
    text-align: center;
}
.pub-profile-card__avatar {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--surface-card, #fff);
    box-shadow: 0 4px 12px rgba(0,0,0,.12);
    margin: 0 auto .625rem;
    display: block;
}
.pub-profile-card__avatar-ph {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 12%, transparent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--brand-primary, #0ea5e9);
    margin: 0 auto .625rem;
    border: 3px solid var(--surface-card, #fff);
    box-shadow: 0 4px 12px rgba(0,0,0,.08);
}
.pub-profile-card__name {
    font-size: .9375rem;
    font-weight: 700;
    color: var(--text-primary, #0f172a);
    line-height: 1.3;
}
.pub-profile-card__sub {
    font-size: .75rem;
    color: var(--text-muted, #94a3b8);
    margin-top: .2rem;
    font-weight: 500;
}
.pub-profile-card__rating {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .25rem;
    margin-top: .5rem;
    font-size: .8125rem;
    font-weight: 600;
    color: #f59e0b;
}
.pub-profile-card__body { padding: .75rem 1.125rem; flex: 1; }
.pub-profile-card__tags {
    display: flex;
    flex-wrap: wrap;
    gap: .3rem;
    margin-bottom: .625rem;
}
.pub-profile-card__tag {
    font-size: .6875rem;
    font-weight: 600;
    padding: .2rem .55rem;
    border-radius: var(--radius-full, 9999px);
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 8%, transparent);
    color: var(--brand-primary, #0ea5e9);
}
.pub-profile-card__bio {
    font-size: .8125rem;
    color: var(--text-secondary, #475569);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pub-profile-card__footer {
    padding: .75rem 1.125rem;
    border-top: 1px solid var(--border-subtle, #e2e8f0);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
}
.pub-profile-card__city {
    display: flex;
    align-items: center;
    gap: .3rem;
    font-size: .75rem;
    color: var(--text-muted, #94a3b8);
}

/* ============================================================
   VIEW TOGGLE (grid / lista)
   ============================================================ */
.pub-view-toggle {
    display: flex;
    gap: .25rem;
    background: var(--surface-sunken, #f1f5f9);
    border-radius: 8px;
    padding: .25rem;
}
.pub-view-btn {
    padding: .375rem .625rem;
    border: none;
    background: none;
    border-radius: 6px;
    color: var(--text-muted, #94a3b8);
    cursor: pointer;
    transition: all var(--transition-fast, 150ms ease);
    font-size: .875rem;
    line-height: 1;
}
.pub-view-btn.active,
.pub-view-btn:hover {
    background: var(--surface-card, #fff);
    color: var(--text-primary, #0f172a);
    box-shadow: var(--shadow-xs);
}

/* ============================================================
   PAGINAÇÃO
   ============================================================ */
.pub-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .375rem;
    padding: 2rem 1.5rem;
    flex-wrap: wrap;
}
.pub-pagination__info {
    font-size: .8125rem;
    color: var(--text-muted, #94a3b8);
    margin-right: .5rem;
}
.pub-page-btn {
    min-width: 36px;
    height: 36px;
    padding: 0 .625rem;
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 8px;
    background: var(--surface-card, #fff);
    color: var(--text-secondary, #475569);
    font-size: .875rem;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: all var(--transition-fast, 150ms ease);
    font-family: inherit;
}
.pub-page-btn:hover { border-color: var(--brand-primary, #0ea5e9); color: var(--brand-primary, #0ea5e9); }
.pub-page-btn.active,
.pub-page-btn--active {
    background: var(--brand-primary, #0ea5e9);
    border-color: var(--brand-primary, #0ea5e9);
    color: #fff;
    font-weight: 600;
}
.pub-page-btn:disabled { opacity: .4; cursor: not-allowed; pointer-events: none; }

/* ============================================================
   EMPTY STATE
   ============================================================ */
.pub-empty {
    text-align: center;
    padding: 4rem 2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.pub-empty__icon {
    width: 64px;
    height: 64px;
    border-radius: 16px;
    background: var(--surface-sunken, #f1f5f9);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--text-muted, #94a3b8);
    margin: 0 auto 1.25rem;
}
.pub-empty__title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text-primary, #0f172a);
    margin-bottom: .5rem;
}
.pub-empty__desc {
    font-size: .9375rem;
    color: var(--text-muted, #94a3b8);
    max-width: 400px;
    line-height: 1.65;
    margin-bottom: 1.5rem;
}

/* ============================================================
   MÓDULOS / LISTAS DE RECURSOS
   ============================================================ */
.pub-module-list {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border-subtle, #e2e8f0);
    border-radius: 14px;
    overflow: hidden;
    background: var(--surface-card, #fff);
}
.pub-module-row {
    display: flex;
    align-items: center;
    gap: .875rem;
    padding: .875rem 1.125rem;
    border-bottom: 1px solid var(--border-subtle, #e2e8f0);
    text-decoration: none;
    color: inherit;
    transition: background var(--transition-fast, 150ms ease);
}
.pub-module-row:last-child { border-bottom: none; }
.pub-module-row:hover { background: var(--surface-sunken, #f1f5f9); }
.pub-module-row__icon {
    width: 36px;
    height: 36px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .875rem;
    flex-shrink: 0;
}
.pub-module-row__text { flex: 1; min-width: 0; }
.pub-module-row__title {
    font-size: .875rem;
    font-weight: 600;
    color: var(--text-primary, #0f172a);
    line-height: 1.35;
}
.pub-module-row__sub {
    font-size: .75rem;
    color: var(--text-muted, #94a3b8);
    margin-top: .1rem;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pub-module-row__arrow {
    margin-left: auto;
    color: var(--text-muted, #94a3b8);
    font-size: .75rem;
    flex-shrink: 0;
    transition: transform var(--transition-fast, 150ms ease), color var(--transition-fast, 150ms ease);
}
.pub-module-row:hover .pub-module-row__arrow {
    color: var(--brand-primary, #0ea5e9);
    transform: translateX(3px);
}

/* ============================================================
   FEATURE CARDS
   ============================================================ */
.pub-feat-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 3rem;
}
.pub-feat-card {
    background: var(--surface-card, #fff);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 16px;
    padding: 1.75rem;
    position: relative;
    transition: border-color var(--transition-normal, 200ms ease),
                box-shadow var(--transition-normal, 200ms ease),
                transform var(--transition-normal, 200ms ease);
}
.pub-feat-card:hover {
    border-color: color-mix(in srgb, var(--brand-primary, #0ea5e9) 40%, transparent);
    box-shadow: 0 8px 24px rgba(0,0,0,.07);
    transform: translateY(-2px);
}
.pub-feat-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.125rem;
    margin-bottom: 1rem;
    flex-shrink: 0;
}
.pub-feat-card__title {
    font-size: .9375rem;
    font-weight: 700;
    color: var(--text-primary, #0f172a);
    margin-bottom: .4rem;
    line-height: 1.35;
}
.pub-feat-card__desc {
    font-size: .8125rem;
    color: var(--text-secondary, #475569);
    line-height: 1.6;
}

/* ============================================================
   PLAN CARDS (teaser de preços)
   ============================================================ */
.pub-plan-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 3rem;
}
.pub-plan-card {
    background: var(--surface-card, #fff);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 20px;
    padding: 2rem 1.75rem;
    display: flex;
    flex-direction: column;
    transition: border-color var(--transition-normal, 200ms ease),
                box-shadow var(--transition-normal, 200ms ease),
                transform var(--transition-normal, 200ms ease);
    position: relative;
}
.pub-plan-card:hover { box-shadow: 0 8px 28px rgba(0,0,0,.08); transform: translateY(-2px); }
.pub-plan-card--featured {
    border-color: var(--brand-primary, #0ea5e9);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-primary, #0ea5e9) 15%, transparent);
}
.pub-plan-card__badge {
    position: absolute;
    top: -1px;
    right: 1.25rem;
    background: var(--brand-primary, #0ea5e9);
    color: #fff;
    font-size: .6875rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
    padding: .25rem .75rem;
    border-radius: 0 0 8px 8px;
}
.pub-plan-card__name {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--brand-primary, #0ea5e9);
    margin-bottom: .625rem;
}
.pub-plan-card__price {
    font-size: 2.5rem;
    font-weight: 800;
    letter-spacing: -.04em;
    color: var(--text-primary, #0f172a);
    line-height: 1;
}
.pub-plan-card__price sup { font-size: 1.125rem; vertical-align: super; font-weight: 600; }
.pub-plan-card__price sub { font-size: .875rem; vertical-align: baseline; color: var(--text-muted, #94a3b8); font-weight: 400; }
.pub-plan-card__desc { font-size: .8125rem; color: var(--text-muted, #94a3b8); margin: .625rem 0 1.25rem; line-height: 1.55; }
.pub-plan-card__features { list-style: none; display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1.5rem; flex: 1; }
.pub-plan-card__feature {
    display: flex;
    align-items: center;
    gap: .5rem;
    font-size: .8125rem;
    color: var(--text-secondary, #475569);
}
.pub-plan-card__feature .ico {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .625rem;
    flex-shrink: 0;
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.pub-testi-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 3rem;
}
.pub-testi-card {
    background: var(--surface-card, #fff);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 16px;
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.pub-testi-card__stars { color: #f59e0b; font-size: .875rem; letter-spacing: .125rem; }
.pub-testi-card__text {
    font-size: .9rem;
    color: var(--text-secondary, #475569);
    line-height: 1.7;
    flex: 1;
    font-style: italic;
}
.pub-testi-card__author { display: flex; align-items: center; gap: .75rem; }
.pub-testi-card__av {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .875rem;
    font-weight: 700;
    flex-shrink: 0;
    color: #fff;
}
.pub-testi-card__name { font-size: .875rem; font-weight: 700; color: var(--text-primary, #0f172a); }
.pub-testi-card__role { font-size: .75rem; color: var(--text-muted, #94a3b8); margin-top: .1rem; }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.pub-faq-list { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: .625rem; }
.pub-faq-item { background: var(--surface-card, #fff); border: 1.5px solid var(--border-subtle, #e2e8f0); border-radius: 12px; overflow: hidden; }
.pub-faq-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 1.125rem 1.25rem;
    background: none;
    border: none;
    text-align: left;
    font-size: .9375rem;
    font-weight: 600;
    color: var(--text-primary, #0f172a);
    cursor: pointer;
    font-family: inherit;
    gap: 1rem;
    transition: color var(--transition-fast, 150ms ease);
}
.pub-faq-btn:hover { color: var(--brand-primary, #0ea5e9); }
.pub-faq-btn .pub-faq-icon {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--surface-sunken, #f1f5f9);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    flex-shrink: 0;
    color: var(--text-muted, #94a3b8);
    transition: background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}
.pub-faq-item.open .pub-faq-btn { color: var(--brand-primary, #0ea5e9); }
.pub-faq-item.open .pub-faq-icon {
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 10%, transparent);
    color: var(--brand-primary, #0ea5e9);
    transform: rotate(180deg);
}
.pub-faq-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease;
}
.pub-faq-item.open .pub-faq-body { max-height: 800px; }
.pub-faq-body__inner {
    padding: 0 1.25rem 1.125rem;
    font-size: .9rem;
    color: var(--text-secondary, #475569);
    line-height: 1.7;
    border-top: 1px solid var(--border-subtle, #e2e8f0);
    padding-top: .875rem;
}

/* ============================================================
   CTA SECTION
   ============================================================ */
.pub-cta {
    background: linear-gradient(135deg, var(--color-gray-900, #0f172a) 0%, var(--color-gray-800, #1e293b) 100%);
    padding: 5rem 1.5rem;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.pub-cta::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 60% 80% at 50% 50%, color-mix(in srgb, var(--brand-primary, #0ea5e9) 12%, transparent), transparent);
    pointer-events: none;
}
.pub-cta__inner { max-width: 640px; margin: 0 auto; position: relative; z-index: 1; }
.pub-cta__title { font-size: 2.25rem; font-weight: 800; letter-spacing: -.04em; line-height: 1.15; color: #fff; margin-bottom: 1rem; }
.pub-cta__desc,
.pub-cta__sub  { font-size: 1rem; color: rgba(255,255,255,.65); line-height: 1.7; margin-bottom: 2rem; }
.pub-cta__actions { display: flex; align-items: center; justify-content: center; gap: .75rem; flex-wrap: wrap; }

/* ── Native <details> FAQ variant ── */
.pub-faq-list details.pub-faq-item {
    background: var(--surface-card, #fff);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 12px;
    overflow: hidden;
}
.pub-faq-list details.pub-faq-item summary {
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.125rem 1.25rem;
    cursor: pointer;
    font-size: .9375rem;
    font-weight: 600;
    color: var(--text-primary, #0f172a);
    gap: 1rem;
    transition: color var(--transition-fast, 150ms ease);
}
.pub-faq-list details.pub-faq-item summary::-webkit-details-marker { display: none; }
.pub-faq-list details.pub-faq-item summary .faq-ico {
    color: var(--brand-primary, #0ea5e9);
    font-size: .875rem;
    flex-shrink: 0;
    transition: transform .2s;
}
.pub-faq-list details.pub-faq-item[open] summary { color: var(--brand-primary, #0ea5e9); }
.pub-faq-list details.pub-faq-item[open] summary .faq-ico { transform: rotate(45deg); }
.pub-faq-list details.pub-faq-item .pub-faq-body__inner {
    padding: 0 1.25rem 1.125rem;
    font-size: .9rem;
    color: var(--text-secondary, #475569);
    line-height: 1.75;
    border-top: 1px solid var(--border-subtle, #e2e8f0);
    padding-top: .875rem;
}

/* ============================================================
   FOOTER PÚBLICO
   ============================================================ */
.pub-footer {
    background: var(--color-gray-900, #0f172a);
    color: rgba(255,255,255,.6);
    padding: 3.5rem 1.5rem 0;
}
.pub-footer__grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 3rem;
    padding-bottom: 3rem;
    border-bottom: 1px solid rgba(255,255,255,.07);
}
.pub-footer__brand {}
.pub-footer__brand-logo {
    display: flex;
    align-items: center;
    gap: .625rem;
    text-decoration: none;
    margin-bottom: 1rem;
}
.pub-footer__brand-icon {
    width: 36px;
    height: 36px;
    background: var(--brand-primary, #0ea5e9);
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: .9rem;
    flex-shrink: 0;
}
.pub-footer__brand-name {
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -.02em;
}
.pub-footer__desc {
    font-size: .8125rem;
    line-height: 1.7;
    color: rgba(255,255,255,.45);
    max-width: 280px;
    margin-bottom: 1.25rem;
}
.pub-footer__col-title {
    font-size: .6875rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: rgba(255,255,255,.35);
    margin-bottom: .875rem;
}
.pub-footer__links { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.pub-footer__links a {
    font-size: .8125rem;
    color: rgba(255,255,255,.5);
    text-decoration: none;
    transition: color var(--transition-fast, 150ms ease);
}
.pub-footer__links a:hover { color: #fff; }
.pub-footer__bottom {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.5rem 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}
.pub-footer__copy {
    font-size: .75rem;
    color: rgba(255,255,255,.3);
}
.pub-footer__copy a { color: rgba(255,255,255,.45); text-decoration: none; }
.pub-footer__copy a:hover { color: rgba(255,255,255,.7); }
.pub-footer__policy-links {
    display: flex;
    gap: 1.25rem;
    flex-wrap: wrap;
}
.pub-footer__policy-links a {
    font-size: .75rem;
    color: rgba(255,255,255,.3);
    text-decoration: none;
    transition: color var(--transition-fast, 150ms ease);
}
.pub-footer__policy-links a:hover { color: rgba(255,255,255,.6); }
.p8w-bar {
    background: #000;
    text-align: center;
    padding: .5rem;
    font-size: .6875rem;
    color: rgba(255,255,255,.25);
}
.p8w-bar a { color: rgba(255,255,255,.4); text-decoration: none; }
.p8w-bar a:hover { color: rgba(255,255,255,.65); }

/* ============================================================
   BREADCRUMB
   ============================================================ */
.pub-breadcrumb {
    display: flex;
    align-items: center;
    gap: .375rem;
    font-size: .8125rem;
    color: var(--text-muted, #94a3b8);
    flex-wrap: wrap;
    margin-bottom: 1rem;
}
.pub-breadcrumb a { color: var(--text-muted, #94a3b8); text-decoration: none; transition: color var(--transition-fast); }
.pub-breadcrumb a:hover { color: var(--brand-primary, #0ea5e9); }
.pub-breadcrumb__sep { color: var(--text-placeholder, #cbd5e1); font-size: .625rem; }
.pub-breadcrumb__current { color: var(--text-secondary, #475569); font-weight: 500; }

/* ============================================================
   TOAST NOTIFICATIONS
   ============================================================ */
.pub-toast-wrap {
    position: fixed;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    pointer-events: none;
}
.pub-toast {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    padding: .875rem 1.125rem;
    border-radius: 12px;
    background: var(--color-gray-900, #0f172a);
    color: #fff;
    font-size: .875rem;
    font-weight: 500;
    box-shadow: 0 8px 24px rgba(0,0,0,.25);
    max-width: 340px;
    pointer-events: auto;
    animation: toastIn .25s ease forwards;
}
.pub-toast--success { background: var(--color-success-600, #16a34a); }
.pub-toast--danger  { background: var(--color-danger-600, #dc2626); }
.pub-toast--warning { background: #d97706; }
@keyframes toastIn {
    from { opacity: 0; transform: translateX(20px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* ============================================================
   SPLIT LAYOUT (seções com visual/texto)
   ============================================================ */
.pub-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4rem;
    align-items: center;
}
.pub-split--rev .pub-split__text  { order: 2; }
.pub-split--rev .pub-split__visual { order: 1; }
.pub-split__visual {
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 5%, transparent);
    border: 1px solid color-mix(in srgb, var(--brand-primary, #0ea5e9) 15%, transparent);
    border-radius: 20px;
    padding: 1.5rem;
    min-height: 280px;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    overflow: hidden;
}
.pub-split__visual--dark {
    background: rgba(255,255,255,.05);
    border-color: rgba(255,255,255,.1);
}
.pub-split__visual--teal {
    background: rgba(255,255,255,.1);
    border-color: rgba(255,255,255,.2);
}

/* ============================================================
   RESPONSIVIDADE
   ============================================================ */
@media (max-width: 1024px) {
    .pub-hero__title { font-size: 2.5rem; }
    .pub-footer__grid { grid-template-columns: 2fr 1fr 1fr; }
    .pub-grid--4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
    .pub-nav__links { display: none; }
    .pub-nav__actions .pub-btn:not(.pub-btn--primary) { display: none; }
    .pub-nav__hamburger { display: flex; align-items: center; justify-content: center; }
    .pub-hero__inner--2col { grid-template-columns: 1fr; gap: 2.5rem; }
    .pub-split { grid-template-columns: 1fr; gap: 2.5rem; }
    .pub-split--rev .pub-split__text  { order: 1; }
    .pub-split--rev .pub-split__visual { order: 2; }
    .pub-feat-grid { grid-template-columns: repeat(2, 1fr); }
    .pub-plan-grid { grid-template-columns: repeat(2, 1fr); }
    .pub-testi-grid { grid-template-columns: repeat(2, 1fr); }
    .pub-stat-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .pub-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
    .pub-heading { font-size: 1.875rem; }
    .pub-heading--lg { font-size: 2.25rem; }
    .pub-hero__title { font-size: 2.125rem; }
    .pub-cta__title { font-size: 1.875rem; }
    .pub-grid--3 { grid-template-columns: repeat(2, 1fr); }
    .pub-stats__inner { flex-wrap: wrap; }
    .pub-stat { min-width: 50%; }
}

@media (max-width: 600px) {
    .pub-section { padding: 3.5rem 1.25rem; }
    .pub-hero { padding: 4rem 1.25rem 3rem; }
    .pub-hero__title { font-size: 1.875rem; }
    .pub-hero__actions { flex-direction: column; align-items: stretch; }
    .pub-feat-grid { grid-template-columns: 1fr; }
    .pub-plan-grid { grid-template-columns: 1fr; }
    .pub-testi-grid { grid-template-columns: 1fr; }
    .pub-grid--2,
    .pub-grid--3,
    .pub-grid--4 { grid-template-columns: 1fr; }
    .pub-stat-grid--2,
    .pub-stat-grid--3,
    .pub-stat-grid--4 { grid-template-columns: 1fr; }
    .pub-footer__grid { grid-template-columns: 1fr; gap: 2rem; }
    .pub-footer__bottom { flex-direction: column; align-items: flex-start; }
    .pub-cta__title { font-size: 1.625rem; }
    .pub-heading { font-size: 1.625rem; }
    .pub-card--list { flex-direction: column; }
    .pub-card--list .pub-card__img,
    .pub-card--list .pub-card__img-placeholder { width: 100%; height: 180px; }
    .pub-stat { min-width: 100%; }
    .pub-stat + .pub-stat { border-left: none; border-top: 1px solid var(--border-subtle, #e2e8f0); }
}

@media (max-width: 480px) {
    .pub-hero__title { font-size: 1.625rem; }
    .pub-hero__stats { gap: 1.25rem; }
    .pub-pagination { padding: 1.5rem 1rem; }
}

/* ============================================================
   LANDING PAGE — LAYOUT & TIPOGRAFIA
   ============================================================ */
.lp-section         { padding: 5.5rem 1.5rem; }
.lp-section--alt    { background: var(--surface-card, #fff); }
.lp-section--dark   { background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%); color: #fff; }
.lp-section--teal   { background: linear-gradient(135deg, #0d9488 0%, #0891b2 100%); color: #fff; }
.lp-section--muted  { background: var(--color-gray-50, #f8fafc); }
.lp-container       { max-width: 1200px; margin: 0 auto; }
.lp-center          { text-align: center; }

.lp-tag {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--brand-primary, #0ea5e9);
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 10%, transparent);
    padding: .3rem .875rem;
    border-radius: var(--radius-full, 9999px);
    margin-bottom: 1rem;
}
.lp-tag--light {
    color: rgba(255,255,255,.9);
    background: rgba(255,255,255,.12);
    border: 1px solid rgba(255,255,255,.2);
}

.lp-h2 {
    font-size: 2.625rem;
    font-weight: 800;
    letter-spacing: -.035em;
    line-height: 1.15;
    color: var(--text-primary, #0f172a);
}
.lp-h2--light { color: #fff; }
.lp-h2--md    { font-size: 2rem; }

.lp-p {
    font-size: 1.0625rem;
    color: var(--text-muted, #94a3b8);
    line-height: 1.75;
    margin-top: .875rem;
}
.lp-p--light { color: rgba(255,255,255,.72); }
.lp-center .lp-p { max-width: 600px; margin-left: auto; margin-right: auto; }

/* Check list */
.lp-check-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: .75rem;
    margin-top: 2rem;
}
.lp-check-list li {
    display: flex;
    align-items: flex-start;
    gap: .75rem;
    font-size: .9375rem;
    color: var(--text-secondary, #475569);
}
.lp-check-list .ico {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .6875rem;
    flex-shrink: 0;
    margin-top: .1rem;
}

/* Split layout (landing) */
.lp-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    align-items: center;
}
.lp-split--rev { direction: rtl; }
.lp-split--rev > * { direction: ltr; }

/* ============================================================
   ADVANTAGE / FEATURE BLOCKS
   ============================================================ */
.adv-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    margin-top: 3rem;
}
.adv-grid--2 { grid-template-columns: repeat(2, 1fr); }

.adv-card {
    background: var(--surface-card, #fff);
    border: 1.5px solid var(--border-subtle, #e2e8f0);
    border-radius: 16px;
    padding: 1.75rem;
    transition: border-color var(--transition-normal, 200ms ease),
                box-shadow var(--transition-normal, 200ms ease),
                transform var(--transition-normal, 200ms ease);
}
.adv-card:hover {
    border-color: var(--brand-primary, #0ea5e9);
    box-shadow: 0 8px 28px rgba(0,0,0,.08);
    transform: translateY(-3px);
}
.adv-card--dark {
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.12);
}
.adv-card--dark:hover {
    background: rgba(255,255,255,.1);
    border-color: rgba(255,255,255,.3);
    transform: translateY(-3px);
}
.adv-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    margin-bottom: 1rem;
    flex-shrink: 0;
}
.adv-title { font-size: 1rem; font-weight: 700; color: var(--text-primary, #0f172a); margin-bottom: .4rem; }
.adv-title--light { color: #fff; }
.adv-desc  { font-size: .875rem; color: var(--text-muted, #94a3b8); line-height: 1.65; }
.adv-desc--light { color: rgba(255,255,255,.65); }

/* ============================================================
   STATS BANNER (lp-banner)
   ============================================================ */
.lp-banner {
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 8%, transparent);
    border-top: 1px solid color-mix(in srgb, var(--brand-primary, #0ea5e9) 20%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--brand-primary, #0ea5e9) 20%, transparent);
    padding: 1.125rem 1.5rem;
}
.lp-banner__inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 1rem;
    align-items: center;
}
.lp-banner__item {
    display: flex;
    align-items: center;
    gap: .625rem;
    justify-content: center;
}
.lp-banner__icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 15%, transparent);
    color: var(--brand-primary, #0ea5e9);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .875rem;
    flex-shrink: 0;
}
.lp-banner__val {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--text-primary, #0f172a);
    letter-spacing: -.02em;
}
.lp-banner__lbl { font-size: .8125rem; color: var(--text-muted, #94a3b8); }

/* ============================================================
   MÓDULOS GRID (landing section)
   ============================================================ */
.lp-modules-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: start;
}

/* ============================================================
   BADGE "NOVO" inline
   ============================================================ */
.pub-badge-new {
    display: inline-block;
    margin-left: .375rem;
    background: color-mix(in srgb, var(--color-success-500, #22c55e) 15%, transparent);
    color: var(--color-success-600, #16a34a);
    font-size: .6rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .05em;
    padding: .1rem .45rem;
    border-radius: var(--radius-full, 9999px);
    vertical-align: middle;
    border: 1px solid color-mix(in srgb, var(--color-success-500, #22c55e) 30%, transparent);
}
.pub-badge-new--abs {
    position: absolute;
    top: .875rem;
    right: .875rem;
    margin-left: 0;
    font-size: .65rem;
    padding: .175rem .55rem;
}

/* ============================================================
   LANDING — RESPONSIVIDADE EXTRA
   ============================================================ */
@media (max-width: 960px) {
    .adv-grid { grid-template-columns: repeat(2, 1fr); }
    .lp-split { grid-template-columns: 1fr; gap: 2.5rem; }
    .lp-split--rev { direction: ltr; }
    .lp-section { padding: 3.5rem 1.25rem; }
    .lp-h2 { font-size: 2rem; }
    .lp-modules-grid { grid-template-columns: 1fr; }
    .lp-banner__inner { grid-template-columns: repeat(3, 1fr); gap: .75rem; }
}
@media (max-width: 600px) {
    .adv-grid { grid-template-columns: 1fr; }
    .lp-h2 { font-size: 1.625rem; }
    .lp-p { font-size: .9375rem; }
    .lp-section { padding: 2.5rem 1rem; }
    .lp-banner__inner { grid-template-columns: repeat(2, 1fr); gap: .625rem; }
    .lp-banner__item { justify-content: flex-start; }
}
@media (max-width: 400px) {
    .lp-h2 { font-size: 1.375rem; }
    .lp-section { padding: 2rem .875rem; }
}

/* ============================================================
   CATÁLOGOS — MKT-HERO / MKT-SEARCH (compartilhado)
   Marketplace, Rental, Brokers, Business Guide, Consórcio
   ============================================================ */
.mkt-hero {
    position: relative;
    overflow: hidden;
    padding: 4.5rem 1.5rem 3.5rem;
    background-color: #0f172a;
    background-image: var(--mkt-banner-url);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.mkt-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(15,23,42,.85) 0%, rgba(15,23,42,.70) 50%, rgba(15,23,42,.55) 100%);
    pointer-events: none;
}
.mkt-search {
    background: rgba(255,255,255,.97);
    border-radius: 14px;
    padding: 1rem;
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    box-shadow: 0 8px 32px rgba(0,0,0,.25);
    max-width: 860px;
    margin: 2rem auto 0;
}
.mkt-search input,
.mkt-search select {
    border: 1.5px solid var(--border-subtle);
    border-radius: 8px;
    padding: .6875rem 1rem;
    font-size: .9375rem;
    font-family: inherit;
    color: var(--text-primary);
    background: #fff;
    outline: none;
    transition: border-color .15s;
    flex: 1;
    min-width: 140px;
}
.mkt-search input:focus,
.mkt-search select:focus { border-color: var(--brand-primary); }

/* ── Stats bar ── */
.mkt-stats { background: #fff; border-bottom: 1px solid var(--border-subtle); }
.mkt-stats__inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2rem 1.5rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
}
.mkt-stat { text-align: center; padding: 1.25rem; }
.mkt-stat:not(:last-child) { border-right: 1px solid var(--border-subtle); }
.mkt-stat__value {
    font-size: 2.25rem;
    font-weight: 800;
    letter-spacing: -.04em;
    color: var(--brand-primary);
    line-height: 1;
    margin-bottom: .375rem;
}
.mkt-stat__label { font-size: .875rem; color: var(--text-muted); font-weight: 500; }

/* ── Filters bar ── */
.mkt-filters {
    background: var(--surface-sunken, #f1f5f9);
    border-bottom: 1px solid var(--border-subtle);
    padding: .875rem 1.5rem;
}
.mkt-filters__inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    gap: .75rem;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: center;
}
.mkt-filters .f-group { display: flex; flex-direction: column; gap: .25rem; }
.mkt-filters label { font-size: .75rem; font-weight: 600; color: var(--text-secondary); }
.mkt-filters input,
.mkt-filters select {
    border: 1.5px solid var(--border-subtle);
    border-radius: 7px;
    padding: .5rem .875rem;
    font-size: .875rem;
    font-family: inherit;
    color: var(--text-primary);
    background: #fff;
    outline: none;
}
.mkt-filters input:focus,
.mkt-filters select:focus { border-color: var(--brand-primary); }

/* ── Grid container ── */
.mkt-grid { max-width: 1200px; margin: 0 auto; padding: 2.5rem 1.5rem; }

/* ── Catalog cards ── */
.mkt-items { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
.mkt-card {
    background: #fff;
    border: 1px solid var(--border-subtle);
    border-radius: 14px;
    overflow: hidden;
    text-decoration: none;
    display: block;
    transition: all .2s;
}
.mkt-card:hover {
    border-color: var(--brand-primary);
    box-shadow: 0 8px 28px rgba(0,0,0,.1);
    transform: translateY(-3px);
}
.mkt-card__img {
    height: 200px;
    background: var(--surface-sunken);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.mkt-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.mkt-card:hover .mkt-card__img img { transform: scale(1.05); }
.mkt-card__placeholder { font-size: 3.5rem; color: var(--text-muted); opacity: .4; }
.mkt-card__badge {
    position: absolute;
    top: .625rem;
    right: .625rem;
    padding: .25rem .625rem;
    border-radius: 999px;
    font-size: .6875rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: .25rem;
}
.mkt-card__badge--auction { background: var(--brand-primary); color: #fff; }
.mkt-card__badge--sale    { background: var(--color-success); color: #fff; }
.mkt-card__badge--auto    { background: var(--brand-primary); color: #fff; }
.mkt-card__badge--re      { background: #10b981; color: #fff; }
.mkt-card__type {
    position: absolute;
    top: .625rem;
    left: .625rem;
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(255,255,255,.5);
    padding: .25rem .625rem;
    border-radius: 999px;
    font-size: .6875rem;
    font-weight: 700;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: .25rem;
}
.mkt-card__body { padding: 1rem 1.125rem 1.125rem; }
.mkt-card__title {
    font-size: .9375rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: .375rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.mkt-card__cat   { font-size: .75rem; color: var(--brand-primary); font-weight: 600; margin-bottom: .5rem; }
.mkt-card__meta {
    font-size: .8125rem;
    color: var(--text-muted);
    margin-bottom: .875rem;
    display: flex;
    align-items: center;
    gap: .375rem;
    flex-wrap: wrap;
}
.mkt-card__meta span { display: flex; align-items: center; gap: .25rem; }
.mkt-card__footer { display: flex; align-items: center; justify-content: space-between; }
.mkt-card__price {
    font-size: 1.0625rem;
    font-weight: 800;
    color: var(--brand-primary);
    letter-spacing: -.02em;
}
.mkt-card__price-sub { font-size: .75rem; color: var(--text-muted); margin-top: .125rem; }
.mkt-card__arrow { color: var(--text-muted); font-size: .75rem; transition: transform .15s; }
.mkt-card:hover .mkt-card__arrow { transform: translateX(3px); color: var(--brand-primary); }

/* ── View toggle (grid / list) ── */
.mkt-view-toggle { display: flex; gap: .25rem; }
.mkt-view-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 7px;
    border: 1.5px solid var(--border-subtle);
    background: #fff;
    color: var(--text-muted);
    cursor: pointer;
    transition: all .15s;
    font-size: .875rem;
}
.mkt-view-btn.active { background: var(--brand-primary); border-color: var(--brand-primary); color: #fff; }
.mkt-view-btn:hover:not(.active) { border-color: var(--brand-primary); color: var(--brand-primary); }

/* ── List view variant ── */
.mkt-items--list { display: flex !important; flex-direction: column; gap: .75rem; }
.mkt-items--list .mkt-card { display: grid; grid-template-columns: 180px 1fr; border-radius: 12px; }
.mkt-items--list .mkt-card__img { height: 140px; border-radius: 12px 0 0 12px; }
.mkt-items--list .mkt-card__body { display: flex; flex-direction: column; justify-content: center; padding: 1rem 1.25rem; }
.mkt-items--list .mkt-card__title { white-space: normal; font-size: 1rem; }
.mkt-items--list .mkt-card__footer { margin-top: .5rem; }

/* ── Section titles (rental) ── */
.mkt-section-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--text-primary);
    margin-bottom: 1.25rem;
    display: flex;
    align-items: center;
    gap: .5rem;
}
.mkt-section-title i { color: var(--brand-primary); }
.mkt-section-sep { border: none; border-top: 1px solid var(--border-subtle); margin: 2.5rem 0; }

/* ── Empty state ── */
.mkt-empty { text-align: center; padding: 5rem 1.5rem; color: var(--text-muted); }
.mkt-empty i { font-size: 3.5rem; opacity: .3; margin-bottom: 1.25rem; display: block; }
.mkt-empty h3 { font-size: 1.25rem; font-weight: 700; color: var(--text-secondary); margin-bottom: .5rem; }

/* ── Pagination ── */
.mkt-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: .5rem;
    margin-top: 2.5rem;
}
.mkt-pagination a,
.mkt-pagination span {
    display: inline-flex;
    align-items: center;
    gap: .375rem;
    padding: .5rem .875rem;
    border-radius: 8px;
    font-size: .875rem;
    font-weight: 500;
    text-decoration: none;
    border: 1.5px solid var(--border-subtle);
    background: #fff;
    color: var(--text-secondary);
    transition: all .15s;
}
.mkt-pagination a:hover { border-color: var(--brand-primary); color: var(--brand-primary); }
.mkt-pagination .active { background: var(--brand-primary); color: #fff; border-color: var(--brand-primary); font-weight: 700; }
.mkt-pagination-info { text-align: center; margin-top: .875rem; font-size: .8125rem; color: var(--text-muted); }

/* ── Filter bar (consórcio / marketplace avançado) ── */
.mkt-filter-bar {
    display: grid;
    grid-template-columns: 1fr auto auto auto auto auto auto;
    gap: .875rem;
    align-items: flex-end;
    flex-wrap: wrap;
    max-width: 1100px;
    margin: 0 auto;
}
.cons-filter-bar {
    display: grid;
    grid-template-columns: 1fr auto auto auto auto;
    gap: .875rem;
    align-items: flex-end;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 900px;
    margin: 0 auto;
}

/* ── Cons / common body wrapper ── */
.cons-body    { max-width: 1200px; margin: 0 auto; padding: 2rem 1.5rem; }
.cons-filters {
    background: #fff;
    border: 1px solid var(--border-subtle);
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    margin-bottom: 2rem;
}

/* ============================================================
   BROKERS — CARD DE CORRETOR
   ============================================================ */
.broker-items { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.broker-card {
    background: #fff;
    border: 1px solid var(--border-subtle);
    border-radius: 14px;
    overflow: hidden;
    text-decoration: none;
    display: block;
    transition: all .2s;
}
.broker-card:hover {
    border-color: var(--brand-primary);
    box-shadow: 0 8px 28px rgba(0,0,0,.1);
    transform: translateY(-3px);
}
.broker-card__head {
    position: relative;
    padding: 1.5rem 1.25rem 1rem;
    text-align: center;
    background: linear-gradient(180deg, #f8fafc, #fff);
}
.broker-card__avatar {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,.12);
    margin: 0 auto var(--space-2);
    display: block;
}
.broker-card__avatar-placeholder {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 12%, transparent);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-2);
}
.broker-card__name   { font-size: 1rem; font-weight: 700; color: var(--text-primary); margin-bottom: .125rem; }
.broker-card__creci  { font-size: .75rem; color: var(--text-muted); margin-bottom: .375rem; }
.broker-card__rating {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .25rem;
    font-size: .8125rem;
    color: #f59e0b;
    font-weight: 600;
}
.broker-card__body {
    padding: .875rem 1.25rem 1.125rem;
    border-top: 1px solid var(--border-subtle);
}
.broker-card__sp { display: flex; flex-wrap: wrap; gap: .375rem; margin-bottom: .75rem; }
.broker-card__sp span {
    font-size: .6875rem;
    font-weight: 600;
    padding: .2rem .625rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--brand-primary, #0ea5e9) 10%, transparent);
    color: var(--brand-primary);
}
.broker-card__bio {
    font-size: .8125rem;
    color: var(--text-muted);
    line-height: 1.5;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.broker-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .75rem 1.25rem;
    border-top: 1px solid var(--border-subtle);
}
.broker-card__city  { font-size: .75rem; color: var(--text-muted); display: flex; align-items: center; gap: .25rem; }
.broker-card__arrow { color: var(--text-muted); font-size: .75rem; transition: transform .15s; }
.broker-card:hover .broker-card__arrow { transform: translateX(3px); color: var(--brand-primary); }
.broker-featured-badge {
    position: absolute;
    top: .625rem;
    right: .625rem;
    background: #f59e0b;
    color: #fff;
    padding: .2rem .5rem;
    border-radius: 999px;
    font-size: .6875rem;
    font-weight: 700;
}

/* ── Broker list view ── */
.broker-items--list { display: flex; flex-direction: column; gap: .75rem; }
.broker-items--list .broker-card { display: grid; grid-template-columns: 200px 1fr; border-radius: 12px; }
.broker-items--list .broker-card__head { border-radius: 12px 0 0 12px; border-right: 1px solid var(--border-subtle); }
.broker-items--list .broker-card__body { border-top: none; display: flex; flex-direction: column; justify-content: center; padding: 1rem 1.5rem; }

/* ============================================================
   CONSÓRCIO — CARD / PILLS
   ============================================================ */
.cons-hero__content { position: relative; z-index: 1; max-width: 700px; margin: 0 auto; text-align: center; }
.cons-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.cons-card {
    background: #fff;
    border: 1.5px solid var(--border-subtle);
    border-radius: 14px;
    overflow: hidden;
    transition: all .18s;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    position: relative;
}
.cons-card:hover {
    border-color: var(--brand-primary);
    box-shadow: 0 8px 28px rgba(0,0,0,.1);
    transform: translateY(-3px);
}
.cons-card__badge {
    position: absolute;
    top: .75rem;
    left: .75rem;
    background: var(--brand-primary);
    color: #fff;
    padding: .2rem .75rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 700;
    z-index: 1;
}
.cons-card__feat {
    position: absolute;
    top: .75rem;
    right: .75rem;
    background: #f59e0b;
    color: #fff;
    padding: .2rem .625rem;
    border-radius: 999px;
    font-size: .75rem;
    font-weight: 700;
    z-index: 1;
}
.cons-card__thumb    { width: 100%; height: 160px; object-fit: cover; background: var(--surface-sunken); display: block; }
.cons-card__thumb-ph { width: 100%; height: 160px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, #0f172a, #1e293b); }
.cons-card__body { padding: 1.125rem 1.25rem 1.25rem; flex: 1; display: flex; flex-direction: column; }
.cons-card__type        { font-size: .75rem; font-weight: 700; margin-bottom: .5rem; }
.cons-card__title       { font-size: 1rem; font-weight: 700; color: var(--text-primary); margin-bottom: .375rem; line-height: 1.35; }
.cons-card__admin       { font-size: .8125rem; color: var(--text-muted); margin-bottom: .75rem; }
.cons-card__credit      { font-size: 1.375rem; font-weight: 800; color: var(--brand-primary); margin-bottom: .125rem; }
.cons-card__installment { font-size: .875rem; color: var(--text-secondary); margin-bottom: .875rem; }
.cons-card__footer      { margin-top: auto; display: flex; gap: .5rem; flex-wrap: wrap; }

/* ── Consórcio pills ── */
.cons-pill { display: inline-flex; align-items: center; gap: .25rem; padding: .2rem .625rem; border-radius: 999px; font-size: .75rem; font-weight: 600; }
.cons-pill--auto   { background: #eff6ff; color: #2563eb; }
.cons-pill--imovel { background: #f5f3ff; color: #7c3aed; }
.cons-pill--months { background: #f0fdf4; color: #15803d; }
.cons-pill--slots  { background: #fff7ed; color: #c2410c; }

/* ============================================================
   CATÁLOGOS — RESPONSIVIDADE
   ============================================================ */
@media (max-width: 900px) {
    .mkt-hero { padding: 3rem 1.25rem 2.5rem; }
    .mkt-search { flex-direction: column; }
    .mkt-search input, .mkt-search select { min-width: 0; width: 100%; }
    .mkt-filters__inner { gap: .5rem; }
    .mkt-items { grid-template-columns: 1fr 1fr; }
    .mkt-stats__inner { grid-template-columns: 1fr 1fr 1fr; }
    .broker-items { grid-template-columns: 1fr 1fr; }
    .cons-grid { grid-template-columns: repeat(2, 1fr); }
    .mkt-filter-bar { grid-template-columns: 1fr auto auto auto; }
}
@media (max-width: 768px) {
    .mkt-search input, .mkt-search select { min-width: 0 !important; flex: 1 1 100%; }
    .mkt-filters__inner { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; justify-content: start; }
    .mkt-filters .f-group { width: 100%; }
    .mkt-filters .f-group input, .mkt-filters .f-group select { width: 100% !important; }
    .mkt-grid > div:first-child { flex-wrap: wrap; gap: .5rem; }
    .mkt-items { grid-template-columns: 1fr 1fr; }
    .mkt-hero h1 { font-size: 2rem !important; }
    .mkt-stats__inner { grid-template-columns: 1fr 1fr; }
    .mkt-stat:nth-child(3) { grid-column: span 2; border-right: none; border-top: 1px solid var(--border-subtle); }
    .cons-filter-bar { grid-template-columns: 1fr 1fr; }
    .cons-filter-bar > div:first-child, .cons-filter-bar > div:last-child { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
    .mkt-filter-bar { display: flex; flex-direction: column; gap: .625rem; }
    .mkt-filter-bar > div, .mkt-filter-bar > input { width: 100%; }
    .mkt-filter-bar input[type="number"], .mkt-filter-bar select { width: 100% !important; min-width: 0 !important; }
    .mkt-filter-bar-row { display: grid; grid-template-columns: 1fr 1fr; gap: .625rem; }
    .mkt-filter-bar-actions { display: flex; gap: .5rem; flex-wrap: wrap; }
}
@media (max-width: 600px) {
    .mkt-hero h1 { font-size: 1.75rem !important; }
    .mkt-hero { padding: 2.5rem 1rem 2rem; }
    .mkt-items { grid-template-columns: 1fr; }
    .mkt-stats__inner { grid-template-columns: 1fr; }
    .mkt-stat:not(:last-child) { border-right: none; border-bottom: 1px solid var(--border-subtle); }
    .mkt-stat:nth-child(3) { grid-column: span 1; border-top: none; border-bottom: 1px solid var(--border-subtle); }
    .mkt-filters__inner { grid-template-columns: 1fr; flex-direction: column; }
    .mkt-filters .f-group { width: 100%; }
    .mkt-filters .f-group input, .mkt-filters .f-group select { width: 100% !important; }
    .mkt-grid { padding: 1.5rem 1rem; }
    .cons-filters { padding: 1rem; }
    .cons-body { padding: 1rem; }
    .mkt-pagination { flex-wrap: wrap; gap: .375rem; }
    .mkt-pagination a, .mkt-pagination span { padding: .4375rem .75rem; font-size: .8125rem; }
    .mkt-items--list .mkt-card { grid-template-columns: 1fr; }
    .mkt-items--list .mkt-card__img { height: 160px; border-radius: 12px 12px 0 0; }
    .broker-items { grid-template-columns: 1fr; }
    .broker-items--list .broker-card { grid-template-columns: 1fr; }
    .broker-items--list .broker-card__head { border-radius: 12px 12px 0 0; }
    .cons-grid { grid-template-columns: 1fr; }
    .cons-filter-bar { display: flex; flex-direction: column; gap: .625rem; }
    .cons-filter-bar > div { width: 100%; }
    .cons-filter-bar input[type="number"] { width: 100% !important; }
    .cons-filter-bar-actions { display: flex; gap: .5rem; }
}
@media (max-width: 540px) {
    .mkt-search { flex-direction: column; }
    .mkt-search input, .mkt-search select { width: 100%; }
}
@media (max-width: 400px) {
    .mkt-hero h1 { font-size: 1.5rem !important; letter-spacing: -.03em; }
    .mkt-hero { padding: 2rem .875rem 1.75rem; }
    .mkt-grid { padding: 1.25rem .875rem; }
    .mkt-card__img { height: 160px; }
    .mkt-search { padding: .75rem; gap: .5rem; }
}

/* ============================================================
   DETALHE DE ITEM — AUTOMOBILE (.au-*)
   ============================================================ */
.au-detail { max-width: 1200px; margin: 0 auto; padding: var(--space-8) var(--space-4); }
.au-layout { display: grid; grid-template-columns: 1fr 340px; gap: var(--space-8); align-items: start; }

/* ── Gallery ── */
.au-gallery {
    background: var(--surface-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--space-6);
}
.au-gallery__main {
    position: relative;
    height: 420px;
    background: var(--surface-sunken);
    overflow: hidden;
}
.au-gallery__main img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.au-gallery__placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    gap: var(--space-3);
}
.au-gallery__placeholder i { font-size: 4rem; opacity: .4; }
.au-gallery__thumbs {
    display: flex;
    gap: var(--space-2);
    padding: var(--space-4);
    flex-wrap: wrap;
    background: var(--surface-sunken);
}
.au-gallery__thumb {
    width: 80px;
    height: 60px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    cursor: pointer;
    border: 2px solid transparent;
    transition: border-color .2s;
}
.au-gallery__thumb.active,
.au-gallery__thumb:hover { border-color: var(--brand-primary); }

/* ── Info block ── */
.au-info {
    background: var(--surface-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    margin-bottom: var(--space-6);
}
.au-info__title { font-size: 1.75rem; font-weight: 700; color: var(--text-primary); margin: 0 0 var(--space-2); }
.au-info__sub   { color: var(--text-muted); font-size: 1rem; margin-bottom: var(--space-6); }

/* ── Specs grid ── */
.au-specs { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); margin-bottom: var(--space-8); }
.au-spec {
    background: var(--surface-sunken);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    text-align: center;
    transition: box-shadow .2s;
}
.au-spec:hover { box-shadow: 0 4px 12px rgba(0,0,0,.08); }
.au-spec i        { font-size: 1.4rem; color: var(--brand-primary); display: block; margin-bottom: var(--space-2); }
.au-spec__value   { font-size: 1rem; font-weight: 700; color: var(--text-primary); }
.au-spec__label   { font-size: .72rem; color: var(--text-muted); margin-top: 2px; }

/* ── Sections ── */
.au-section { border-top: 1px solid var(--border-subtle); padding-top: var(--space-6); margin-top: var(--space-6); }
.au-section h2 { font-size: 1.2rem; font-weight: 700; color: var(--text-primary); margin: 0 0 var(--space-4); }
.au-section p  { color: var(--text-secondary); line-height: 1.7; }

/* ── Attributes ── */
.au-attrs { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.au-attr {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    background: var(--surface-sunken);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    padding: var(--space-4);
}
.au-attr i           { color: var(--brand-primary); width: 20px; text-align: center; flex-shrink: 0; }
.au-attr__label      { font-size: .72rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: .05em; }
.au-attr__val        { font-size: .95rem; font-weight: 600; color: var(--text-primary); }

/* ── Sidebar ── */
.au-sidebar { position: sticky; top: 80px; }
.au-price-card {
    background: var(--surface-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    margin-bottom: var(--space-4);
}
.au-price-card__amount {
    background: var(--brand-primary);
    color: #fff;
    border-radius: var(--radius-md);
    padding: var(--space-4) var(--space-6);
    text-align: center;
    font-size: 1.6rem;
    font-weight: 800;
    margin-bottom: var(--space-4);
}
.au-price-card__badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-size: .8rem;
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 99px;
    margin-bottom: var(--space-4);
}
.au-price-card__badge--auction { background: color-mix(in srgb, var(--color-info) 15%, transparent); color: var(--color-info); }
.au-price-card__badge--sale    { background: color-mix(in srgb, var(--color-success) 15%, transparent); color: var(--color-success); }
.au-price-card__end {
    font-size: .8rem;
    color: var(--text-muted);
    margin-bottom: var(--space-4);
    display: flex;
    align-items: center;
    gap: var(--space-1);
    justify-content: center;
}
.au-price-card__actions { display: flex; flex-direction: column; gap: var(--space-2); }
.au-price-card__meta {
    border-top: 1px solid var(--border-subtle);
    margin-top: var(--space-4);
    padding-top: var(--space-4);
    font-size: .83rem;
    color: var(--text-muted);
}

/* ── Similar items ── */
.au-similar { margin-top: var(--space-12); }
.au-similar h2 { font-size: 1.3rem; font-weight: 700; color: var(--text-primary); margin-bottom: var(--space-6); }
.au-similar-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }

/* ── Breadcrumb ── */
.au-breadcrumb { display: flex; align-items: center; gap: var(--space-2); font-size: .85rem; color: var(--text-muted); margin-bottom: var(--space-6); }
.au-breadcrumb a      { color: var(--brand-primary); text-decoration: none; }
.au-breadcrumb a:hover { text-decoration: underline; }
.au-breadcrumb span   { opacity: .5; }

/* ── Detalhe — Responsividade ── */
@media (max-width: 1000px) { .au-similar-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 900px)  { .au-layout { grid-template-columns: 1fr; } .au-sidebar { position: static; } }
@media (max-width: 700px)  { .au-specs { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) {
    .au-detail { padding: var(--space-4) var(--space-3); }
    .au-gallery__main { height: 240px; }
    .au-info { padding: var(--space-5); }
    .au-price-card { padding: var(--space-4); }
    .au-specs { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 500px) {
    .au-attrs { grid-template-columns: 1fr; }
    .au-similar-grid { grid-template-columns: 1fr; }
}
