.cp-text-col2 .cp-text-l {
 float:left;
 width: 48%;
}
.cp-text-col2 .cp-text-r {
 float:right;
 width: 48%;
}
.cp-text-col3 .cp-text-l {
 float:left;
 width: 30%;
 margin-right: 20px;
}
.cp-text-col3 .cp-text-r {
 float:right;
 width: 30%;
}
.cp-text-col4 .cp-text-l {
 float:left;
 width: 22%;
}
.cp-text-col4 .cp-text-r {
 float:right;
 width: 22%;
}
.cp-img-r {
 float:right;
}
.cp-img-c {
 text-align:center
}
.cp-img-c img {
 margin: 0 auto;
}

.cp-ti .cp-text {
 float:left;
 width: 48%;
}
.cp-ti .cp-img {
 float:right;
 width: 48%;
}
.cp-it .cp-img {
 float:left;
 width: 48%;
}
.cp-it .cp-text {
 float:right;
 width: 48%;
}
.cp-img-col2 .cp-col-01 {
 float:left;
 width: 48%;
}
.cp-img-col2 .cp-col-02 {
 float:right;
 width: 48%;
}
.cp-img-col3 .cp-col-01 {
 float:left;
 width: 30%;
}
.cp-img-col3 .cp-col-02 {
 float:left;
 width: 30%;
}
.cp-img-col3 .cp-col-03 {
 float:right;
 width: 30%;
}
.cp-img-col4 .cp-col-01 {
 float:left;
 width: 22%;
}
.cp-img-col4 .cp-col-02 {
 float:left;
 width: 22%;
}
.cp-img-col4 .cp-col-03 {
 float:left;
 width: 22%;
}
.cp-img-col4 .cp-col-04 {
 float:right;
 width: 22%;
}
.cp-wp {
 background:#FAFAFA;
 border:1px solid #CCC;
 padding:20px;
}
.cp-text-col2 .cp-text-l {
 float:left;
 width: 48%;
}
.cp-text-col2 .cp-text-r {
 float:right;
 width: 48%;
}
.cp-text-col3 .cp-text-l {
 float:left;
 width: 30%;
 margin-right: 20px;
}
.cp-text-col3 .cp-text-r {
 float:right;
 width: 30%;
}
.cp-text-col4 .cp-text-l {
 float:left;
 width: 22%;
}
.cp-text-col4 .cp-text-r {
 float:right;
 width: 22%;
}
.cp-img-c {
 text-align:center
}
.cp-img-c img {
 margin: 0 auto;
}
.cp-wp {
 background:#FAFAFA;
 border:1px solid #CCC;
 padding:20px;
}
.cp-ti .cp-text {
 float:left;
 width: 48%;
}
.cp-ti .cp-img {
 float:right;
 width: 48%;
}
.cp-wp {
 background:#FAFAFA;
 border:1px solid #CCC;
 padding:20px;
}
.cp-it .cp-img {
 float:left;
 width: 48%;
}
.cp-it .cp-text {
 float:right;
 width: 48%;
}

.cp-wp {
 background:#FAFAFA;
 border:1px solid #CCC;
 padding:20px;
}
.cp-space-L {
 height:45px;
 clear: both;
}
.cp-space-M {
 height:30px;
 clear: both;
}
.cp-space-S {
 height:15px;
 clear: both;
}
.cp-solid {
 border-top:1px solid #ccc;
}
.cp-solid hr{
 display:none;
}
.cp-dotted {
 border-top:1px dotted #ccc;
}
.cp-dotted hr{
 display:none;
}
.color-gray-bg{
  margin: 40px 0;
  padding: 40px 0;
  background: #f0f0f0;
}
.color-gray-bg .cp-all:first-child{
  margin-top: 0;
}
.color-gray-bg .cp-all:last-child{
  margin-bottom: 0;
}
.wrap-blue-bdr.cp-all{
  width: calc(100% - 80px);
  max-width: 1000px;
  padding: 40px;
  border: 1px solid #3C428F;
  background: #fff;
}
.wrap-blue-bdr.cp-all .cp-all{
  padding: 0;
}
@media screen and (max-width: 959px) {
  .wrap-blue-bdr.cp-all{
    width: 92%;
    padding: 20px 4%;
  }
}
.profile-img-text{
  -js-display: flex;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: -20px;
}
.profile-img-text .profile-box{
  width: 49%;
  margin-bottom: 20px;
}
.profile-img-text .profile-box:nth-child(2n){
  margin-left: 2%;
}
.profile-img-text .profile-box-img{
  float: left;
  width: 180px;
}
.profile-img-text .profile-box-text{
  float: right;
  width: calc(100% - 200px);
  font-size: 13px;
  font-size: 1.3rem;
}
.profile-img-text .profile-text-name{
  margin-bottom: 15px;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 959px) {
  .profile-img-text .profile-box{
    width: 100%;
  }
  .profile-img-text .profile-box:nth-child(2n){
    margin-left: 0;
  }
  .profile-img-text .profile-box-img{
    width: 120px;
  }
  .profile-img-text .profile-box-text{
    width: calc(96% - 120px);
  }
}
.html.visible .project-acc-number{
  color: #fff !important;
}

