/* Contact Page Styles - Polished Professional */

.contact-cta {
  --contact-cta-panel-width: 100%;
  position: relative;
  overflow: hidden;
  background: var(--surface);
}

/* Background */
.contact-cta__background {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  background: transparent;
  opacity: 1;
}

.contact-cta__background canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  mix-blend-mode: normal;
  opacity: 1;
  filter: none;
}

.cta {
  border: none;
}

.is-contact .cta {
  background: transparent;
  border: none;
}

.is-contact .contact-cta__background canvas {
  mix-blend-mode: normal;
  opacity: 0.82;
  filter: saturate(1.08) brightness(1.02);
}

/* Intro Section with Entrance Animation */
.contact-cta__intro {
  position: relative;
  z-index: 1;
  margin-top: clamp(2rem, 5vw, 3rem);
  margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
  padding-top: clamp(1rem, 4vw, 2rem);
  opacity: 0;
  transform: translateY(1.5rem);
  animation: contact-fade-in 650ms cubic-bezier(0.25, 0.9, 0.35, 1) forwards;
  animation-delay: 100ms;
}

.contact-cta__header {
  gap: 0.5rem;
}

.contact-cta__header h1 {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: 0.01em;
  text-wrap: balance;
  margin: 0;
  color: var(--fg);
}

.contact-cta__header .eyebrow {
  color: color-mix(in srgb, var(--accent-700) 70%, var(--fg) 30%);
}

[data-theme="dark"] .contact-cta__header .eyebrow {
  color: color-mix(in srgb, var(--accent-300) 80%, var(--fg) 20%);
}

/* Content and Form Container Animation */
.contact-cta .cta__inner {
  position: relative;
  z-index: 1;
  margin-top: clamp(1rem, 3vw, 2rem);
  padding-top: clamp(1rem, 3vw, 2rem);
  gap: clamp(1.25rem, 3vw, 2rem);
  align-items: stretch;
}

.contact-cta .cta__content {
  opacity: 0;
  transform: translateY(1.25rem);
  animation: contact-fade-in 650ms cubic-bezier(0.25, 0.9, 0.35, 1) forwards;
  animation-delay: 200ms;
  text-align: left;
  justify-items: start;
}

.contact-cta .cta__content,
.contact-cta .cta__form {
  width: min(100%, var(--contact-cta-panel-width));
}

/* Lead Text */
.contact-cta .cta__lead,
.contact-cta .cta__note {
  font-size: clamp(1rem, 2.2vw, 1.1rem);
  line-height: 1.7;
  margin-top: 0;
}

.contact-cta .cta__note {
  margin-bottom: 1rem;
}

html[data-theme="light"] .is-contact .cta__note {
  color: var(--fg);
}

/* Glassmorphism Form Container */
.contact-cta .cta__form {
  opacity: 0;
  transform: translateY(1.25rem);
  animation: contact-fade-in 650ms cubic-bezier(0.25, 0.9, 0.35, 1) forwards;
  animation-delay: 300ms;
  position: relative;
  padding: 1.75rem;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.35);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: none;
  box-shadow:
    0 8px 32px -8px rgba(6, 26, 28, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

[data-theme="dark"] .contact-cta .cta__form {
  background: color-mix(in srgb, var(--surface) 50%, rgba(17, 197, 198, 0.12) 50%);
  box-shadow:
    0 8px 32px -8px rgba(0, 0, 0, 0.4),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

/* Enhanced Form Fields */
.contact-cta .cta__field input,
.contact-cta .cta__field textarea {
  padding: 0.85rem 1rem;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  background: color-mix(in srgb, var(--surface) 96%, var(--bg) 4%);
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.03);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease;
}

.contact-cta .cta__field input:hover,
.contact-cta .cta__field textarea:hover {
  border-color: color-mix(in srgb, var(--accent-400) 30%, var(--border) 70%);
  background: var(--surface);
}

.contact-cta .cta__field input:focus-visible,
.contact-cta .cta__field textarea:focus-visible {
  outline: none;
  border-color: color-mix(in srgb, var(--accent-500) 55%, var(--border) 45%);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent-300) 28%, transparent),
    inset 0 2px 4px rgba(0, 0, 0, 0.02);
  background: var(--surface);
}

[data-theme="dark"] .contact-cta .cta__field input,
[data-theme="dark"] .contact-cta .cta__field textarea {
  background: color-mix(in srgb, var(--surface) 90%, rgba(17, 197, 198, 0.04) 10%);
  border-color: color-mix(in srgb, var(--border) 60%, rgba(255, 255, 255, 0.06) 40%);
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.12);
}

