.navette-res-wrap { max-width: 720px; }
.navette-res-title { display:none;  margin: 10px 0 16px; }
.navette-res-message { padding: 15px; border-radius: 6px; margin: 15px 0; text-align:center; font-weight:400; line-height:1.2em; }
.navette-res-ok { background: #ecf7ed; border: 1px solid #46b450; }
.navette-res-ok i {  color:#46b450; }
.navette-res-ok b {  color:#46b450; font-weight:800; text-transform:uppercase; }
.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-grid small { display:block; line-height:1.1em; margin-top:5px; font-size:12px; font-style:italic; color:#000000;}
.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; color:#000000; font-weight:600;
}
.navette-res-form input[type="number"] { max-width:80px;}
.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(4, minmax(0, 1fr)); gap: 10px; margin-top: 6px; grid-column: 1 / -1;}
.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; display:block; width:100%; text-align:center; }
.navette-slot-remaining { font-size:12px; color:#6b7280; display:block; text-align:center; }
.navette-slot:hover { border-color:#000000; }
.navette-slot:has(input:checked) { border-color:#b70e0c; box-shadow: 0 0 0 2px rgba(17,24,39,.12); background:#f8f8f8; }
.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:#b70e0c; box-shadow: 0 0 0 2px rgba(17,24,39,.12);  background:#f8f8f8;  }

.navette-field-error { display:block; margin-top:6px; font-size:12px; color:#dc3232; }
.navette-submit-row { display:flex; gap:12px; align-items:center; margin-top: 12px; }
.navette-res-btn.is-disabled, .navette-res-btn:disabled { opacity:.6; cursor:not-allowed; }