.project-acc-header .project-acc-btn br{
  display: none;
}
@media screen and (min-width: 960px) {
  .project-acc{
    margin-bottom: 20px;
  }
  .project-acc-header{
    height: 300px;
    cursor: pointer;
  }
  .project-acc-header.no-content{
    cursor: auto;
  }
  .project-acc-header .project-acc-bg{
    height: 300px;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
  }
  .project-acc-header .bg-inner{
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 40px;
  }
  .project-acc-header .project-acc-number{
    position: relative;
    padding: 20px 0;
    color: #fff;
    font-family: Vidaloka, serif;
  }
  .project-acc-header .project-acc-number .project{
    position: absolute;
    margin: 70px 0 0 120px;
    font-size: 1.8px;
    font-size: 1.8rem;
    transform: rotate(90deg);
    line-height: 1;
  }
  .project-acc-header .project-acc-number .number{
    margin-left: 160px;
    font-size: 220px;
    font-size: 22rem;
    line-height: 1.17;
  }
  .project-acc-header .project-acc-title{
    position: relative;
    top: -300px;
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
    padding: 60px 40px 0 400px;
    font-size: 22px;
    font-size: 2.2rem;
    font-weight: 600;
    color: #fff;
  }
  .project-acc-header .project-acc-btn{
    position: relative;
    top: -300px;
    width: 100%;
    max-width: 1080px;
    margin: 0 auto;
    padding: 20px 40px 0 400px;
    color: #fff;
  }
  .project-acc-header .project-acc-btn a{
    display: inline-block;
    min-width: 200px;
    text-align: center;
    padding: 5px 50px;
    border: 1px solid #fff;
    color: #fff;
    transition: 0.2s;
  }
  .project-acc-header .project-acc-btn a:hover{
    text-decoration: none;
  }
  .project-acc-header:hover .project-acc-btn a{
    background: #fff;
    color: #3C428F;
  }
}
@media screen and (max-width: 959px) {
  .project-acc-header .project-acc-number{
    position: relative;
    padding: 20px 0;
    color: #fff;
    font-family: Vidaloka, serif;
    text-align: center;
  }
  .project-acc-header .project-acc-number .project{
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -10px 0 0 -85px;
    font-size: 15px;
    font-size: 1.5rem;
  }
  .project-acc-header .project-acc-number .number{
    font-size: 120px;
    font-size: 12rem;
    line-height: 1;
  }
  .project-acc-header .project-acc-bg{
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
  }
  .project-acc-header .project-acc-title{
    padding: 10px 4%;
    background: #eee;
  }
  .project-acc-header .project-acc-btn{
    padding: 0 4% 20px 4%;
    background: #eee;
    min-height: 50px;
  }
  .project-acc-header .project-acc-btn a{
    display: inline-block;
    min-width: 160px;
    text-align: center;
    padding: 4px 40px;
    background: #3C428F;
    color: #fff;
    font-size: 13px;
    font-size: 1.3rem;
  }
}
.project-acc-content{
  display: none;
}
.project-acc-content > *:first-child{
  margin-top: 40px;
}
.project-acc-content .cp-h3-text{
  font-size: 28px;
  font-size: 2.8rem;
}
@media screen and (max-width: 959px) {
  .project-acc-content .cp-h3-text{
    font-size: 21px;
    font-size: 2.1rem;
  }
}
.project-acc-close-btn{
  width: 200px;
  margin: 40px auto 80px auto;
  text-align: center;
  padding: 5px 50px;
  border: 1px solid #3C428F;
  color: #fff;
  background: #3C428F;
  transition: 0.2s;
}
.project-acc-close-btn:hover{
  cursor: pointer;
  background: #242856;
  color: #999;
}
