/* Основные стили секции контактов */
.contacts-section {
  padding: 5vw 0;
  background-color: var(--bg-color);
}

.contacts-section__container {
  width: 80vw;
  margin: 0 auto;
}

.contacts-section__subtitle {
  font-size: 2vw;
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin: 0 0 3vw 0;
}

.contacts-section__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4vw;
  align-items: start;
}

.iframe {
	width: 100% !important;
	height: 35vw !important;
}

/* Левая колонка */
.contacts-section__left {
  display: flex;
  flex-direction: column;
  gap: 3vw;
}

.contacts-info {
  display: flex;
  flex-direction: column;
  gap: 2vw;
}

.contacts-info__item {
  display: flex;
  align-items: flex-start;
  gap: 1vw;
}

.contacts-info__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5vw;
  height: 2.5vw;
  flex-shrink: 0;
  margin-top: 0.3vw;
  color: var(--color-primary);
}

.contacts-info__icon svg {
  width: 100%;
  height: 100%;
}

.contacts-info__content {
  display: flex;
  flex-direction: column;
  gap: 0.3vw;
  text-align: left;
}

.contacts-info__label {
  font-size: 1vw;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.contacts-info__value {
  font-size: 1.1vw;
  font-weight: var(--font-weight-normal);
  color: var(--color-text);
  line-height: 1.4;
}

.contacts-info__link {
  font-size: 1.1vw;
  font-weight: var(--font-weight-medium);
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.contacts-info__link:hover,
.contacts-info__link:focus {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

/* Реквизиты */
.contacts-info__requisites {
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: 2vw;
  background-color: var(--color-bg-secondary);
}

.contacts-info__requisites-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5vw;
}

.contacts-info__requisites-title {
  font-size: 1.2vw;
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin: 0;
}

.contacts-info__requisites-actions {
  display: flex;
  gap: 0.5vw;
}

.contacts-info__action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2vw;
  height: 2vw;
  background-color: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--border-radius-sm);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}

.contacts-info__action-btn:hover,
.contacts-info__action-btn:focus {
  background-color: var(--color-primary-hover);
}

.contacts-info__action-btn svg {
  width: 60%;
  height: 60%;
}

.contacts-info__requisites-content {
  font-size: 0.9vw;
  color: var(--color-text);
  line-height: 1.5;
}

.contacts-info__requisites-content p {
  margin: 0;
}

/* Мессенджеры в секции контактов */
.contacts-info__messengers {
  display: flex;
  gap: 1vw;
  margin-top: 0.5vw;
}

.contacts-info__messenger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5vw;
  height: 2.5vw;
  border-radius: var(--border-radius-md);
  background-color: rgba(6, 150, 238, 0.1);
  transition: var(--transition-fast);
  border: none;
  cursor: pointer;
  text-decoration: none;
}

.contacts-info__messenger:hover,
.contacts-info__messenger:focus {
  background-color: rgba(6, 150, 238, 0.2);
  transform: scale(1.05);
  text-decoration: none;
}

.contacts-info__messenger-icon {
  width: 1.5vw;
  height: 1.5vw;
  display: block;
}

/* Социальные сети в контактах */
.contacts-info__social {
  display: flex;
  gap: 1vw;
  margin-top: 0.5vw;
}

.contacts-info__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5vw;
  height: 2.5vw;
  border-radius: var(--border-radius-md);
  background-color: rgba(6, 150, 238, 0.1);
  transition: var(--transition-fast);
  border: none;
  cursor: pointer;
  text-decoration: none;
}

.contacts-info__social-link:hover,
.contacts-info__social-link:focus {
  background-color: rgba(6, 150, 238, 0.2);
  transform: scale(1.05);
  text-decoration: none;
}

.contacts-info__social-icon {
  width: 1.5vw;
  height: 1.5vw;
  display: block;
}

/* Правая колонка - форма */
.contacts-section__right {
  background-color: var(--color-bg-secondary);
  border-radius: var(--border-radius-lg);
  padding: 3vw;
}

.contacts-form {
  display: flex;
  flex-direction: column;
  gap: 1vw;
}

.contacts-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.5vw;
}

.contacts-form__label {
  font-size: 1vw;
  font-weight: var(--font-weight-medium);
  color: var(--color-text);
}

.contacts-form__input,
.contacts-form__textarea {
  padding: 1vw;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  font-size: 1vw;
  font-family: var(--font-family);
  transition: border-color var(--transition-fast);
}

.contacts-form__input:focus,
.contacts-form__textarea:focus {
  outline: none;
  border-color: var(--color-primary);
}

.contacts-form__textarea {
  resize: vertical;
  min-height: 8vw;
}

.contacts-form__checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 0.8vw;
  cursor: pointer;
  font-size: 0.9vw;
  color: var(--color-text);
  line-height: 1.4;
}

