/* Reset conflits Bootstrap / ancien style.css */
.vendor-grid { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 20px !important; }
.vendor-card { background: var(--white) !important; border-radius: 8px !important; overflow: hidden !important; border: 1px solid var(--border) !important; transition: all .25s !important; display: flex !important; flex-direction: column !important; }
.vendor-card:hover { box-shadow: 0 16px 40px rgba(72,36,15,.1) !important; transform: translateY(-4px) !important; }
.vendor-img { height: 200px !important; background: linear-gradient(135deg,var(--cream-lt) 0%,var(--cream) 60%,var(--gold-lt) 100%) !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 3rem !important; position: relative !important; overflow: hidden !important; }
.vendor-badge { position: absolute !important; top: 12px !important; background: var(--white) !important; border-radius: 100px !important; padding: 4px 10px !important; font-size: .7rem !important; font-weight: 600 !important; color: var(--brown) !important; box-shadow: 0 2px 8px rgba(72,36,15,.12) !important; }
.vendor-body { padding: 18px 20px !important; flex: 1 !important; display: flex !important; flex-direction: column !important; }
.vendor-cat-tag { font-size: .7rem !important; font-weight: 600 !important; letter-spacing: .08em !important; text-transform: uppercase !important; color: var(--gold) !important; margin-bottom: 6px !important; }
.vendor-name { font-size: .98rem !important; font-weight: 600 !important; color: var(--brown) !important; margin-bottom: 4px !important; }
.vendor-loc { font-size: .8rem !important; color: var(--text-lt) !important; }
.vendor-stars { display: flex !important; align-items: center !important; gap: 5px !important; margin-top: 12px !important; padding-top: 12px !important; border-top: 1px solid var(--border) !important; }
.btn-main { font-size: .85rem !important; font-weight: 600 !important; color: var(--white) !important; background: var(--brown) !important; text-decoration: none !important; padding: 14px 30px !important; border-radius: 4px !important; transition: all .22s !important; display: inline-block !important; }
.btn-main:hover { background: var(--coral) !important; }
.cat-tab { font-size: .8rem !important; font-weight: 500 !important; color: var(--text-md) !important; background: var(--white) !important; border: 1px solid var(--border) !important; border-radius: 100px !important; padding: 8px 18px !important; cursor: pointer !important; transition: all .2s !important; white-space: nowrap !important; text-decoration: none !important; }
.cat-tab:hover, .cat-tab.active { background: var(--brown) !important; color: var(--white) !important; border-color: var(--brown) !important; }
.cat-tabs { display: flex !important; gap: 8px !important; flex-wrap: wrap !important; margin-bottom: 32px !important; }
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
.reveal.visible { opacity: 1 !important; transform: translateY(0) !important; }
@media (max-width: 1024px) { .vendor-grid { grid-template-columns: repeat(2, 1fr) !important; } }
@media (max-width: 640px) { .vendor-grid { grid-template-columns: 1fr !important; } }