/* =========================================================
   Contact Us page (shortcode: [gb_contact])
   ========================================================= */

#top .dason-contact-page,
.dason-contact-page {
  width: 100vw;
  max-width: 100vw;
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  background: #fff;
  color: var(--dason-text);
  font-family: var(--dason-body-font) !important;
  line-height: var(--dason-line-body);
  overflow: hidden;
}

.dason-contact-page *,
.dason-contact-page *::before,
.dason-contact-page *::after {
  box-sizing: border-box;
}

.dason-contact-page h1,
.dason-contact-page h2,
.dason-contact-page h3,
.dason-contact-page p,
.dason-contact-page ul,
.dason-contact-page ol {
  margin: 0;
  padding: 0;
}

#top .dason-contact-page h2,
#top .dason-contact-page h3,
#top .dason-contact-page .dason-eyebrow {
  font-family: var(--dason-title-font) !important;
}

#top .dason-contact-page p,
#top .dason-contact-page a,
#top .dason-contact-page li,
#top .dason-contact-page label,
#top .dason-contact-page small {
  font-family: var(--dason-body-font) !important;
}

#top .dason-contact-page,
#top .dason-contact-page * {
  letter-spacing: 0 !important;
}

#top .dason-contact-page .dason-eyebrow {
  color: var(--dason-accent) !important;
  text-transform: uppercase;
}

.dason-contact-page .dason-section {
  position: relative;
  width: 100%;
}

.dason-contact-page .dason-container {
  width: min(100% - 96px, var(--dason-container-max));
  margin: 0 auto;
}

.dason-contact-page .dason-media-placeholder {
  position: relative;
  display: block;
  width: 100%;
  background: var(--dason-placeholder);
}

/* ---------------------------------------------------------
   Hero
   --------------------------------------------------------- */
.dason-contact-hero {
  position: relative;
  min-height: clamp(280px, 32vw, 480px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.dason-contact-page .dason-contact-hero__media {
  position: absolute;
  inset: 0;
  background: var(--dason-placeholder-dark)
    url("/wp-content/uploads/2026/05/tica1140011184-scaled.jpg") center center /
    cover no-repeat;
  min-height: 100%;
}

.dason-contact-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.36);
}

.dason-contact-hero__overlay {
  position: relative;
  z-index: 1;
  text-align: center;
  color: #fff;
}

#top .dason-contact-page .dason-contact-hero__overlay strong {
  display: block;
  font-family: var(--dason-title-font) !important;
  font-size: clamp(48px, 5.6vw, 84px);
  font-weight: var(--dason-fw-bold);
  color: #fff;
  line-height: 1;
  margin-bottom: clamp(10px, 1vw, 18px);
}

#top .dason-contact-page .dason-contact-hero__overlay{
  margin-top: clamp(10px, 1vw, 18px);
  font-size: clamp(15px, 1.2vw, 20px);
  font-weight: var(--dason-fw-medium);
  color: #fff;
}

/* ---------------------------------------------------------
   Body
   --------------------------------------------------------- */
.dason-contact-body {
  padding: clamp(64px, 7vw, 95px) 0 clamp(96px, 14vw, 200px);
}

/* ---- Intro: eyebrow + big heading (unified with other pages) ---- */
.dason-contact-intro {
  margin-bottom: clamp(56px, 8vw, 140px);
}

#top .dason-contact-page .dason-contact-intro .dason-eyebrow {
  margin-bottom: clamp(14px, 1.6vw, 24px);
}

#top .dason-contact-page .dason-contact-intro__title {
  font-family: var(--dason-title-font) !important;
  font-size: clamp(26px, 3.4vw, 50px);
  font-weight: var(--dason-fw-bold);
  color: var(--dason-text);
  line-height: 1.35;
}

/* ---------------------------------------------------------
   Contact Form 7 — mobiem-inspired styling
   #top prefix used to beat Enfold (Avia) parent-theme specificity
   --------------------------------------------------------- */
.dason-contact-form {
  width: 100%;
}

#top .dason-contact-page .wpcf7 {
  margin: 0;
  padding: 0;
}

#top .dason-contact-page .wpcf7-form {
  display: flex;
  flex-wrap: wrap;
  gap: 25px;
  background: transparent;
}

#top .dason-contact-page .wpcf7-form > p {
  margin: 0;
  padding: 0;
  width: 100%;
}

/* 2-column rows for first 4 fields:
   문의 유형 + 이름  /  이메일 + 전화번호 */
#top .dason-contact-page .wpcf7-form > p:nth-of-type(-n+4) {
  flex: 0 0 calc(50% - 12.5px);
  max-width: calc(50% - 12.5px);
}

/* Labels */
#top .dason-contact-page .wpcf7-form label {
  display: block;
  font-family: var(--dason-body-font) !important;
  font-size: clamp(15px, 1.15vw, 18px);
  font-weight: var(--dason-fw-bold);
  color: var(--dason-text);
  letter-spacing: 0 !important;
  line-height: 1.4;
}

