/* ========================================
   Calendar Specific Styles - Modern Bento
   ======================================== */

/* Filters Wrapper - Glass Effect */
.filters-wrapper {
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.filters-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
}

.filters-label {
  font-weight: 600;
  color: var(--gray-700);
  min-width: 90px;
  font-size: 0.875rem;
}

@media (max-width: 767px) {
  .filters-wrapper {
    padding: var(--space-lg);
  }

  .filters-group {
    flex-direction: column;
    align-items: flex-start;
  }

  .filters-label {
    margin-bottom: var(--space-xs);
  }
}

/* Filter Buttons - Pill Style */
.calendar-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.filter-btn {
  padding: 8px 16px;
  border: 1px solid var(--gray-200);
  border-radius: var(--radius-xl);
  background-color: var(--white);
  color: var(--gray-600);
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-normal);
}

.filter-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background-color: var(--accent-glow);
}

.filter-btn--active {
  background: var(--gradient-primary);
  border-color: transparent;
  color: var(--white);
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
}

/* View Toggle - Modern Segmented Control */
.calendar-view-toggle {
  display: flex;
  gap: 4px;
  background-color: var(--gray-100);
  padding: 4px;
  border-radius: var(--radius-lg);
}

.view-btn {
  padding: 8px 16px;
  border: none;
  border-radius: var(--radius-md);
  background-color: transparent;
  color: var(--gray-600);
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-normal);
}

.view-btn:hover {
  color: var(--gray-800);
}

.view-btn--active {
  background-color: var(--white);
  color: var(--gray-900);
  box-shadow: var(--shadow-md);
}

/* Calendar Container */
#calendar {
  padding: var(--space-xl);
  min-height: 600px;
}

/* Calendar Wrapper - Bento Card */
.calendar-wrapper {
  background-color: var(--white);
  border-radius: var(--radius-xl);
  border: 1px solid var(--gray-200);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.calendar-header {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  justify-content: space-between;
  align-items: center;
  padding: var(--space-lg) var(--space-xl);
  background: linear-gradient(135deg, var(--gray-50) 0%, var(--white) 100%);
  border-bottom: 1px solid var(--gray-100);
}

.calendar-header h2 {
  font-size: 1.125rem;
  margin: 0;
}

/* FullCalendar Toolbar */
.fc .fc-toolbar {
  flex-wrap: wrap;
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}

.fc .fc-toolbar-title {
  font-family: var(--font-heading);
  font-size: 1.375rem !important;
  font-weight: 700;
  color: var(--gray-900);
}

/* Navigation Buttons */
.fc .fc-button-group {
  gap: 4px;
}

.fc .fc-button {
  background-color: var(--gray-100) !important;
  border: none !important;
  color: var(--gray-700) !important;
  font-weight: 500;
  padding: 8px 14px;
  font-size: 0.8125rem;
  border-radius: var(--radius-md) !important;
  transition: all var(--transition-fast);
}

.fc .fc-button:hover {
  background-color: var(--gray-200) !important;
}

.fc .fc-button:focus {
  box-shadow: 0 0 0 3px var(--accent-glow) !important;
}

.fc .fc-button-primary:disabled {
  background-color: var(--gray-100) !important;
  color: var(--gray-400) !important;
}

.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):active {
  background: var(--gradient-primary) !important;
  color: var(--white) !important;
}

/* Today Button */
.fc .fc-today-button {
  background: var(--gradient-primary) !important;
  color: var(--white) !important;
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
}

.fc .fc-today-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(99, 102, 241, 0.4);
}

.fc .fc-today-button:disabled {
  background: var(--gray-300) !important;
  box-shadow: none;
  transform: none;
}

/* Day Grid */
.fc .fc-daygrid-day {
  transition: background-color var(--transition-fast);
}

.fc .fc-daygrid-day:hover {
  background-color: var(--gray-50);
}

.fc .fc-daygrid-day.fc-day-today {
  background-color: var(--accent-glow) !important;
}

.fc .fc-daygrid-day-number {
  padding: var(--space-sm);
  color: var(--gray-700);
  font-weight: 500;
  font-size: 0.875rem;
}

.fc .fc-day-today .fc-daygrid-day-number {
  background: var(--gradient-primary);
  color: var(--white);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
}

/* Column Headers (Day Names) */
.fc .fc-col-header-cell {
  background-color: var(--gray-50);
  padding: var(--space-sm) 0;
}

.fc .fc-col-header-cell-cushion {
  color: var(--gray-500);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.7rem;
  letter-spacing: 0.5px;
}

/* Events - Modern Pills */
.fc .fc-event {
  border: none !important;
  border-radius: var(--radius-md) !important;
  padding: 4px 8px !important;
  font-size: 0.7rem !important;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--transition-fast);
  border-left: 3px solid transparent !important;
}

.fc .fc-event:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.fc .fc-event-main {
  color: var(--gray-800);
}

.fc .fc-daygrid-event-dot {
  display: none !important;
}

