@charset "UTF-8";


@font-face {
  font-family: "american";
  src:url(../../font/ac.otf);
}

/* =====<=====<=====<=====<=====<=====<===== */
/* !<- GENERAL control ->                    */
/* =====>=====>=====>=====>=====>=====>===== */

body {
  min-width: 1100px;
  max-height: 100%;
  color: #303030;
}
header,
footer {
  width: 100%;
}
p {
  font-size: 15.5px;
  line-height: 2.3;
  letter-spacing: -.05em
}
p+p {
  margin-top: 2.5em;
}

dl,ol,ul {
  font-size: 15px;
  line-height:1.6 ;
}
a {
  color: #303030;
  line-height: 1;
}
.co {
  display: block;
  color: #ef924d;
  font-weight: bold;
  font-size: 18px;
}
.fx {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}



/* =====<=====<=====<=====<=====<=====<===== */
/* !<- WRAPPER & INNER control ->            */
/* =====>=====>=====>=====>=====>=====>===== */


.inner {
  width: 1100px;
  margin: 0 auto;
}

/* =====<=====<=====<=====<=====<=====<===== */
/* !<- HEADDING control ->                   */
/* =====>=====>=====>=====>=====>=====>===== */

header {
}
h1,h2,h3,h4,h5,h6 {
  font-weight: bold;
  text-align: center;
}
h1 {
  position: absolute;
  top: 0;
  left: 90px;
  color:#122a88;
  font-size: 15px;
  line-height: 1.3;
}
h2 {
  color: #004986;
  font-size: 30px;
  line-height: 1.6;
}

h3 {
  color:#004986;
  font-size: 35px;
  margin: 0 0 70px;
}


/* =====<=====<=====<=====<=====<=====<===== */
/* !<- TOP-HEADER control ->                 */
/* =====>=====>=====>=====>=====>=====>===== */

#TH {
  padding:20px 0 30px;
  background: #ddecf9;
}
#TH .fx {
  width: 1100px;
  display: flex;
  justify-content: space-between;
}
.menu-trigger {display: none;}
.mailmagazine p {
  text-align: center;
}
.hdrLogo {
  position: relative;
}
.ctcBox p,
.mailmagazine p {
  margin-top: .5em;
  font-size: 13px;
  line-height: 2;
}
#TH .ctcBox p span {
  font-weight: bold;
}
#TH .ctcBox p span:last-of-type {
  display: block;
  color: #b91428;
}



/* =====<=====<=====<=====<=====<=====<===== */
/* !<- MAIN-VISUAL control ->                */
/* =====>=====>=====>=====>=====>=====>===== */
#MV {
  width: 100%;
  height: 740px;
  position: relative;
  background: url(../../img/co/MV.jpg)no-repeat;
  background-size: 2000px;
  background-position: center top;
}
#MV img {
  width: 260px;
  height: auto;
  position: absolute;
  right: 0;
  bottom: 0;
}



/* =====<=====<=====<=====<=====<=====<===== */
/* !<- SECTION control ->                    */
/* =====>=====>=====>=====>=====>=====>===== */

main{  background: #ddecf9; }
article {
/*
  background: url(../../img/co/sec01_bg.jpg) no-repeat ;
  background-position: center top;
  background-attachment: fixed;
  background-size: 2000px;
*/}

section .cntBox header h2 {
  text-align: left;
  line-height: 1.4;
  margin-left: 100px;
}
section .cntBox header {
  margin-bottom: 20px;
  overflow: visible;
  position: relative;
}
section .cntBox header span {
  width: 200px;
  display: block;
  padding: .5em 0 0;
  transform: rotate(90deg);
  color:#004986;
  font-family: "american","Hiragino Kaku Gothic ProN";
  font-size: 30px;
  font-weight: bold;
  border-top: 2px solid ;
  text-align: right;
  position: absolute;
  top: 84px;
  left: -50px;
  z-index: 4;
}
section .inner:nth-of-type(1) .cntBox:nth-of-type(1) header span {
  color:#fff
}



/* =====<=====<=====<=====<=====<=====<===== */
/* !<- BOX CONTROL ->                        */
/* =====>=====>=====>=====>=====>=====>===== */

.cntBox {
}
.Left {
  float: left;
}
.Right {
  float: right;
}
.fx {
  display: flex;
}



/* =====<=====<=====<=====<=====<=====<===== */
/* !<- FOOTER control ->                     */
/* =====>=====>=====>=====>=====>=====>===== */

footer {padding-top: 45px; background: #1466a1; position: relative;}

#ftrLogo img {margin: auto;}
footer .inner { overflow: visible;}
#pagetop {
  position: absolute;
  bottom: 60px;
  right: 5%;
}
footer .ctcBox,footer .mailmagazine {display: none;}
.ctcBox+p {display: none;}

/*===== #ftrNav =====*/
#ftrNav {
 justify-content: center;
}
#ftrNav ul {
  width: 470px;
  padding: 45px 0 50px;
  flex-wrap: wrap;
  justify-content: space-around;
}
#ftrNav ul a {
  color:#fff;
  font-size: 12px;
}
#ftrNav i {
  color:#e1ce1e;
}
/*===== COPYRIGHT =====*/
small {
  width: 100%;
  display: block;
  padding: 15px 0 14px;
  color:#fff;
  font-size: 10px;
  text-align: center;
  background: #143c72;
}

