@charset "utf-8";


.page-project-index .content-top {
  margin-top: 0;
}
@media all and (max-width: 767px) {
  .page-project-index .content-top {
    margin-top: 0;
    width: 100vw;
  }
}
main{
  display: flex;
  flex-direction: column;
}
.global_navi_project a {
  border-bottom: solid 1px #000;
  pointer-events: none;
}
.tab {
  margin-right: 12px;
  margin-left: 12px;
}
@media all and (max-width: 1280px) {
  .tab {
    margin-right: calc(12vw / 1280 * 100);
    margin-left: calc(12vw / 1280 * 100);
  }
}
@media all and (max-width: 800px) {
  .tab {
    margin-right: calc(19vw / 375 * 100);
    margin-left: calc(19vw / 375 * 100);
  }
}
@media all and (max-width: 500px) {
  .tab {
    margin-right: calc(8vw / 375 * 100);
    margin-left: calc(8vw / 375 * 100);
  }
}


.page_title{
  position: relative;
}
.list-menu{
  display: none;
}
@media all and (max-width: 767px) {
  .list-menu{
    position: absolute;
    right: calc(19vw / 375 * 100);
    top:0;
    width: 22px;
    display: block;
  }
  .list-menu img{
    width: 100%;
  }
}

.tab_cont {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: -48px;
}
@media all and (max-width: 1280px) {
  .tab_cont {
    margin-bottom: calc(-48vw / 1280 * 100);
  }
}

.tab_cont .item {
  margin: 0 16px 38px 16px;
  width: calc(16.66666667% - 32px);
  display: none;
}


@media all and (max-width: 1920px) {
  .tab_cont .item {
    width: calc(16.66666667% - 32px);
  }
}
@media all and (max-width: 1280px) {
  .tab_cont .item {
    margin: 0 calc(16vw / 1280 * 100) 38px calc(16vw / 1280 * 100);
    width: calc(20% - 32vw / 1280 * 100);
  }
}
@media all and (max-width: 800px) {
  .tab_cont .item {
    margin: 0 calc(16vw / 800 * 100) 38px calc(16vw / 800 * 100);
    width: calc(33.333% - 32vw / 800 * 100);
  }
}
@media all and (max-width: 500px) {
  .tab_cont .item {
    margin: 0 calc(12vw / 375 * 100) 38px;
    width: calc(50% - 24vw / 375 * 100);
  }
}

body.view_hopkins .item.hoshino,
body.view_hoshino .item[class*="hopkins"] { display: none; }

.tab_cont .item a { color: #fff; }
.tab_cont .item:not(.hoshino) a { color: #1e88e5; }

.tab_cont .item .cover{
  margin-bottom: 9px;
  position: relative;
  padding-top: 100%;
  width: 100%;
}

.tab_cont .item figure {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}

.tab_cont .item h3 {
  letter-spacing: .1px;
  padding-bottom: 10px;
}
@media all and (max-width: 1280px) {
  .tab_cont .item h3 {
    letter-spacing: calc(.1vw / 1280 * 100);
  }
}
@media all and (max-width: 767px) {
  .tab_cont .item h3 {
    height: auto;
    margin-top: 0;
  }
}

.tab_cont .item .lang {
  margin-top: -3px;
  margin-bottom: -6px;
}
@media all and (max-width: 1280px) {
  .tab_cont .item .lang {
    margin-top: calc(-3vw / 1280 * 100);
    margin-bottom: calc(-6vw / 1280 * 100);
  }
}
@media all and (max-width: 767px) {
  .tab_cont .item .lang {
    margin-top: calc(-5vw / 375 * 100);
    margin-bottom: calc(-5vw / 375 * 100);
  }
}

.tab_cont .item .area {
  letter-spacing: .1px;
  color: #fff;
}

@media all and (max-width: 500px) {
  .tab_cont .item .lang.area {
    margin-top: 0;
  }
}

.tab_cont .item:not(.hoshino) .area {
  color: #1e88e5;
}
@media all and (max-width: 1280px) {
  .tab_cont .item .area {
    letter-spacing: calc(.1vw / 1280 * 100);
    margin-top: 0;
  }

}
@media all and (max-width: 767px) {
  .tab_cont .item .area {
    margin-top: -6px;
  }
}

.tab_cont .item h3 span { border-bottom: 1px solid transparent;}
.tab_cont .item a:hover h3 span { border-bottom: 1px solid #fff; }
.tab_cont .item:not(.hoshino) a:hover h3 span { border-bottom: 1px solid #2f4c99; }

.footer{
  background-color: #000;
}
.footer .small{
  color: #fff;
  border-color: #fff;
}

/*SP版 2Column甩*/
@media all and (max-width: 767px) {
  .tab_cont__2columns{
    display: flex;
    justify-content: flex-start;
    width: calc(100% + 26px);
    margin-left: -13px;
  }
  .tab_cont__2columns .item{
    width: calc(50% - 26px);
    margin-right: 13px;
    margin-left: 13px;
  }
  .tab_cont.tab_cont__2columns .item figure{
    height: calc(50vw - 26px);
  }
}

/* item list */
.list_typography {
  font-size: 10px;
  line-height: 16px;
}

.list-caption {
  margin-bottom: 13px;
}