.contacts-form__checkbox {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.contacts-form__checkbox-custom {
  position: relative;
  width: 1.2vw;
  height: 1.2vw;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-sm);
  background-color: white;
  transition: all var(--transition-fast);
  flex-shrink: 0;
  margin-top: 0.2vw;
}

.contacts-form__checkbox:checked + .contacts-form__checkbox-custom {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.contacts-form__checkbox:checked + .contacts-form__checkbox-custom::after {
  content: '';
  position: absolute;
  top: 0.2vw;
  left: 0.4vw;
  width: 0.4vw;
  height: 0.7vw;
  border: solid white;
  border-width: 0 0 0.15vw 0.15vw;
  transform: rotate(45deg);
}

.contacts-form__checkbox-text {
  margin: 0;
}

.contacts-form__submit {
  background-color: var(--color-primary);
  color: white;
  border: none;
  border-radius: var(--border-radius-md);
  padding: 1.2vw 2vw;
  font-size: 1.1vw;
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  transition: background-color var(--transition-fast);
  align-self: flex-start;
}

.contacts-form__submit:hover,
.contacts-form__submit:focus {
  background-color: var(--color-primary-hover);
}

/* Заголовок страницы */
.page-header {
  padding: 3vw 0;
  text-align: center;
}

.page-header__container {
  width: 80vw;
  margin: 0 auto;
}

.page-header__title {
  font-weight: 900;
  font-size: 3.125vw;
  line-height: 4.1666666667vw;
  letter-spacing: 0.04em;
  text-align: center;
  margin: 0;
  color: var(--color-text);
}

/* Секции карт */
.map-section {
  padding: 5vw 0;
  background-color: var(--color-bg-secondary);
}

.map-section__container {
  width: 80vw;
  margin: 0 auto;
  text-align: center;
}

.map-section__title {
  font-size: 2.5vw;
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin: 0 0 3vw 0;
}

.map-section__map {
  width: 80vw;
  height: 800px;
  margin: 0 auto;
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-medium);
  border: 1px solid var(--color-border);
}

.map-section__map iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* Секция фасада */
.facade-section {
  padding: 5vw 0;
  background-color: var(--bg-color);
}

.facade-section__container {
  width: 80vw;
  margin: 0 auto;
  text-align: center;
}

.facade-section__title {
  font-size: 2.5vw;
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin: 0 0 3vw 0;
}

.facade-section__placeholder {
  width: 80vw;
  height: 30vw;
  margin: 0 auto;
  border: 2px dashed var(--color-border);
  border-radius: var(--border-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-bg-secondary);
}

.facade-section__placeholder-content {
  text-align: center;
  color: var(--text-light);
}

.facade-section__placeholder-content svg {
  margin-bottom: 1vw;
}

.facade-section__placeholder-content p {
  margin: 0;
  font-size: 1.2vw;
  font-weight: var(--font-weight-medium);
}

/* SEO секция */
.seo-section {
  padding: 5vw 0;
  background-color: var(--color-bg-secondary);
}

.seo-section__container {
  width: 80vw;
  margin: 0 auto;
}

.seo-section__content {
  width: 80vw;
  margin: 0 auto;
}

.seo-section__content h2 {
  font-size: 2vw;
  font-weight: var(--font-weight-bold);
  color: var(--color-text);
  margin: 0 0 2vw 0;
}

.seo-section__content h3 {
  font-size: 1.5vw;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  margin: 2vw 0 1vw 0;
}

.seo-section__content p {
  font-size: 1vw;
  color: var(--color-text);
  line-height: 1.6;
  margin: 0 0 1.5vw 0;
}

.seo-section__content ul {
  font-size: 1vw;
  color: var(--color-text);
  line-height: 1.6;
  margin: 0 0 1.5vw 0;
  padding-left: 2vw;
}

.seo-section__content li {
  margin-bottom: 0.5vw;
}

/* ============================================
   МОБИЛЬНАЯ АДАПТАЦИЯ
   ============================================ */

/* Планшеты и маленькие ноутбуки (до 1024px) */
@media (max-width: 1024px) {
  .contacts-section__container,
  .page-header__container,
  .map-section__container,
  .facade-section__container,
  .seo-section__container {
    width: 90vw;
  }

  .contacts-section__grid {
    gap: 3vw;
  }

  .contacts-section__subtitle {
    font-size: 2.5vw;
    margin-bottom: 2.5vw;
  }

  .page-header__title {
    font-size: 4vw;
    line-height: 5vw;
  }

  .map-section__title,
  .facade-section__title {
    font-size: 3vw;
    margin-bottom: 2.5vw;
  }

  .contacts-info__icon {
    width: 3vw;
    height: 3vw;
  }

  .contacts-info__label {
    font-size: 1.2vw;
  }

  .contacts-info__value,
  .contacts-info__link {
    font-size: 1.3vw;
  }

  .contacts-info__requisites-title {
    font-size: 1.4vw;
  }

  .contacts-form__label {
    font-size: 1.2vw;
  }

  .contacts-form__input,
  .contacts-form__textarea {
    font-size: 1.2vw;
    padding: 1.2vw;
  }

  .contacts-form__submit {
    font-size: 1.3vw;
    padding: 1.4vw 2.2vw;
  }
}

