@charset "UTF-8";

/* pageTtl */
#pageTtl {
  background-image: url(../img/design/mv.jpg);
}


/* common */
span.num{
  font-family: Roboto;
  font-weight: bold;
  font-size: 18px;
  line-height: 30px;
  width: 30px;
  height: 30px;
  border-radius: 30px;
  margin-right: .5em;
  background-color: #2d88df;
  color: #FFF !important;
  display: inline-block;
  text-align: center;
}


/* ul.funcName */
ul.funcName{
  display: inline-flex;
  flex-wrap:wrap;
  margin-bottom: 1em;
}
ul.funcName li {
  font-size: 0.8em;
  margin: 0.5em;
  border-left: 1px solid #2d89df;
  border-right: 1px solid #4cd5bd;
  display: block;
}
ul.funcName li:before, 
ul.funcName li:after {
  content: "　";
  display: block;
  height: 1px;
  width: 100%;
  background: #2d89df;
  background: -moz-linear-gradient(left,  #2d89df 0%, #4cd5bd 100%);
  background: -webkit-linear-gradient(left,  #2d89df 0%,#4cd5bd 100%);
  background: linear-gradient(to right,  #2d89df 0%,#4cd5bd 100%);
}
ul.funcName li span{
  padding: .2em 1em;
  display: block;
  font-weight: bold;
  color: #666666;
}
@media screen and (max-width:767px) {
  ul.funcName li {
    min-width: 60%;
    margin: 0.2em auto;
  }
  ul.funcName li span {
    padding: .2em 1.5em;
  }
}


/* table.dataTable01 */
table.dataTable01 {
  margin-bottom: 2em;
}
table.dataTable01 th,
table.dataTable01 td {
  border: 1px solid #CCCCCC;
  border-collapse: collapse;
  padding: 1.5em 1em;
  background-color: #FFF;
}
table.dataTable01 th {
  color: #FFFFFF;
  background-color: #5b9edd;
  padding: 0.5em 1em;
}
table.dataTable01 thead th{
  background-color: #2d88df;
  padding: 1em;
}
@media screen and (max-width:767px) {
  table.dataTable01 {
    border-bottom: 1px solid #CCCCCC;
  }
  table.dataTable01 tbody th {
    display: none;
  }
  table.dataTable01 tbody td:first-child {
    color: #FFFFFF;
    background-color: #5b9edd;
    font-weight: bold;
    padding: 0.5em 1em;
  }
  table.dataTable01 tbody td {
    display: block;
    width: 100%;
    border-bottom: none;
  }
}

/* ul.designlist*/
ul.designlist > li{
  display: flex;
  flex-wrap: wrap;
  border-bottom: 1px solid #e5e5e5;
  padding-bottom: 3em;
  margin-bottom: 3em;
}
ul.designlist > li:last-child{
  border-bottom: none;
}
ul.designlist > li article{
  width: 50%;
  padding-right: 60px;
  margin-bottom: 2em;
}
ul.designlist > li article h3{
  letter-spacing: 0.05em;
  font-size: 1.6em;
  margin-bottom: 1em;
  display: flex;
  align-items: center;
}
ul.designlist > li article h3 span{
  font-size: 0.8em;
  color: #999999;
  margin-top: 0.2em;
}
ul.designlist > li figure{
  box-shadow: 0px 4px 38px 2px rgba(51, 134, 164, 0.1);
  width: 50%;
  border: 1px solid #dee5ea;
}
ul.designlist > li.col01{
  display: block;
}
ul.designlist > li.col01 article,
ul.designlist > li.col01 figure{
  width: 100%;
  padding-right: 0;
}
@media screen and (max-width:767px) {
  ul.designlist > li article {
    width: 100%;
    padding-right: 0;
    text-align: center;
  }
  ul.designlist > li article h3 {
    width: 100%;
    justify-content: center;
    flex-wrap: wrap;
    padding-right: 1em;
    display: block;
  }
  ul.designlist > li article h3 span {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1em;
  }
  ul.designlist > li article p {
    text-align: left;
  }
  ul.designlist > li figure {
    width: 100%;
  }
}


/* sec */
.sec01 {
  background-image: url(../img/bg02.jpg);
  background-repeat: repeat-y;
  background-size: contain;
  background-position: center top 10vw;
}
.sec02, .sec04, .sec06, .sec08 {
  background-color: #f2f7fa;
}
.sec02 article {
  width: 600px;
  margin: 0 auto 4em;
}
@media screen and (max-width:767px) {
  .sec02 article {
    width: 100%;
    margin: 0 auto 2em;
  }
  .sec02 {
    padding-bottom: 0px;
  } 
}
