/* ===========================================================================
   Ezdok ZaiZoi — hoja de estilos propia (sin frameworks).
   Paleta tomada de la lata: navy profundo, rojo, cian, crema y oro.
   Móvil primero.
   =========================================================================== */

:root {
    --fondo: #0b0b0b;
    --fondo-2: #050505;
    --carta: #181818;
    --borde: #2c2c2c;
    --texto: #f2ede0;
    --texto-suave: #a3a3a3;
    --rojo: #e23a31;
    --rojo-oscuro: #c22d25;
    --cian: #35a9bf;
    --cian-claro: #58c6da;
    --cian-soft: #def0f4;
    --cian-texto: #1d6c7c;
    --oro: #f2c14e;

    /* Administración (esquema claro, legible para gestión de datos) */
    --admin-fondo: #eceff3;
    --admin-carta: #ffffff;
    --admin-borde: #d7dee7;
    --admin-cabecera: #f1f4f8;
    --tinta: #1d2733;

    --radio: 10px;
    --ancho: 1100px;
    --sombra: 0 2px 10px rgba(0, 0, 0, .28);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    color: var(--texto);
    background-color: var(--fondo);
    line-height: 1.55;
}

h1, h2, h3 { line-height: 1.2; font-weight: 700; }
h1 { font-size: 1.9rem; margin: 0 0 .5em; }
h2 { font-size: 1.35rem; }
h3 { font-size: 1.1rem; }

a { color: var(--cian-claro); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; display: block; }

.contenedor {
    width: 100%;
    max-width: var(--ancho);
    margin: 0 auto;
    padding: 0 1rem;
}

