@charset "UTF-8";
/*============================================================
	COMPANY
============================================================*/
/*------------------------------------------------------------
	PAGE TITLE
------------------------------------------------------------*/
.pageTitle {
  background: url("../img/company/bg_company_01.png") center center / cover no-repeat;
  height: 480px;
}
/*------------------------------------------------------------
	MESSAGE
------------------------------------------------------------*/
#message {
  padding: 80px 0 60px;
}
#message .signature {
  font-weight: 400;
  font-size: 2.0rem;
  letter-spacing: 0.1em;
  color: #333;
  margin-left: 20px;
}
#message p {
  margin-bottom: 22px;
  line-height: 1.85;
  letter-spacing: 0.1em;
  text-align: justify;
  text-justify: inter-ideograph;
}
#message p.lead {
  font-weight: 400;
  font-size: 2.8rem;
  letter-spacing: 0.05em;
  color: #333;
  margin-bottom: 40px;
}
#message .photo {
  width: 265px;
  border-radius: 10px;
}
#message ul {
  padding: 0 15px;
}
#message li {
  letter-spacing: 0.1em;
}
#message table ul {
  padding: 0;
}
@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;
  }
  #message p {
    font-size: 1.2rem;
  }
  #message p.lead {
    font-size: 1.6rem;
    margin-bottom: 20px;
  }
  #message ol {
    padding: 0;
  }
  #message li {
    font-size: 1.2rem;
  }
  #message .photo {
    width: auto;
    margin-bottom: 16px;
  }
}
/*------------------------------------------------------------
	ABOUT US
------------------------------------------------------------*/
#aboutus {
  padding: 110px 0 100px;
  background: #e9f8ff;
}
#aboutus .certification {
  display: flex;
  margin-top: 60px;
  align-self: center;
}
#aboutus .certification img {
  padding: 0 40px 0 20px;
  border-right: dashed 1px #999;
  width: 100px;
}
#aboutus .certification p {
  padding-left: 40px;
  margin: auto 0;
  font-size: 1.4rem;
}
#aboutus a {
  letter-spacing: 0.1em;
  line-height: 1.85;
  color: #2355a7;
}
#aboutus a:hover {
  border-bottom: solid 1px;   
  transition: .1s;
}
@media all and (max-width: 896px) {
  #aboutus .certification {
    display: block;
    text-align: center;
  }
  #aboutus .certification img {
    border: none;
    margin: 0 auto;
    padding: 0 0 20px;
    width: 160px;
  }
  #aboutus .certification p {
    padding: 0;
    text-align: left;
    font-size: 1.2rem;
  }
}
/*------------------------------------------------------------
	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;
  position: relative;
}
#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;
}
#welfareprogram li a:before {
  content: "";
  position: absolute;
  top: -1px;
  left: -1px;
  right: -1px;
  bottom: -1px;
}
#welfareprogram li a:after {
  content: "";
  bottom: 0;
  right: 0;
  border-top: 40px solid transparent;
  border-right: 40px solid #09a6bf;
  position: absolute;
  z-index: 100;
}
#welfareprogram li a:hover:after {
  opacity: 0.3;
}
@media all and (max-width: 896px) {
  #welfareprogram ul {
    display: block;
  }
  #welfareprogram li {
    height: auto;
    width: auto;
    padding: 20px 20px 24px;
    font-size: 1.2rem;
    border-bottom: 1px dotted #333;
  }
  #welfareprogram li:last-child {
    border-bottom: none;
  }
  #welfareprogram li span {
    margin: 0;
    text-align: left;
    font-size: 1.6rem;
  }
  #welfareprogram li.bRight {
    border-right: none;
  }
  #welfareprogram li.bLeft {
    border-left: none;
  }
}
*/
/*------------------------------------------------------------
	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: 480px;
}
#philosophy h4 {
  font-size: 2.1rem;
  font-weight: 500;
  color: #2355a7;
  letter-spacing: 0.1em;
}
#philosophy .head span {
    display: inline-block;
  padding-top: 10px;
}
#philosophy .title span {
  font-size: 1.4rem;
  font-weight: 400;
  color: #555;
  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;
}
#philosophy p.mmc {
  font-size: 2.0em;
  font-weight: 500;
  color: #333;
  letter-spacing: 0.15em;
  padding-bottom: 30px;
}
@media all and (max-width: 896px) {
  #philosophy .title {
    display: block;
    align-items: center;
  }
  #philosophy h4 {
    font-size: 1.6rem;
  }
  #philosophy .description {
    padding: 10px 0 5px;
  }
  #philosophy p.mmc {
  font-size: 1.5em;
  }
  #philosophy .box {
  margin: 0 0 30px;
  padding: 24px;
  font-size: 1.2rem;
  }
}
/*------------------------------------------------------------
	HEALTH MANAGEMENT
------------------------------------------------------------*/
#healthmanagement {
  padding: 110px 0 100px;
  background: #e9f8ff;
}
#healthmanagement p {
  margin-bottom: 40px;
  letter-spacing: 0.1em;
  line-height: 1.85;
}
#healthmanagement li span {
  letter-spacing: 0.1em;
  line-height: 1.85;
  font-size: 0.8em;
  color: #666;
}
#healthmanagement ul.listCircle li {
  letter-spacing: 0.1em;
  line-height: 1.8;
}
#healthmanagement a {
  letter-spacing: 0.1em;
  line-height: 1.85;
  color: #2355a7;
}
#healthmanagement a:hover {
  border-bottom: solid 1px;   
  transition: .1s;
}
@media all and (max-width: 896px) {
    #healthmanagement p,
    #healthmanagement li {
        font-size: 1.2rem;
    }
}
/*------------------------------------------------------------
	MODAL
------------------------------------------------------------*/
.hide-area {
  display: none;
}
.modaal-close:after, .modaal-close:before {
  background: #ccc;
}
.modaal-close:focus:after, .modaal-close:focus:before, .modaal-close:hover:after, .modaal-close:hover:before {
  background: #666;
}
/*------------------------------------------------------------
	PROGRAM - MODAL
------------------------------------------------------------*/
.modaal-content-container {
  padding: 0;
  background-color: #deebf7;
}
.mdlProgram {
  margin: 100px 60px 80px;
}
.mdlProgram h3 {
  font-weight: 600;
  font-size: 2.0rem;
  letter-spacing: 0.1rem;
  line-height: 1.6;
  color: #1264c0;
  padding-bottom: 24px;
  margin-bottom: 36px;
  border-bottom: 1px dashed #999;
}
.mdlProgram p {
  padding-bottom: 2.0rem;
}
.mdlProgram p:last-child {
  padding-bottom: 0;
}