/* 联系页 · 传真/网站/邮箱/地址 + 地图 */

/* [hidden] 会被下方 display:flex 覆盖，必须用专用类控制显隐 */
.contact-detail-panel__map.td-is-hidden,
.contact-detail-panel__map-footer.td-is-hidden,
.contact-detail-panel__map-empty.td-is-hidden {
  display: none !important;
}

/* 地图高度变量：挂在面板与 map-wrap，避免地图移出面板后高度塌陷 */
.contact-detail-panel,
.contact-detail-panel__map-wrap {
  --map-h-min: clamp(200px, 26vw, 280px);
  --map-h-max: min(52vh, 420px);
  --map-h-boost: 1.2;
}

.contact-detail-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(16px, 3vw, 28px);
  align-items: stretch;
  margin: clamp(18px, 3.5vw, 28px) 0 clamp(24px, 4vw, 36px);
  padding: clamp(16px, 3vw, 24px);
  border-radius: var(--radius, 12px);
  background: var(--card);
  border: 1px solid color-mix(in srgb, var(--border) 80%, transparent);
  box-shadow: 0 1px 3px var(--shadow-card, rgba(0, 0, 0, 0.08));
}

.contact-detail-panel__info {
  min-width: 0;
}

.contact-detail-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.contact-detail-list__row {
  display: grid;
  grid-template-columns: minmax(4.5em, 5.5em) minmax(0, 1fr);
  gap: clamp(8px, 2vw, 14px);
  align-items: start;
  padding: clamp(8px, 1.8vw, 12px) 0;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 55%, transparent);
}

.contact-detail-list__row:last-child {
  border-bottom: none;
}

.contact-detail-list__row dt {
  margin: 0;
  font-weight: 700;
  color: var(--text);
  line-height: 1.45;
}

.contact-detail-list__row dd {
  margin: 0;
  color: var(--text);
  line-height: 1.55;
  word-break: break-word;
}

.contact-detail-list__row dd a {
  color: var(--accent2, #0284c7);
  text-decoration: none;
}

.contact-detail-list__row dd a:hover {
  text-decoration: underline;
}

.contact-detail-list__row dd.contact-detail-list__value--empty {
  color: var(--muted);
  font-style: italic;
  font-weight: 400;
}

.contact-detail-panel__intro {
  margin: clamp(12px, 2.5vw, 18px) 0 0;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--muted);
}

.contact-detail-panel__video {
  min-width: 0;
}

.contact-detail-panel__video-title {
  margin: 10px 0 0;
  font-size: inherit;
  font-weight: 700;
}

.contact-detail-panel__map-wrap {
  min-width: 0;
  width: 100%;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow: hidden;
  position: relative;
  isolation: isolate;
}

.contact-detail-panel__map {
  position: relative;
  flex: 1 1 auto;
  width: 100%;
  min-height: calc(var(--map-h-min) * var(--map-h-boost));
  max-height: calc(var(--map-h-max) * var(--map-h-boost));
  border-radius: calc(var(--radius, 12px) - 2px);
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  background: #e8ecef;
  contain: layout paint;
}

.contact-detail-panel__map iframe,
.contact-map-canvas {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.contact-map-canvas {
  z-index: 0;
  background: #e8ecef;
}

.contact-detail-panel__map .leaflet-container {
  position: absolute !important;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
  max-width: 100%;
  max-height: 100%;
  z-index: 0;
  font: inherit;
}

.contact-detail-panel__map .leaflet-pane,
.contact-detail-panel__map .leaflet-control-container {
  z-index: auto;
}

.contact-detail-panel__map-footer {
  flex: 0 0 auto;
  margin: 0;
  font-size: 0.8125rem;
  text-align: right;
}

.contact-detail-panel__map-footer a {
  color: var(--accent2, #0284c7);
  text-decoration: none;
}

.contact-detail-panel__map-footer a:hover {
  text-decoration: underline;
}

.contact-detail-panel__map-footer a[hidden] {
  display: none;
}

.contact-detail-panel__map-sep {
  margin: 0 0.35em;
  color: var(--muted);
}

.contact-detail-panel__map-empty:not(.td-is-hidden) {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
  margin: 0;
  padding: 16px;
  text-align: center;
  font-size: 0.9rem;
  color: var(--muted);
  border-radius: calc(var(--radius, 12px) - 2px);
  border: 1px dashed color-mix(in srgb, var(--border) 80%, transparent);
  background: color-mix(in srgb, var(--border) 12%, transparent);
}

/* 桌面：地图加高 20% 时不拉高左侧文字列（顶对齐） */
@media (min-width: 769px) {
  .contact-detail-panel {
    align-items: start;
  }

  .contact-detail-panel__map {
    flex: 0 0 auto;
    height: calc(var(--map-h-min) * var(--map-h-boost));
  }

  .contact-detail-panel__map-empty:not(.td-is-hidden) {
    flex: 0 0 auto;
    height: calc(var(--map-h-min) * var(--map-h-boost));
    min-height: calc(var(--map-h-min) * var(--map-h-boost));
  }
}

@media (max-width: 768px) {
  .contact-detail-panel {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .contact-detail-panel__video {
    order: 2;
    min-height: 0;
  }

  .contact-detail-panel__map,
  .contact-detail-panel__map-empty:not(.td-is-hidden) {
    flex: none;
    height: calc(clamp(192px, 50.4vw, 240px) * var(--map-h-boost));
    min-height: calc(clamp(192px, 50.4vw, 240px) * var(--map-h-boost));
  }
}

/* 留言左、地图右：桌面端地图列与留言区（含发送按钮）同高 */
.contact-grid--msg-map {
  align-items: stretch;
}

.contact-grid--msg-map #msg-block {
  min-width: 0;
}

.contact-grid--msg-map .contact-grid__map {
  grid-area: map;
  min-width: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 0;
}

@media (min-width: 801px) {
  .contact-grid--msg-map .contact-grid__map {
    align-self: stretch;
    height: 100%;
  }

  .contact-grid--msg-map .contact-detail-panel__map,
  .contact-grid--msg-map .contact-detail-panel__map-empty:not(.td-is-hidden) {
    flex: 1 1 0;
    width: 100%;
    min-height: 0;
    height: auto;
    max-height: none;
  }

  .contact-grid--msg-map .contact-detail-panel__map-footer {
    flex: 0 0 auto;
  }

  .contact-grid--msg-map .contact-detail-panel__map-empty:not(.td-is-hidden) {
    flex: 1 1 auto;
    min-height: 0;
  }
}

@media (max-width: 800px) {
  .contact-grid--msg-map {
    align-items: start;
  }

  .contact-grid--msg-map .contact-detail-panel__map,
  .contact-grid--msg-map .contact-detail-panel__map-empty:not(.td-is-hidden) {
    flex: 0 0 auto;
    height: calc(clamp(192px, 50vw, 260px) * var(--map-h-boost));
    min-height: calc(clamp(192px, 50vw, 260px) * var(--map-h-boost));
    max-height: calc(clamp(220px, 56vw, 300px) * var(--map-h-boost));
  }
}
