/* kontaktbox-neu.css v1.2 (2025-10-17 17:39:28)
   - Verfeinertes Mobile-Verhalten (Berlin in 2. Zeile, kleinerer Font auf XS)
   - Stärkerer Schatten, leicht mehr Innenabstand
   - Farben kompatibel zum TM-Rot (#e30613)
   - Kapselung über Klassen (.tm-kontakt-*) zur Kollisionsvermeidung
*/

.tm-kontakt-outer{
  width:100%;
  margin:22px auto;
  padding:0 20px;
  max-width:1200px;
  box-sizing:border-box;
}

.tm-kontakt{
  display:flex;
  gap:16px;
  align-items:center;
  justify-content:flex-start;
  flex-wrap:nowrap;
  padding:18px;
  background:#fff;
  border:2px solid #d60000;
  border-radius:12px;
  box-sizing:border-box;
  overflow:hidden;
  box-shadow:0 8px 24px rgba(0,0,0,.10);
}
.tm-kontakt > *{box-sizing:border-box;margin:0}

.tm-kontakt .tm-media{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.tm-kontakt .tm-media img{
  max-width:100%;
  height:auto;
  border-radius:8px;
  display:block;
}

.tm-kontakt .tm-body{
  flex:1 1 420px;
  min-width:280px;
}
.tm-kontakt h3{
  color:#d60000;
  font-size:22px;
  font-weight:700;
  margin:0 0 6px;
}
.tm-kontakt p{margin:0 0 8px;line-height:1.6}

.tm-tel{
  font-size:18px;
  font-weight:700;
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  align-items:center;
  word-break:normal;
  white-space:normal;
}
.tm-tel .sep{opacity:.6}
.tm-tel a{color:inherit;text-decoration:none}

.tm-btn{
  display:inline-block;
  padding:10px 20px;
  background:#e30613;
  color:#fff;
  border-radius:12px;
  text-decoration:none;
  font-weight:700;
  line-height:1;
}

/* Telefon-/Icon-Reset gegen Theme/Plugin-Overlays auf tel:-Links */
a[href^="tel:"],a[href^="tel:"]::before,a[href^="tel:"]::after,
.fa-phone:before,.dashicons-phone:before,[class*="icon-phone"]:before,svg.phone{
  content:none!important;
  background:none!important;
  box-shadow:none!important;
  width:auto!important;height:auto!important;
  display:inline!important;
}

/* Tablet/Phone: Spalten -> Zeilen */
@media (max-width:980px){
  .tm-kontakt{
    flex-direction:column;
    align-items:stretch;
    flex-wrap:nowrap;
  }
  .tm-kontakt .tm-media{
    flex:0 1 auto;
    width:100%;
  }
  .tm-kontakt .tm-media img{
    width:100%;
    max-width:320px;
    height:auto;
    margin:0 auto;
  }
  .tm-kontakt .tm-body{
    flex:0 1 auto;
    width:100%;
    min-width:0;
  }
}

/* Phone schmal: Berlin unter Herford, Trenner ausblenden, leichte Typo-Reduktion */
@media (max-width:560px){
  .tm-tel{display:block;line-height:1.55;font-size:17px}
  .tm-tel .sep{display:none}
  .tm-tel .city-berlin{display:block;margin-top:2px}
}
