@charset "utf-8";

.beacon { max-width: 900px; margin: 0 auto; }
.beacon .kv { position: relative; margin: 0 auto 50px; }
.beacon .kv h2 { width: 100%; position: absolute; left: 0; top:0; background: rgba(255, 255, 255, .75); padding: 15px; }

.service_beacon_point { margin: 0 auto 50px; }
.service_beacon_point h2 { font-size: min(3.3vw,1.5rem); line-height: 1.5; margin: 0 auto 50px; color: #59AA46; }
.service_beacon_point h2 em { display: inline-block; font-size: min(3vw,1rem); line-height: 1.1; margin: 0 0 15px; padding: 5px 15px; background: #59AA46; color: #fff; font-weight: 600; border-radius: 5px; }
.service_beacon_point h2 small  { display: inline-block; font-size: min(3vw,1.2rem); line-height: 1.5;color: #111; font-weight: 500; }
.service_beacon_point .inr { background: #F2F3F3; padding: 30px 15px; text-align: center; }
.service_beacon_about { margin: 0 auto 50px; }
.service_beacon_about h2 { font-size: 1.2rem; color: #59AA46; padding: 0 0 10px; margin: 0 0 25px; border-bottom: 2px solid #59AA46; }
.service_beacon_about > p { margin: 0 0 25px; }
.service_beacon_about .inr { display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between;  }
.service_beacon_about .inr dl { width: calc((100% - 20px) / 2); border: 1px solid #ccc;  border-radius: 5px; overflow: hidden; }
.service_beacon_about .inr dl dt { background: #50AA80; color: #fff; text-align: center; padding: 5px; min-height: 80px; position: relative; display: flex; align-items: center; justify-content: center; }
.service_beacon_about .inr dl dt::before { counter-increment: number 1; content: counter(number) " "; line-height: 1; font-family: Arial, Helvetica, sans-serif; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: #56834B; border-radius: 100px; color: rgba(255, 255, 255, .9); font-size: 14px; position: absolute; left: 15px; top:calc(50% - 20px); }
.service_beacon_about .inr dl dt span { display: block; color: #fff; font-weight: 600; margin: 0 0 0 50px; }
.service_beacon_about .inr dl dd { padding: 15px; text-align: center; }
.service_beacon_about .inr dl dd img { width: 300px; margin: 15px auto 0; }
.service_beacon_melit { margin: 0 auto 50px; }
.service_beacon_melit h2 { font-size: 1.2rem; color: #59AA46; padding: 0 0 10px; margin: 0 0 25px; border-bottom: 2px solid #59AA46; }
.service_beacon_melit ul { display: flex; flex-wrap: wrap; justify-content: space-between; }
.service_beacon_melit li { width: calc((100% - 60px) / 3); border: 1px solid #ccc; border-radius: 5px; border-top: 5px solid #59AA46; border-radius: 5px; padding: 15px; text-align: center; }



@media screen and (max-width: 940px) {
  .service_beacon_point h2 { margin: 0 20px 50px;}
  .service_beacon_about { margin: 0 20px 50px; }
  .service_beacon_about .inr dl dt::before { left: 10px; }
  .service_beacon_melit { margin: 0 20px 50px; }
  .service_beacon_melit li { width: calc((100% - 20px) / 3);}
}

@media screen and (max-width: 640px) {
  .service_beacon_point h2 small br { display: none; }
  .service_beacon_about .inr { gap: 10px; }
  .service_beacon_about .inr dl { width: 100%; }
  .service_beacon_about .inr dl dd p br { display: none; }
  .service_beacon_melit ul { gap: 10px; }
  .service_beacon_melit ul li { width: 100%; }
}