/* (필수) — wrapped in <small> by the CF7 template */
#top .dason-contact-page .wpcf7-form label small {
  display: inline-block;
  margin-left: 4px;
  padding: 0 4px;
  font-family: var(--dason-body-font) !important;
  font-size: clamp(12px, 0.85vw, 14px);
  font-weight: var(--dason-fw-regular);
  color: #ff3b30;
  letter-spacing: 0 !important;
}

/* Push the form-control onto a new line below the label text */
#top .dason-contact-page .wpcf7-form label br {
  display: block;
  content: "";
  margin-bottom: 12px;
}

#top .dason-contact-page .wpcf7-form-control-wrap {
  display: block;
  margin-top: 12px;
  width: 100%;
}

/* Inputs / selects / textareas — high specificity to beat Enfold */
#top .dason-contact-page .wpcf7-text,
#top .dason-contact-page .wpcf7-email,
#top .dason-contact-page .wpcf7-tel,
#top .dason-contact-page .wpcf7-select,
#top .dason-contact-page .wpcf7-textarea,
#top .dason-contact-page input.wpcf7-form-control,
#top .dason-contact-page select.wpcf7-form-control,
#top .dason-contact-page textarea.wpcf7-form-control {
  display: block;
  width: 100%;
  height: clamp(50px, 5vw, 60px);
  min-height: clamp(50px, 5vw, 60px);
  padding: 0 20px;
  margin: 0;
  background: #ecedf1;
  border: 0;
  border-radius: 12px;
  box-shadow: none;
  color: var(--dason-text);
  font-family: var(--dason-body-font) !important;
  font-size: clamp(14px, 1.1vw, 17px);
  font-weight: var(--dason-fw-medium);
  letter-spacing: 0 !important;
  line-height: 1.5;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  transition: background 0.18s ease, box-shadow 0.18s ease;
}

#top .dason-contact-page .wpcf7-textarea,
#top .dason-contact-page textarea.wpcf7-form-control {
  height: clamp(180px, 22vw, 300px);
  min-height: clamp(180px, 22vw, 300px);
  padding: 18px 20px;
  resize: none;
}

#top .dason-contact-page .wpcf7-select,
#top .dason-contact-page select.wpcf7-form-control {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none' stroke='%23848484' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M1 1l5 5 5-5'/></svg>");
  background-repeat: no-repeat;
  background-position: right 20px center;
  background-size: 12px 8px;
  padding-right: 50px;
  cursor: pointer;
  color: var(--dason-text);
}

#top .dason-contact-page .wpcf7-text::placeholder,
#top .dason-contact-page .wpcf7-email::placeholder,
#top .dason-contact-page .wpcf7-tel::placeholder,
#top .dason-contact-page .wpcf7-textarea::placeholder {
  color: #848484;
  font-weight: var(--dason-fw-regular);
  opacity: 1;
}

#top .dason-contact-page .wpcf7-text:hover,
#top .dason-contact-page .wpcf7-email:hover,
#top .dason-contact-page .wpcf7-tel:hover,
#top .dason-contact-page .wpcf7-select:hover,
#top .dason-contact-page .wpcf7-textarea:hover {
  background: #e3e5eb;
}

#top .dason-contact-page .wpcf7-text:focus,
#top .dason-contact-page .wpcf7-email:focus,
#top .dason-contact-page .wpcf7-tel:focus,
#top .dason-contact-page .wpcf7-select:focus,
#top .dason-contact-page .wpcf7-textarea:focus {
  outline: none;
  background: #fff;
  box-shadow: 0 0 0 2px var(--dason-text);
}

/* ---- Acceptance (privacy consent) row ---- */
#top .dason-contact-page .wpcf7-form > p:nth-last-of-type(2) {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 10px;
  font-size: clamp(13px, 1vw, 16px);
  font-weight: var(--dason-fw-regular);
  color: var(--dason-text);
}

#top .dason-contact-page .wpcf7-acceptance {
  display: inline-flex;
  margin: 0;
  padding: 0;
}

#top .dason-contact-page .wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
  display: inline-flex;
  align-items: center;
}

#top .dason-contact-page .wpcf7-acceptance .wpcf7-list-item-label {
  margin-left: 8px;
  font-weight: var(--dason-fw-regular);
}

#top .dason-contact-page .wpcf7-acceptance input[type="checkbox"] {
  display: inline-block !important;
  vertical-align: middle;
  position: relative;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px;
  min-height: 20px;
  margin: 0;
  padding: 0;
  border: 1px solid var(--dason-text);
  border-radius: 0;
  background: #fff;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  flex-shrink: 0;
  transition: background 0.15s ease;
}

#top .dason-contact-page .wpcf7-acceptance input[type="checkbox"]:checked {
  background: var(--dason-text);
}

#top .dason-contact-page .wpcf7-acceptance input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 6px;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

#top .dason-contact-page .wpcf7-form > p:nth-last-of-type(2) a {
  color: var(--dason-muted);
  text-decoration: underline;
  text-underline-offset: 2px;
}

