/* SupFinance Sessions v2 */
.sfs-wrapper { font-family: inherit; margin: 30px 0; }

/* ── CARDS (liste) ── */
.sfs-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 20px; margin-top: 20px; }

.sfs-card { background: #fff; border-radius: 10px; box-shadow: 0 2px 12px rgba(0,0,0,0.08); padding: 20px; border-left: 4px solid #1a3c5e; transition: transform .2s, box-shadow .2s; }
.sfs-card:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.12); }
.sfs-card-full { border-left-color: #ccc; opacity: .7; }
.sfs-card-highlight { background: #e8f0fe !important; }

.sfs-card-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.sfs-card-title { font-size: 1.05rem; font-weight: 700; color: #1a3c5e; margin: 0; }

.sfs-places-badge { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: .8rem; font-weight: 600; white-space: nowrap; flex-shrink: 0; }
.sfs-badge-ok  { background: #e8f5e9; color: #2e7d32; }
.sfs-badge-low { background: #fff3e0; color: #e65100; }
.sfs-badge-full { background: #fce4e4; color: #c62828; }

.sfs-card-desc { font-size: .88rem; color: #555; line-height: 1.5; margin: 0 0 12px; padding: 10px 12px; background: #f8f9ff; border-radius: 6px; }

.sfs-card-meta { display: flex; flex-direction: column; gap: 5px; margin-bottom: 16px; }
.sfs-meta-item { font-size: .88rem; color: #444; }

.sfs-card-footer { border-top: 1px solid #f0f0f0; padding-top: 14px; }
.sfs-btn-register { display: inline-block; padding: 10px 22px; background: #1a3c5e; color: #fff !important; border-radius: 6px; text-decoration: none !important; font-size: .9rem; font-weight: 600; transition: background .2s; }
.sfs-btn-register:hover { background: #2d5f8a !important; }
.sfs-btn-full { display: inline-block; padding: 10px 22px; background: #eee; color: #999; border-radius: 6px; font-size: .9rem; }

.sfs-list-title { font-size: 1.4em; margin-bottom: 5px; color: #1a3c5e; }
.sfs-no-sessions { color: #888; font-style: italic; }

/* ── CALENDRIER ── */
.sfs-calendar-wrapper { background: #fff; border-radius: 10px; box-shadow: 0 2px 10px rgba(0,0,0,0.08); overflow: hidden; margin-bottom: 30px; }
.sfs-calendar-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; background: #1a3c5e; color: #fff; }
.sfs-cal-title { font-size: 1.1em; font-weight: 600; text-transform: capitalize; }
.sfs-cal-prev, .sfs-cal-next { background: none; border: 2px solid rgba(255,255,255,0.4); color: #fff; padding: 5px 12px; border-radius: 5px; cursor: pointer; font-size: 1em; transition: background .2s; }
.sfs-cal-prev:hover, .sfs-cal-next:hover { background: rgba(255,255,255,0.2); }
.sfs-cal-days-header { display: grid; grid-template-columns: repeat(7,1fr); background: #f0f4f8; }
.sfs-cal-days-header span { text-align: center; padding: 10px; font-size: .8em; font-weight: 600; color: #666; text-transform: uppercase; }
.sfs-cal-days { display: grid; grid-template-columns: repeat(7,1fr); }
.sfs-cal-day { min-height: 80px; padding: 6px; border: 1px solid #f0f0f0; }
.sfs-cal-day.sfs-other-month { background: #fafafa; color: #ccc; }
.sfs-cal-day.sfs-today { background: #e8f0fe; }
.sfs-cal-day-num { font-size: .82em; color: #666; margin-bottom: 3px; }
.sfs-cal-day.sfs-today .sfs-cal-day-num { color: #1a3c5e; font-weight: 700; }

.sfs-cal-event { background: #1a3c5e; color: #fff; font-size: .72em; padding: 2px 5px; border-radius: 3px; margin-bottom: 2px; cursor: pointer; transition: background .2s; }
.sfs-cal-event:hover { background: #2d5f8a; }
.sfs-cal-event.sfs-full-event { background: #ccc; color: #888; cursor: default; }
.sfs-cal-event.sfs-multiday { background: #2d5f8a; border-radius: 0; }
.sfs-cal-event.sfs-multiday-first { border-radius: 3px 0 0 3px; }

@media(max-width:768px){
    .sfs-cards { grid-template-columns: 1fr; }
    .sfs-cal-day { min-height: 55px; }
    .sfs-cal-event { font-size: .65em; }
}
.sfs-btn-closed { display: inline-block; padding: 10px 22px; background: #fff3cd; color: #856404; border-radius: 6px; font-size: .9rem; font-weight: 600; border: 1px solid #ffc107; }
