/* ================================================================
   APPOINTMENTS — Modern UI  |  BS5 uyumlu
   appointments.html · approved.html · cancelled.html
   close.html · denied.html tarafından paylaşılır.
   Sadece görsel. Hiçbir JS/mantık kodu değiştirilmemiştir.
================================================================ */

/* ════════════════════════════════════════════════════════════
   1. SAYFA & GENEL
════════════════════════════════════════════════════════════ */
body          { background: #F1F5F9 !important; }
.page-wrapper { background: #F1F5F9; }

/* ════════════════════════════════════════════════════════════
   2. FİLTRE KARTI (.card .wizard-content)
════════════════════════════════════════════════════════════ */
.card {
  border-radius: 14px !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.07) !important;
  border: none !important;
  margin-bottom: 1.25rem !important;
}
.card .card-body { padding: 1.5rem !important; }

/* Başlık aksanı */
.card-body .card-title {
  font-size: 1rem !important;
  font-weight: 800 !important;
  color: #1E293B !important;
  margin-bottom: 0.2rem !important;
  display: flex;
  align-items: center;
  gap: 0.55rem;
}
.card-body .card-title::before {
  content: '';
  flex-shrink: 0;
  display: inline-block;
  width: 4px; height: 17px;
  background: linear-gradient(180deg, #4F46E5, #7C3AED);
  border-radius: 99px;
}
.card-body .card-subtitle {
  font-size: 0.8rem !important;
  color: #94A3B8 !important;
  font-weight: 500 !important;
  margin-bottom: 1.2rem !important;
  line-height: 1.5;
}

/* ════════════════════════════════════════════════════════════
   3. FİLTRE FORM KONTROLLERI
════════════════════════════════════════════════════════════ */
.wizard-content .form-control,
.wizard-content select.form-control {
  border-radius: 9px !important;
  border: 1.5px solid #E2E8F0 !important;
  font-size: 0.875rem !important;
  color: #374151 !important;
  background: #fff !important;
  padding: 0.475rem 0.875rem !important;
  height: auto !important;
  min-height: 38px !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  box-shadow: none !important;
  cursor: pointer;
}
.wizard-content .form-control:focus,
.wizard-content select.form-control:focus {
  border-color: #4F46E5 !important;
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1) !important;
  outline: none !important;
}

/* Yıl/Ay select ikilisi */
#yillar, #aylar {
  border-radius: 9px !important;
  border: 1.5px solid #E2E8F0 !important;
  font-size: 0.875rem !important;
  color: #374151 !important;
  background: #fff !important;
  padding: 0.475rem 0.875rem !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  box-shadow: none !important;
}
#yillar:focus, #aylar:focus {
  border-color: #4F46E5 !important;
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1) !important;
  outline: none !important;
}

/* ════════════════════════════════════════════════════════════
   4. TARİH NAVİGASYON BUTONLARI (← →)
════════════════════════════════════════════════════════════ */
.x-button.btn-success {
  border-radius: 9px !important;
  background: #EEF2FF !important;
  color: #4F46E5 !important;
  border-color: transparent !important;
  font-size: 1rem !important;
  padding: 0.45rem 0.6rem !important;
  transition: all 0.16s;
  box-shadow: none !important;
  display: flex;
  align-items: center;
  justify-content: center;
}
.x-button.btn-success:hover {
  background: #4F46E5 !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(79,70,229,0.25) !important;
}
.x-button.btn-success:active { transform: translateY(0); }

/* Tarih input (pickadate, filter kartı içinde) */
.wizard-content .pickadate-translations,
.wizard-content input[type="text"].form-control {
  border-radius: 9px !important;
  border: 1.5px solid #E2E8F0 !important;
  font-size: 0.875rem !important;
  color: #374151 !important;
  background: #fff !important;
  padding: 0.5rem 0.875rem !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
  box-shadow: none !important;
  text-align: center;
  font-weight: 600;
  cursor: pointer;
}
.wizard-content .pickadate-translations:focus,
.wizard-content input[type="text"].form-control:focus {
  border-color: #4F46E5 !important;
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1) !important;
  outline: none !important;
}