#top .dason-contact-page .wpcf7-form > p:nth-last-of-type(2) a:hover {
  color: var(--dason-text);
}

/* ---- Submit button — right aligned (mobiem .btnWrap) ---- */
#top .dason-contact-page .wpcf7-form > p:last-of-type {
  margin-top: clamp(8px, 1vw, 20px);
  text-align: right;
}

#top .dason-contact-page .wpcf7-submit,
#top .dason-contact-page input.wpcf7-submit {
  display: inline-block;
  width: auto;
  height: auto;
  padding: clamp(16px, 1.6vw, 22px) clamp(40px, 4vw, 70px);
  margin: 0;
  background: var(--dason-text);
  color: #fff;
  border: 0;
  border-radius: 999px;
  box-shadow: none;
  font-family: var(--dason-body-font) !important;
  font-weight: var(--dason-fw-bold);
  font-size: clamp(15px, 1.2vw, 18px);
  letter-spacing: 0 !important;
  text-transform: none;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

#top .dason-contact-page .wpcf7-submit:hover,
#top .dason-contact-page input.wpcf7-submit:hover {
  background: var(--dason-accent-strong);
  color: #fff;
}

#top .dason-contact-page .wpcf7-submit:active {
  transform: translateY(1px);
}

#top .dason-contact-page .wpcf7-submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

#top .dason-contact-page .wpcf7-spinner {
  margin-left: 12px;
  vertical-align: middle;
}

/* ---- Validation ---- */
#top .dason-contact-page .wpcf7-not-valid-tip {
  margin-top: 6px;
  font-size: clamp(12px, 0.95vw, 14px);
  font-weight: var(--dason-fw-regular);
  color: #ff3b30;
}

#top .dason-contact-page .wpcf7-not-valid {
  box-shadow: 0 0 0 1px #ff3b30 !important;
}

#top .dason-contact-page .wpcf7-response-output {
  width: 100%;
  margin: clamp(16px, 1.6vw, 24px) 0 0;
  padding: clamp(12px, 1.3vw, 18px) clamp(14px, 1.4vw, 20px);
  border-radius: 8px;
  font-size: clamp(13px, 1vw, 15px);
  line-height: 1.5;
}

#top .dason-contact-page .wpcf7 form.sent .wpcf7-response-output {
  border: 1px solid #2e7d32;
  background: rgba(46, 125, 50, 0.08);
  color: #2e7d32;
}

#top .dason-contact-page .wpcf7 form.failed .wpcf7-response-output,
#top .dason-contact-page .wpcf7 form.aborted .wpcf7-response-output,
#top .dason-contact-page .wpcf7 form.invalid .wpcf7-response-output,
#top .dason-contact-page .wpcf7 form.unaccepted .wpcf7-response-output {
  border: 1px solid #ff3b30;
  background: rgba(255, 59, 48, 0.06);
  color: #c22;
}

/* ---------------------------------------------------------
   Responsive
   --------------------------------------------------------- */
@media (max-width: 1024px) {
  #top .dason-contact-page .wpcf7-form {
    gap: 18px;
  }
}

@media (max-width: 820px) {
  .dason-contact-page .dason-container {
    width: min(100% - 32px, var(--dason-container-max));
  }

  /* Collapse two-column rows to single column on mobile */
  #top .dason-contact-page .wpcf7-form > p:nth-of-type(-n+4) {
    flex: 0 0 100%;
    max-width: 100%;
  }

  #top .dason-contact-page .wpcf7-form {
    gap: 15px;
  }

  #top .dason-contact-page .wpcf7-text,
  #top .dason-contact-page .wpcf7-email,
  #top .dason-contact-page .wpcf7-tel,
  #top .dason-contact-page .wpcf7-select {
    height: 50px;
    min-height: 50px;
    font-size: 15px;
  }

  #top .dason-contact-page .wpcf7-textarea {
    height: 200px;
    min-height: 200px;
    font-size: 15px;
  }

  #top .dason-contact-page .wpcf7-form > p:last-of-type {
    text-align: center;
  }

  #top .dason-contact-page .wpcf7-submit {
    width: 100%;
    max-width: 320px;
  }

  
}

@media (max-width: 767px) {
  #top .dason-contact-page .dason-contact-hero__overlay strong {
    font-size: 34px;
  }
}

@media (max-width: 500px) {
  #top .dason-contact-page .wpcf7-form label {
    font-size: 14px;
  }

  #top .dason-contact-page .wpcf7-form label small {
    font-size: 12px;
  }

  #top .dason-contact-page .wpcf7-text,
  #top .dason-contact-page .wpcf7-email,
  #top .dason-contact-page .wpcf7-tel,
  #top .dason-contact-page .wpcf7-select {
    height: 46px;
    min-height: 46px;
    font-size: 14px;
  }

  #top .dason-contact-page .wpcf7-textarea {
    height: 160px;
    min-height: 160px;
    font-size: 14px;
  }
}
