.contact__grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 60px; align-items: start; }

/* ---- Info column ---- */
.contact-info__item {
  display: flex; align-items: flex-start; gap: 18px;
  padding: 24px 0; border-bottom: 1px solid #ececec;
}
.contact-info__item:last-of-type { border-bottom: none; }
.contact-info__icon {
  width: 52px; height: 52px; background: var(--red); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.contact-info__icon svg { width: 22px; height: 22px; fill: var(--white); }
.contact-info__label { font-family: var(--font-h); font-size: 11px; letter-spacing: 2.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.contact-info__value { font-size: 15px; font-weight: 500; color: var(--black); line-height: 1.5; }

/* ---- Social links ---- */
.contact-social { display: flex; gap: 10px; margin-top: 28px; }
.contact-social a {
  width: 40px; height: 40px; border: 1.5px solid #ddd;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-family: var(--font-h); font-weight: 700;
  color: var(--muted); transition: var(--ease);
}
.contact-social a:hover { background: var(--red); border-color: var(--red); color: var(--white); }

/* ---- Hours card ---- */
.contact-hours {
  background: var(--dark); padding: 28px; margin-top: 32px;
}
.contact-hours__title { font-family: var(--font-h); font-size: 14px; letter-spacing: 2px; text-transform: uppercase; color: var(--white); margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.contact-hours__row { display: flex; justify-content: space-between; font-size: 13px; color: rgba(255,255,255,0.55); padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.contact-hours__row:last-child { border-bottom: none; }
.contact-hours__row span:last-child { color: var(--red); font-weight: 500; }

/* ---- Form ---- */
.contact-form { background: var(--gray-bg); padding: 40px; }
.contact-form__title { font-family: var(--font-h); font-size: 22px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--black); margin-bottom: 28px; padding-bottom: 16px; border-bottom: 2px solid var(--red); }

.form-group { margin-bottom: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px; }

.form-group label,
.form-row label {
  display: block; font-family: var(--font-h); font-size: 11px;
  letter-spacing: 2px; text-transform: uppercase;
  color: var(--muted); margin-bottom: 8px;
}

.form-group input,
.form-group select,
.form-group textarea,
.form-row input,
.form-row select {
  width: 100%; padding: 13px 16px;
  border: 1.5px solid #e0e0e0; background: var(--white);
  font-family: var(--font-b); font-size: 14px;
  color: var(--black); outline: none;
  transition: border-color var(--ease);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus,
.form-row input:focus,
.form-row select:focus { border-color: var(--red); }

.form-group textarea { resize: vertical; min-height: 120px; }

.form-submit { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 8px; }
.form-msg { font-size: 14px; color: var(--red); display: none; }
.form-msg.visible { display: block; }

/* ---- Map placeholder ---- */
.contact-map {
  width: 100%; height: 380px; background: #e8e8e8;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  margin-top: 60px;
}
.contact-map iframe { width: 100%; height: 100%; border: none; }
.contact-map__pin {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  background: var(--red); color: var(--white);
  font-family: var(--font-h); font-size: 13px; letter-spacing: 2px; text-transform: uppercase;
  padding: 12px 24px;
}

/* ---- Responsive ---- */
@media (max-width: 1024px) { .contact__grid { grid-template-columns: 1fr; } }
@media (max-width: 768px)  { .form-row { grid-template-columns: 1fr; } .contact-form { padding: 28px 20px; } }
