@charset "UTF-8";
/*============================================================
	COMPANY
============================================================*/
/*------------------------------------------------------------
	PAGE TITLE
------------------------------------------------------------*/
.pageTitle {
  background: url("../img/service/bg_service_01.png") center center / cover no-repeat;
  height: 480px;
}
/*------------------------------------------------------------
	ORGANIZATION
------------------------------------------------------------*/
#organization {
  padding: 80px 0 90px;
}
#organization .signature {
  font-weight: 400;
  font-size: 2.0rem;
  letter-spacing: 0.1em;
  color: #333;
}
#organization .chart g a {
    opacity: 1;
    transition: opacity 0.3s ease;
}
#organization .chart g a:hover {
    opacity: 0.5;
}
#main p {
  margin-bottom: 40px;
  line-height: 1.85;
  letter-spacing: 0.1em;
}
#main p.lead {
  font-weight: 400;
  font-size: 2.8rem;
  letter-spacing: 0.05em;
  color: #333;
  margin-bottom: 40px;
}
.photo {
  width: 265px;
  border-radius: 10px;
}
#main ul {
  padding: 0 15px;
}
#main li {
  letter-spacing: 0.1em;
}
@media all and (max-width: 896px) {
  h3.message {
    padding-bottom: 25px;
    font-size: 2.0rem;
    line-height: 1.4;
    letter-spacing: 0.1em;
  }
  h3.message::after {
    width: 40px;
  }
  #main p {
    font-size: 1.2rem;
  }
  #main p.lead {
    font-size: 1.6rem;
    margin-bottom: 20px;
  }
  #main ol {
    padding: 0;
  }
  #main li {
    font-size: 1.2rem;
  }
  .photo {
    width: auto;
    padding-bottom: 16px;
  }
}
/*------------------------------------------------------------
	SERVICE
------------------------------------------------------------*/
.service_01 {
  padding: 110px 0 100px;
  background: #e9f8ff;
}
.service_03 {
  padding: 110px 0 100px;
  background: #b8ebf2;
}
.service_02 {
  padding: 110px 0 100px;
  background: #fff;
}
.service_01 .box, .service_02 .box, .service_03 .box {
  display: block;
  width: 100%;
  text-align: center;
  margin: 0;
  padding: 36px 24px;
  border-right: dashed 1px #666;
}
.service_01 .box:first-child, .service_02 .box:first-child, .service_03 .box:first-child {
  border-radius: 20px 0 0 20px;
}
.service_01 .box:last-child, .service_02 .box:last-child, .service_03 .box:last-child {
  margin-right: 0;
  border-radius: 0 20px 20px 0;
  border-right: none;
}
.service_01 .box p.name, .service_02 .box p.name, .service_03 .box p.name {
  font-size: 1.9rem;
  font-weight: 500;
  line-height: 1.6em;
  letter-spacing: 0.1;
  color: #1264c0;
  margin: 24px 0 16px !important;
}
.service_01 .box p, .service_02 .box p, .service_03 .box p {
  font-size: 1.3rem;
  line-height: 1.8em;
  color: #333;
}
.service_01 .box img, .service_02 .box img, .service_03 .box img {
  width: 120px;
  padding-top: 30px;
}
.service_01 .box, .service_03 .box {
  background: #fff;
}
.service_02 .box {
  background: #fafafa;
}
.service_01 .solo, .service_02 .solo, .service_03 .solo {
  border-radius: 20px !important;
    }
@media all and (max-width: 896px) {
  .service_01, .service_02, .service_03 {
    padding: 60px 0 50px;
  }
  .service_01 .box, .service_02 .box, .service_03 .box {
    display: block;
    width: auto;
    padding: 12px 8px;
    border-right: none;
    border-bottom: dashed 1px #666;
  }
  .service_01 .box:first-child, .service_02 .box:first-child, .service_03 .box:first-child {
    border-radius: 10px 10px 0 0;
  }
  .service_01 .box:last-child, .service_02 .box:last-child, .service_03 .box:last-child {
    margin-right: 0;
    border-radius: 0 0 10px 10px;
    border-bottom: none;
  }
  .service_01 .box p.name, .service_02 .box p.name, .service_03 .box p.name {
    margin: 12px 0 12px !important;
  }
}
/*------------------------------------------------------------
	WELFARE PROGRAM
------------------------------------------------------------*/
#welfareprogram {
  padding: 110px 0 100px;
  background: #b8ebf2;
}
#welfareprogram ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
}
#welfareprogram li {
  display: block;
  width: 27%;
  height: 270px;
  padding: 3%;
  background: #fff;
  text-align: left;
  font-size: 1.4rem;
  line-height: 1.8;
}
#welfareprogram li span {
  display: block;
  font-weight: 600;
  margin: 24px 0 12px;
  text-align: center;
  font-size: 1.8rem;
}
#welfareprogram li.bTop {
  border-top: 1px dotted #333;
}
#welfareprogram li.bRight {
  border-right: 1px dotted #333;
}
#welfareprogram li.bBottom {
  border-bottom: 1px dotted #333;
}
#welfareprogram li.bLeft {
  border-left: 1px dotted #333;
}
/*------------------------------------------------------------
	PHILOSOPHY
------------------------------------------------------------*/
#philosophy {
  padding: 110px 0 100px;
  border-bottom: 1px solid #dadada;
}
#philosophy .title {
  display: flex;
  align-items: center;
}
#philosophy .title li::marker {
  color: #1264BE;
}
#philosophy .title div.head {
  width: 320px;
}
#philosophy h4 {
  font-size: 2.1rem;
  font-weight: 500;
  color: #0053a7;
  letter-spacing: 0.1em;
  padding-bottom: 10px;
}
#philosophy .title span {
  font-size: 1.4rem;
  font-weight: 400;
  color: #333;
  letter-spacing: 0.05em;
  margin-bottom: 0;
}
#philosophy .box {
  background: #f3f7fd;
  border-radius: 10px;
}
#philosophy .box p {
  font-weight: 400;
}
#philosophy .box p:last-child {
  margin-bottom: 0;
}
#philosophy .box li {
  font-weight: 400;
  margin-bottom: 0;
  padding-bottom: 0;
}
#philosophy ul {
  padding: 0;
}