/* Element Styles */

/* Element Display */
.element-name {
  background-color: var(--light-gray);
  color: var(--medium-gray);
  font-weight: bold;
  margin-bottom: 0.5rem;
}

.element-link {
  display: block;
  padding: 0.25rem;
  color: var(--dark-gray);
  text-decoration: none;
  border-radius: 0.25rem;
}

.element-link:hover {
  background-color: var(--light-gray);
  text-decoration: underline;
}

/* Element Lists */
.elements-list {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.element-item {
  display: flex;
  align-items: center;
  padding: 0.25rem;
  background-color: white;
  border-radius: 0.25rem;
  border: 1px solid var(--medium-gray);
  border-bottom: 0px none;
}

.element-item:last-of-type {
  border-bottom: 1px solid var(--medium-gray);
}

/* Element Ranks */
.element-rank {
  display: inline-block;
  padding: 0.1rem 0.3rem;
  border-radius: 0.25rem;
  color: white;
  text-shadow: 1px 1px 1px black;
}

/* Rank color classes */
.rank-ready {
  background-color: var(--badge-ready);
  /* Green */
}

.rank-notice {
  background-color: var(--badge-notice);
  /* Gold/Yellow */
}

.rank-caution {
  background-color: var(--badge-caution);
  /* Orange */
}

.rank-warning {
  background-color: var(--badge-warning);
  /* Red */
}

.rank-danger {
  background-color: var(--badge-danger);
  /* Dark red */
}

.rank-stop {
  background-color: var(--badge-stop);
}

/* Segment Elements */
.segment-elements-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.segment-element-item {
  padding: 0.25rem 0;
  border-bottom: 1px dotted var(--light-gray);
}

.segment-element-item:last-child {
  border-bottom: none;
}

.segment-name {
  color: var(--secondary-color);
  font-weight: 600;
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
}

/* Element Details */
.element-reps,
.element-weight {
  color: var(--medium-gray);
  font-size: 0.8rem;
}

.element-last-completed {
  font-size: 0.75rem;
  color: var(--medium-gray);
}

/* Elements with Ranks Display */
.elements-with-ranks {
  position: relative;
  margin-top: 0.5rem;
  border: 1px dotted var(--light-gray);
  background-color: white;
  background-image: repeating-linear-gradient(45deg,
      transparent,
      transparent 2px,
      var(--light-gray) 2px,
      var(--light-gray) 8px);
  padding: 0;
  color: var(--medium-gray);
}

.elements-with-ranks-content {
  padding-bottom: var(--spacing-unit);
  max-height: 40vh;
  overflow-y: auto;
  margin-top: var(--spacing-unit);
}

.elements-with-ranks-title {
  font-size: 1.1rem;
  color: var(--primary-color);
  border-bottom: 1px solid var(--medium-gray);
  padding-bottom: 0.25rem;
  position: sticky;
}

/* Cycle Elements Display (now uses ElementsWithRanks) */
.cycle-elements-display {
  margin-top: 0.5rem;
}

.cycle-elements-title {
  font-size: 1.1rem;
  color: var(--primary-color);
  margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--medium-gray);
  padding-bottom: 0.25rem;
}

.active-cycles {
  font-size: 0.9rem;
  /* color: var(--medium-gray); */
  margin-bottom: 0.5rem;
  padding-left: 0.5rem;
}

.cycles-list {
  font-weight: 500;
  color: var(--dark-gray);
}

/* No elements/workouts placeholders */
.no-workouts,
.no-elements {
  text-align: center;
  color: var(--medium-gray);
  font-style: italic;
  padding: var(--spacing-unit);
}

/* Jumble list grid */
.jumble-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 0.5rem;
  margin-top: 0.5rem;
}

.jumble-item {
  background-color: var(--primary-color);
  border-radius: 0.25rem;
  transition: all 0.2s ease;
  display: block;
  padding: 0.75rem 0.5rem;
  color: var(--light-gray);
  text-decoration: none;
  text-align: center;
  font-size: 0.9rem;
  font-weight: 500;
  border-radius: 0.25rem;
  transition: background-color 0.2s ease;
}

.jumble-item:hover {
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  background-color: var(--primary-color);
  color: white;
}

/* Workout History Section */
.workout-history {
  margin-bottom: 1rem;
  border: 1px solid var(--light-gray);
  border-radius: 0.5rem;
  background-color: #f8f9fa;
}

.workout-history-days {
  display: flex;
  gap: 1rem;
  padding: 0.75rem;
  overflow-x: auto;
}

.workout-history-summary {
  cursor: pointer;
  padding: 0.75rem;
  font-weight: 600;
  color: var(--primary-color);
  border-radius: 0.5rem;
  background-color: white;
  user-select: none;
}

.workout-history-summary:hover {
  background-color: var(--light-gray);
}

.workout-history[open] .workout-history-summary {
  border-bottom: 1px solid var(--light-gray);
  border-radius: 0.5rem 0.5rem 0 0;
}

.workout-history-day {
  flex: 0 0 200px;
  background-color: white;
  border: 1px solid var(--light-gray);
  border-radius: 0.25rem;
  padding: 0.75rem;
}

.workout-history-current {
  background-color: #e3f2fd;
  border-left: 4px solid var(--primary-color);
}

.workout-history-date {
  font-size: 1rem;
  font-weight: 600;
  color: var(--dark-gray);
  margin-bottom: 0.5rem;
  padding-bottom: 0.25rem;
  border-bottom: 1px dotted var(--medium-gray);
}

.workout-history-elements {
  margin-bottom: 0.75rem;
}

.workout-history-groups {
  margin-bottom: 0.75rem;
}

.section-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--secondary-color);
  margin-bottom: 0.5rem;
}

.workout-history-muscle-list {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.workout-history-muscle-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.25rem 0.5rem;
  background-color: white;
  border-radius: 0.25rem;
  border: 1px solid var(--light-gray);
  font-size: 0.875rem;
}

.muscle-name {
  font-weight: 500;
  color: var(--dark-gray);
}

.muscle-recovery {
  font-size: 0.75rem;
  color: var(--medium-gray);
  font-weight: 400;
}

.workout-history-empty {
  text-align: center;
  color: var(--medium-gray);
  font-style: italic;
  padding: 1rem;
}

@media (max-width: 768px) {
  .jumble-list {
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 0.25rem;
  }

  .jumble-item {
    display: block;
    padding: 0.5rem 0.25rem;
    font-size: 0.8rem;
  }

  .workout-history-summary {
    padding: 0.5rem;
    font-size: 0.9rem;
  }

  .workout-history-day {
    flex: 0 0 150px;
    padding: 0.5rem;
  }

  .workout-history-days {
    gap: 0.5rem;
    padding: 0.5rem;
  }

  .workout-history-date {
    font-size: 0.9rem;
  }

  .section-title {
    font-size: 0.8rem;
  }

  .workout-history-muscle-item {
    font-size: 0.8rem;
    padding: 0.25rem;
  }

  .muscle-recovery {
    font-size: 0.7rem;
  }
}
