/* =============================================
   HAUS EDELWEISS — Contact Page
   Figma source: 1572:21557
   ============================================= */

/* --- Page background + spacing for fixed header --- */
.page-contact {
  background-color: var(--color-cream);   /* #F4F1DE — Figma neutrals/500 */
  padding-top: clamp(100px, 8vw, 140px);
}


/* Header scroll state — match warmer cream bg on contact page */
.page-contact .header.is-scrolled {
  background-color: rgba(244, 241, 222, 0.92);  /* #F4F1DE at 92% */
}


/* =============================================
   CONTACT HERO (label + heading + address)
   ============================================= */
.contact-hero {
  text-align: center;
  padding-bottom: var(--space-2xl);
}

.contact-hero__heading {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
}

.contact-hero__title {
  font-family: var(--font-heading);
  font-size: var(--text-5xl);            /* 78px in Figma */
  font-weight: var(--weight-medium);
  line-height: var(--leading-tight);     /* 1.24 */
  letter-spacing: -0.02em;              /* -1.56px at 78px */
  color: var(--color-rust);
}

.contact-hero__address {
  margin-top: 64px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}

.contact-hero__address-title {
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.625rem);  /* ~26px */
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
  color: var(--color-rust);
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-thickness: 1px;
}

.contact-hero__address-text {
  font-family: var(--font-body);
  font-size: var(--text-base);           /* 16px */
  font-weight: 300;
  line-height: var(--leading-relaxed);   /* 1.6 */
  letter-spacing: -0.015em;             /* -0.24px */
  color: var(--color-wine);
}


/* =============================================
   CONTACT CONTENT (image + form two-column)
   ============================================= */
.contact-content {
  padding-top: var(--space-3xl);
  padding-bottom: var(--space-4xl);
}

.contact-content__grid {
  display: grid;
  grid-template-columns: 678fr 674fr;
  gap: 32px;
  align-items: start;
}

/* --- Left: image (sticky on desktop) --- */
.contact-content__image {
  aspect-ratio: 678 / 868;
  overflow: hidden;
  position: sticky;
  top: clamp(113px, 8.5vw, 123px);
}

.contact-content__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* --- Right: details + form --- */
.contact-content__right {
  padding-left: 32px;
  display: flex;
  flex-direction: column;
  gap: 96px;                             /* Figma gap between details & form */
}


/* =============================================
   CONTACT DETAILS (Call us + Office Hours)
   ============================================= */
.contact-details {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: flex-start;
}

.contact-detail {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}

.contact-detail__icon {
  width: 56px;
  height: 56px;
  min-width: 56px;
  border: 1px solid #DEDAC5;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.contact-detail__icon svg {
  width: 24px;
  height: 24px;
  color: var(--color-rust);
  stroke: var(--color-rust);
  fill: none;
}

.contact-detail__info {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.contact-detail__title {
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.625rem);  /* 26px */
  font-weight: var(--weight-medium);
  line-height: 1.24;                                    /* Figma exact */
  letter-spacing: -0.03em;
  color: var(--color-rust);
}

.contact-detail__text {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 300;
  line-height: 1.6;                                     /* Figma: 1.6 (was 1.7) */
  letter-spacing: -0.015em;
  color: var(--color-wine);
}

.contact-detail__text a {
  color: var(--color-wine);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.contact-detail__text a:hover {
  color: var(--color-rust);
}


/* =============================================
   CONTACT FORM
   ============================================= */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 48px;                              /* Figma: 48px between all form children */
}

/* --- Form field --- */
.contact-form__field {
  position: relative;
  height: 76px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-bottom: 1px solid var(--color-wine);
}

.contact-form__field label {
  font-family: var(--font-body);
  font-size: clamp(0.9375rem, 0.85rem + 0.35vw, 1.125rem);  /* ~18px */
  font-weight: 300;
  letter-spacing: -0.015em;
  color: var(--color-rust);
  pointer-events: none;
}

.contact-form__field input {
  font-family: var(--font-body);
  font-size: clamp(0.9375rem, 0.85rem + 0.35vw, 1.125rem);
  font-weight: 300;
  letter-spacing: -0.015em;
  color: var(--color-wine);
  border: none;
  background: transparent;
  outline: none;
  padding: 0;
  margin-top: 4px;
}

.contact-form__field input::placeholder {
  color: var(--color-wine);
  opacity: 0.4;
}

/* --- Message textarea field — same rhythm as other fields --- */
.contact-form__field--textarea {
  height: auto;
  min-height: 76px;
  justify-content: flex-start;
  padding-top: 16px;
  padding-bottom: 16px;
}

.contact-form__field--textarea textarea {
  font-family: var(--font-body);
  font-size: clamp(0.9375rem, 0.85rem + 0.35vw, 1.125rem);
  font-weight: 300;
  letter-spacing: -0.015em;
  color: var(--color-wine);
  border: none;
  background: transparent;
  outline: none;
  resize: vertical;
  min-height: 24px;
  padding: 0;
  margin-top: 4px;                        /* match input margin-top in regular fields */
  line-height: var(--leading-relaxed);
}

.contact-form__field--textarea textarea::placeholder {
  color: var(--color-wine);
  opacity: 0.4;
}

/* --- Consent checkbox --- */
.contact-form__consent {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 0 12px;
  align-items: start;
}