/* =====<=====<=====<=====<=====<=====<===== */
/* !<- SPECIAL DECO control ->               */
/* =====>=====>=====>=====>=====>=====>===== */

/*===== { btn } =====*/
.btn {
  width: 175px;
  display: block;
  margin: 65px auto 0;
  padding: 0.8em 0;
  color: #1879c0;
  font-weight: bold;
  text-align: center;
  background: #fff;
  transition: .8s;
}
.btn:hover {
  color: #eee;
  background: #fff;
}

/* =====<=====<=====<=====<=====<=====<===== */
/* !<- ORDERD SKIN / index.html ->           */
/* =====>=====>=====>=====>=====>=====>===== */
#sec01 {
  padding-top: 130px;
  position: relative;
}
#sec01 .inner:nth-of-type(2n) {
  width: 1500px
}
#sec01 .cntBox figure {
  width: 100%;
  position: relative;
  z-index: 2;
  margin-bottom: 50px;
}
#sec01 .cntBox figure img {
  width: 100%;
  height: auto;
}

#sec01 .inner .cntBox {
  margin-bottom: 150px;
  position: relative;
}

#sec01 .inner .cntBox>img {
  position: absolute;
  top: 0
}



#sec01 .inner:nth-of-type(1) .cntBox>img {
  left:-100px
}
#sec01 .inner:nth-of-type(2) .cntBox:nth-of-type(1)>img {
  right: -92px;
}
#sec01 .inner:nth-of-type(2) .cntBox:nth-of-type(2)>img {
  right: -85px;
}
#sec01 .inner:nth-of-type(3) .cntBox>img {
  left:-90px
}
#sec01 .inner:nth-of-type(4) .cntBox:nth-of-type(1)>img {
  right: -90px;
}
#sec01 .inner:nth-of-type(4) .cntBox:nth-of-type(2)>img {
  right: -90px;
}



#sec01 .inner:nth-of-type(1) .cntBox {
  margin-bottom: 50px;
}

#sec01 .cntBox .left {
  width: 650px;
}
#sec01 .cntBox .right {
  width: 395px;
}

#sec01 .inner:nth-of-type(2n) .cntBox {
  width: 650px;
}


#sec01 .inner:nth-of-type(2n) .cntBox figure {
  margin-bottom: 50px;
}


#sec01 .inner:nth-of-type(3) .cntBox .right {
  width: 400px;
  float: right;
}
#sec01 .inner:nth-of-type(3) .cntBox .right .bottom {
  width: 100%;
}


#sec01 .inner:nth-of-type(2) .cntBox:nth-of-type(2) ,
#sec01 .inner:nth-of-type(4) .cntBox:nth-of-type(1) {
  margin-top: 150px;
}

#sec02 {
  padding-top: 270px;
}
#sec02 .inner {
  width: 1500px;
}
#sec02 .cntBox {
  width: 100%;
  padding: 180px 0 70px;
  position: relative;
  overflow: visible;
  background: #fcfdfe;
}
#sec02 .cntBox h3 {
  position: absolute;
  top: -55px;
  left: 0;
  right: 0;
  margin: auto;
}
#sec02 .cntBox h3 img {
  margin: auto;
}
#sec02 .cntBox ul {
  width: 1285px;
  margin: 0 auto ;
}
#sec02 .cntBox li {
  width: 50%;
  font-weight: bold;
  font-size: 30px;
}
#sec02 .cntBox li::before {
  font-family: "FontAwesome";
  content: "\f14a";
  color:#2987bf;
  margin-right: .5em;
}



#sec02 .cntBox li+li {
  margin-top: .5em;
}

#sec02 .cntBox + .cntBox {
  margin-top: 145px;
  height: 580px;
  padding: 240px 0 110px;
  background: url(../../img/co/sec02_bg.jpg) no-repeat;
  background-size: cover;
}
#sec02 .cntBox + .cntBox h3 {
  top: -25px;
}
#sec02 .cntBox + .cntBox p {
  color:#fff;
  font-size: 30px;
  text-align: center;
  line-height: 2;
}
#sec02 .cntBox + .cntBox p span {
  font-weight: bold;
  font-size: 1.3em;
}


#sec03 {
  padding: 175px 0 240px;
  padding-left: 40px;
}
#sec03 .inner {
  width: 1060px;
  border-left: 1px solid #004986
}
#sec03 h2 {
  padding-left: 1em;
  font-size: 35px;
  text-align: left;
  letter-spacing: .1em
}
#sec03 .cntBox {
  margin-top: 120px;
  padding-left: 100px;
  position: relative;
}
#sec03 .cntBox::after {
  width: 875px;
  height: 130px;
  content:"";
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
  border-left:1px solid #004986;
  border-bottom:1px solid #004986;
}


#sec03 dl {
  width:750px
}
#sec03 dt {
  font-weight: bold;
  font-size: 30px;
}
#sec03 dd+dt{
  margin-top: 1em;
}

