.global_body > section:not([class]):first-child {
  padding-top: 0;
}

.padding_box {
  margin-inline: calc(50% - 50vw);
}

.main_visual_wrapper {
  padding: 79px 0 15px 0;
  color: #1a5986;
  text-align: center;
}

h1 {
  font-size: 5.25vw;
  padding: 50px 0 15px 0;
  letter-spacing: 1px;
  font-weight: bold;
  line-height: 1.5;
}

/*
h1 {
  font-size: 6.25vw;
  padding: 50px 0 15px 0;
  letter-spacing: 1px;
  font-weight: bold;
  line-height: 1.5;
}

.h1_span_01 {
  letter-spacing: 3px;
  border-bottom: 2px solid #1a5986;
  padding-bottom: 5px;
}

.h1_span_02 {
  font-size: 3.75vw;
}
*/
.main_visual_box {
  display: flex;
  gap: clamp(10px, 3.13vw, 20px);
  align-items: center;
  justify-content: center;
  font-size: clamp(10px, 3.13vw, 15px);
  font-weight: 700;
}

.main_visual_box_content {
  width: clamp(235px,73.44vw,356px) ;
  display: grid;
  place-content: center;
  background: url("/tsushin/topics/2026/campaign/img/svg_01.svg") no-repeat center;
  background-size: cover;
  aspect-ratio: 467 / 90;
  padding-top: 5px;
}

.tag_01 {
  border-radius: 30px;
  display: grid;
  place-content: center;
  text-align: center;
  font-weight: 700;
  font-size: 16px;
  width: 150px;
  aspect-ratio: 21 / 5;
  background-color: #fff;
  border: 2px solid #000;
  margin-bottom: 30px;
}

.module_title-type04 > span {
  padding: 2px 55px 4px;
}

.box_02 {
  font-weight: 600;
  padding: 20px;
  text-align: center;
  border: 6px solid #000;
}

@media screen and (min-width: 768px) {
  .padding_box {
    padding: 0 38px 50px 38px;
  }

  .main_visual_wrapper {
    padding: 0 0 clamp(30px, 3.91vw, 100px) 0;
    background: url("/tsushin/img/briefing/regular/mainvisual_pic.png") no-repeat center;
    background-size: contain;
  }

  h1 {
    font-size: clamp(30px, 3.2vw, 76px);
    padding: 90px 0 19px 0;
    letter-spacing: 1px;
    line-height: 1.2
  }


/*
  h1 {
    font-size: clamp(34px, 4.43vw, 76px);
    padding: 90px 0 19px 0;
    letter-spacing: 1px;
    line-height: 1.2
  }

  .h1_span_01 {
    letter-spacing: 9px;
  }

  .h1_span_02 {
    font-size: clamp(20px, 2.6vw, 43px);
  }
*/
  .main_visual_box {
    gap: clamp(10px, 2.6vw, 30px);
    font-size: clamp(13px, 1.69vw, 21px);
    font-weight: 800;
  }

  .main_visual_box_content {
    width: clamp(300px, 39.06vw, 514px);
    padding-top: 10px;
  }
}

.tsushin_voice_box_wrapper {
  padding-inline: clamp(18px, 10vw, 150px);
}

.tsushin_voice_box {
  margin-top: 15px;
  display: flex;
  gap: 30px;
  align-items: center;
}

.tsushin_voice_logo img {
  max-width: 200px;
}

.tsushin_voice_text {
  display: flex;
  align-items: center;
  justify-content: end;
}

.tsushin_voice_text p {
  font-size: clamp(20px, 2.6vw, 24px);
  line-height: 1.5;
  font-weight: bold;
  color: #005781;
  background-color: #E1F7FF;
  width: 373px;
  height: 125px;
  padding-inline: 50px;
  border-radius: 22px;
  position: relative;
  margin-right: 0;
  display: grid;
  place-content: center;
  border-radius: 10vw;
}

.tsushin_voice_text p::before {
  content: '';
  position: absolute;
  right: auto;
  left: -50px;
  width: 66px;
  height: 34px;
  background: url(/tsushin/architecture/img/explanation/arrow_voice.png) no-repeat;
  background-size: contain;
  top: 40px;
  bottom: 0;
  margin: auto;
}

.tsushin_voice_box.even {
  justify-content: flex-end;
}

.tsushin_voice_box.even .tsushin_voice_text {
  justify-content: flex-start;
}

.tsushin_voice_box.even .tsushin_voice_text p::before {
  transform: scale(-1, 1);
  right: -50px;
  left: auto;
}

@media screen and (max-width: 767px) {

  .tsushin_voice_box_wrapper {
    padding-inline: 0;
  }

  .tsushin_voice_logo img {
    width: clamp(100px, 31.25vw, 150px);
  }

  .tsushin_voice_text p {
    font-size: clamp(14px, 4.38vw, 20px);
    background-color: #E1F7FF;
    width: clamp(170px, 53.13vw, 373px);
    height: 125px;
    padding-inline: 20px;
    border-radius: 15vw;
  }

  .tsushin_voice_text p::before {
    left: -50px;
    width: 66px;
    height: 34px;
  }

  .tsushin_voice_box {
    margin-top: 30px;
  }

  .tsushin_voice_text p {
    font-size: 16px;
    padding: 30px 18px;
  }
}