@charset "utf-8";


/* -----------------------------------

                style

-------------------------------------*/
#main{
  max-width: 924px;
  width: 100%;
  margin: 0 auto;
  text-align: left;
  margin-left: 20px;
}

sup,
sub {
  height: 0;
  line-height: 1;
  position: relative;
	font-size: 60%;
}
.cooper_lens_point img {
  display: block;
}

.mainvisual{
  position: relative;
  z-index: 0;
}
.mainvisual .title{
  position: absolute;
  z-index: 10;
  color: #005cab;
  font-size: 30px;
  line-height: 46px;
  font-weight: bold;
  top: 95px;
  left: 30px;
  letter-spacing: 0;
}
.mainvisual .text{
  position: absolute;
  z-index: 10;
  font-size: 16px;
  line-height: 30px;
  top: 200px;
  left: 30px;
  letter-spacing: 0;
}
.reason-section h2 {
  text-align: center;
  background: none;
  padding: 0;
  margin: 0;
  border-bottom: 0;
}
.reason-section h2 span {
  font-size: 24px;
  background:
    url(../img/icon_title.png) no-repeat left center/34px 32px,
    url(../img/icon_title.png) no-repeat right center/34px 32px;
  color: #333;
  padding: 0 50px;
  margin: 100px auto 50px;
  display: inline-block;
}
.reason-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 20px;
}
.reason-image {
  width: 400px;
}
.reason-content {
  width: 515px;
  margin-left: 30px;
  box-sizing: border-box;
  letter-spacing: 0;
}
.reason-text{
  font-size: 16px;
  font-weight: 28px;
}
.reason-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 30px 0 30px;
  flex-wrap: wrap;
}
.reason-row.reason-row-1 .reason-head {
  width: 362px;
}
.reason-row.reason-row-2 .reason-head {
  width: 362px;
}
.reason-row.reason-row-3 .reason-head {
  width: 362px;
}
.media_artcl_box h3.reason-title {
  margin: 0 0 14px;
  color: #b2117f;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.55;
  
  background: none;
  padding: 0;
  border-left: 0;
}
.reason-row.reason-row-2 .reason-content {
  margin-left: 0;
  margin-right: 30px;
}



.reason-section2{
  background: url(../img/illust1_pc.png) no-repeat left top/contain;
  width: 100%;
  height: 220px;
  margin: 0 auto 80px;
}
.reason-section2 h3{
  font-size: 34px;
  background: none;
  text-align: center;
  padding: 0;
  margin: 90px auto 0;
  border-left: 0;
  border-bottom: 1px solid #005cab;
  color: #005cab;
  width: 684px;
  letter-spacing: 0;
}
.reason-section2 p{
  margin: 20px auto 0;
  width: 684px;
  letter-spacing: 0;
  font-size: 16px;
  line-height: 32px;
}


.linkbox-section{
  background: #f5f5f5;
  width: 100%;
  padding: 30px 20px 40px;
  margin: 0 auto 80px;
  box-sizing: border-box;
}
.linkbox-section h4{
  padding: 0;
  margin: 0 0 20px;
  border-bottom: 0;
  text-align: center;
  font-size: 24px;
}

