/**
 * Contacts Page
 * Layout и sticky левого сайдбара — из archive.css (как на category). Здесь только контент и форма.
 */

body.page-template-page-contacts-php {
  background-color: var(--color-background-alt);
  background-image: url(../../img/backing.png);
  background-repeat: repeat;
  background-position: top left;
}

.page-contacts__wrap {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 24px;
  border-radius: 24px;
  background: #F6F6F6;
}

.page-contacts__first-block {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

@media (min-width: 768px) {
  .page-contacts__first-block {
    flex-direction: row;
    align-items: flex-start;
    gap: 12px;
  }
}

@media (max-width: 1100px) {
  .page-contacts__first-block {
    flex-direction: column;
    align-items: center;
  }
}

.page-contacts__first-content {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.page-contacts__title {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 38px;
  line-height: 40px;
  color: #303030;
  margin: 0;
}

.page-contacts__text-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.page-contacts__greeting {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 18px;
  line-height: 24px;
  color: #6E4F95;
  margin: 0;
}

.page-contacts__description {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 16px;
  line-height: 20px;
  color: #4D4D4D;
  margin: 0;
}

.page-contacts__first-image {
  flex-shrink: 0;
}

.page-contacts__img {
  display: block;
  max-width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  .page-contacts__first-image {
    max-width: 280px;
  }
}

.page-contacts__get-in-touch {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.page-contacts__get-in-touch-title {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 26px;
  line-height: 32px;
  color: #303030;
  margin: 0;
}

.page-contacts__get-in-touch-text {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 16px;
  line-height: 20px;
  color: #4D4D4D;
  margin: 0;
}

.page-contacts__main {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.page-contacts__form-block {
  padding: 24px;
  border-radius: 18px;
  background: #FFFFFF;
  width: 100%;
  box-sizing: border-box;
}

.page-contacts__sms-block {
  display: flex;
  align-items: center;
  gap: 32px;
  padding: 24px;
  border-radius: 18px;
  background: #F5E8EF;
  width: 100%;
  box-sizing: border-box;
}

@media (max-width: 1165px) {
  .page-contacts__sms-block {
    flex-direction: column;
  }
}

.page-contacts__sms-block-img {
  flex-shrink: 0;
  max-width: 152px;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.page-contacts__sms-block-inner {
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.page-contacts__sms-block-head {
  display: flex;
  align-items: center;
  gap: 12px;
}

.page-contacts__sms-block-icon {
  flex-shrink: 0;
}

.page-contacts__sms-block-title {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 22px;
  line-height: 32px;
  color: #303030;
  margin: 0;
}

.page-contacts__sms-copy {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 16px;
  line-height: 20px;
  color: #4D4D4D;
  margin: 0;
}

.page-contacts__sms-copy--second {
  margin-top: -4px;
}

.page-contacts__form-intro {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 18px;
  line-height: 24px;
  color: #000000;
  text-align: center;
  margin: 0 0 16px;
}

.page-contacts__form-message {
  font-family: var(--font-primary);
  font-size: 16px;
  line-height: 22px;
  padding: 12px 16px;
  border-radius: 8px;
  margin: 0 0 16px;
}

.page-contacts__form-message--success {
  background: #e8f5e9;
  color: #2e7d32;
}

.page-contacts__form-message--error {
  background: #ffebee;
  color: #c62828;
}

.page-contacts__form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.page-contacts__field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.page-contacts__label {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 16px;
  line-height: 20px;
  color: #303030;
  margin: 0;
}

.page-contacts__input,
.page-contacts__textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 12px 16px;
  border: none;
  border-radius: 8px;
  background: #F6F6F6;
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
  color: #303030;
}

.page-contacts__input::placeholder,
.page-contacts__textarea::placeholder {
  color: #878787;
}

.page-contacts__field .iti {
  width: 100%;
  display: block;
}
.page-contacts__field .iti__flag-container {
  border-radius: 8px 0 0 8px;
}
.page-contacts__field .iti input {
  width: 100%;
  box-sizing: border-box;
  padding: 12px 16px 12px 52px;
  border: none;
  border-radius: 8px;
  background: #F6F6F6;
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
  color: #303030;
}
.page-contacts__field .iti input::placeholder {
  color: #878787;
}

.page-contacts__textarea-wrap {
  position: relative;
  border-radius: 8px;
  background: #F6F6F6;
  border: 1px solid var(--stroke-soft-200, #E2E4E9);
  box-shadow: 0 1px 2px 0 rgba(228, 229, 231, 0.24);
}

.page-contacts__field--message .page-contacts__label {
  margin-bottom: 0;
}

.page-contacts__textarea {
  display: block;
  width: 100%;
  min-height: 80px;
  max-height: 140px;
  padding: 12px 16px 36px;
  border: none;
  border-radius: 8px;
  background: transparent;
  resize: vertical;
}

.page-contacts__textarea-meta {
  position: absolute;
  right: 12px;
  bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
  pointer-events: none;
}

.page-contacts__char-count {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
  color: #878787;
}

.page-contacts__form-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 4px;
}

.page-contacts__agree {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  margin: 0;
  flex: 1;
  min-width: 0;
}

.page-contacts__checkbox {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  margin-top: 2px;
  border: 1px solid #8FB56C;
  border-radius: 2px;
  cursor: pointer;
  accent-color: #8FB56C;
}

.page-contacts__agree-text {
  width: 100%;
  box-sizing: border-box;
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 14px;
  line-height: 16px;
  color: #303030;
}

.page-contacts__privacy-link {
  color: #6E4F95;
  text-decoration: underline;
}

.page-contacts__privacy-link:hover {
  color: #5A3D7A;
}

.page-contacts__submit-btn {
  flex-shrink: 0;
  padding: 16px 24px;
  border: none;
  border-radius: 10px;
  background: #71BE76;
  color: #FFFFFF;
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 16px;
  line-height: 16px;
  cursor: pointer;
}

.page-contacts__submit-btn:hover {
  background: #5fa864;
}

/* Info block (Important Notice, Privacy & Safety, Contact Information) */
.page-contacts__info-block {
  padding: 24px;
  border-radius: 18px;
  background: #F6F6F6;
  width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

.page-contacts__info-title {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 32px;
  line-height: 32px;
  color: #303030;
  margin: 0 0 8px;
}

.page-contacts__info-title--privacy {
  margin-top: 24px;
  margin-bottom: 8px;
}

.page-contacts__info-text {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 16px;
  line-height: 20px;
  color: #000000;
  margin: 0;
}

.page-contacts__info-thanks {
  font-family: var(--font-primary);
  font-weight: 400;
  font-size: 16px;
  line-height: 20px;
  color: #4D4D4D;
  margin: 12px 0 0;
}

.page-contacts__info-section-title {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 26px;
  line-height: 32px;
  color: #303030;
  margin: 24px 0 0;
}

.page-contacts__info-contact-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}

.page-contacts__info-contact-icon {
  flex-shrink: 0;
}

.page-contacts__info-email {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 18px;
  line-height: 24px;
  color: #4D4D4D;
  text-decoration: none;
}

.page-contacts__info-email:hover {
  color: #303030;
  text-decoration: underline;
}

.page-contacts__info-footer {
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 16px;
  line-height: 16px;
  color: #6E4F95;
  margin: 24px 0 0;
}

/* ===========================================
 * RESPONSIVE (breakpoints: 576, 768, 992)
 * =========================================== */

/* Mobile: max-width 767px */
@media (max-width: 767px) {
  .page-contacts__wrap {
    padding: 16px;
    border-radius: 16px;
    gap: 12px;
  }

  .page-contacts__title {
    font-size: 28px;
    line-height: 32px;
  }

  .page-contacts__greeting {
    font-size: 18px;
    line-height: 24px;
  }

  .page-contacts__get-in-touch-title {
    font-size: 22px;
    line-height: 28px;
  }

  .page-contacts__main {
    gap: 24px;
  }

  .page-contacts__form-block {
    padding: 16px;
    border-radius: 14px;
  }

  .page-contacts__form-intro {
    font-size: 18px;
    line-height: 24px;
    margin-bottom: 16px;
  }

  .page-contacts__form-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .page-contacts__submit-btn {
    width: 100%;
  }

  .page-contacts__agree-text {
    max-width: 100%;
  }

  .page-contacts__sms-block {
    flex-direction: column;
    gap: 16px;
    padding: 16px;
    border-radius: 14px;
    align-items: flex-start;
  }

  .page-contacts__sms-block-img {
    max-width: 80px;
  }

  .page-contacts__sms-block-head {
    gap: 8px;
  }

  .page-contacts__sms-block-title {
    font-size: 18px;
    line-height: 26px;
  }

  .page-contacts__sms-copy {
    font-size: 16px;
    line-height: 20px;
  }

  .page-contacts__info-block {
    padding: 16px;
    border-radius: 14px;
  }

  .page-contacts__info-title {
    font-size: 32px;
    line-height: 32px;
    margin-bottom: 8px;
  }

  .page-contacts__info-title--privacy {
    margin-top: 20px;
    margin-bottom: 6px;
  }

  .page-contacts__info-text {
    font-size: 16px;
    line-height: 20px;
    margin-bottom: 8px;
  }

  .page-contacts__info-thanks {
    font-size: 16px;
    line-height: 20px;
    margin-top: 12px;
  }

  .page-contacts__info-section-title {
    font-size: 22px;
    line-height: 28px;
    margin-top: 20px;
  }

  .page-contacts__info-contact-row {
    flex-wrap: wrap;
    margin-top: 6px;
  }

  .page-contacts__info-email {
    font-size: 18px;
    line-height: 24px;
    word-break: break-word;
  }

  .page-contacts__info-footer {
    font-size: 16px;
    line-height: 16px;
    margin-top: 24px;
  }
}

/* Small mobile: max-width 575px (--breakpoint-sm - 1) */
@media (max-width: 575px) {
  .page-contacts__wrap {
    padding: 24px 16px;
    border-radius: 16px;
    gap: 16px;
  }

  .page-contacts__title {
    font-size: 24px;
    line-height: 28px;
  }

  .page-contacts__get-in-touch-title {
    font-size: 26px;
    line-height: 32px;
  }

  .page-contacts__form-block,
  .page-contacts__sms-block,
  .page-contacts__info-block {
    padding: 24px 16px;
    border-radius: 16px;
  }

  .page-contacts__agree-text {
    font-size: 12px;
    line-height: 16px;
  }

  .page-contacts__agree-line-break {
    display: block;
  }

  .page-contacts__main {
    gap: 24px;
  }

  .page-contacts__sms-block {
    gap: 32px;
  }



  .page-contacts__sms-block-img {
    max-width: 100%;
    height: 177px;
  }

  .page-contacts__sms-block-title {
    font-size: 22px;
    line-height: 32px;
  }

  .page-contacts__info-title {
    font-size: 20px;
    line-height: 26px;
    margin-bottom: 8px;
  }

  .page-contacts__info-section-title {
    font-size: 26px;
    line-height: 32px;
    margin-top: 24px;
  }

  .page-contacts__info-contact-icon {
    width: 40px;
    height: 40px;
  }
}

/* Desktop: min-width 992px */
@media (min-width: 992px) {
  .page-contacts__wrap {
    padding: 24px;
  }

  .page-contacts__sms-block-img {
    max-width: 152px;
  }
}
