/* Contact Representatives Button Styles */
/* Matches the project's .btn and .btn-primary design */

.contact-reps-button {
  border: solid 1px var(--primary);
  text-shadow: none;
  text-decoration: none !important;
  box-shadow: none;
  background: var(--primary);
  border-radius: 5px;
  box-sizing: border-box;
  color: #ffffff;
  display: inline-block;
  font-size: 16px;
  line-height: 1.3;
  padding: 0.4em 1em 0.38em;
  text-align: center;
  margin: 5px 0;
  cursor: pointer;
  font-family: "Proxima Nova", "Helvetica Neue", Helvetica, Arial, sans-serif;
  transition: all 0.2s ease;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  white-space: nowrap;
  vertical-align: middle;
}

.contact-reps-button:hover {
  background: var(--primary-blue-700) !important;
  border-color: var(--primary-blue-700) !important;
  color: #ffffff !important;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 74, 173, 0.3);
}

.contact-reps-button:active,
.contact-reps-button.active {
  background: var(--primary-blue-800) !important;
  border-color: var(--primary-blue-800) !important;
  color: #ffffff !important;
  transform: translateY(0);
  box-shadow: 0 1px 4px rgba(0, 74, 173, 0.2);
}

.contact-reps-button:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 74, 173, 0.3);
}

.contact-reps-button:disabled,
.contact-reps-button[disabled] {
  opacity: 0.5 !important;
  pointer-events: none;
  cursor: default;
}

/* Responsive design */
@media (max-width: 768px) {
  .contact-reps-button {
    max-width: 300px;
    font-size: 14px;
    padding: 0.5em 0.8em 0.48em;
  }
} 