.linkbox-section .boxlist{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.linkbox-section .box {
  position: relative;
  padding-bottom: 70px;
}
.linkbox-section .box picture {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
}

.linkbox-section .box picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.linkbox-section .box .textblock {
  margin-top: 20px;
}
.linkbox-section .box .textblock .title {
  font-size: 20px;
  line-height: 30px;
  color: #005cab;
  font-weight: bold;
}
.linkbox-section .box p {
  font-size: 16px;
  line-height: 26px;
  margin-bottom: 10px;
  letter-spacing: 0;
}
.linkbox-section .box .btn {
  position: absolute;
  bottom: 0;
  height: 60px;
  width: 100%;
}
.linkbox-section .box .btn a {
  display: block;
  text-align: center;
  color: #fff;
  font-weight: bold;
  background: #005cab;
  width: 240px;
  height: 50px;
  line-height: 50px;
  border-radius: 25px;
  margin: 0 auto;
}
.linkbox-section .note {
  font-size: 10px;
  line-height: 16px;
  letter-spacing: 0;
  margin-top: 20px;
  margin-bottom: 0;
}

.banner-section {
  margin-bottom: 55px;
}
.banner-section .note {
  font-size: 10px;
  line-height: 14px;
  margin: 10px 0 80px;
  letter-spacing: 0;
}



.foottext-section{
  margin: 0 0 100px;
}
.foottext-section h5{
  font-size: 20px;
  line-height: 30px;
  color: #005cab;
  margin: 0 0 15px;
  letter-spacing: 0;
}
.foottext-section p{
  font-size: 16px;
  line-height: 28px;
  margin: 0;
  letter-spacing: 0;
}
.foottext-section .mb60{
  margin: 0 0 60px;
}


.brsp{display: none;}
.brpc{display: block;}
.spimg{display: none;}
.pcimg{display: block;}


@media screen and (max-width: 768px) {
.brpc{display: none;}
.brsp{display: block;}
.spimg{display: block;}
.pcimg{display: none;}
  
#main{
  max-width: 100%;
  width: 100%;
  margin-left: 0;
}

.mainvisual .title{
  font-size: 5.2vw;
  line-height: 1.45;
  top: 29%;
  left: 17px;
  letter-spacing: 0.05rem;
}

.mvtext{
  font-size: 12px;
  line-height: 21px;
  letter-spacing: 0;
  padding: 15px 20px;
  background: #fff;
  background: linear-gradient(
    -100deg,
    #ffffff 0%,
    #ffffff 50%,
    #f2f8fc 100%
  );
  margin-bottom: 0 !important;
}


.reason-section h2 {
  text-align: center;
  background: none;
  padding: 0;
  margin: 0;
  border-bottom: 0;
}


.reason-section h2 {
  padding: 0;
  margin: 0;
}
.reason-section h2 span {
  font-size: 20px;
  line-height: 26px;
  background:
    url(../img/icon_title.png) no-repeat left center/24px 23px,
    url(../img/icon_title.png) no-repeat right center/24px 23px;
  color: #333;
  padding: 0 50px;
  margin: 45px auto 30px;
  width: 100%;
  box-sizing: border-box;
}

.reason-row {
  display: block;
  margin-bottom: 20px;
}
.reason-image {
  width: 100%;
  margin-bottom: 30px;
}
 
.reason-content {
  width: 100%;
  margin-left: 0;
}
.reason-text{
  font-size: 16px;
  line-height: 28px;
  margin-bottom: 15px !important;
}
 
.reason-head {
  display: block;
  margin: 0 0 20px;
}

.reason-row.reason-row-1 .reason-head {
  width: 68%;
}
.reason-row.reason-row-2 .reason-head {
  width: 68%;
}
.reason-row.reason-row-3 .reason-head {
  width: 68%;
}

.media_artcl_box h3.reason-title {
  margin: 0 0 10px;
  font-size: 18px;
}
.media_artcl_box p.media_lastupdated {
  line-height: 1.75;
  letter-spacing: 0.07rem;
  margin-bottom: 0.9rem;
}

.reason-row.reason-row-2 .reason-content {
  margin-right: 0;
}


.reason-section2{
  background: none;
  width: 100%;
  height: auto;
  margin: 0 auto 50px;
}

.reason-section2 h3{
  background: url(../img/illust1_sp.png) no-repeat left top/contain;
  font-size: 18px;
  padding: 0;
  margin: 50px auto 0;
  width: 100%;
  line-height: 40px;
  height: auto;
  padding-bottom: 10px;
}
.reason-section2 p{
  margin: 20px auto 0;
  width: 100%;
  font-size: 16px;
  line-height: 29px;
}
  
  
.linkbox-section{
  padding: 20px 20px 30px;
  margin: 0 auto 30px;
  box-sizing: border-box;
}
  
.linkbox-section h4{
  padding: 0;
  margin: 0;
  font-size: 18px;
  line-height: 24px;
}

.linkbox-section .boxlist{
  display: block;
  margin-bottom: 20px;
}
.linkbox-section .spbox{
  margin: 25px 0 20px 0;
  display: grid;
  grid-template-columns: 46.6% 53.4%;
  gap: 15px;
}

.linkbox-section .box {
    position: relative;
    padding-bottom: 10px;
}
.linkbox-section .box .textblock {
    margin-top: 0;
}
.linkbox-section .box .textblock .title {
  font-size: 14px;
  line-height: 18px;
  margin-bottom: 5px;
}
 
.linkbox-section .box p {
  font-size: 12px;
  line-height: 20px;
  margin-bottom: 10px;
}
.linkbox-section .box .btn {
  position: relative;
  bottom: 0;
  height: auto;
  width: 100%;
}
.linkbox-section .box .btn a {
  font-size: 15px;
  width: 170px;
  height: 40px;
  line-height: 40px;
  border-radius: 20px;
}
.linkbox-section .note {
  font-size: 10px;
  line-height: 14px;
}
  
.banner-section {
  margin-bottom: 40px;
}
.banner-section .note {
  font-size: 10px;
  line-height: 14px;
  margin: 10px 0 30px;
}



.foottext-section{
  margin: 0;
  padding: 0 0 100px;
}
.foottext-section h5{
  font-size: 16px;
  line-height: 24px;
  color: #005cab;
  margin: 0 0 5px;
}
.foottext-section p{
  font-size: 14px;
  line-height: 24px;
  margin: 0;
}
.foottext-section .mb60{
  margin: 0 0 60px;
}
.foottext-section .indent{
  text-indent: -1em;
  margin-left: 1em;
}

}