/* css/sections/contacts.css */

/* =========================
   CONTACTS SECTION
   ========================= */

.contacts{
  padding:100px 0;
  background:var(--page-bg);
  position:relative;
}

/* =========================
   HEADER (centered)
   ========================= */

.contacts__header{
  text-align:center;
  margin-bottom:44px;
}

.contacts__title{
  font-size:var(--text-6xl);
  font-weight:var(--font-black);
  color:var(--primary-dark);
  margin:0 0 12px;
  font-family:var(--font-display);
  letter-spacing:-1px;
  line-height:1.15;
}

.contacts__subtitle{
  font-size:var(--text-lg);
  color:var(--text-muted);
  margin:0 auto;
  font-weight:var(--font-semibold);
  line-height:1.5;
  max-width:640px;
}

/* =========================
   LAYOUT: MAP (left) + INFO (right)
   ========================= */

.contacts__layout{
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap:24px;
  align-items:stretch;
  min-height:460px;
}

/* MAP */
.contacts__map-wrapper{
  background:#fff;
  border:1.5px solid rgba(20, 20, 20, 0.08);
  border-radius:var(--radius-18);
  overflow:hidden;
  box-shadow:0 8px 22px rgba(0,0,0,0.05);
  height:100%;
}

.contacts__map{
  width:100%;
  height:100%;
  min-height:0;
  position:relative;
}

/* RIGHT COLUMN */
.contacts__info{
  display:flex;
  flex-direction:column;
  gap:20px;
  height:100%;
}

/* =========================
   INFO CHIPS — GREEN STYLE
   ========================= */

.contacts-chip{
  background:linear-gradient(
    135deg,
    rgba(31,143,74,0.06),
    rgba(31,143,74,0.02)
  );
  border:2px solid rgba(31,143,74,0.25);
  border-radius:var(--radius-16);
  padding:22px 22px 20px;
  position:relative;
  flex:1 1 0;
  min-height:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  box-shadow:0 6px 18px rgba(31,143,74,0.10);
  transition:all var(--transition-base);
}

.contacts-chip:hover{
  border-color:rgba(31,143,74,0.45);
  box-shadow:0 12px 28px rgba(31,143,74,0.22);
  transform:translateY(-2px);
}

/* Курсор pointer для кликабельных чипов */
.contacts-chip[data-copy] {
  cursor:pointer;
}

.contacts-chip__label{
  font-size:12px;
  color:var(--text-muted);
  font-weight:var(--font-bold);
  text-transform:uppercase;
  letter-spacing:0.8px;
  margin:0 0 10px;
  text-align:center;
}

.contacts-chip__value{
  font-size:var(--text-xl);
  color:var(--primary-dark);
  font-weight:var(--font-black);
  line-height:1.25;
  text-align:center;
  text-decoration:none;
}

a.contacts-chip__value:hover{
  color:var(--primary);
}

/* Телефон - десктоп/мобайл */
.contacts-chip__phone-desktop {
  display:inline-block;
  cursor:pointer;
}

.contacts-chip__phone-mobile {
  display:none;
}

@media (max-width:768px) {
  .contacts-chip__phone-desktop {
    display:none;
  }
  
  .contacts-chip__phone-mobile {
    display:inline-block;
  }
}

/* =========================
   MAP PIN — КАК У ЯНДЕКСА (красная капля + белый круг)
   ========================= */

.map-pin{
  width:34px;
  height:34px;
  position:relative;
  cursor:pointer;
  transform:translateZ(0);
}

.map-pin::before{
  content:'';
  position:absolute;
  inset:0;
  width:28px;
  height:28px;
  left:50%;
  top:2px;
  transform:translateX(-50%) rotate(-45deg);
  transform-origin:center center;
  background:#E53935;
  border-radius:50% 50% 50% 0;
  box-shadow:
    0 10px 22px rgba(0,0,0,0.22),
    0 2px 0 rgba(255,255,255,0.35) inset;
}

.map-pin::after{
  content:'';
  position:absolute;
  width:10px;
  height:10px;
  left:50%;
  top:11px;
  transform:translateX(-50%);
  background:#fff;
  border-radius:50%;
  box-shadow:0 0 0 1px rgba(0,0,0,0.08);
}

/* =========================
   YANDEX MAP CONTROLS — под стиль сайта
   ========================= */

.contacts__map-wrapper .ymaps-2-1-79-float-button,
.contacts__map-wrapper .ymaps-2-1-79-zoom__button,
.contacts__map-wrapper .ymaps-2-1-79-fullscreen__control{
  background:rgba(255,255,255,0.96) !important;
  border:1.5px solid rgba(20,20,20,0.10) !important;
  border-radius:12px !important;
  box-shadow:0 8px 22px rgba(0,0,0,0.08) !important;
  backdrop-filter:saturate(160%) blur(10px);
}

.contacts__map-wrapper .ymaps-2-1-79-zoom__button:after,
.contacts__map-wrapper .ymaps-2-1-79-float-button:after{
  display:none !important;
}

.contacts__map-wrapper .ymaps-2-1-79-float-button:hover,
.contacts__map-wrapper .ymaps-2-1-79-zoom__button:hover,
.contacts__map-wrapper .ymaps-2-1-79-fullscreen__control:hover{
  border-color:rgba(31,143,74,0.28) !important;
  box-shadow:0 14px 30px rgba(0,0,0,0.12) !important;
  transform:translateY(-1px);
}

.contacts__map-wrapper .ymaps-2-1-79-zoom__button,
.contacts__map-wrapper .ymaps-2-1-79-float-button{
  color:var(--primary-dark) !important;
  font-weight:800 !important;
}

.contacts__map-wrapper .ymaps-2-1-79-controls__control{
  margin:12px !important;
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width:1024px){
  .contacts{
    padding:80px 0;
  }

  .contacts__layout{
    min-height:420px;
  }
}

@media (max-width:768px){
  .contacts{
    padding:60px 0;
  }

  .contacts__header{
    margin-bottom:32px;
  }

  .contacts__title{
    font-size:var(--text-5xl);
  }

  .contacts__layout{
    grid-template-columns:1fr;
    gap:20px;
    min-height:auto;
  }

  .contacts__map{
    min-height:320px;
  }

  .contacts-chip{
    min-height:auto;
    padding:20px;
    flex:0 0 auto;
  }
}

@media (max-width:640px){
  .contacts{
    padding:50px 0;
  }

  .contacts__title{
    font-size:var(--text-4xl);
  }

  .contacts__subtitle{
    font-size:var(--text-base);
  }

  .contacts-chip__value{
    font-size:var(--text-lg);
  }

  .contacts__map{
    min-height:280px;
  }
}