/* ---------- Botones ---------- */
.boton {
    display: inline-block;
    background: var(--rojo);
    color: #fff;
    padding: .65rem 1.2rem;
    border-radius: var(--radio);
    font-weight: 600;
    border: none;
    cursor: pointer;
}
.boton:hover { background: var(--rojo-oscuro); text-decoration: none; color: #fff; }
.boton-secundario { background: var(--cian); }
.boton-secundario:hover { background: #2b8da0; }

button {
    font: inherit;
    background: var(--rojo);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: .5rem .9rem;
    cursor: pointer;
}
button:hover { background: var(--rojo-oscuro); }
.boton-enlace { background: none; color: var(--cian); padding: 0; font-weight: 600; }
.boton-enlace:hover { background: none; text-decoration: underline; }

/* Enlace de alta ("+ Nuevo …") como botón rojo */
.btn-nuevo, .admin .btn-nuevo {
    display: inline-block; background: var(--rojo); color: #fff;
    padding: .45rem .85rem; border-radius: 8px; font-weight: 600;
}
.btn-nuevo:hover, .admin .btn-nuevo:hover { background: var(--rojo-oscuro); color: #fff; text-decoration: none; }

/* ===========================================================================
   Barra superior (solo el acceso de administrador)
   =========================================================================== */
.barra-top { background: var(--fondo-2); border-bottom: 1px solid var(--borde); }
.barra-top-interior {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    padding-top: .5rem;
    padding-bottom: .5rem;
}
.btn-admin {
    background: var(--rojo);
    color: #fff;
    font-size: .85rem;
    font-weight: 600;
    padding: .35rem .8rem;
    border-radius: 999px;
}
.btn-admin:hover { background: var(--rojo-oscuro); text-decoration: none; color: #fff; }

main.contenedor { padding-top: 1.5rem; padding-bottom: 2.5rem; }

/* ===========================================================================
   Marca de la página (sustituye al header)
   =========================================================================== */
.marca-pagina { text-align: center; padding: 1.5rem 0 1rem; }
.logo-portada { width: 55%; max-width: 230px; height: auto; margin: 0 auto; display: block; }
.marca-pagina h1 {
    font-size: 2.4rem;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: #fff;
    margin-bottom: .2rem;
}
.marca-pagina h1::after {
    content: "";
    display: block;
    width: 64px;
    height: 4px;
    background: var(--rojo);
    margin: .5rem auto 0;
    border-radius: 2px;
}
.claim { max-width: 46ch; margin: .6rem auto 0; color: var(--texto-suave); }

/* Encabezados de sección */
.seccion-grifos, .seccion-catalogo { margin-top: 2rem; }
.seccion-grifos h2, .seccion-catalogo h2 {
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 1rem;
}

/* ===========================================================================
   Grifos
   =========================================================================== */
.grifos {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column;
}
/* La lista de grifos como una tarjeta grande (la diferencia de la carta de cervezas) */
.seccion-grifos .grifos {
    background: var(--carta);
    border: 1px solid var(--borde);
    border-radius: 14px;
    padding: .3rem 1.1rem;
    box-shadow: var(--sombra);
}
.grifo {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1rem 1.2rem;
    padding: .9rem .2rem;
    border-bottom: 1px solid rgba(230, 221, 204, .14);
}
.grifo:last-child { border-bottom: none; }
/* Numeración automática de los grifos (no en la carta de cervezas) */
.grifos:not(.grifos-compacto) { counter-reset: grifo; }
.grifos:not(.grifos-compacto) .grifo { align-items: flex-start; flex-wrap: nowrap; }
.grifos:not(.grifos-compacto) .grifo::before {
    counter-increment: grifo;
    content: counter(grifo);
    flex: 0 0 auto; align-self: center;
    width: 1.9rem; height: 1.9rem;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--oro); color: #1a1a1a;
    border-radius: 50%; font-weight: 800; font-size: .95rem;
}
/* Info + precios (a la derecha del número). En escritorio en fila (precios a la derecha). */
.grifo-main { flex: 1 1 auto; min-width: 0; display: flex; align-items: center; gap: 1rem; }
.grifo-main .grifo-info { flex: 1 1 auto; min-width: 0; }
/* Icono junto a los títulos de sección */
.icono-titulo { width: 1.15em; height: 1.15em; margin-right: .45rem; vertical-align: -.2em; color: var(--oro); }
.grifo-info { flex: 1 1 60%; min-width: 0; }
.grifo-titulo { margin: 0 0 .4rem; line-height: 1.3; }
.g-cervecera { margin-right: .4rem; }
.g-cervecera { color: var(--cian-claro); font-weight: 500; font-size: 1.25rem; }
.g-cerveza { color: #fff; font-weight: 500; font-size: 1.25rem; }
.grifo-burbujas { margin: 0; display: flex; flex-wrap: wrap; gap: .35rem; }
.burbuja {
    display: inline-block;
    border: 1px solid var(--borde);
    border-radius: 999px;
    padding: .08rem .6rem;
    font-size: .76rem;
    color: var(--texto-suave);
}
.burbuja-estilo { background: var(--rojo); border-color: var(--rojo); color: #fff; font-weight: 700; text-transform: uppercase; letter-spacing: .3px; }
.burbuja-nuevo { background: var(--cian); border-color: var(--cian); color: #05222a; font-weight: 800; text-transform: uppercase; letter-spacing: .3px; }
.burbuja-origen { display: inline-flex; align-items: center; gap: .3rem; }

.grifo-tamanos { flex: 0 0 auto; display: flex; gap: .9rem; }
.tam-col { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.2; min-width: 3.2rem; }
.tam-nombre { font-size: .7rem; text-transform: uppercase; letter-spacing: .3px; color: var(--texto-suave); }
.tam-precio { font-weight: 600; color: var(--oro); }

.grifo-logo { flex: 0 0 auto; width: 54px; height: 54px; display: flex; align-items: center; justify-content: center; }
.grifo-logo img { max-width: 100%; max-height: 100%; object-fit: contain; }

/* Carta = misma estructura que los grifos pero como enlace y más compacta */
.grifo-enlace {
    flex: 1 1 auto; width: 100%;
    display: flex; flex-wrap: wrap; align-items: center; gap: .6rem 1.2rem;
    color: inherit;
}
.grifo-enlace:hover { text-decoration: none; }
.grifos-compacto .grifo { padding: .55rem .2rem; gap: .5rem 1rem; }
.grifos-compacto .g-cervecera, .grifos-compacto .g-cerveza { font-size: 1rem; }
/* Carta en escritorio: nombre y burbujas seguidos (una línea), precios a la derecha */
.grifos-compacto .grifo-info { display: flex; flex-wrap: wrap; align-items: baseline; gap: .25rem .65rem; }
.grifos-compacto .grifo-titulo { margin-bottom: 0; gap: .12rem .45rem; }
.grifos-compacto .grifo-burbujas { gap: .3rem; }

/* En móvil, formato apilado (3 líneas y precios debajo) */
@media (max-width: 600px) {
    .grifo-main { flex-direction: column; align-items: stretch; gap: .4rem; }
    .grifos:not(.grifos-compacto) .grifo::before { align-self: flex-start; }
    .grifos-compacto .grifo-enlace { flex-direction: column; align-items: stretch; gap: .25rem; }
    .grifos-compacto .grifo-info { display: block; }
    .grifos-compacto .grifo-titulo { margin-bottom: .2rem; }
}
.grifos-compacto .burbuja { font-size: .68rem; padding: .05rem .45rem; }
.grifos-compacto .grifo-tamanos { gap: .7rem; }
.grifos-compacto .tam-nombre { font-size: .6rem; }
.grifos-compacto .tam-precio { font-size: .95rem; font-weight: 400; }
.grifos-compacto .tam-col { flex-direction: row; align-items: baseline; gap: .35rem; }
.tam-cl { font-size: .8rem; color: var(--texto-suave); }

.badge-nuevo {
    display: inline-block;
    background: var(--cian);
    color: #05222a;
    font-size: .68rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: .5px;
    padding: .1rem .45rem; border-radius: 999px;
}

/* Banderas */
.bandera { display: inline-block; width: 1.3em; height: auto; vertical-align: -.2em; border-radius: 2px; }
.bandera-emoji { font-size: 1.1em; line-height: 1; }

/* Edición de tamaños del grifo (admin) */
.tamanos-edit { border: 1px solid var(--admin-borde); border-radius: var(--radio); padding: 1rem; margin-bottom: 1rem; max-width: 480px; }
.tamanos-edit legend { font-weight: 700; padding: 0 .4rem; }
.tamanos-edit .ayuda { color: #5c6877; font-size: .85rem; margin: 0 0 .8rem; }
.tamano-fila { display: flex; gap: .5rem; align-items: center; margin-bottom: .5rem; }
.tamano-fila input[type="number"] { max-width: 140px; }
.tamano-check { flex: 1 1 auto; display: flex; align-items: center; gap: .4rem; font-weight: 600; }
.tamano-check input[type="checkbox"] { width: auto; max-width: none; }
.tamano-check small { font-weight: 400; color: #5c6877; }

/* ===========================================================================
   Desplegable propio (combos estilo Ordulari, colores del template)
   =========================================================================== */
.ordsel { position: relative; width: 100%; max-width: 480px; }
.ordsel.is-open { z-index: 50; }
.ordsel__native { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.ordsel__trigger {
    width: 100%; text-align: left; font: inherit; color: var(--tinta);
    background: #fff; border: 1px solid var(--borde); border-radius: 10px;
    padding: .62rem 2.2rem .62rem .8rem; cursor: pointer; position: relative;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
    transition: border-color .15s, box-shadow .15s;
}
.ordsel__trigger::after {
    content: ""; position: absolute; right: .85rem; top: 50%; width: .5rem; height: .5rem;
    border-right: 2px solid #5c6877; border-bottom: 2px solid #5c6877;
    transform: translateY(-65%) rotate(45deg); transition: transform .15s;
}
.ordsel__trigger:hover { background: var(--cian-soft); border-color: var(--cian); }
.ordsel.is-open .ordsel__trigger { background: #fff; border-color: var(--cian); box-shadow: 0 0 0 3px rgba(53, 169, 191, .3); }
.ordsel.is-open .ordsel__trigger::after { transform: translateY(-35%) rotate(225deg); }
.ordsel__panel {
    display: none; position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 60;
    background: #fff; border: 1px solid var(--borde); border-radius: 10px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, .22); padding: 6px; max-height: 280px; overflow-y: auto;
}
.ordsel.is-open .ordsel__panel { display: block; }
.ordsel__buscar { width: 100%; max-width: none; margin-bottom: 6px; }
.ordsel__opt {
    padding: .5rem .65rem; border-radius: 6px; font-size: .95rem;
    color: var(--tinta); cursor: pointer;
}
.ordsel__opt:hover, .ordsel__opt.is-hl { background: var(--cian-soft); color: var(--cian-texto); }
.ordsel__opt.is-sel { background: var(--cian-soft); color: var(--cian-texto); font-weight: 700; }

/* En la barra de filtros el combo ocupa como un campo más */
.filtros .ordsel { flex: 1 1 160px; max-width: none; }

/* En la web pública (fondo negro) los controles van oscuros, no blancos */
body:not(.admin) input,
body:not(.admin) select,
body:not(.admin) textarea { background: #1a1a1a; color: var(--texto); border-color: var(--borde); }
body:not(.admin) input::placeholder { color: #7f7f7f; }
body:not(.admin) .ordsel__trigger { background: #1a1a1a; color: var(--texto); border-color: var(--borde); }
body:not(.admin) .ordsel__trigger::after { border-color: var(--texto-suave); }
body:not(.admin) .ordsel__trigger:hover { background: #242424; border-color: var(--cian); }
body:not(.admin) .ordsel.is-open .ordsel__trigger { background: #1a1a1a; border-color: var(--cian); }
body:not(.admin) .ordsel__panel { background: #141414; border-color: var(--borde); box-shadow: 0 10px 28px rgba(0, 0, 0, .6); }
body:not(.admin) .ordsel__opt { color: var(--texto); }
body:not(.admin) .ordsel__opt:hover,
body:not(.admin) .ordsel__opt.is-hl,
body:not(.admin) .ordsel__opt.is-sel { background: rgba(53, 169, 191, .22); color: var(--cian-claro); }

/* Buscador sobre un listado de tabla (admin) */
.buscador-lista { max-width: 480px; margin: 0 0 1rem; }

/* Edición inline de grifos (admin) */
.grifos-edit { display: flex; flex-direction: column; }
.ge-fila { display: flex; align-items: flex-end; gap: .8rem; padding: .7rem 0; border-bottom: 1px solid var(--admin-borde); flex-wrap: wrap; }
.ge-fila:last-child { border-bottom: none; }
.ge-libre .ordsel__trigger { color: var(--muted, #8a93a0); }
.ge-form { display: flex; align-items: flex-end; gap: .8rem; flex: 1 1 auto; flex-wrap: wrap; }
.ge-cerveza { flex: 1 1 240px; min-width: 200px; display: flex; align-items: center; gap: .5rem; }
.ge-cerveza .ordsel { max-width: none; flex: 1 1 auto; }
.ge-precios { display: flex; gap: .6rem; flex-wrap: wrap; }
.ge-precio { display: flex; flex-direction: column; font-size: .7rem; text-transform: uppercase; letter-spacing: .3px; color: #5c6877; }
.ge-precio input { width: 100px; max-width: 100px; padding: .4rem .55rem; margin-top: 2px; font-size: 1.05rem; font-weight: 600; }
.ge-eliminar { margin-left: auto; }

/* Alta rápida (crear estilo/cervecera al vuelo) */
.alta-rapida { max-width: 480px; margin-top: .45rem; border: 1px dashed var(--admin-borde); border-radius: 8px; padding: .5rem .7rem; }
.alta-rapida summary { cursor: pointer; font-size: .9rem; color: #1d6c7c; }
.alta-rapida input, .alta-rapida select { margin-top: .45rem; }
.alta-rapida label { display: block; margin-top: .45rem; font-weight: 600; }

/* ===========================================================================
   Cabecera del catálogo + botón de filtros
   =========================================================================== */
.catalogo-cab { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.catalogo-cab h2 { margin: 0; }
.btn-filtros {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    background: var(--carta);
    color: var(--texto);
    border: 1px solid var(--borde);
    border-radius: 999px;
    padding: .45rem .6rem;
    cursor: pointer;
}
.btn-filtros:hover { background: var(--carta); border-color: var(--cian); color: var(--cian-claro); }
.btn-filtros svg { display: block; }
.punto-filtro { color: var(--oro); font-size: .7rem; line-height: 1; }
.oculto { display: none !important; }

/* ===========================================================================
   Filtros del catálogo
   =========================================================================== */
.filtros {
    display: flex; flex-wrap: wrap; gap: .6rem; align-items: center;
    background: var(--carta);
    border: 1px solid var(--borde);
    border-radius: var(--radio);
    padding: .8rem;
    margin-bottom: 1.2rem;
}
.filtros input, .filtros select { flex: 1 1 160px; }
.filtros button { flex: 0 0 auto; }
.filtros .limpiar { font-size: .9rem; }

/* ===========================================================================
   Catálogo en modo lista
   =========================================================================== */
.catalogo { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .45rem; }
.fila {
    background: var(--carta);
    border: 1px solid var(--borde);
    border-radius: 8px;
    transition: border-color .12s ease;
}
.fila:hover { border-color: var(--cian); }
.fila-enlace { color: inherit; display: flex; align-items: center; gap: .7rem; padding: .45rem .65rem; }
.fila-enlace:hover { text-decoration: none; }
.fila-img {
    flex: 0 0 auto; width: 46px; height: 46px;
    background: var(--fondo-2);
    border-radius: 6px; overflow: hidden;
    display: flex; align-items: center; justify-content: center;
}
.fila-img img { width: 100%; height: 100%; object-fit: cover; }
.fila-info { flex: 1 1 auto; min-width: 0; }
.fila-cab { display: flex; align-items: baseline; flex-wrap: wrap; gap: .15rem .6rem; }
.fila-cab h3 { margin: 0; font-size: 1.25rem; line-height: 1.2; }
.fila-cervecera { font-weight: 600; font-size: 1.05rem; color: var(--texto); }
.fila-meta { display: flex; flex-wrap: wrap; gap: .35rem .7rem; align-items: center; margin: .45rem 0 .25rem; font-size: .8rem; color: var(--texto-suave); }
.fila-precios { margin: 0; font-size: 1.05rem; color: var(--texto-suave); display: flex; flex-wrap: wrap; gap: .15rem 1rem; }
.fila-precio-item { white-space: nowrap; }
.fila-precios .precio { color: var(--oro); font-weight: 500; }

.etiqueta {
    display: inline-block;
    background: var(--rojo);
    color: #fff;
    font-size: .72rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .4px;
    padding: .15rem .5rem; border-radius: 999px;
}
.precio { font-weight: 700; color: var(--oro); }
.vacio { color: var(--texto-suave); font-style: italic; }

/* ===========================================================================
   Ficha de cerveza
   =========================================================================== */
.migas { margin-bottom: 1rem; }
.ficha { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.ficha-imagen {
    background: var(--fondo-2);
    border: 1px solid var(--borde);
    border-radius: var(--radio);
    min-height: 200px;
    display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.ficha-imagen img { width: 100%; object-fit: cover; }
.ficha-datos h1 { margin-bottom: .3rem; color: #fff; }
.ficha-meta { display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; color: var(--texto-suave); }
.ficha-origen { color: var(--texto-suave); margin: .2rem 0 1rem; }
.ficha-descripcion { font-size: 1.05rem; }
.formatos { list-style: none; margin: 0; padding: 0; }
.formatos li { display: flex; justify-content: space-between; border-top: 1px dashed var(--borde); padding: .35rem 0; }

/* ===========================================================================
   Formularios (login y administración)
   =========================================================================== */
.campo { margin-bottom: 1rem; max-width: 480px; }
.campo label { display: block; font-weight: 600; margin-bottom: .25rem; }
.campo-check label { font-weight: 400; }
input, select, textarea {
    font: inherit; width: 100%; max-width: 480px;
    padding: .62rem .8rem;
    border: 1px solid var(--borde);
    border-radius: 10px;
    background: #fff; color: var(--tinta);
    transition: border-color .15s, box-shadow .15s;
}
/* Combos: ocultamos la flecha nativa y ponemos un chevron propio (forma tipo Ordulari). */
select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 2.2rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235c6877' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 1rem;
    cursor: pointer;
}
select::-ms-expand { display: none; }
/* Multi-selección (colaboradoras): listbox nativo, sin flecha */
select[multiple] {
    -webkit-appearance: listbox; -moz-appearance: listbox; appearance: auto;
    background-image: none; padding-right: .65rem; height: auto;
}
select[multiple] option { padding: .25rem .4rem; }
.campo-check input { width: auto; max-width: none; margin-right: .4rem; }
input:focus, select:focus, textarea:focus {
    outline: none; border-color: var(--cian);
    box-shadow: 0 0 0 3px rgba(53, 169, 191, .3);
}
textarea { resize: vertical; }
.error { color: #ff8b84; font-size: .9rem; }
.error ul { margin: .3rem 0; padding-left: 1.1rem; }
.exito { color: #7fdc8a; font-size: .95rem; font-weight: 600; }
.thumb { width: 48px; height: 48px; object-fit: cover; border-radius: 6px; border: 1px solid var(--admin-borde); }
form .boton, .campo + button { margin-right: .5rem; }
/* Separación entre el botón de guardar y el de cancelar */
form button[type="submit"] + a { margin-left: .9rem; }
/* Separación de los enlaces de acción superiores (Nuevo · Volver) */
.admin-main > h1 + p { display: flex; flex-wrap: wrap; align-items: center; gap: .85rem; }

/* ===========================================================================
   Administración (esquema claro)
   =========================================================================== */
body.admin { background-image: none; background-color: var(--admin-fondo); color: var(--tinta); }
.admin a { color: #1d6c7c; }
.admin h1, .admin h2, .admin h3 { color: var(--tinta); }
.admin .error { color: var(--rojo-oscuro); }
.admin input, .admin select, .admin textarea { border-color: var(--admin-borde); }

.admin-cabecera { background: var(--fondo-2); color: #fff; }
.admin-cabecera-interior {
    display: flex; flex-wrap: wrap; align-items: center; gap: .6rem 1.2rem;
    padding-top: .7rem; padding-bottom: .7rem;
}
.marca { font-size: 1.2rem; font-weight: 800; color: #fff; }
.marca:hover { text-decoration: none; }
.admin-menu { display: flex; flex-wrap: wrap; gap: .25rem .9rem; flex: 1 1 auto; }
.admin-menu a { color: #fff; opacity: .9; font-size: .92rem; }
.admin-menu a:hover { opacity: 1; text-decoration: none; border-bottom: 2px solid var(--rojo); }
.admin-usuario { display: flex; align-items: center; gap: .7rem; font-size: .9rem; }
.admin-usuario span { font-weight: 600; }
.admin-usuario a, .admin-usuario .boton-enlace { color: #fff; }
.admin-main { padding-top: 1.5rem; padding-bottom: 2rem; }

.panel-tarjetas { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.panel-tarjetas a {
    display: flex; flex-direction: column;
    background: var(--admin-carta);
    border: 1px solid var(--admin-borde);
    border-radius: var(--radio);
    padding: 1.1rem; color: var(--tinta);
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.panel-tarjetas a:hover { text-decoration: none; border-color: var(--rojo); }
.panel-titulo { font-weight: 700; font-size: 1.1rem; }
.panel-desc { color: #5c6877; font-size: .9rem; }

/* Tablas (solo administración) */
table {
    width: 100%; border-collapse: collapse;
    background: var(--admin-carta);
    border: 1px solid var(--admin-borde);
    border-radius: var(--radio); overflow: hidden;
    margin-bottom: 1.5rem;
}
th, td { text-align: left; padding: .6rem .7rem; border-bottom: 1px solid var(--admin-borde); vertical-align: middle; font-size: .95rem; }
thead th { background: var(--admin-cabecera); font-size: .82rem; text-transform: uppercase; letter-spacing: .3px; }
tbody tr:last-child td { border-bottom: none; }
tbody tr:hover { background: #f7fafd; }
tr.inactivo td { color: #9aa6b2; }
.inline { display: inline; }
td .inline button { background: none; color: #5c6877; padding: .15rem .3rem; font-size: .9rem; }
td .inline button:hover { color: var(--rojo); }
td a { margin-right: .6rem; }

/* ===========================================================================
   Breakpoints
   =========================================================================== */
@media (min-width: 600px) {
    .panel-tarjetas { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 900px) {
    .ficha { grid-template-columns: 320px 1fr; align-items: start; }
    .panel-tarjetas { grid-template-columns: repeat(4, 1fr); }
}