/* ════════════════════════════════════════════════════════════
   5. SELECT2 (Müşteri seçici - #musterinew)
════════════════════════════════════════════════════════════ */
.wizard-content .select2-container { width: 100% !important; }

.wizard-content .select2-container--default .select2-selection--single {
  border-radius: 9px !important;
  border: 1.5px solid #E2E8F0 !important;
  height: 38px !important;
  background: #fff !important;
  transition: border-color 0.18s;
}
.wizard-content .select2-container--default .select2-selection--single
    .select2-selection__rendered {
  line-height: 36px !important;
  padding-left: 0.875rem !important;
  font-size: 0.875rem !important;
  color: #374151 !important;
}
.wizard-content .select2-container--default .select2-selection--single
    .select2-selection__arrow {
  height: 36px !important;
  right: 8px !important;
}
.wizard-content .select2-container--default.select2-container--focus
    .select2-selection--single,
.wizard-content .select2-container--default.select2-container--open
    .select2-selection--single {
  border-color: #4F46E5 !important;
  box-shadow: 0 0 0 3px rgba(79,70,229,0.1) !important;
}
.select2-dropdown {
  border-radius: 10px !important;
  border: 1.5px solid #E2E8F0 !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12) !important;
  overflow: hidden;
}
.select2-results__option {
  font-size: 0.85rem !important;
  padding: 0.45rem 0.875rem !important;
  color: #374151 !important;
}
.select2-results__option--highlighted {
  background: #EEF2FF !important;
  color: #4F46E5 !important;
}
.select2-search--dropdown .select2-search__field {
  border-radius: 7px !important;
  border: 1.5px solid #E2E8F0 !important;
  padding: 0.4rem 0.75rem !important;
  font-size: 0.85rem !important;
}
.select2-search--dropdown .select2-search__field:focus {
  border-color: #4F46E5 !important;
  outline: none !important;
}

/* ════════════════════════════════════════════════════════════
   6. FİLTRE BUTONLARI
════════════════════════════════════════════════════════════ */

/* Geçmişleri Görüntüle/Gizle */
.wizard-content .btn-primary {
  border-radius: 9px !important;
  font-weight: 700 !important;
  font-size: 0.82rem !important;
  padding: 0.45rem 1.1rem !important;
  background: #EEF2FF !important;
  color: #4F46E5 !important;
  border-color: transparent !important;
  transition: all 0.18s;
  box-shadow: none !important;
}
.wizard-content .btn-primary:hover {
  background: #4F46E5 !important;
  color: #fff !important;
  box-shadow: 0 3px 10px rgba(79,70,229,0.25) !important;
}

/* ════════════════════════════════════════════════════════════
   7. BÖLÜM BAŞLIĞI (#randevuText + Filtreleri Kaldır)
════════════════════════════════════════════════════════════ */
.col-md-12.align-self-center.mb-3 h3.text-themecolor {
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  color: #1E293B !important;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.65rem;
}
#randevuText {
  font-size: 1rem;
  font-weight: 800;
  color: #1E293B;
}

/* Filtreleri Kaldır */
.btn.filter.btn-info {
  border-radius: 99px !important;
  font-weight: 700 !important;
  font-size: 0.75rem !important;
  padding: 0.3rem 0.9rem !important;
  background: #FEF3C7 !important;
  color: #92400E !important;
  border-color: transparent !important;
  transition: all 0.16s;
  box-shadow: none !important;
}
.btn.filter.btn-info:hover {
  background: #F59E0B !important;
  color: #fff !important;
}

/* ════════════════════════════════════════════════════════════
   8. TOPLU ONAYLAMA KARTI (appointments.html)
════════════════════════════════════════════════════════════ */
.wizard-content .btn-success.btn-block {
  border-radius: 10px !important;
  font-weight: 700 !important;
  font-size: 0.9rem !important;
  padding: 0.7rem 1rem !important;
  background: linear-gradient(135deg, #10B981, #059669) !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(16,185,129,0.3) !important;
  transition: all 0.18s;
  letter-spacing: 0.01em;
}
.wizard-content .btn-success.btn-block:hover {
  opacity: 0.9;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(16,185,129,0.38) !important;
}

/* ════════════════════════════════════════════════════════════
   9. RANDEVU KARTLARI (#appointments — JS tarafından üretilir)
════════════════════════════════════════════════════════════ */
#appointments {
  gap: 0;
}

