@charset "UTF-8";

/* =====================================================
   SECCION GENERAL
===================================================== */

.catalogos {

    max-width: 1800px;

    margin: 0 auto;

    padding: 8px 24px 34px;

    background: #f9fbff;

    border-radius: 16px;
}

/* =====================================================
   TITULO
===================================================== */

.catalogos h2{

    text-align:center;

      font-size:28px;

    font-weight:800;

    color:#1e5cc8;

    line-height:1.25;

    margin:0 0 22px;
}

.catalogos h2::after {

    content: "";

    width: 90px;

    height: 4px;

    border-radius: 999px;

    background: #2563eb;

    display: block;

    margin: 14px auto 0;
}

/* =====================================================
   GRID
===================================================== */

.catalogos-grid {

    display: grid;

    grid-template-columns:
        repeat(
            auto-fit,
            minmax(260px, 320px)
        );

    justify-content: center;

    gap: 28px;

    align-items: stretch;
}

/* =====================================================
   CARD
===================================================== */

.catalogo-card {

    background: #fff;

    border-radius: 18px;

    overflow: hidden;

    display: flex;

    flex-direction: column;

    box-shadow:
        0 6px 18px rgba(0,0,0,0.06);

    transition:
        transform .28s ease,
        box-shadow .28s ease;

    min-height: 100%;
}

.catalogo-card:hover {

    transform: translateY(-6px);

    box-shadow:
        0 14px 32px rgba(0,0,0,0.12);
}

/* =====================================================
   IMAGEN
===================================================== */

.catalogo-img {

    padding: 18px;

    text-align: center;
}

.catalogo-img img {

    width: 100%;

    height: 240px;

    object-fit: contain;

    transition: transform .28s ease;
}

.catalogo-card:hover img {

    transform: scale(1.03);
}

/* =====================================================
   INFO
===================================================== */

.catalogo-info {

    text-align: center;

    padding: 14px 16px;

    flex-grow: 1;

    display: flex;

    flex-direction: column;

    justify-content: center;
}

.catalogo-info h3 {

    font-size: 17px;

    font-weight: 700;

    color: #0f172a;

    line-height: 1.45;

    display: -webkit-box;

    -webkit-line-clamp: 2;

    -webkit-box-orient: vertical;

    overflow: hidden;
}

/* =====================================================
   BOTONES
===================================================== */

.catalogo-actions {

    display: flex;

    gap: 12px;

    padding: 16px;
}

.btn-ver,
.btn-descargar {

    flex: 1;

    border: none;

    padding: 12px;

    border-radius: 10px;

    cursor: pointer;

    transition: .25s ease;

    font-weight: 600;

    font-size: 14px;

    text-align: center;

    text-decoration: none;
}

/* VER */

.btn-ver {

    background: #1e5cc8;

    color: #fff;
}

.btn-ver:hover {

    background: #1548a3;
}

/* DESCARGAR */

.btn-descargar {

    background: #28a745;

    color: #fff;
}

.btn-descargar:hover {

    background: #1f7d35;
}

/* =====================================================
   VISOR CONTENEDOR
===================================================== */

.catalogo-preview {

    margin-top: 32px;

    padding: 20px;
}

/* =====================================================
   OCULTO
===================================================== */

.oculto {

    display: none;
}

/* =====================================================
   MENSAJE UX
===================================================== */

.mensaje-uso {

    text-align: center;

    font-size: 14px;

    color: #555;

    margin-bottom: 12px;
}

/* =====================================================
   CONTROLES
===================================================== */

.controles-flipbook {

    display: flex;

    justify-content: center;

    align-items: center;

    gap: 22px;

    margin-bottom: 18px;

    flex-wrap: wrap;
}

.controles-flipbook button {

    background: #007bff;

    color: #fff;

    border: none;

    padding: 11px 18px;

    border-radius: 10px;

    cursor: pointer;

    transition: .25s ease;

    font-weight: 600;
}

.controles-flipbook button:hover {

    background: #0056b3;
}

#contador {

    font-weight: bold;

    font-size: 15px;

    color: #0f172a;
}

/* =====================================================
   FLIPBOOK
===================================================== */

#flipbook {

    width: 100%;

    height: 720px;

    background: #2c2c2c;

    border-radius: 18px;

    overflow: hidden;

    padding: 12px;

    box-shadow:
        0 10px 30px rgba(0,0,0,.12);
}

/* PAGINAS */

.page {

    background: #fff;
}

