/* Section */
.bb-fl-section { padding: 2.5rem 1rem; }
.bb-fl-container { max-width: 1280px; margin: 0 auto; text-align: center; }
.bb-fl-title { font-family: var(--font-primary, ui-sans-serif, system-ui); font-size: clamp(1.8rem, 2.6vw, 2.6rem); font-weight: 800; color: var(--trust-blue, #183C66); margin: 0 0 .5rem 0; }
.bb-fl-subtitle { color: var(--text-muted, #6C757D); margin: 0 0 1.75rem 0; font-size: 1.05rem; }

/* Grid */
.bb-fl-grid { display: grid; gap: 1.25rem; text-align: left; }
.bb-fl-cols-2 { grid-template-columns: repeat(2, 1fr); }
.bb-fl-cols-3 { grid-template-columns: repeat(3, 1fr); }
.bb-fl-cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1100px) { .bb-fl-cols-3, .bb-fl-cols-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) { .bb-fl-cols-2, .bb-fl-cols-3, .bb-fl-cols-4 { grid-template-columns: 1fr; } }

/* Card */
.bb-fl-card { background: #fff; border: 1px solid var(--border-color, #E9ECEF); border-radius: 16px; box-shadow: 0 10px 28px rgba(16,24,40,.08); overflow: hidden; display: flex; flex-direction: column; }
.bb-fl-media { position: relative; }
.bb-fl-media img { width: 100%; height: 220px; object-fit: cover; display: block; }
.bb-fl-placeholder { height: 220px; display: grid; place-items: center; color: #98A2B3; background: #F3F4F6; }
.bb-fl-image-btn { position: absolute; right: 10px; bottom: 10px; }
.bb-fl-badge { position: absolute; top: 12px; right: 12px; background: #26C281; color: #fff; font-weight: 700; font-size: .8rem; border-radius: 999px; padding: .35rem .6rem; display: inline-flex; align-items: center; gap: .4rem; box-shadow: 0 4px 14px rgba(38,194,129,.35); }
.bb-fl-badge-dot { width: 8px; height: 8px; background: #fff; border-radius: 999px; display: inline-block; }

.bb-fl-body { padding: 1rem 1rem 0.75rem; }
.bb-fl-title-row { display: flex; align-items: center; justify-content: space-between; gap: .75rem; }
.bb-fl-card-title { font-size: 1.25rem; font-weight: 800; color: #1F2937; margin: 0; }
.bb-fl-card-title a { color: inherit; text-decoration: none; }
.bb-fl-card-title a:hover { text-decoration: underline; }
.bb-fl-rating { display: inline-flex; align-items: center; gap: 3px; color: #111; font-weight: 600; }
.bb-fl-rating .is-filled path { fill: #F5B301; }
.bb-fl-reviews { color: #4B5563; font-size: .95rem; }

.bb-fl-location { display: flex; align-items: center; gap: .4rem; color: #6B7280; margin: .35rem 0 .6rem; }

.bb-fl-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: .75rem; }
.bb-fl-chip { background: #EEF2FF; color: #3156e2; border: 1px solid rgba(49,86,226,.25); padding: .28rem .55rem; border-radius: 999px; font-size: .85rem; font-weight: 600; }

.bb-fl-footer { display: flex; align-items: center; justify-content: space-between; padding: 0 .9rem 1rem; }
.bb-fl-price-amount { font-size: 1.25rem; font-weight: 800; color: #111827; }
.bb-fl-price-unit { color: #6B7280; margin-left: .15rem; }
.bb-fl-cta-link { color: #3156e2; font-weight: 700; text-decoration: none; }
.bb-fl-cta-link:hover { text-decoration: underline; }

/* Section CTA */
.bb-fl-cta { margin-top: 1.25rem; }
.bb-fl-btn { display: inline-block; background: #3156e2; color: #fff; padding: 12px 20px; border-radius: 10px; font-weight: 800; text-decoration: none; box-shadow: 0 10px 24px rgba(49,86,226,.28); }
.bb-fl-btn:hover { box-shadow: 0 12px 28px rgba(49,86,226,.35); }
