.fl-wrap{
    margin: 20px auto;
}

.fl-grid{
    display:grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}

.fl-card{
    position:relative;
    display:block;
    border-radius: 18px;
    overflow:hidden;
    text-decoration:none;
    background: #0b1220;
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 10px 28px rgba(0,0,0,.12);
    aspect-ratio: 16 / 9;
}

.fl-media{
    position:absolute;
    inset: 0;
    background: #111827 center/cover no-repeat;
    transform: scale(1);
    transition: transform .35s ease;
}

.fl-overlay{
    position:absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.40) 45%, rgba(0,0,0,.10) 100%),
        linear-gradient(0deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.10) 100%);
}

.fl-content{
    position:relative;
    z-index:2;
    padding: 22px 22px;
    color:#fff;
    max-width: 78%;
}

.fl-rating{
    display:flex;
    gap: 4px;
    margin-bottom: 10px;
    color: #facc15;
    text-shadow: 0 2px 10px rgba(0,0,0,.35);
    font-size: 16px;
    line-height: 1;
}

.fl-title{
    font-weight: 900;
    font-size: 34px;
    line-height: 1.05;
    letter-spacing: -0.02em;
    text-shadow: 0 2px 18px rgba(0,0,0,.40);
}

.fl-subtitle{
    margin-top: 8px;
    font-size: 14px;
    font-weight: 600;
    opacity: .92;
    text-shadow: 0 2px 12px rgba(0,0,0,.35);
}

.fl-btn{
    margin-top: 16px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding: 10px 16px;
    border-radius: 999px;
    background: rgba(15, 23, 42, .75);
    border: 1px solid rgba(255,255,255,.25);
    color:#fff;
    font-weight: 800;
    font-size: 13px;
    backdrop-filter: blur(6px);
}

.fl-card:hover{
    border-color: rgba(34,197,94,.35);
    box-shadow: 0 18px 38px rgba(0,0,0,.18);
}

.fl-card:hover .fl-media{
    transform: scale(1.04);
}

@media (max-width: 992px){
    .fl-title{ font-size: 28px; }
    .fl-content{ max-width: 86%; }
}

@media (max-width: 640px){
    .fl-grid{ grid-template-columns: 1fr; }
    .fl-card{ aspect-ratio: 16 / 10; }
    .fl-title{ font-size: 26px; }
    .fl-content{ padding: 18px; max-width: 92%; }
}