/* Her randevu kartı */
#appointments .card,
#appointments > .col-12 > .card,
#appointments > .col-md-12 > .card,
#appointments > [class*="col"] > .card {
  border-radius: 14px !important;
  box-shadow: 0 2px 14px rgba(0,0,0,0.07) !important;
  border: none !important;
  border-left: 4px solid #4F46E5 !important;
  transition: box-shadow 0.18s, transform 0.18s;
  overflow: hidden;
}
#appointments .card:hover {
  box-shadow: 0 6px 24px rgba(79,70,229,0.12) !important;
  transform: translateY(-2px);
}

/* Kart başlığı alanı */
#appointments .card .card-header,
#appointments .card-header {
  background: #F8FAFC !important;
  border-bottom: 1px solid #F1F5F9 !important;
  padding: 0.85rem 1.25rem !important;
  font-size: 0.875rem !important;
  font-weight: 700 !important;
  color: #1E293B !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.4rem;
}

/* Kart body */
#appointments .card-body {
  padding: 1rem 1.25rem !important;
}

/* Randevu bilgi satırları */
#appointments .card-body p,
#appointments .card-body .info-row {
  font-size: 0.83rem !important;
  color: #475569 !important;
  margin-bottom: 0.4rem !important;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
#appointments .card-body strong,
#appointments .card-body b {
  color: #1E293B !important;
  font-weight: 700 !important;
}

/* İkon renkler */
#appointments .mdi,
#appointments .ti {
  color: #4F46E5 !important;
  font-size: 1rem !important;
}

/* ── Durum Rozetleri ─────────────────────────────────────── */
#appointments .badge,
#appointments .label {
  border-radius: 99px !important;
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  padding: 0.25rem 0.65rem !important;
  letter-spacing: 0.03em;
  display: inline-flex;
  align-items: center;
}

/* Onaylı */
#appointments .badge-success,
#appointments .badge-primary,
#appointments .label-success {
  background: #D1FAE5 !important;
  color: #065F46 !important;
  border: none !important;
}
/* Bekleyen */
#appointments .badge-warning,
#appointments .label-warning {
  background: #FEF3C7 !important;
  color: #92400E !important;
  border: none !important;
}
/* İptal */
#appointments .badge-danger,
#appointments .label-danger {
  background: #FEE2E2 !important;
  color: #991B1B !important;
  border: none !important;
}
/* Reddedilmiş */
#appointments .badge-secondary,
#appointments .badge-dark,
#appointments .label-default {
  background: #F1F5F9 !important;
  color: #475569 !important;
  border: none !important;
}
/* Bilgi */
#appointments .badge-info,
#appointments .label-info {
  background: #EEF2FF !important;
  color: #4F46E5 !important;
  border: none !important;
}

/* ── Aksiyon Butonları (randevu kartı içi) ───────────────── */
#appointments .btn {
  border-radius: 8px !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  padding: 0.38rem 0.85rem !important;
  transition: all 0.16s !important;
  box-shadow: none !important;
  border: none !important;
}
#appointments .btn + .btn { margin-left: 0.35rem; }

/* Onayla */
#appointments .btn-success:not(.btn-block),
#appointments .approveButton {
  background: #D1FAE5 !important;
  color: #065F46 !important;
  border: none !important;
}
#appointments .btn-success:not(.btn-block):hover,
#appointments .approveButton:hover {
  background: #10B981 !important;
  color: #fff !important;
  box-shadow: 0 3px 10px rgba(16,185,129,0.3) !important;
}

/* Reddet */
#appointments .btn-danger:not(.btn-block) {
  background: #FEE2E2 !important;
  color: #991B1B !important;
  border: none !important;
}
#appointments .btn-danger:not(.btn-block):hover {
  background: #EF4444 !important;
  color: #fff !important;
  box-shadow: 0 3px 10px rgba(239,68,68,0.3) !important;
}

