/* ============================================================
   Developers / Doc Site
   Sólo lo mínimo que no se puede resolver con utilidades de WebAwesome:
   - Sidebar sticky
   - Bloque de código dark con copy-button absoluto
   - Active state del link en el sidebar
   - Tabla responsive scroll
   ============================================================ */

/* Layout: sidebar 280px + main flexible */
.dev-grid {
    --min-column-size: 1fr;          /* lo controlamos abajo */
    grid-template-columns: 280px minmax(0, 1fr);
}

@media (max-width: 960px) {
    .dev-grid {
        grid-template-columns: 1fr;
    }
}

/* Sidebar sticky para que acompañe el scroll del contenido */
.dev-sidebar {
    position: sticky;
    top: calc(var(--header-height, 81px) + var(--wa-space-m));
    align-self: start;
    max-height: calc(100vh - var(--header-height, 81px) - var(--wa-space-l));
}

.dev-sidebar-card {
    overflow-y: auto;
    max-height: inherit;
}

/* Items del sidebar a ancho completo y alineados a la izquierda */
.dev-nav-link {
    width: 100%;
}
.dev-nav-link::part(base) {
    justify-content: flex-start;
    width: 100%;
}

/* Estado activo del link */
.dev-nav-link.is-active::part(base) {
    background-color: var(--wa-color-neutral-fill-normal);
    color: var(--wa-color-neutral-on-normal);
    font-weight: 600;
}

/* Quitar margen interno del wa-details cuando va dentro del sidebar */
.dev-sidebar wa-details::part(content) {
    padding-block: var(--wa-space-2xs);
    padding-inline: var(--wa-space-xs);
}

.dev-sidebar wa-details::part(header) {
    padding-block: var(--wa-space-2xs);
}

/* wa-details rota internamente ::part(icon) cuando abre y, con los slots
   expand-icon/collapse-icon, esa rotación deja al chevron-down apuntando
   hacia la izquierda. Deshabilitamos la rotación para que cada slot se
   muestre tal cual (chevron-right cerrado, chevron-down abierto). */
.dev-sidebar wa-details::part(icon) {
    rotate: none;
}

/* Pager: usar wa-split + un truco para que se oculten huecos cuando falta prev o next */
.dev-pager:empty { display: none; }
.dev-pager-link::part(base) {
    width: 100%;
    text-align: start;
}

/* ============================================================
   Code blocks (no hay equivalente nativo en WebAwesome)
   ============================================================ */
.dev-code {
    position: relative;
    background: #0f172a;
    color: #e2e8f0;
    border-radius: var(--wa-border-radius-m);
    overflow: hidden;
}

.dev-code::before {
    content: attr(data-lang);
    position: absolute;
    top: var(--wa-space-2xs);
    left: var(--wa-space-m);
    font: 600 0.7rem ui-monospace, monospace;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #64748b;
    pointer-events: none;
}

.dev-code pre {
    margin: 0;
    padding: calc(var(--wa-space-l)) var(--wa-space-l) var(--wa-space-m);
    overflow-x: auto;
    font: 0.85rem/1.55 ui-monospace, SFMono-Regular, Menlo, monospace;
}

.dev-code code {
    color: inherit;
    background: transparent;
    padding: 0;
}

.dev-code-copy {
    position: absolute;
    top: var(--wa-space-2xs);
    right: var(--wa-space-2xs);
    color: #cbd5e1;
}

/* Article: code inline (fuera de bloque) */
.dev-article-card :where(p, li, td, summary) > code {
    background: var(--wa-color-neutral-fill-quiet);
    padding: 0.1em 0.4em;
    border-radius: 4px;
    font-size: 0.88em;
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

.dev-article-card > article > div > header > h1 {
    margin-top: var(--wa-space-m);
}

wa-tag code { background-color: transparent; }

/* ============================================================
   Tablas responsivas — usan estilos nativos wa-table + scroll
   ============================================================ */
.wa-table-wrapper {
    overflow-x: auto;
    border: 1px solid var(--wa-color-neutral-border-quiet);
    border-radius: var(--wa-border-radius-m);
}
.wa-table {
    width: 100%;
    border-collapse: collapse;
}
.wa-table th, .wa-table td {
    padding: var(--wa-space-2xs) var(--wa-space-s);
    text-align: start;
    border-bottom: 1px solid var(--wa-color-neutral-border-quiet);
    vertical-align: top;
}
.wa-table thead th {
    background: var(--wa-color-neutral-fill-quiet);
    font-weight: 600;
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}
.wa-table tbody tr:last-child td { border-bottom: 0; }

/* ============================================================
   Pequeños ajustes
   ============================================================ */
.dev-loading-bar {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 9999;
    --height: 3px;
}

.dev-endpoint code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
