/* ------------------------------------------------
   Contact page
   ------------------------------------------------ */

/* Animations */
@keyframes contact-blob-1 {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(3rem, 2rem) scale(1.1); }
}

@keyframes contact-blob-2 {
  0% { transform: translate(0, 0); }
  100% { transform: translate(-2rem, -2rem); }
}


@keyframes contact-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* Hero */
.contact-hero {
  padding: var(--space-20) var(--space-4) var(--space-20);
  text-align: center;
  position: relative;
  z-index: var(--z-content);
}

.contact-hero__blob {
  position: absolute;
  pointer-events: none;
  z-index: -1;
}

.contact-hero__blob--1 {
  width: clamp(30rem, 50vw, 48rem);
  height: clamp(30rem, 50vw, 48rem);
  top: 10%;
  right: -15%;
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--color-green) 16%, transparent) 0%, transparent 50%);
  animation: contact-blob-1 30s ease-in-out infinite alternate;
}

.contact-hero__blob--2 {
  width: clamp(28rem, 45vw, 44rem);
  height: clamp(28rem, 45vw, 44rem);
  top: 20%;
  left: -10%;
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--color-blue) 14%, transparent) 0%, transparent 50%);
  animation: contact-blob-2 25s ease-in-out infinite alternate;
}

.contact-hero__title {
  font-size: var(--font-size-5xl);
  font-weight: 800;
  color: var(--color-heading);
  letter-spacing: -0.03em;
  line-height: 1.1;
  margin-bottom: var(--space-6);
}

.contact-hero__accent {
  font-family: var(--font-heading);
  font-weight: 500;
  color: #0000;
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  background-clip: text;
}

.contact-hero__subtitle {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  max-width: 38rem;
  margin: 0 auto;
  line-height: 1.7;
}

@media (min-width: 48rem) {
  .contact-hero {
    padding-top: var(--space-20);
  }
  .contact-hero__title {
    font-size: var(--font-size-5xl);
  }
}

@media (min-width: 64rem) {
  .contact-hero {
    padding-top: var(--space-24);
  }
  .contact-hero__title {
    font-size: var(--font-size-6xl);
  }
}

/* ------------------------------------------------
   Main two-column layout: team left, form right
   ------------------------------------------------ */
.contact-main {
  padding: var(--space-8) var(--space-4) var(--space-20);
  position: relative;
  z-index: var(--z-content);
}

.contact-main__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  max-width: 72rem;
  margin: 0 auto;
}

.contact-main__form {
  order: 1;
}

.contact-main__team {
  order: 2;
}

@media (min-width: 64rem) {
  .contact-main__grid {
    grid-template-columns: 5fr 7fr;
    gap: var(--space-10);
    align-items: start;
  }

  .contact-main__form,
  .contact-main__team {
    order: initial;
  }
}

.contact-team__heading,
.contact-form__heading {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  font-weight: 600;
  color: var(--color-heading);
}

/* ------------------------------------------------
   Team column (left)
   ------------------------------------------------ */
.contact-main__team {
  margin-top: var(--space-10);
}

.contact-team__heading {
  margin-bottom: var(--space-5);
}

.contact-team__heading {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.contact-team__heading::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-blue);
  box-shadow: 0 0 8px var(--color-blue);
  animation: contact-blink 2s infinite;
  flex-shrink: 0;
}

.contact-team__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Team card */
.team-card {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-6);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  backdrop-filter: blur(var(--glass-blur));
  transition:
    transform var(--transition-base),
    box-shadow var(--transition-base),
    border-color var(--transition-base);
}

.team-card:hover {
  transform: translateY(-0.25rem);
  box-shadow: var(--shadow-lg);
  border-color: var(--glass-border-hover);
}

.team-card__photo {
  width: 5.5rem;
  height: 5.5rem;
  border-radius: var(--radius-full);
  object-fit: cover;
  flex-shrink: 0;
  border: 3px solid var(--color-grey-200);
  transition: border-color var(--transition-base);
}

.team-card:hover .team-card__photo {
  border-color: var(--color-blue-light);
}

.team-card__info {
  min-width: 0;
}

.team-card__name {
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--color-heading);
  margin-bottom: var(--space-1);
}

.team-card__role {
  font-size: var(--font-size-sm);
  color: var(--color-blue);
  font-weight: 500;
  margin-bottom: var(--space-3);
}

.team-card__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.team-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.team-card__link:hover {
  color: var(--color-blue);
  text-decoration: none;
}

.team-card__link svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}

/* ------------------------------------------------
   Contact form column (right)
   ------------------------------------------------ */
.contact-form-wrap {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-8);
  backdrop-filter: blur(var(--glass-blur));
}

@media (min-width: 48rem) {
  .contact-form-wrap {
    padding: var(--space-10) var(--space-10);
  }
}

.contact-form__heading {
  margin-bottom: var(--space-8);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.contact-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 48rem) {
  .contact-form__row {
    grid-template-columns: 1fr 1fr;
  }
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.contact-form__label {
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--color-heading);
}

.contact-form__input,
.contact-form__textarea {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  background: var(--glass-bg);
  color: var(--color-text);
  font-family: var(--font-text);
  font-size: var(--font-size-base);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-form__input:focus,
.contact-form__textarea:focus {
  outline: none;
  border-color: var(--color-blue);
  box-shadow: 0 0 0 3px rgba(10, 165, 195, 0.12);
}

.contact-form__input::placeholder,
.contact-form__textarea::placeholder {
  color: var(--color-grey-400);
}

.contact-form__textarea {
  min-height: 8rem;
  resize: vertical;
}

select.contact-form__input {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  padding-right: var(--space-10);
  cursor: pointer;
}

select.contact-form__input:invalid {
  color: var(--color-grey-400);
}

/* Submit -- layout only, visual styles from .btn */
.contact-form__submit {
  align-self: flex-start;
  padding-left: var(--space-8);
  padding-right: var(--space-8);
  min-height: 3rem;
}

.contact-form__submit[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}

.contact-form__status {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted, var(--color-text));
  min-height: 1.25rem;
}

.contact-form__status[data-state="success"] {
  color: var(--color-green, #3ecf8e);
}

.contact-form__status[data-state="error"] {
  color: var(--color-red, #e5484d);
}

/* ------------------------------------------------
   Staggered fade-in for contact page
   ------------------------------------------------ */
.contact-hero,
.team-card,
.contact-form-wrap {
  opacity: 0;
  transform: translateY(1.5rem);
  transition:
    opacity 0.6s ease,
    transform 0.6s ease;
}

.js-ready .contact-hero {
  opacity: 1;
  transform: translateY(0);
}

.js-ready .team-card {
  opacity: 1;
  transform: translateY(0);
}

.js-ready .team-card:nth-child(1) { transition-delay: 0.1s; }
.js-ready .team-card:nth-child(2) { transition-delay: 0.2s; }
.js-ready .team-card:nth-child(3) { transition-delay: 0.3s; }

.js-ready .contact-form-wrap.fade-in--visible {
  opacity: 1;
  transform: translateY(0);
}