/* Планшеты портретная ориентация (до 768px) */
@media (max-width: 768px) {
  .contacts-section {
    padding: 6vw 0;
  }

  .contacts-section__container,
  .page-header__container,
  .map-section__container,
  .facade-section__container,
  .seo-section__container {
    width: 92vw;
  }

  .contacts-section__grid {
    grid-template-columns: 1fr;
    gap: 5vw;
  }

  .contacts-section__subtitle {
    font-size: 3.5vw;
    margin-bottom: 3vw;
  }

  .page-header {
    padding: 4vw 0;
  }

  .page-header__title {
    font-size: 5vw;
    line-height: 6vw;
  }

  .contacts-info {
    gap: 3vw;
  }

  .contacts-info__item {
    gap: 2vw;
  }

  .contacts-info__icon {
    width: 4vw;
    height: 4vw;
  }

  .contacts-info__label {
    font-size: 2vw;
  }

  .contacts-info__value,
  .contacts-info__link {
    font-size: 2.2vw;
  }

  .contacts-info__requisites {
    padding: 3vw;
  }

  .contacts-info__requisites-title {
    font-size: 2.2vw;
  }

  .contacts-info__requisites-content {
    font-size: 1.8vw;
  }

  .contacts-info__action-btn {
    width: 3vw;
    height: 3vw;
  }

  .contacts-info__messenger,
  .contacts-info__social-link {
    width: 4vw;
    height: 4vw;
  }

  .contacts-info__messenger-icon,
  .contacts-info__social-icon {
    width: 2.5vw;
    height: 2.5vw;
  }

  .contacts-section__right {
    padding: 4vw;
  }

  .contacts-form {
    gap: 2vw;
  }

  .contacts-form__field {
    gap: 1vw;
  }

  .contacts-form__label {
    font-size: 2vw;
  }

  .contacts-form__input,
  .contacts-form__textarea {
    font-size: 2vw;
    padding: 2vw;
  }

  .contacts-form__textarea {
    min-height: 12vw;
  }

  .contacts-form__checkbox-label {
    font-size: 1.8vw;
    gap: 1.5vw;
  }

  .contacts-form__checkbox-custom {
    width: 2vw;
    height: 2vw;
    margin-top: 0.3vw;
  }

  .contacts-form__checkbox:checked + .contacts-form__checkbox-custom::after {
    top: 0.35vw;
    left: 0.65vw;
    width: 0.5vw;
    height: 1vw;
    border-width: 0 0.25vw 0.25vw 0;
  }

  .contacts-form__submit {
    font-size: 2.2vw;
    padding: 2.5vw 4vw;
    align-self: stretch;
  }

  .map-section {
    padding: 6vw 0;
  }

  .map-section__title,
  .facade-section__title {
    font-size: 4vw;
    margin-bottom: 3vw;
  }

  .map-section__map {
    width: 92vw !important;
    height: 50vw !important;
  }

  .facade-section {
    padding: 6vw 0;
  }

  .facade-section__placeholder {
    width: 92vw;
    height: 40vw;
  }

  .facade-section__placeholder-content p {
    font-size: 2vw;
  }

  .seo-section {
    padding: 6vw 0;
  }

  .seo-section__content h2 {
    font-size: 3.5vw;
    margin-bottom: 3vw;
  }

  .seo-section__content h3 {
    font-size: 2.5vw;
    margin: 3vw 0 2vw 0;
  }

  .seo-section__content p,
  .seo-section__content ul {
    font-size: 2vw;
    margin-bottom: 2.5vw;
  }

  .seo-section__content ul {
    padding-left: 4vw;
  }

  .seo-section__content li {
    margin-bottom: 1vw;
  }
}

