/* 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-image: repeating-linear-gradient(45deg,
      transparent,
      transparent 2px,
      var(--light-gray) 2px,
      var(--light-gray) 8px);
  padding: 0;
}

.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;
}

@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;
  }
}
