/* ============================================
   afspraak.css — BespaarIsolatie V2
   3-stappen boekingsformulier
   ============================================ */

/* ── Progress stepper ── */
.afspraak-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin: 0 auto 2.5rem;
    max-width: 480px;
}
.afspraak-progress-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .4rem;
    position: relative;
    z-index: 1;
}
.afspraak-step-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--slate-200);
    color: var(--slate-500);
    font-family: var(--font-display);
    font-size: .95rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .25s, color .25s, box-shadow .25s;
}
.afspraak-progress-step span {
    font-size: .72rem;
    font-weight: 600;
    color: var(--slate-400);
    white-space: nowrap;
    transition: color .25s;
}
.afspraak-progress-step.active .afspraak-step-circle,
.afspraak-progress-step.completed .afspraak-step-circle {
    background: var(--primary);
    color: #fff;
    box-shadow: 0 4px 14px rgba(22,163,74,.35);
}
.afspraak-progress-step.active span,
.afspraak-progress-step.completed span {
    color: var(--primary);
    font-weight: 700;
}
.afspraak-progress-bar {
    flex: 1;
    height: 3px;
    background: var(--slate-200);
    margin: 0 .5rem;
    margin-bottom: 1.2rem;
    border-radius: 2px;
    overflow: hidden;
    min-width: 40px;
}
.afspraak-progress-fill {
    height: 100%;
    background: var(--primary);
    width: 0%;
    transition: width .4s ease;
}

/* ── Card wrapper ── */
.afspraak-card {
    background: #fff;
    border: 1px solid #E8EAE6;
    border-radius: var(--radius-xl);
    padding: 2rem;
    margin-bottom: 1.25rem;
    box-shadow: 0 2px 16px rgba(15,23,42,.05);
}
.afspraak-card h2 {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: 1.25rem;
}
.afspraak-card h3 {
    font-family: var(--font-display);
    font-size: .95rem;
    font-weight: 700;
    color: var(--slate-800);
    margin-bottom: .75rem;
}
.afspraak-subtitle {
    font-size: .88rem;
    color: var(--slate-500);
    margin-bottom: 1rem;
}

/* ── Stap visibility ── */
.afspraak-step { display: none; }
.afspraak-step.active { display: block; }

/* ── Type cards (inspectie / telefonisch) ── */
.afspraak-type-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
@media (max-width: 520px) { .afspraak-type-options { grid-template-columns: 1fr; } }

.afspraak-type-card {
    border: 2px solid #E8EAE6;
    border-radius: var(--radius-lg);
    padding: 1.25rem 1rem;
    cursor: pointer;
    transition: border-color .2s, background .2s, box-shadow .2s;
    position: relative;
}
.afspraak-type-card input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0; height: 0;
}
.afspraak-type-card:hover {
    border-color: var(--green-300);
    background: var(--green-50);
}
.afspraak-type-card.selected,
.afspraak-type-card:has(input:checked) {
    border-color: var(--primary);
    background: var(--green-50);
    box-shadow: 0 0 0 3px rgba(22,163,74,.12);
}
.afspraak-type-icon { font-size: 1.75rem; margin-bottom: .5rem; }
.afspraak-type-title {
    font-family: var(--font-display);
    font-size: .92rem;
    font-weight: 700;
    color: var(--slate-900);
    margin-bottom: .3rem;
}
.afspraak-type-desc {
    font-size: .8rem;
    color: var(--slate-500);
    line-height: 1.5;
    margin-bottom: .5rem;
}
.afspraak-type-duration {
    font-size: .75rem;
    color: var(--slate-400);
    font-weight: 600;
}

/* ── Kalender ── */
.afspraak-calendar {
    border: 1.5px solid #E8EAE6;
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 1rem;
}
.afspraak-cal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--green-600);
    padding: .75rem 1rem;
}
.afspraak-cal-title {
    font-family: var(--font-display);
    font-weight: 700;
    color: #fff;
    font-size: .95rem;
}
.afspraak-cal-nav {
    background: rgba(255,255,255,.15);
    border: none;
    color: #fff;
    width: 32px; height: 32px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 1.2rem;
    line-height: 1;
    transition: background .2s;
    display: flex; align-items: center; justify-content: center;
}
.afspraak-cal-nav:hover { background: rgba(255,255,255,.3); }

.afspraak-cal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--green-50);
    border-bottom: 1px solid #E8EAE6;
}
.afspraak-cal-weekdays span {
    text-align: center;
    font-size: .72rem;
    font-weight: 700;
    color: var(--slate-500);
    padding: .5rem 0;
    letter-spacing: .04em;
}
.afspraak-cal-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
    padding: .5rem;
    background: #fff;
}
.afspraak-cal-day {
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    font-size: .85rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, color .15s;
    border: none;
    background: transparent;
    color: var(--slate-700);
}
.afspraak-cal-day:hover:not(:disabled):not(.disabled) {
    background: var(--green-100);
    color: var(--green-800);
}
.afspraak-cal-day.selected {
    background: var(--primary);
    color: #fff;
    box-shadow: 0 2px 8px rgba(22,163,74,.3);
}
.afspraak-cal-day.today:not(.selected) {
    border: 2px solid var(--green-300);
    color: var(--green-700);
}
.afspraak-cal-day.disabled,
.afspraak-cal-day:disabled {
    color: var(--slate-300);
    cursor: not-allowed;
}
.afspraak-cal-day.empty { cursor: default; }

