/*
 * Application-wide styles for Limberjack
 *
 * This file now contains only global layout and typography styles.
 * Component-specific styles have been moved to their own files:
 * - navigation.css: Header, navigation, and footer styles
 * - buttons.css: Button styles and variants
 * - cards.css: Card component styles
 * - tables.css: Table styles
 * - forms.css: Form controls and input styles
 * - calendar.css: Calendar-specific styles
 * - workouts.css: Workout-related styles
 * - builder.css: Builder interface styles
 * - elements.css: Element display and list styles
 * - utilities.css: Utility classes and helpers
 * - workout_preview.css: Live workout preview styles
 * - workout_name_suggestions.css: Workout name suggestion component styles
 * - tabulator.css: Tabulator table styles for bulk editing
 */

/* Bulk Edit Table Styles */
.row-modified {
  background-color: #fff3cd !important;
}

.row-modified:hover {
  background-color: #ffe69c !important;
}

#elements-table {
  margin: 20px 0;
}

/* Ensure Tabulator pagination is visible */
.tabulator-footer {
  background-color: #fff;
  border-top: 1px solid #ddd;
  padding: 10px;
}

.tabulator-paginator {
  display: flex;
  align-items: center;
  justify-content: center;
}

.bulk-edit-controls {
  margin: 20px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.status-message {
  padding: 10px;
  border-radius: 4px;
  margin-top: 10px;
}

.status-message.success {
  background-color: #d4edda;
  color: #155724;
  border: 1px solid #c3e6cb;
}

.status-message.error {
  background-color: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
}

/* Hotwire Combobox Styles */
.combobox {
  position: relative;
}

.combobox__input {
  width: 100%;
}

.combobox__listbox {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: white;
  border: 1px solid #d1d5db;
  border-top: none;
  border-radius: 0 0 0.375rem 0.375rem;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  max-height: 200px;
  overflow-y: auto;
  z-index: 10;
}

.combobox__option {
  padding: 0.5rem;
  cursor: pointer;
}

.combobox__option:hover,
.combobox__option[aria-selected="true"] {
  background-color: #f3f4f6;
}

.combobox__option[data-combobox-option-selected] {
  background-color: #3b82f6;
  color: white;
}

:root {
  --breakpoint-md: 768px;
  --breakpoint-lg: 992px;
  --breakpoint-xl: 1200px;

  --container-md: 720px;
  --container-lg: 960px;
  --container-xl: 1140px;
}

/* Container */
.container {
  width: 100%;
  padding-right: var(--spacing-unit);
  padding-left: var(--spacing-unit);
  margin-right: auto;
  margin-left: auto;
}

/* Grid system */
.grid {
  display: grid;
  gap: var(--spacing-unit);
  grid-template-columns: 1fr;
}

/* Typography */
h1,
h2,
h3,
h4,
h5,
h6 {
  margin-bottom: 0.5rem;
  font-weight: 500;
  line-height: 1.2;
}

h1 {
  margin: 0.5rem 0;
  text-transform: uppercase;
  color: var(--medium-gray);
}

h3 {
  margin: 0.5rem 0;
  border-bottom: 1px solid var(--medium-gray);
}

h4 {
  background-color: var(--medium-gray);
  color: var(--light-gray);
  margin: 0.5rem 0;
  border-bottom: 1px solid var(--medium-gray);
  padding: 0.5rem;
}

label {
  font-weight: bold;
}

/* Sortable table headers */
.sortable-header {
  color: inherit;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  font-weight: bold;
}

.sortable-header:hover {
  color: var(--color-primary);
  text-decoration: none;
}

.sort-indicator {
  margin-left: 0.25rem;
  font-size: 0.8em;
  opacity: 0.7;
}

/* Responsive breakpoints */
@media (min-width: var(--breakpoint-md)) {
  .container {
    max-width: var(--container-md);
  }

  .grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: var(--breakpoint-lg)) {
  .container {
    max-width: var(--container-lg);
  }

  .grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: var(--breakpoint-xl)) {
  .container {
    max-width: var(--container-xl);
  }

  .grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
