:root{
  --tmg-bg: #0f1013;
  --tmg-panel: #15171b;
  --tmg-text: #e6e7eb;
  --tmg-muted: #9aa0a6;
  --tmg-accent: #6aa4ff;
  --tmg-border: #23252b;
}

.tmg.tmg-dark{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  background: var(--tmg-bg);
  color: var(--tmg-text);
  padding: 14px;
  border-radius: 14px;
  border: 1px solid var(--tmg-border);
  height: var(--tmg-height, 70vh);
  box-shadow: 0 10px 30px rgba(0,0,0,0.4);
}

.tmg .tmg-map, .tmg .tmg-gallery{
  background: var(--tmg-panel);
  border-radius: 10px;
  border: 1px solid var(--tmg-border);
  overflow: hidden;
}

.tmg .tmg-map { min-height: 300px; }

.tmg .tmg-gallery{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 8px;
  padding: 10px;
  align-content: start;
}

.tmg .tmg-item{
  position: relative;
  margin: 0;
  outline: none;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid transparent;
  background: #0c0d10;
  cursor: pointer;
  transition: transform .12s ease, border-color .12s ease;
}

.tmg .tmg-item:focus-visible{
  border-color: var(--tmg-accent);
  box-shadow: 0 0 0 3px rgba(106,164,255,0.25);
}

.tmg .tmg-item img{
  width: 100%; height: 100%; object-fit: cover; display: block;
  aspect-ratio: 4/3;
  filter: saturate(0.95) contrast(1.05);
}

.tmg .tmg-item figcaption{
  position: absolute; left: 0; right: 0; bottom: 0;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.6));
  color: var(--tmg-text);
  font-size: 12px;
  padding: 6px 8px;
}

.tmg .tmg-item.is-active{
  transform: scale(1.02);
  border-color: var(--tmg-accent);
}

.tmg .tmg-controls{
  position: absolute;
  display: flex; gap: 8px;
  z-index: 10;
  right: 22px; bottom: 18px;
}

.tmg .tmg-controls button{
  background: var(--tmg-panel);
  color: var(--tmg-text);
  border: 1px solid var(--tmg-border);
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 14px;
  cursor: pointer;
  transition: transform .12s ease, background .12s ease;
}
.tmg .tmg-controls button:hover{
  transform: translateY(-1px);
  background: #1b1d22;
}

@media (max-width: 900px){
  .tmg.tmg-dark{ grid-template-columns: 1fr; height: auto; }
  .tmg .tmg-map{ height: 42vh; }
}