#sec03 dt::before {
  content:"";
  width: 10px;
  height: 10px;
  margin-top: .6em;
  margin-right: .5em;
  display: block;
  float: left;
  border-radius: 100%;
  background:#2987bf;
}
#sec03 dd {
  font-size: 25px;
}
#sec03 dd::before {
  content:"→";
}





#sec04 {
  padding: 70px 0;
  background: #fcfdfe;
}
#sec04 header {
  margin-bottom: 45px;
}
#sec04 header h2 {
  font-size: 40px;
  text-align: center;
}
#sec04 header h2 .hidden {
  display: none;
}
#sec04 .col_r {
  width: auto;
  display: contents;
  padding: 0;
  transform: none;
  color: #e60012;
  font-family: "american","Hiragino Kaku Gothic ProN";
  font-size: 40px;
  font-weight: bold;
  border-top: none;
  text-align: center;
  position: unset;
  top: 0;
  left: 0;
}
#sec04 table th,
#sec04 table td {
  padding: .8em 0;
  line-height: 1.5;
  font-size: 20px;
  vertical-align: top;
}
#sec04 table tr:nth-last-of-type(2) td {
  padding-top: 0;
}
#sec04 table th {
  width: 150px;
  padding-right: 1em;
  font-weight: bold;
}
#sec04 table th::after {
  content:"|";
  float: right;
  font-weight: normal;
}
#sec04 table td span:nth-of-type(1) {
  text-decoration: line-through #e60012;
}

#sec04 table td span:nth-of-type(2) {
  color:#e60012;
  font-weight: bold;
}
#sec04 table td .col_r {
  font-size: 20px;
  text-decoration: none !important;
}
#sec04 table td span span{
  font-weight: bold;
  font-size: 2em;
  text-decoration: none!important;
}
#sec04 .map {
  position: relative;
  margin-top: 40px;
  margin-bottom: 40px;
}
#sec04 .map iframe {
  width: 100%;
  height: 400px;
}
#sec04 .map h3 {
  position: absolute;
  width: 280px;
  display: block;
  padding: .5em 0;
  top: -10px;
  left: 0;
  right: 0;
  margin: auto;
  color:#fff;
  font-size: 25px;
  text-align: center;
  background: #004986;
}
#sec04 p {
  font-weight: bold;
  font-size: 20px;
  text-align: center;
}

#sec04 .btn {
  width: 400px;
  margin-top: 1em;
  padding: 1em 0;
  color:#fff;
  font-size: 22px;
  background: #004986;
  background-image: linear-gradient(to top, #3dbbe0 0%, #065ade 100%);
}



#sec04 .cntBox+.cntBox {
  margin-top: 100px;
}

#sec04 .cntBox:first-of-type {
  justify-content: space-between;
  flex-wrap: wrap;
}
#sec04 .cntBox:first-of-type header {
  width: 100%;
  margin-bottom: 50px;
}
#sec04 dl {
  width: 792px;
}
#sec04 dt {
  padding-bottom: 20px;
  font-size: 23px;
  border-bottom: 1px solid #2987bf;
}
#sec04 dt span {
  font-weight: bold;
  font-size: 30px;
}
#sec04 dd {
  padding-top: 25px;
  padding-right: 50px;
  font-size: 16px;
  line-height: 2.1;
  letter-spacing: 1px;
}


#top #sec04 .cntBox .contactUs {
  margin-top: 40px;
  padding-bottom: 40px;
}



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

  #MV {
    width: 100%;
    background-size: cover;
    background-position: left top;
  }
  #MV img {
    display: none;
  }


  #sec01 .inner:nth-of-type(2n) {
    width: 1100px
  }

  #sec01 .inner:nth-of-type(2n) .cntBox {
    width: 520px;
  }
  #sec01 .inner .cntBox>img {
    width: 50px;
    height: auto;
    opacity: .2;
    z-index: 3;
  }
  #sec01 .inner:nth-of-type(1) .cntBox>img {
    left:0px
  }
  #sec01 .inner:nth-of-type(2) .cntBox:nth-of-type(1)>img {
    right: auto;
    left: 0;
  }
  #sec01 .inner:nth-of-type(2) .cntBox:nth-of-type(2)>img {
    right: auto;
    left: 0;
  }
  #sec01 .inner:nth-of-type(3) .cntBox>img {
    left:0
  }
  #sec01 .inner:nth-of-type(4) .cntBox:nth-of-type(1)>img {
    right: auto;
    left: 0;
  }
  #sec01 .inner:nth-of-type(4) .cntBox:nth-of-type(2)>img {
    right: auto;
    left: 0;
  }


  #sec02 .inner {
    width: 1100px;
  }

#sec02 .cntBox ul {
  width: 90%;
}
#sec02 .cntBox li {
  font-size: 20px;
}
#sec02 .cntBox+.cntBox {
  padding-top: 180px;
  height: 423px;
}
#sec02 .cntBox+.cntBox h3 img {
  width: 40%;
}

#sec02 .cntBox+.cntBox p {
  font-size: 20px;
}

#sec03 dl {
  width:600px
}

}