[data-theme="dark"] .contact-cta .cta__field input:hover,
[data-theme="dark"] .contact-cta .cta__field textarea:hover {
  border-color: color-mix(in srgb, var(--accent-400) 40%, var(--border) 60%);
}

[data-theme="dark"] .contact-cta .cta__field input:focus-visible,
[data-theme="dark"] .contact-cta .cta__field textarea:focus-visible {
  border-color: color-mix(in srgb, var(--accent-400) 60%, var(--border) 40%);
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent-500) 22%, transparent),
    inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.contact-cta .cta__field--message textarea {
  min-height: clamp(12rem, 28vw, 20rem);
}

/* Submit Button */
.contact-cta .cta__form .button-primary {
  padding: 0.95rem 2rem;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.015em;
  border: 1px solid color-mix(in srgb, var(--accent-600) 40%, transparent);
  background: var(--accent-600);
  box-shadow: 0 4px 12px -4px color-mix(in srgb, var(--accent-700) 40%, transparent);
  transition:
    background 200ms ease,
    box-shadow 200ms ease,
    transform 150ms ease;
}

.contact-cta .cta__form .button-primary:hover {
  background: var(--accent-500);
  box-shadow: 0 6px 16px -4px color-mix(in srgb, var(--accent-700) 50%, transparent);
}

.contact-cta .cta__form .button-primary:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--accent-300) 40%, transparent),
    0 4px 12px -4px color-mix(in srgb, var(--accent-700) 40%, transparent);
}

.contact-cta .cta__form .button-primary:active {
  transform: scale(0.98);
}

[data-theme="dark"] .contact-cta .cta__form .button-primary {
  background: var(--accent-500);
  border-color: rgba(43, 202, 203, 0.5);
  color: #001a1c;
  box-shadow: 0 4px 16px -4px rgba(17, 197, 198, 0.5);
}

[data-theme="dark"] .contact-cta .cta__form .button-primary:hover {
  background: var(--accent-400);
  box-shadow: 0 6px 20px -4px rgba(17, 197, 198, 0.6);
}

/* Actions Button */
.contact-cta .cta__actions {
  opacity: 0;
  transform: translateY(1rem);
  animation: contact-fade-in 650ms cubic-bezier(0.25, 0.9, 0.35, 1) forwards;
  animation-delay: 400ms;
  justify-content: flex-start;
  margin-top: clamp(1.5rem, 4vw, 2.5rem);
}

/* Entrance Animation Keyframes */
@keyframes contact-fade-in {
  from {
    opacity: 0;
    transform: translateY(1.5rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .contact-cta__intro,
  .contact-cta .cta__content,
  .contact-cta .cta__form,
  .contact-cta .cta__actions {
    opacity: 1;
    transform: none;
    animation: none;
  }

  .contact-cta .cta__form .button-primary::after {
    transition: none;
  }
}

/* Responsive Styles */
@media (max-width: 767px) {
  .contact-cta .cta__content {
    text-align: center;
    justify-items: center;
  }

  .contact-cta .cta__actions {
    justify-content: center;
  }

  .contact-cta__header h1 {
    font-size: clamp(1.9rem, 7vw, 2.5rem);
  }

  .contact-cta .cta__form {
    padding: 1.5rem;
  }
}

@media (min-width: 768px) and (max-width: 959px) {
  .contact-cta {
    --contact-cta-panel-width: 560px;
  }

  .contact-cta .cta__inner {
    grid-template-columns: minmax(0, 1fr);
    justify-items: center;
    gap: clamp(1.5rem, 4vw, 2.5rem);
  }

  .contact-cta .cta__content {
    text-align: center;
    justify-items: center;
  }

  .contact-cta .cta__actions {
    justify-content: center;
    width: 100%;
  }

  .contact-cta .cta__form {
    justify-self: center;
    align-self: start;
  }
}

@media (min-width: 960px) {
  .contact-cta {
    --contact-cta-panel-width: 520px;
  }

  .contact-cta .cta__inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
    justify-content: center;
  }

  .contact-cta .cta__actions {
    grid-column: 1 / -1;
    justify-self: center;
    justify-content: center;
  }
}

/* Footer adjustment */
.is-contact .footer__inner {
  margin-top: 0;
  padding-top: 0;
}