.contact-form__checkbox {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background-color: var(--color-rust);
  border: none;
  cursor: pointer;
  position: relative;
  margin-top: 3px;                        /* align center of checkbox with first text line */
  align-self: start;
  flex-shrink: 0;
}

.contact-form__checkbox::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 45%;
  width: 6px;
  height: 10px;
  border: solid var(--color-cream);
  border-width: 0 2px 2px 0;
  transform: translate(-50%, -50%) rotate(45deg);
  opacity: 0;
  transition: opacity var(--duration-fast) ease;
}

.contact-form__checkbox:checked::after {
  opacity: 1;
}

.contact-form__consent-text {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 300;
  line-height: var(--leading-relaxed);
  color: var(--color-wine);
}

.contact-form__consent-text a {
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-skip-ink: none;
}

/* --- Validation error states --- */
.contact-form--submitted .contact-form__field--invalid {
  border-bottom-color: #C1121F;
}

input.is-invalid::placeholder,
textarea.is-invalid::placeholder {
  color: #C1121F;
  opacity: 1;
}

.contact-form--submitted .contact-form__consent--invalid .contact-form__checkbox {
  outline: 2px solid #C1121F;
  outline-offset: 2px;
}

/* --- Submit button --- */
.contact-form__submit {
  align-self: flex-start;
}

.contact-form__submit .btn-stamp__inner {
  width: 200px;
}

/* Submit status message (sending / success / error) */
.contact-form__status {
  margin-top: var(--space-md);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}

.contact-form__status[data-state="sending"] {
  color: var(--color-text-light);
}

.contact-form__status[data-state="success"] {
  color: var(--color-sage);
}

.contact-form__status[data-state="error"] {
  color: var(--color-rust);
}


/* =============================================
   ACTION CARDS (Directions / Book now / FAQ)
   Notebook card style — scalloped top edge
   ============================================= */
.action-cards {
  padding-top: var(--space-4xl);
  padding-bottom: var(--space-4xl);
}

.action-cards__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* Notebook card — scalloped top + white body */
.action-card {
  display: flex;
  flex-direction: column;
  position: relative;
  cursor: pointer;
  transition: transform var(--duration-normal) var(--ease-out);
}

.action-card:hover {
  transform: translateY(-4px);
}

/* Stretch the link over the entire card */
.action-card__link::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
}

/* Grain texture overlay (matches booking widget) */
.action-card::after {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0.04;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  mix-blend-mode: multiply;
}

/* Scalloped top edge — reuse booking widget notes-tile pattern */
.action-card__tabs {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  height: 48px;
  flex-shrink: 0;
  background: url('../../assets/images/notes-tilebeige.svg') 17px top / 26px 48px repeat-x;
}

.action-card__tab-edge {
  display: block;
  height: 48px;
  width: 17px;
  flex-shrink: 0;
}

.action-card__tab-edge--right {
  transform: scaleX(-1);
}

/* Dotted separator (same as booking widget) */
.action-card__separator {
  width: 100%;
  height: 1.85px;
  border: none;
  background: radial-gradient(circle closest-side, var(--color-sage) 99%, transparent 100%) 0 center / 5.95px 1.85px repeat-x;
}

/* Card body below the scalloped edge */
.action-card__body {
  background: var(--color-cream-light);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.action-card__inner {
  padding: 48px 48px 48px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
  flex: 1;
}

.action-card__title {
  font-family: var(--font-heading);
  font-size: clamp(1.25rem, 1rem + 0.8vw, 1.625rem);
  font-weight: var(--weight-medium);
  line-height: 1.3;
  color: var(--color-rust);
}

.action-card__text {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 300;
  line-height: var(--leading-relaxed);
  letter-spacing: -0.015em;
  color: var(--color-wine);
}

/* Link — btn-secondary style with text-scroll hover */
.action-card__link {
  padding: 13px 0;
  margin-top: auto;
}

.action-card__link .btn-secondary__text {
  color: var(--color-rust);
}

.action-card__link .btn-secondary__arrow {
  filter: brightness(0) saturate(100%) invert(16%) sepia(66%) saturate(3413%) hue-rotate(14deg) brightness(85%) contrast(96%);
}


/* =============================================
   RESPONSIVE
   ============================================= */
@media (max-width: 1024px) {
  .contact-content__grid {
    grid-template-columns: 1fr 1fr;
  }

  .contact-content__right {
    padding-left: 0;
    gap: 48px;
  }

  .contact-details {
    gap: 24px;
  }

  .contact-form {
    gap: 32px;
  }

  .contact-form__field {
    height: 64px;
  }
}

@media (max-width: 768px) {
  .page-contact {
    padding-top: 80px;
  }

  .contact-hero__title {
    font-size: var(--text-4xl);
  }

  .contact-hero__address {
    margin-top: 40px;
  }

  .contact-content__grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .contact-content__image {
    aspect-ratio: 16 / 10;
    position: relative;
    top: auto;
  }

  .contact-content__right {
    gap: 40px;
  }

  .contact-details {
    flex-direction: column;
    gap: 24px;
  }

  .contact-form {
    gap: 24px;
  }

  .contact-form__field {
    height: 60px;
  }

  .action-cards__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .action-card__inner {
    padding: 32px 24px 24px;
  }
}
