.navette-res-wrap { max-width: 720px; }
.navette-res-title { margin: 10px 0 16px; }
.navette-res-message { padding: 10px; border-radius: 6px; margin: 12px 0; }
.navette-res-ok { background: #ecf7ed; border: 1px solid #46b450; }
.navette-res-error { background: #fbeaea; border: 1px solid #dc3232; }
.navette-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; }
.navette-grid p { margin: 0; }
.navette-res-form label { display:block; font-weight: 600; margin-bottom: 6px; }
.navette-res-form input, .navette-res-form select, .navette-res-event-switch select {
  width: 100%; max-width: 100%; padding: 8px; border: 1px solid #ccc; border-radius: 4px;
}
.navette-res-btn { padding: 10px 16px; border: 0; border-radius: 6px; cursor: pointer; }
@media (max-width: 640px) { .navette-grid { grid-template-columns: 1fr; } }

/* Slots as modern radio cards */
.navette-slot-wrap { grid-column: 1 / -1; }
.navette-slots { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 6px; }
.navette-slot { display:flex; flex-direction:column; gap:6px; padding:10px 12px; border:1px solid #d1d5db; border-radius:10px; cursor:pointer; user-select:none; background:#fff; position:relative; }
.navette-slot input { position:absolute; opacity:0; pointer-events:none; }
.navette-slot-time { font-weight:700; font-size:16px; }
.navette-slot-remaining { font-size:12px; color:#6b7280; }
.navette-slot:hover { border-color:#9ca3af; }
.navette-slot:has(input:checked) { border-color:#111827; box-shadow: 0 0 0 2px rgba(17,24,39,.12); }
.navette-slot.is-disabled { opacity:.5; cursor:not-allowed; background:#f9fafb; }
@media (max-width: 640px) { .navette-slots { grid-template-columns: 1fr 1fr; } }

.navette-slot.is-selected { border-color:#111827; box-shadow: 0 0 0 2px rgba(17,24,39,.12); }
