/* === Basislayout === */
.btl-form-wrapper {
    max-width:800px;
    margin:30px auto;
    padding:20px;
    font-family:Arial,sans-serif;
}

.btl-form-title { color:#0b703b;margin-bottom:10px; }

.btl-lesson-cards {
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:20px;
    margin:25px 0;
}

.btl-lesson-card {
    border:2px solid #ddd;
    border-radius:12px;
    cursor:pointer;
    overflow:hidden;
    transition:.2s;
    background:#fff;
}
.btl-lesson-card:hover {
    border-color:#0b703b;
    box-shadow:0 0 6px rgba(11,112,59,0.3);
}
.btl-lesson-card.selected {
    border-color:#0b703b;
    box-shadow:0 0 8px rgba(11,112,59,0.4);
}
.btl-card-image img {
    width:100%;
    height:220px;
    object-fit:cover;
    object-position:50% 20%;
    display:block;
}

/* === Nieuwe opmaak lesvormkaarten === */
.btl-card-content {
    text-align:center;
    padding:12px;
}

/* Oude titel verbergen (we gebruiken nu .btl-lesson-title) */
.btl-card-content h3 { display:none; }

/* Structuur voor 2 regels titel */
.btl-lesson-title {
    line-height:1.2;
    margin-bottom:6px;
    text-transform:none;
    font-family:"Helvetica Neue", Arial, sans-serif;
}

/* Eerste regel (bijv. "Groepsles 4P") */
.btl-lesson-title .line-1 {
    font-size:1.15rem;
    font-weight:700;
    color:#222;
}

/* Tweede regel (bijv. "Leden" of "Niet-leden") */
.btl-lesson-title .line-2 {
    font-size:1rem;
    color:#555;
    font-weight:500;
}

/* Prijsregel */
.btl-lesson-price {
    font-size:1.3rem;
    color:#0b703b;
    font-weight:700;
    margin-top:4px;
}

.btl-lesson-card:hover .btl-lesson-price {
    color:#087d3a;
}

/* Zorg voor correcte kleuren, ook als andere CSS dit overschrijft */
.btl-lesson-title .line-1 { color:#222 !important; }
.btl-lesson-title .line-2 { color:#555 !important; }
.btl-lesson-price { color:#0b703b !important; }

/* === Knoppen === */
.btl-submit-btn,
.btl-prev-btn,
.btl-next-btn {
    background:#0b703b;
    color:#fff;
    border:0;
    padding:10px 22px;
    border-radius:8px;
    cursor:pointer;
    font-size:16px;
    transition:background .2s;
}
.btl-prev-btn:hover,
.btl-next-btn:hover,
.btl-submit-btn:hover {
    background:#095d31;
}
.btl-step-nav {
    margin-top:20px;
    display:flex;
    justify-content:space-between;
}

/* === Wizardstappen === */
.btl-step { display:none; }
.btl-step.active { display:block; }

.btl-progress {
    position:relative;
    margin-bottom:25px;
}
.btl-progress-bar {
    position:absolute;
    top:12px;
    left:0;
    height:4px;
    background:#0b703b;
    width:0;
    transition:width .3s;
}
.btl-progress-steps {
    display:flex;
    justify-content:space-between;
    list-style:none;
    padding:0;
    margin:0;
    font-size:14px;
}
.btl-progress-steps li {
    width:20%;
    text-align:center;
    color:#999;
}
.btl-progress-steps li.active {
    color:#0b703b;
    font-weight:bold;
}

/* === Beschikbaarheid tabs === */
.btl-time-tabs {
    display:flex;
    justify-content:center;
    gap:8px;
    margin:15px 0;
    flex-wrap:wrap;
}
.btl-tab-btn {
    background:#eee;
    border:1px solid #ccc;
    border-radius:6px;
    padding:8px 16px;
    cursor:pointer;
    font-weight:600;
    transition:all .2s;
}
.btl-tab-btn.active {
    background:#0b703b;
    color:#fff;
    border-color:#0b703b;
}

/* === Tabellen === */
.btl-availability-table {
    display:none;
    width:100%;
    border-collapse:collapse;
    margin-top:10px;
}
.btl-availability-table.active {
    display:table;
}
.btl-availability-table th,
.btl-availability-table td {
    border:1px solid #ddd;
    padding:6px 10px;
    text-align:center;
}
.btl-availability-table th:first-child,
.btl-availability-table td:first-child {
    text-align:left;
    background:#f8f8f8;
    font-weight:600;
}

/* === Voortgangsbalk === */
.btl-progress-wrapper {
    margin-bottom:30px;
}
.btl-progress-text {
    font-weight:600;
    color:#0b703b;
    margin-bottom:6px;
    text-align:center;
}
.btl-progress-bar-outer {
    height:8px;
    background:#eaeaea;
    border-radius:4px;
    overflow:hidden;
}
.btl-progress-bar-inner {
    height:8px;
    width:0;
    background:#0b703b;
    border-radius:4px;
    transition:width .4s ease-in-out;
}

/* === Samenvatting stap 5 === */
.btl-summary-list {
    list-style:none;
    padding:0;
    margin:15px 0;
}
.btl-summary-list li {
    padding:4px 0;
    border-bottom:1px solid #eee;
}
.btl-summary-list strong { color:#0b703b; }

/* Beschikbaarheid in kolommen */
.btl-availability-summary {
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    margin-top:10px;
}
.btl-day-col {
    flex:1;
    min-width:100px;
    background:#f8f8f8;
    border:1px solid #ddd;
    border-radius:6px;
    padding:8px;
}
.btl-day-title {
    font-weight:600;
    color:#0b703b;
    text-align:center;
    margin-bottom:5px;
    border-bottom:1px solid #ddd;
    padding-bottom:3px;
}
.btl-time-item {
    text-align:center;
    padding:3px 0;
}
/* === Foutmelding onder de leskaarten === */
.btl-error-msg {
  display: none;
  color: #b32626;               /* helder rood */
  font-weight: 600;
  margin-top: 10px;
  background: #ffecec;          /* zacht rood vlak */
  border: 1px solid #f5b5b5;
  border-radius: 6px;
  padding: 8px 12px;
  font-size: 0.9rem;
  animation: btlFadeIn 0.4s ease-in-out;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.btl-error-msg::before {
  content: "⚠️";
  font-size: 1.1rem;
  line-height: 1;
}

/* Kleine fade-in animatie */
@keyframes btlFadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.btl-form-field.inline-radio label {
  display: inline-block;
  margin-right: 20px;
}

.btl-form-field label,
.btl-step label {
  display: block;
  margin-top: 8px;
  margin-bottom: 4px;
  font-weight: 600;
}

#btl-summary {
  background: #f9f9f9;
  border: 1px solid #ddd;
  padding: 15px;
  border-radius: 8px;
}
#btl-summary strong {
  color: #0b703b;
}
/* === Extra styling voor stappen & animatie === */
.btl-step {
  animation: btlStepFade .3s ease;
}
@keyframes btlStepFade {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* === Persoonsgegevens & formfields iets luchtiger === */
.btl-step input[type=text],
.btl-step input[type=email],
.btl-step input[type=tel],
.btl-step input[type=date],
.btl-step input[type=number],
.btl-step select,
.btl-step textarea {
  width: 100%;
  border: 1px solid #ccc;
  border-radius: 6px;
  padding: 8px 10px;
  font-size: 15px;
  transition: border-color .2s;
}
.btl-step input:focus,
.btl-step select:focus,
.btl-step textarea:focus {
  border-color: #0b703b;
  outline: none;
}

/* === Responsief: knoppen onder elkaar op mobiel === */
@media (max-width: 600px) {
  .btl-step-nav {
    flex-direction: column;
    gap: 10px;
  }
  .btl-step-nav button {
    width: 100%;
  }
}
/* === Geslacht radio buttons === */
.btl-gender-group {
  display: flex;
  gap: 25px;                /* ruimte tussen Man / Vrouw */
  align-items: center;
  margin: 8px 0 16px;
}

.btl-gender-group label {
  display: flex;
  align-items: center;
  font-weight: 500;
  cursor: pointer;
  color: #333;
}

.btl-gender-group input[type="radio"] {
  accent-color: #0b703b;   /* groene kleur in moderne browsers */
  width: 18px;
  height: 18px;
  margin-right: 6px;
}
/* === Akkoord voorwaarden (Stap 5) === */
.btl-terms-box {
  margin-top: 20px;
  padding: 12px 14px;
  background: #f9f9f9;
  border: 1px solid #ddd;
  border-radius: 8px;
  font-size: 0.95rem;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.5;
}

.btl-terms-box input[type="checkbox"] {
  transform: scale(1.2);
  accent-color: #0b703b; /* ✅ zorgt voor groene checkbox in moderne browsers */
  margin-top: 2px;
}

.btl-terms-box a {
  color: #0b703b;
  text-decoration: underline;
}

.btl-terms-box a:hover {
  text-decoration: none;
  color: #095d31;
}

.btl-terms-box label {
  cursor: pointer;
  font-weight: 600;
  color: #333;
}

/* Mobile optimalisatie */
@media (max-width: 600px) {
  .btl-terms-box {
    flex-direction: column;
    align-items: flex-start;
    font-size: 0.9rem;
  }
}
/* === ADMIN OVERZICHT INSCHRIJVINGEN === */
.btl-admin-table td,
.btl-admin-table th {
    padding: 6px 10px;
    border-bottom: 1px solid #eee;
    vertical-align: middle;
}

.btl-admin-table th {
    background-color: #f8f8f8;
    font-weight: 600;
}

.btl-admin-table tr:hover {
    background-color: #f1f9f4;
}

.btl-admin-table a {
    color: #0073aa;
    text-decoration: none;
}

.btl-admin-table a:hover {
    text-decoration: underline;
}

.btl-filter-form input[type="text"] {
    padding: 4px 6px;
    border: 1px solid #ccc;
    border-radius: 4px;
    margin-right: 6px;
}

.btl-filter-form .button {
    margin-right: 4px;
}
#btl-summary .btl-summary-box {
    background: #f7f7f7;
    border: 1px solid #ddd;
    padding: 25px;
    border-radius: 8px;
    font-size: 16px;
    line-height: 1.6;
}

.btl-summary-section {
    margin-bottom: 24px;
}

.btl-summary-section h4 {
    margin: 0 0 6px 0;
    padding: 0;
    font-size: 18px;
    font-weight: 600;
    color: #444;
}

.btl-summary-section p {
    margin: 0;
}

.btl-summary-days {
    margin-top: 10px;
}

.btl-summary-row {
    display: flex;
    gap: 40px;
    margin-bottom: 10px;
}

.btl-summary-day {
    min-width: 90px;
}
.btl-summary-box h4 {
    color: #0b703b;
    font-weight: 600;
}
/* FORCE seizoen picker styling (werkt ook zonder specifieke wrapper) */
.btl-form-wrapper label,
.btl-form-wrapper .btl-season-label,
.btl-form-wrapper label[for*="season"],
.btl-form-wrapper label[for*="Season"],
.btl-form-wrapper label:has(+ select[name="season_id"]) {
  font-weight: 900 !important;
  font-size: 28px !important;
  color: #1f7a3a !important;
}

.btl-form-wrapper select,
.btl-form-wrapper select[name="season_id"],
.btl-form-wrapper select[name="season"] {
  font-size: 18px !important;
  font-weight: 800 !important;
  padding: 12px 14px !important;
  border: 2px solid #1f7a3a !important;
  border-radius: 10px !important;
  color: #1f7a3a !important;
  background: #fff !important;
}

.btl-form-wrapper select:focus {
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(31, 122, 58, 0.25) !important;
}
