/* ============================================
   SotoTecho - Contact Form Stylesheet
   Theme: Hotel Reservation (Borderless Inputs)
   ============================================ */

.contact-main {
  padding-top: calc(var(--header-height) + var(--space-xl));
  background-color: var(--hotel-bg-light);
  padding-bottom: var(--space-2xl);
}

.contact-header {
  text-align: center;
  margin-bottom: var(--space-xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
}

.contact-header__sub {
  font-family: var(--font-display);
  font-size: 0.9rem;
  letter-spacing: 0.3em;
  color: var(--hotel-accent-gold);
  text-transform: uppercase;
}

.contact-header__title {
  font-size: 2.2rem;
  font-weight: 400;
  letter-spacing: 0.25em;
  margin-left: 0.25em; /* Center compensation */
  color: var(--hotel-text-dark);
}

.contact-header__desc {
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 200;
  line-height: 1.8;
  color: var(--hotel-text-gray);
  max-width: 520px;
  margin-top: 5px;
}

.contact-header__line {
  width: 40px;
  height: 1px;
  background-color: var(--hotel-accent-gold);
  margin-top: var(--space-md);
}

/* --- Form Layout --- */
.booking-form,
.wpcf7-form {
  max-width: 620px;
  margin: 0 auto;
  background-color: #ffffff;
  border: 1px solid var(--hotel-border-fine);
  padding: var(--space-xl) var(--space-xl) var(--space-lg);
  box-shadow: 0 4px 25px rgba(24, 23, 22, 0.02);
}

.form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: var(--space-md);
}

.form-label {
  font-size: 0.8rem;
  letter-spacing: 0.1em;
  color: var(--hotel-text-gray);
  font-weight: 400;
}

.required {
  color: #c0392b;
}

/* Minimal Line Inputs */
.form-input,
.form-select,
.form-textarea,
.wpcf7-form-control-wrap input,
.wpcf7-form-control-wrap select,
.wpcf7-form-control-wrap textarea {
  border: none;
  border-bottom: 1px solid var(--hotel-border-fine);
  background-color: transparent;
  padding: 12px 4px;
  width: 100%;
  outline: none;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 300;
  color: var(--hotel-text-dark);
  border-radius: 0;
  transition: border-color var(--transition-base);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus,
.wpcf7-form-control-wrap input:focus,
.wpcf7-form-control-wrap select:focus,
.wpcf7-form-control-wrap textarea:focus {
  border-bottom-color: var(--hotel-accent-gold);
}

.form-textarea,
.wpcf7-form-control-wrap textarea {
  min-height: 120px;
  resize: vertical;
  line-height: 1.6;
}

.form-select,
.wpcf7-form-control-wrap select {
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23B39257' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}

/* Date input specific reset for placeholder text visual align */
.form-input[type="date"],
.wpcf7-form-control-wrap input[type="date"] {
  font-family: var(--font-sans);
}

.form-submit-row {
  margin-top: var(--space-xl);
  text-align: center;
}

.booking-btn,
.wpcf7-submit {
  display: inline-block;
  width: 100%;
  padding: 14px;
  background-color: var(--hotel-accent-gold);
  border: 1px solid var(--hotel-accent-gold);
  color: #ffffff;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--transition-base);
  box-shadow: 0 4px 15px rgba(179, 146, 87, 0.2);
}

.booking-btn:hover,
.wpcf7-submit:hover {
  background-color: transparent;
  color: var(--hotel-accent-gold);
  box-shadow: none;
}

/* Contact Form 7 Error & Success Messages */
.wpcf7-response-output {
  margin: var(--space-md) 0 0 !important;
  padding: var(--space-sm) !important;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  border-radius: 4px;
  border: 1px solid var(--hotel-border-fine) !important;
  color: var(--hotel-text-dark);
}
.wpcf7-not-valid-tip {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  color: #c0392b;
  margin-top: 4px;
}

/* --- Responsive (Mobile) --- */
@media (max-width: 768px) {
  .booking-form,
  .wpcf7-form {
    padding: var(--space-md);
  }
}
