.dr-booking-wrapper{max-width:900px;margin:0 auto;padding:20px}
.dr-page-description{margin:0 0 25px;padding:18px 22px;background:#fafafa;border-left:4px solid #222;border-radius:0 6px 6px 0;line-height:1.6;color:#444}
.dr-page-description p{margin:0 0 10px}
.dr-page-description p:last-child{margin-bottom:0}
.dr-page-description a{color:#222;text-decoration:underline}
.dr-step{margin-bottom:30px;padding:20px;background:#fafafa;border-radius:8px}
.dr-step-title{font-size:18px;margin:0 0 20px;display:flex;align-items:center;gap:10px}
.dr-step-num{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:#222;color:#fff;font-weight:600;font-size:14px}
.dr-hidden{display:none}

.dr-month-nav{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:20px;padding:10px 0}
.dr-month-btn{width:40px;height:40px;border-radius:50%;border:1px solid #e5e5e5;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:#222;transition:all .15s}
.dr-month-btn:hover:not(:disabled){border-color:#222;background:#222;color:#fff}
.dr-month-btn:disabled{opacity:.3;cursor:not-allowed}
.dr-month-label{font-size:18px;font-weight:600;min-width:180px;text-align:center;text-transform:capitalize}
.dr-dates-empty{text-align:center;color:#999;padding:30px;font-style:italic}

.dr-dates{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.dr-date-btn{padding:12px 8px;background:#fff;border:2px solid #e5e5e5;border-radius:6px;cursor:pointer;text-align:center;transition:all .15s;display:flex;flex-direction:column;gap:2px}
.dr-date-btn:hover{border-color:#222}
.dr-date-btn.dr-active{border-color:#222;background:#222;color:#fff}
.dr-date-weekday{font-size:11px;text-transform:uppercase;opacity:.7}
.dr-date-day{font-size:24px;font-weight:700;line-height:1}
.dr-date-month{font-size:12px;text-transform:uppercase}

.dr-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.dr-slot-btn{padding:10px;background:#fff;border:2px solid #e5e5e5;border-radius:6px;cursor:pointer;font-weight:600;transition:all .15s}
.dr-slot-btn:hover{border-color:#222}
.dr-slot-btn.dr-active{border-color:#222;background:#222;color:#fff}
.dr-loading,.dr-empty{grid-column:1/-1;text-align:center;color:#888;padding:20px}

.dr-recap{background:#fff8e1;border:1px solid #ffd54f;padding:12px 16px;border-radius:6px;margin-bottom:20px;font-weight:500}

.dr-fields{display:grid;grid-template-columns:1fr 1fr;gap:15px}
.dr-field{display:flex;flex-direction:column}
.dr-field-full{grid-column:1/-1}
.dr-field label{font-weight:600;margin-bottom:6px;font-size:14px}
.dr-field input,.dr-field textarea{padding:10px 12px;border:1px solid #ccc;border-radius:6px;font-family:inherit;font-size:14px;background:#fff}
.dr-field input:focus,.dr-field textarea:focus{outline:none;border-color:#222}

.dr-actions{margin-top:20px}
.dr-btn-submit{padding:14px 30px;background:#222;color:#fff;border:none;border-radius:6px;font-weight:600;font-size:15px;cursor:pointer;transition:background .15s}
.dr-btn-submit:hover{background:#000}
.dr-btn-submit:disabled{opacity:.5;cursor:not-allowed}
.dr-note{margin-top:12px;font-size:13px;color:#777}

@media (max-width:600px){
  .dr-fields{grid-template-columns:1fr}
}