/* Event Type Colors */
.fc-event--tournament {
  background-color: var(--tournament-bg) !important;
  border-left-color: var(--tournament) !important;
}

.fc-event--tournament .fc-event-main {
  color: var(--tournament);
}

.fc-event--casual {
  background-color: var(--casual-bg) !important;
  border-left-color: var(--casual) !important;
}

.fc-event--casual .fc-event-main {
  color: var(--casual);
}

.fc-event--learning {
  background-color: var(--learning-bg) !important;
  border-left-color: var(--learning) !important;
}

.fc-event--learning .fc-event-main {
  color: var(--learning);
}

/* Week View Specific */
.fc .fc-timegrid-slot {
  height: 44px !important;
}

.fc .fc-timegrid-slot-label-cushion {
  font-size: 0.75rem;
  color: var(--gray-400);
}

.fc .fc-timegrid-event {
  border-radius: var(--radius-md) !important;
}

.fc .fc-timegrid-event .fc-event-main {
  padding: var(--space-xs);
}

.fc .fc-timegrid-event .fc-event-time {
  font-size: 0.7rem;
  font-weight: 600;
}

.fc .fc-timegrid-event .fc-event-title {
  font-size: 0.75rem;
}

/* Current Time Indicator */
.fc .fc-timegrid-now-indicator-line {
  border-color: var(--accent);
  border-width: 2px;
}

.fc .fc-timegrid-now-indicator-arrow {
  border-color: var(--accent);
  border-top-color: transparent;
  border-bottom-color: transparent;
}

/* List View */
.fc .fc-list {
  border: none;
}

.fc .fc-list-sticky .fc-list-day > * {
  background-color: var(--gray-50);
}

.fc .fc-list-day-cushion {
  background-color: var(--gray-50) !important;
  padding: var(--space-md) var(--space-lg);
}

.fc .fc-list-day-text,
.fc .fc-list-day-side-text {
  color: var(--gray-700);
  font-weight: 600;
  font-size: 0.9375rem;
}

.fc .fc-list-event {
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.fc .fc-list-event:hover td {
  background-color: var(--gray-50);
}

.fc .fc-list-event-dot {
  border-color: currentColor !important;
}

.fc .fc-list-event-time {
  color: var(--gray-500);
  font-size: 0.875rem;
}

.fc .fc-list-event-title {
  font-weight: 500;
  color: var(--gray-800);
}

/* Scrollbar Styling */
.fc-scroller::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

.fc-scroller::-webkit-scrollbar-track {
  background: var(--gray-100);
  border-radius: var(--radius-md);
}

.fc-scroller::-webkit-scrollbar-thumb {
  background: var(--gray-300);
  border-radius: var(--radius-md);
}

.fc-scroller::-webkit-scrollbar-thumb:hover {
  background: var(--gray-400);
}

/* More Events Popover */
.fc .fc-popover {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--gray-100);
  overflow: hidden;
}

.fc .fc-popover-header {
  background-color: var(--gray-50);
  padding: var(--space-sm) var(--space-md);
  font-weight: 600;
  font-size: 0.875rem;
}

.fc .fc-popover-body {
  padding: var(--space-sm);
}

/* More Link */
.fc .fc-daygrid-more-link {
  color: var(--accent);
  font-weight: 600;
  font-size: 0.75rem;
}

.fc .fc-daygrid-more-link:hover {
  color: var(--accent-light);
}

/* No Events Message */
.fc .fc-list-empty {
  background-color: var(--gray-50);
}

.fc .fc-list-empty-cushion {
  color: var(--gray-500);
  font-size: 1rem;
  padding: var(--space-3xl);
}

/* Responsive Adjustments */
@media (max-width: 767px) {
  #calendar {
    padding: var(--space-md);
  }

  .fc .fc-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .fc .fc-toolbar-title {
    font-size: 1.125rem !important;
    text-align: center;
    order: -1;
    margin-bottom: var(--space-sm);
  }

  .fc .fc-toolbar-chunk {
    display: flex;
    justify-content: center;
  }

  .fc .fc-button {
    padding: 6px 12px;
    font-size: 0.75rem;
  }

  .fc .fc-daygrid-day-number {
    padding: var(--space-xs);
    font-size: 0.8125rem;
  }

  .fc .fc-event {
    font-size: 0.65rem !important;
    padding: 2px 6px !important;
  }

  .filter-btn {
    font-size: 0.75rem;
    padding: 6px 12px;
  }

  .calendar-header {
    flex-direction: column;
    gap: var(--space-sm);
    padding: var(--space-md);
  }
}

/* Print Styles */
@media print {
  .calendar-header,
  .fc-toolbar,
  .filters-wrapper {
    display: none !important;
  }

  #calendar {
    padding: 0;
  }

  .fc .fc-event {
    print-color-adjust: exact;
    -webkit-print-color-adjust: exact;
  }

  .event-list-item {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid var(--gray-300);
  }
}