/* =====================================================
   MONITORES GRANDES
===================================================== */

@media (min-width:1600px){

    .catalogos{

        max-width:2200px;

        padding:10px 36px 45px;
    }

    .catalogos h2{

        font-size:46px;

        margin-bottom:28px;
    }

    .catalogos-grid{

        grid-template-columns:
            repeat(
                auto-fit,
                minmax(300px, 360px)
            );

        justify-content:center;

        gap:36px;
    }

    .catalogo-card{
        border-radius:22px;
    }

    .catalogo-img img{
        height:300px;
    }

    .catalogo-info h3{
        font-size:20px;
    }

    .btn-ver,
    .btn-descargar{
        font-size:16px;
    }

    #flipbook{
        height:920px;
    }
}

/* =====================================================
   LAPTOPS 19 / 15
===================================================== */

@media (max-width:1400px){

    .catalogos-grid{

        grid-template-columns:
            repeat(
                auto-fit,
                minmax(250px, 310px)
            );

        justify-content:center;

        gap:24px;
    }

    #flipbook{
        height:650px;
    }
}

/* =====================================================
   LAPTOPS 14
===================================================== */

@media (max-width:1200px){

    .catalogos{

        padding:6px 18px 28px;
    }

    .catalogos h2{
        font-size:30px;
    }

    .catalogos-grid{

        grid-template-columns:
            repeat(
                auto-fit,
                minmax(220px, 290px)
            );

        justify-content:center;

        gap:20px;
    }

    .catalogo-img img{
        height:210px;
    }

    #flipbook{
        height:560px;
    }
}

/* =====================================================
   TABLET HORIZONTAL
===================================================== */

@media (max-width:992px){

    .catalogos{

        padding:12px 16px 26px;
    }

    .catalogos-grid{

        grid-template-columns:
            repeat(
                auto-fit,
                minmax(210px, 1fr)
            );

        gap:18px;
    }

    .catalogo-card{
        border-radius:16px;
    }

    .catalogo-img img{
        height:190px;
    }

    .catalogo-info h3{
        font-size:15px;
    }

    #flipbook{
        height:500px;
    }
}

/* =====================================================
   TABLET VERTICAL
===================================================== */

@media (max-width:768px){

    .catalogos{

        padding:10px 14px 22px;
    }

    .catalogos h2{

        font-size:25px;

        margin-bottom:18px;
    }

    .catalogos-grid{

        grid-template-columns:
            repeat(2,minmax(0,1fr));

        gap:16px;
    }

    .catalogo-card{
        border-radius:15px;
    }

    .catalogo-img{

        padding:14px;
    }

    .catalogo-img img{
        height:170px;
    }

    .catalogo-info{
        padding:12px;
    }

    .catalogo-info h3{
        font-size:14px;
    }

    .catalogo-actions{

        flex-direction: column;

        gap:10px;

        padding:14px;
    }

    .btn-ver,
    .btn-descargar{
        padding:11px;
    }

    .catalogo-preview{
        padding:18px 0;
    }

    .controles-flipbook{
        gap:14px;
    }

    #flipbook{
        height:420px;
    }
}

/* =====================================================
   TELEFONOS GRANDES
===================================================== */

@media (max-width:580px){

    .catalogos{

        padding:8px 12px 20px;
    }

    .catalogos h2{
        font-size:22px;
    }

    .catalogos-grid{

        grid-template-columns:1fr 1fr;

        gap:12px;
    }

    .catalogo-card{
        border-radius:14px;
    }

    .catalogo-img img{
        height:140px;
    }

    .catalogo-info h3{
        font-size:13px;
    }

    .catalogo-actions{
        padding:12px;
    }

    .btn-ver,
    .btn-descargar{

        font-size:13px;

        padding:10px;
    }

    .mensaje-uso{

        font-size:13px;
    }

    .controles-flipbook{

        gap:10px;
    }

    .controles-flipbook button{

        padding:10px 14px;

        font-size:13px;
    }

    #contador{
        font-size:13px;
    }

    #flipbook{
        height:320px;
    }
}

/* =====================================================
   TELEFONOS PEQUEÑOS
===================================================== */

@media (max-width:420px){

    .catalogos-grid{

        gap:10px;
    }

    .catalogo-img img{
        height:120px;
    }

    .catalogo-info h3{
        font-size:12px;
    }

    .btn-ver,
    .btn-descargar{

        font-size:12px;

        padding:9px;
    }

    #flipbook{
        height:260px;
    }
}