/* ─── Page hero ─── */
.page-hero {
    padding: 56px 0 20px;
}
.page-hero h1, .page-hero h2 {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 4vw, 2rem); font-weight: 900;
    color: white;
    letter-spacing: -0.03em;
    line-height: 1.15;
}
.page-hero p {
    font-size: 0.95rem; color: var(--text-secondary);
    margin-top: 12px; max-width: 480px;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════════
/* ─── Stats ─── */
.stats {
    padding: 8px 0 12px;
    color: var(--text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 500;
}

/* ─── Filters ─── */
.filters {
    display: flex; gap: 8px; flex-wrap: wrap;
    padding: 0 0 16px;
}
.filters select {
    appearance: none;
    background: var(--bg-chrome-up) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b8680' d='M2 4l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 10px center;
    color: var(--text-secondary);
    border: 1px solid var(--border-chrome);
    padding: 10px 32px 10px 12px;
    min-height: 44px;
    border-radius: 6px;
    font-family: var(--font-ui);
    font-size: 0.8rem; font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
}
.filters select:hover { border-color: var(--text-muted); color: var(--text-primary); }
.filters select:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-soft); }

/* ─── Law list ─── */
.law-list {
    list-style: none;
    display: flex; flex-direction: column;
    gap: 2px;
}
.law-item {
    padding: 12px 16px;
    border-radius: 8px;
    transition: background 0.15s ease;
    display: flex; flex-direction: column; gap: 6px;
}
.law-item:hover { background: var(--bg-chrome-up); }
.law-title {
    font-family: var(--font-body);
    font-size: 0.95rem; font-weight: 400;
    color: var(--text-primary);
    line-height: 1.4;
    display: block;
}
.law-title:hover { color: white; text-decoration: none; }
.law-meta {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    font-size: 0.72rem; color: var(--text-muted);
}
.badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px; border-radius: 3px;
    font-size: 0.7rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 0.06em;
    font-family: var(--font-ui);
}
.badge { background: var(--accent-soft); color: var(--accent); }
.badge-vigente { background: var(--vigente-bg); color: var(--vigente); }
.badge-derogada { background: var(--derogada-bg); color: var(--derogada); }

/* ─── Pagination ─── */
.pagination {
    display: flex; gap: 4px; padding: 32px 0; flex-wrap: wrap;
    justify-content: center;
}
.pagination a, .pagination span {
    padding: 6px 12px; border-radius: 4px;
    font-size: 0.8rem; font-weight: 500;
}
.pagination a {
    color: var(--text-secondary);
    transition: all 0.15s ease;
}
.pagination a:hover { color: var(--text-primary); background: var(--bg-chrome-up); text-decoration: none; }
.pagination .current { background: var(--accent); color: white; }

/* ═══════════════════════════════════════════════════
/* ─── htmx indicator ─── */
.htmx-indicator { display: none; }
.htmx-request .htmx-indicator { display: inline; }
.htmx-request.htmx-indicator { display: inline; }

/* ─── Search ─── */
.search-form { padding: 32px 0 8px; }
.search-input {
    width: 100%;
    background: var(--bg-chrome-up);
    color: var(--text-primary);
    border: 1px solid var(--border-chrome);
    padding: 12px 20px;
    border-radius: 8px;
    font-family: var(--font-ui);
    font-size: 1rem;
    transition: all 0.15s ease;
}
.search-input:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px var(--accent-soft);
}
.search-input::placeholder { color: var(--text-muted); }
mark {
    background: rgba(26, 86, 219, 0.12);
    color: var(--accent);
    padding: 1px 3px; border-radius: 2px;
}

/* ─── Load more (lazy loading) ─── */
.load-more {
    display: block;
    width: 100%;
    padding: 12px 20px;
    margin: 16px 0;
    background: var(--bg-chrome-up);
    border: 1px solid var(--border-chrome);
    border-radius: 8px;
    color: var(--accent);
    font-size: 0.85rem;
    cursor: pointer;
    text-align: center;
    transition: background 0.15s;
}
.load-more:hover { background: var(--bg-chrome-up2); }
.load-more.htmx-request { opacity: 0.5; pointer-events: none; }