.afspraak-selected-date {
    background: var(--green-50);
    border: 1.5px solid var(--green-200);
    border-radius: var(--radius-md);
    padding: .6rem 1rem;
    font-size: .88rem;
    font-weight: 600;
    color: var(--green-700);
    margin-top: .5rem;
}

/* ── Tijdslots ── */
.afspraak-slots {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: .6rem;
}
@media (max-width: 420px) { .afspraak-slots { grid-template-columns: repeat(2, 1fr); } }

.afspraak-slot {
    border: 1.5px solid #E8EAE6;
    border-radius: var(--radius-md);
    padding: .65rem .5rem;
    text-align: center;
    cursor: pointer;
    font-size: .88rem;
    font-weight: 600;
    color: var(--slate-700);
    background: #fff;
    transition: border-color .15s, background .15s, color .15s;
}
.afspraak-slot:hover:not(.slot-unavailable) {
    border-color: var(--green-400);
    background: var(--green-50);
    color: var(--green-700);
}
.afspraak-slot.selected {
    border-color: var(--primary);
    background: var(--primary);
    color: #fff;
}
.afspraak-slot.slot-unavailable {
    color: var(--slate-300);
    cursor: not-allowed;
    text-decoration: line-through;
}

/* ── Maatregelen checkboxes ── */
.afspraak-maatregelen {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: .5rem;
    margin-bottom: 1rem;
}
@media (max-width: 600px) { .afspraak-maatregelen { grid-template-columns: repeat(2, 1fr); } }

.afspraak-maatregel {
    border: 1.5px solid #E8EAE6;
    border-radius: var(--radius-md);
    padding: .6rem .4rem;
    cursor: pointer;
    text-align: center;
    transition: border-color .15s, background .15s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .3rem;
}
.afspraak-maatregel:hover {
    border-color: var(--green-300);
    background: var(--green-50);
}
.afspraak-maatregel:has(input:checked) {
    border-color: var(--primary);
    background: var(--green-50);
}
.afspraak-maatregel input { display: none; }
.maatregel-icon { font-size: 1.3rem; }
.maatregel-text {
    font-size: .72rem;
    font-weight: 600;
    color: var(--slate-700);
    line-height: 1.3;
}

/* ── Formuliervelden ── */
.afspraak-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .85rem;
}
@media (max-width: 520px) { .afspraak-form-grid { grid-template-columns: 1fr; } }

.afspraak-field { display: flex; flex-direction: column; gap: .3rem; }
.afspraak-field-full { grid-column: 1 / -1; }
.afspraak-field label {
    font-size: .8rem;
    font-weight: 700;
    color: var(--slate-700);
    letter-spacing: .02em;
}
.afspraak-field input,
.afspraak-field textarea {
    border: 1.5px solid #E8EAE6;
    border-radius: var(--radius-md);
    padding: .65rem .85rem;
    font-size: .9rem;
    color: var(--slate-900);
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
    font-family: inherit;
    width: 100%;
    box-sizing: border-box;
}
.afspraak-field input:focus,
.afspraak-field textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(22,163,74,.12);
}
.afspraak-field textarea { resize: vertical; min-height: 80px; }

/* ── Navigatie knoppen ── */
.afspraak-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    margin-top: .5rem;
    flex-wrap: wrap;
}

/* Foutmelding links van de Volgende/Bevestig knop */
.afspraak-nav-error {
    display: none;
    flex: 1;
    text-align: center;
    font-size: .82rem;
    font-weight: 600;
    color: #DC2626;
    line-height: 1.4;
    padding: .5rem .75rem;
    background: #FEF2F2;
    border: 1.5px solid #FECACA;
    border-radius: var(--radius-md);
    animation: afspraakShake .4s ease;
}
@media (max-width: 520px) {
    .afspraak-nav-error {
        order: -1;
        width: 100%;
        text-align: left;
    }
}

/* ── Samenvatting boekingssummary ── */
.afspraak-summary {
    background: var(--green-50);
    border: 1.5px solid var(--green-200);
    border-radius: var(--radius-md);
    padding: .85rem 1rem;
    margin-bottom: 1.25rem;
    font-size: .88rem;
    color: var(--green-800);
    font-weight: 600;
}

/* ── Bevestiging ── */
.afspraak-confirm-details {
    background: var(--slate-50);
    border-radius: var(--radius-md);
    padding: 1rem;
    margin-top: 1rem;
    font-size: .9rem;
    color: var(--slate-700);
    line-height: 1.8;
    text-align: left;
}

/* ── Loading spinner ── */
.afspraak-loading {
    text-align: center;
    padding: 2rem;
    color: var(--slate-500);
    font-size: .88rem;
}
.afspraak-spinner {
    width: 32px; height: 32px;
    border: 3px solid var(--green-100);
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: spin .7s linear infinite;
    margin: 0 auto .75rem;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Result states ── */
.afspraak-result { display: none; }

/* ── Validatie foutmeldingen ── */
.afspraak-field input.error,
.afspraak-field textarea.error {
    border-color: #DC2626;
    background: #FFF5F5;
    box-shadow: 0 0 0 3px rgba(220,38,38,.1);
}
.afspraak-field input.error:focus,
.afspraak-field textarea.error:focus {
    border-color: #DC2626;
    box-shadow: 0 0 0 3px rgba(220,38,38,.18);
}

.afspraak-error-banner {
    display: none;
    background: #FEF2F2;
    border: 1.5px solid #FECACA;
    border-radius: var(--radius-md);
    padding: .75rem 1rem;
    margin-bottom: 1.25rem;
    font-size: .88rem;
    font-weight: 600;
    color: #B91C1C;
}
