/* ==========================================================================
   RIVAL Shoes - Contact Pages (Contact Form + Contact Info)
   ========================================================================== */

/* ---- Hero Compact Variant ---- */

.hero--compact {
  height: 45vh;
  min-height: 320px;
}

/* ---- Contact Cards Section ---- */

.section--contact-cards {
  background: var(--color-off-white);
}

.contact-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
  text-align: center;
}

.contact-card {
  background: var(--color-white);
  padding: var(--space-lg) var(--space-md);
  transition: all var(--duration-normal) var(--ease-out);
  box-shadow: var(--shadow-sm);
}

.contact-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}

.contact-card__icon {
  width: 48px;
  height: 48px;
  margin: 0 auto var(--space-sm);
  color: var(--color-accent);
}

.contact-card__icon img,
.contact-card__icon svg {
  width: 100%;
  height: 100%;
}

.contact-card__title {
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: var(--space-xs);
  color: var(--color-black);
}

.contact-card__value {
  color: var(--color-gray-400);
  font-size: 0.95rem;
  line-height: 1.7;
  font-weight: var(--fw-light);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

a.contact-card__value:hover {
  color: var(--color-accent);
}

/* ---- Office Hours Section ---- */

.section--hours {
  background: var(--color-white);
}

.office-hours {
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
  padding: var(--space-md) 0;
}

.office-hours__title {
  font-size: 1.5rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-md);
  color: var(--color-black);
}

.office-hours__text {
  color: var(--color-gray-400);
  font-size: 0.95rem;
  line-height: 2;
  font-weight: var(--fw-light);
}

.office-hours__text p {
  margin-bottom: var(--space-xs);
}

/* ---- Contact Form Section ---- */

.section--contact-form {
  background: var(--color-off-white);
}

.container--narrow {
  max-width: 700px;
}

/* ---- Form Messages ---- */

.form-message {
  padding: 1rem 1.25rem;
  margin-bottom: var(--space-md);
  font-size: 0.9rem;
  line-height: 1.6;
  border-radius: 0;
}

.form-message--success {
  background: #f0fef4;
  border: 1px solid var(--color-success);
  color: var(--color-success);
}

.form-message--error {
  background: #fef0ef;
  border: 1px solid var(--color-error);
  color: var(--color-error);
}

.form-message p {
  margin: 0;
}

/* ---- Contact Form ---- */

.contact-form {
  padding: var(--space-md) 0;
}

/* ---- Form Group (BEM overrides for contact) ---- */

.form-group__input {
  width: 100%;
  padding: 1rem;
  border: 1px solid var(--color-gray-200);
  background: var(--color-white);
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--color-gray-500);
  transition: border-color var(--duration-fast) var(--ease-out);
  outline: none;
}

.form-group__input:focus {
  border-color: var(--color-accent);
}

.form-group__input::placeholder {
  color: transparent;
}

.form-group__label {
  position: absolute;
  left: 1rem;
  top: 1rem;
  color: var(--color-gray-300);
  font-size: 1rem;
  font-weight: var(--fw-light);
  pointer-events: none;
  transition: all var(--duration-fast) var(--ease-out);
  background: transparent;
}

/* Float the label up when the input is focused or has content */
.form-group__input:focus ~ .form-group__label,
.form-group__input:not(:placeholder-shown) ~ .form-group__label {
  top: -0.5rem;
  left: 0.75rem;
  font-size: 0.75rem;
  background: var(--color-white);
  padding: 0 0.25rem;
  color: var(--color-accent);
}

/* Inside the off-white form section, use off-white bg for label float */
.section--contact-form .form-group__input:focus ~ .form-group__label,
.section--contact-form .form-group__input:not(:placeholder-shown) ~ .form-group__label {
  background: var(--color-off-white);
}

/* ---- Textarea ---- */

.form-group__input--textarea {
  min-height: 160px;
  resize: vertical;
  line-height: 1.6;
}

/* ---- Character Counter ---- */

.form-group__counter {
  display: block;
  text-align: right;
  font-size: 0.8rem;
  color: var(--color-gray-300);
  margin-top: 0.35rem;
  font-weight: var(--fw-light);
}

.form-group__counter-current {
  transition: color var(--duration-fast) var(--ease-out);
}

/* Warning state (e.g., near limit) */
.form-group__counter--warning .form-group__counter-current {
  color: var(--color-accent);
}

/* Error state (at limit) */
.form-group__counter--error .form-group__counter-current {
  color: var(--color-error);
}

/* ---- CAPTCHA Group ---- */

.form-group--captcha {
  padding-top: var(--space-xs);
}

.form-group--captcha .form-group__label--static {
  position: static;
  display: block;
  font-size: 0.85rem;
  font-weight: var(--fw-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
  margin-bottom: var(--space-xs);
  pointer-events: auto;
  background: none;
  padding: 0;
}

.captcha-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.captcha-row__image {
  height: 56px;
  border: 1px solid var(--color-gray-200);
  flex-shrink: 0;
  background: var(--color-white);
}

.captcha-row__refresh {
  cursor: pointer;
  color: var(--color-gray-300);
  transition: color var(--duration-fast) var(--ease-out);
  background: none;
  border: none;
  padding: 0.5rem;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.captcha-row__refresh:hover {
  color: var(--color-accent);
}

.captcha-row__refresh svg {
  width: 20px;
  height: 20px;
}

/* CAPTCHA input does not float its label (handled by --static label) */
.form-group--captcha .form-group__input {
  margin-top: 0;
}

/* ---- Submit Group ---- */

.form-group--submit {
  margin-top: var(--space-md);
  margin-bottom: 0;
  text-align: center;
}

/* ---- Full-Width Button ---- */

.btn--full {
  display: block;
  width: 100%;
}

/* ---- Responsive: Tablet ---- */

@media (max-width: 1024px) {
  .contact-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ---- Responsive: Mobile ---- */

@media (max-width: 768px) {
  .hero--compact {
    height: 38vh;
    min-height: 260px;
  }

  .contact-cards {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }

  .contact-card {
    padding: var(--space-md);
  }

  .office-hours {
    padding: 0;
  }

  .office-hours__title {
    font-size: 1.25rem;
  }

  .container--narrow {
    padding-left: var(--space-sm);
    padding-right: var(--space-sm);
  }

  .contact-form {
    padding: var(--space-sm) 0;
  }

  .captcha-row {
    flex-wrap: wrap;
  }

  .captcha-row__image {
    width: 100%;
    height: auto;
  }

  .form-group__input--textarea {
    min-height: 130px;
  }
}