/* İptal et */
#appointments .btn-warning {
  background: #FEF3C7 !important;
  color: #92400E !important;
  border: none !important;
}
#appointments .btn-warning:hover {
  background: #F59E0B !important;
  color: #fff !important;
  box-shadow: 0 3px 10px rgba(245,158,11,0.3) !important;
}

/* Detay / Bilgi */
#appointments .btn-info,
#appointments .btn-primary:not(.btn-block) {
  background: #EEF2FF !important;
  color: #4F46E5 !important;
  border: none !important;
}
#appointments .btn-info:hover,
#appointments .btn-primary:not(.btn-block):hover {
  background: #4F46E5 !important;
  color: #fff !important;
  box-shadow: 0 3px 10px rgba(79,70,229,0.3) !important;
}

/* Kapat / Varsayılan */
#appointments .btn-default,
#appointments .btn-secondary {
  background: #F1F5F9 !important;
  color: #475569 !important;
  border: none !important;
}
#appointments .btn-default:hover,
#appointments .btn-secondary:hover {
  background: #CBD5E1 !important;
  color: #1E293B !important;
}

/* Kart footer */
#appointments .card-footer {
  background: #F8FAFC !important;
  border-top: 1px solid #F1F5F9 !important;
  padding: 0.7rem 1.25rem !important;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem;
}

/* ── Randevu durum sol çizgisi ────────────────────────────── */
/* appointments.html — bekleyen: indigo */
#appointments .card.pending,
#appointments .card.onaylanacak { border-left-color: #4F46E5 !important; }
/* approved — yeşil */
#appointments .card.approved,
#appointments .card.onaylandi   { border-left-color: #10B981 !important; }
/* cancelled — sarı */
#appointments .card.cancelled,
#appointments .card.iptal       { border-left-color: #F59E0B !important; }
/* denied — kırmızı */
#appointments .card.denied,
#appointments .card.reddedildi  { border-left-color: #EF4444 !important; }
/* close — mor */
#appointments .card.close,
#appointments .card.kapatildi   { border-left-color: #8B5CF6 !important; }

/* Geçmiş collapse bölümü */
#appointments .collapse .card,
#appointments .collapsing .card {
  border-left: none !important;
  border-top: 2px solid #E2E8F0 !important;
  border-radius: 10px !important;
  background: #F8FAFC !important;
  font-size: 0.82rem !important;
  color: #475569 !important;
}
#appointments .collapse .card-body,
#appointments .collapsing .card-body {
  padding: 0.85rem 1rem !important;
}

/* ════════════════════════════════════════════════════════════
   10. RESPONSIVE
════════════════════════════════════════════════════════════ */
@media (max-width: 767px) {
  .card .card-body { padding: 1.1rem !important; }

  /* Tarih navigasyon butonları tam yükseklikte */
  .x-button.btn-success { width: 100%; padding: 0.5rem 0.6rem !important; }

  /* Filter buton */
  .wizard-content .btn-primary {
    width: 100% !important;
    margin-top: 0.75rem !important;
    float: none !important;
  }

  /* Randevu kartı */
  #appointments .card { border-left-width: 3px !important; }
  #appointments .card-header { padding: 0.65rem 0.9rem !important; }
  #appointments .card-body { padding: 0.75rem 0.9rem !important; }
  #appointments .card-footer { padding: 0.6rem 0.9rem !important; flex-wrap: wrap; }

  /* Aksiyon butonları tam genişlik */
  #appointments .card-footer .btn {
    flex: 1 1 calc(50% - 0.35rem) !important;
    text-align: center;
  }

  /* Toplu Onaylama */
  .wizard-content .btn-success.btn-block { font-size: 0.85rem !important; padding: 0.65rem 1rem !important; }

  /* Bölüm başlığı */
  .col-md-12.align-self-center.mb-3 h3.text-themecolor {
    font-size: 0.92rem !important;
    gap: 0.4rem;
  }
}

@media (max-width: 480px) {
  .card { border-radius: 11px !important; }
  #appointments .card-footer .btn { flex: 1 1 100% !important; }
}
