.geps-premium-lock{
    padding:16px 18px;
    border-radius:14px;
    background:#fff7ed;
    color:#9a3412;
    border:1px solid #fdba74;
    font-size:14px;
}

.geps-premium-catalog{
    display:grid;
    gap:24px;
    margin:24px 0;
}

.geps-cols-1{ grid-template-columns:repeat(1, minmax(0,1fr)); }
.geps-cols-2{ grid-template-columns:repeat(2, minmax(0,1fr)); }
.geps-cols-3{ grid-template-columns:repeat(3, minmax(0,1fr)); }
.geps-cols-4{ grid-template-columns:repeat(4, minmax(0,1fr)); }

.geps-cat-card{
    position:relative;
    display:flex;
    flex-direction:column;
    min-height:100%;
    background:#ffffff;
    border:1px solid #e5e7eb;
    border-radius:22px;
    overflow:hidden;
    box-shadow:0 10px 30px rgba(2, 6, 23, 0.06);
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.geps-cat-card:hover{
    transform:translateY(-4px);
    box-shadow:0 20px 40px rgba(2, 6, 23, 0.10);
    border-color:#cbd5e1;
}

.geps-cat-ribbon{
    position:absolute;
    top:14px;
    right:14px;
    z-index:3;
    padding:7px 12px;
    border-radius:999px;
    background:linear-gradient(135deg,#0f172a,#334155);
    color:#fff;
    font-size:12px;
    font-weight:700;
    letter-spacing:.2px;
}

.geps-cat-media{
    position:relative;
    background:linear-gradient(180deg,#f8fafc 0%, #eef2ff 100%);
    padding:18px;
}

.geps-cat-image-link{
    display:block;
    text-decoration:none;
}

.geps-cat-image{
    display:block;
    width:100%;
    aspect-ratio:16/10;
    object-fit:cover;
    border-radius:16px;
    background:#fff;
    border:1px solid #e5e7eb;
}

.geps-cat-no-image{
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    aspect-ratio:16/10;
    border-radius:16px;
    border:1px dashed #cbd5e1;
    color:#64748b;
    background:#fff;
    font-size:14px;
}

.geps-cat-body{
    display:flex;
    flex-direction:column;
    flex:1;
    padding:22px;
}

.geps-cat-top{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    margin-bottom:12px;
}

.geps-cat-badge{
    display:inline-flex;
    align-items:center;
    padding:6px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
    line-height:1;
}

.geps-cat-badge.is-plan{
    background:#eff6ff;
    color:#1d4ed8;
}

.geps-cat-badge.is-multi{
    background:#ecfeff;
    color:#0f766e;
}

.geps-cat-title{
    margin:0 0 8px;
    font-size:22px;
    line-height:1.25;
    font-weight:800;
}

.geps-cat-title a{
    color:#0f172a;
    text-decoration:none;
}

.geps-cat-title a:hover{
    color:#2563eb;
}

.geps-cat-subtitle{
    font-size:14px;
    line-height:1.5;
    color:#475569;
    margin-bottom:12px;
}

.geps-cat-excerpt{
    font-size:14px;
    line-height:1.7;
    color:#64748b;
    margin-bottom:16px;
}

.geps-cat-features{
    list-style:none;
    margin:0 0 18px;
    padding:0;
    display:grid;
    gap:10px;
}

.geps-cat-features li{
    position:relative;
    padding-left:18px;
    color:#0f172a;
    font-size:14px;
    line-height:1.55;
}

.geps-cat-features li::before{
    content:"✓";
    position:absolute;
    left:0;
    top:0;
    color:#16a34a;
    font-weight:700;
}

.geps-cat-footer{
    margin-top:auto;
    padding-top:8px;
}

.geps-cat-price{
    font-size:24px;
    font-weight:800;
    color:#0f172a;
    margin-bottom:14px;
}

.geps-cat-actions{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.geps-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:42px;
    padding:10px 16px;
    border-radius:12px;
    text-decoration:none;
    font-size:14px;
    font-weight:700;
    transition:all .2s ease;
    border:1px solid transparent;
}

.geps-btn-primary{
    background:#2563eb;
    color:#fff;
}

.geps-btn-primary:hover{
    background:#1d4ed8;
    color:#fff;
}

.geps-btn-secondary{
    background:#0f172a;
    color:#fff;
}

.geps-btn-secondary:hover{
    background:#1e293b;
    color:#fff;
}

.geps-btn-light{
    background:#f8fafc;
    color:#0f172a;
    border-color:#dbeafe;
}

.geps-btn-light:hover{
    background:#eff6ff;
    color:#0f172a;
}

@media (max-width: 1080px){
    .geps-cols-4,
    .geps-cols-3{
        grid-template-columns:repeat(2, minmax(0,1fr));
    }
}

@media (max-width: 680px){
    .geps-cols-4,
    .geps-cols-3,
    .geps-cols-2{
        grid-template-columns:repeat(1, minmax(0,1fr));
    }

    .geps-cat-title{
        font-size:20px;
    }

    .geps-cat-actions{
        flex-direction:column;
    }

    .geps-btn{
        width:100%;
    }
}