/* Мобильные телефоны (до 480px) */
@media (max-width: 480px) {
  .contacts-section {
    padding: 8vw 0;
  }

  .contacts-section__container,
  .page-header__container,
  .map-section__container,
  .facade-section__container,
  .seo-section__container {
    width: 94vw;
  }

  .contacts-section__subtitle {
    font-size: 5vw;
    margin-bottom: 4vw;
  }

  .page-header {
    padding: 5vw 0;
  }

  .page-header__title {
    font-size: 6.5vw;
    line-height: 8vw;
  }

  .contacts-info {
    gap: 4vw;
  }

  .contacts-info__item {
    gap: 3vw;
  }

  .contacts-info__icon {
    width: 6vw;
    height: 6vw;
    margin-top: 0.5vw;
  }

  .contacts-info__label {
    font-size: 3.2vw;
  }

  .contacts-info__value,
  .contacts-info__link {
    font-size: 3.8vw;
  }

  .contacts-info__requisites {
    padding: 4vw;
  }

  .contacts-info__requisites-header {
    margin-bottom: 2.5vw;
  }

  .contacts-info__requisites-title {
    font-size: 4vw;
  }

  .contacts-info__requisites-content {
    font-size: 3.2vw;
  }

  .contacts-info__requisites-actions {
    gap: 1vw;
  }

  .contacts-info__action-btn {
    width: 5vw;
    height: 5vw;
  }

  .contacts-info__messengers,
  .contacts-info__social {
    gap: 2vw;
    margin-top: 1vw;
  }

  .contacts-info__messenger,
  .contacts-info__social-link {
    width: 7vw;
    height: 7vw;
  }

  .contacts-info__messenger-icon,
  .contacts-info__social-icon {
    width: 4.5vw;
    height: 4.5vw;
  }

  .contacts-section__right {
    padding: 5vw;
    border-radius: 2vw;
  }

  .contacts-form {
    gap: 3vw;
  }

  .contacts-form__field {
    gap: 1.5vw;
  }

  .contacts-form__label {
    font-size: 3.5vw;
  }

  .contacts-form__input,
  .contacts-form__textarea {
    font-size: 3.8vw;
    padding: 3vw;
    border-radius: 1.5vw;
  }

  .contacts-form__textarea {
    min-height: 20vw;
  }

  .contacts-form__checkbox-label {
    font-size: 3.2vw;
    gap: 2vw;
  }

  .contacts-form__checkbox-custom {
    width: 4vw;
    height: 4vw;
    margin-top: 0.5vw;
  }

  .contacts-form__checkbox:checked + .contacts-form__checkbox-custom::after {
    top: 0.7vw;
    left: 1.35vw;
    width: 0.9vw;
    height: 1.8vw;
    border-width: 0 0.35vw 0.35vw 0;
  }

  .contacts-form__submit {
    font-size: 4vw;
    padding: 3.5vw 5vw;
    border-radius: 1.5vw;
  }

  .map-section {
    padding: 8vw 0;
  }

  .map-section__title,
  .facade-section__title {
    font-size: 5.5vw;
    margin-bottom: 4vw;
  }

  .map-section__map {
    width: 94vw !important;
    height: 60vw !important;
    border-radius: 2vw;
  }

  .facade-section {
    padding: 8vw 0;
  }

  .facade-section__placeholder {
    width: 94vw;
    height: 50vw;
    border-radius: 2vw;
  }

  .facade-section__placeholder-content svg {
    width: 12vw;
    height: 12vw;
    margin-bottom: 2vw;
  }

  .facade-section__placeholder-content p {
    font-size: 3.5vw;
  }

  .seo-section {
    padding: 8vw 0;
  }

  .seo-section__content h2 {
    font-size: 5.5vw;
    margin-bottom: 4vw;
  }

  .seo-section__content h3 {
    font-size: 4.5vw;
    margin: 4vw 0 2.5vw 0;
  }

  .seo-section__content p,
  .seo-section__content ul {
    font-size: 3.5vw;
    margin-bottom: 3vw;
  }

  .seo-section__content ul {
    padding-left: 6vw;
  }

  .seo-section__content li {
    margin-bottom: 1.5vw;
  }
}

/* Очень маленькие мобильные устройства (до 360px) */
@media (max-width: 360px) {
  .contacts-section__subtitle {
    font-size: 5.5vw;
  }

  .page-header__title {
    font-size: 7vw;
    line-height: 8.5vw;
  }

  .contacts-info__icon {
    width: 7vw;
    height: 7vw;
  }

  .contacts-info__label {
    font-size: 3.5vw;
  }

  .contacts-info__value,
  .contacts-info__link {
    font-size: 4vw;
  }

  .contacts-info__requisites-title {
    font-size: 4.5vw;
  }

  .contacts-info__requisites-content {
    font-size: 3.5vw;
  }

  .contacts-form__label {
    font-size: 4vw;
  }

  .contacts-form__input,
  .contacts-form__textarea {
    font-size: 4vw;
  }

  .contacts-form__submit {
    font-size: 4.5vw;
  }

  .map-section__title,
  .facade-section__title {
    font-size: 6vw;
  }

  .seo-section__content h2 {
    font-size: 6vw;
  }

  .seo-section__content h3 {
    font-size: 5vw;
  }

  .seo-section__content p,
  .seo-section__content ul {
    font-size: 3.8vw;
  }
}