/* 共通
***********************************************************/
.title_top {
  box-sizing: border-box;
  display: -webkit-box;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
}
.title_top h2 {
  font-size: 48px;
  font-family: 'Roboto';
  font-weight: 400;
  letter-spacing: 2px;
  color: #083a71;
}
.title_top h2 span {
  font-size: 14px;
  font-family: 'Noto Sans JP';
  letter-spacing: 3px;
}



/* mv
***********************************************************/
#mv {
  padding: 20vw 5vw;
  background: url(../images/obj_mv.jpg) no-repeat left top/cover;
  text-align: left;
  color: #083a71;
  position: relative;
}
#mv p:first-child {
  letter-spacing: 4.9px;
  font-size: 18px;
  font-weight: bold;
  text-shadow: 3px 3px 5px rgba(255, 255, 255, 1);
}
#mv h2 {
  padding: 2vw 0 0;
  font-size: 76px;
  font-family: 'Roboto';
  font-weight: 400;
  letter-spacing: 4px;
  font-style: italic;
  line-height: 1.1;
}
#mv h2 + p {
  max-width: 640px;
  font-size: 14px;
}
#mv a.more {
  margin: 3vw 0 0;
  padding: 0 3vw 3px 0;
  color: #083a71;
  border-bottom: 1px solid #083a71;
  font-size: 13px;
  transition: all .4s;
  display: inline-block;
}
#mv a.more:hover {
  padding: 0 0 3px;
  opacity: 1;
}
#mv p.cr {
     position: absolute;
     right: 50px;
     top: 50%;
     transform: translateY(-50%);
     -webkit-transform: translateY(-50%);
     -ms-transform: translateY(-50%);
     writing-mode: vertical-rl;
     font-size: 12px;
}
#mv p.sd {
     padding: 0 0 80px;
     position: absolute;
     left: 50%;
     bottom: -30px;
     transform: translateX(-50%);
     -webkit-transform: translateX(-50%);
     -ms-transform: translateX(-50%);
     font-size: 12px;
}
#mv p.sd::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 70px;
  background: #083a71;
  animation: sdl 3s cubic-bezier(1, 0, 0, 1) infinite;
}
@keyframes sdl {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}



/* 共通
***********************************************************/
.section_inner {
  margin: 0 auto;
  max-width: 1600px;
}



/* Business
***********************************************************/
.top_business {
  margin: 10vw 0 0;
  padding: 0 4vw;
}
.top_business_item {
  margin: 6vw 0 0; 
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.top_business_item:first-child {
  margin: 3vw 0 0;
}
.top_business_item:nth-child(even) {
  flex-direction: row-reverse;
}
.top_business_item img {
  width: calc(50% - 2vw);
}
.top_business_item_txt {
  width: calc(50% - 2vw);
  text-align: left;
}
.top_business_item_txt h3 {
  font-size: 24px;
  font-weight: bold;
  color: #000;
}
.top_business_item_txt h4 {
  font-weight: bold;
  color: #000;
}
.top_business_item_txt p {
  margin: 20px 0 0;
}



/* About
***********************************************************/
.top_about {
  margin: 14vw 0 0;
  padding: 0 4vw;
}
.top_about img {
  margin: 3vw auto 0;
  display: block;
  max-width: 1200px;
  width: 100%;
}
.top_about_txt {
  margin: 0 auto;
  max-width: 1000px;
}
.top_about_txt p {
  margin: 40px auto 0;
  text-align: left;
}
.top_about_txt .more {
  margin: 3vw 0 0 auto;
  text-align: right;
  width: 80px;
  display: block;
}



/* Slide
***********************************************************/
.top_slide {
  margin: 8vw 0 0;
}
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
    to {
    transform: translateX(-100%);
  }
}
@keyframes infinity-scroll-right {
  from {
    transform: translateX(-100%);
  }
    to {
      transform: translateX(0);
    }
}
.scroll-infinity__wrap {
  display: flex;
  overflow: hidden;
}
.scroll-infinity__list {
  display: flex;
  list-style: none;
  gap: 20px;
  padding: 0
}
.scroll-infinity__list--left {
  margin: 0 0 0 20px;
  animation: infinity-scroll-left 80s infinite linear 0.5s both;
}
.scroll-infinity__list--right {
  margin: 30px 20px 0 0;
  animation: infinity-scroll-right 80s infinite linear 0.5s ;
}
.scroll-infinity__item {
  width: calc(100vw / 12);
}
.scroll-infinity__item>img {
  width: 100%;
}



/* Consultant
***********************************************************/
.top_consultant {
  margin: 14vw 0 0;
  padding: 3vw 4vw 0;
  background: url(../images/bg_consultant.png) repeat-x center top -160px;
  text-align: left;
}
.top_consultant .title_top h2 {
  color: #fff
}
.top_consultant_wrapper {
  margin: 4vw 0 0;
  display: flex;
  justify-content: space-between;
  gap: 5vw;
}
.top_consultant_wrapper:nth-child(2)  {
  justify-content: center;
  gap: 5vw;
}
.top_consultant_wrapper .top_consultant_item {
  width: 30%;
}

.top_consultant_item img + p {
  margin: 0;
  font-size: 12px;
  color: #083a71;
}
.top_consultant_item img {
  margin: 0 0 20px;
}
.top_consultant_name {
  display: flex;
  gap: 20px;
  align-items: center;
}
.top_consultant_name h3 {
  font-size: 22px;
  color: #000;
  font-weight: bold;
}
.top_consultant_name span {
  color: #999;
  font-size: 12px;
  letter-spacing: 2px;
}
.top_consultant_item p {
  margin: 20px 0 0;
  text-align: left;
  font-size: 14px;
}



/* Service
***********************************************************/
.top_service {
  margin: 14vw 0 0;
  padding: 0 4vw;
}
.top_service_wrapper {
  margin: 3vw auto 0;
  display: flex;
  justify-content: space-between;
  
}
.top_service_item {
  width: 30.5%;
}
.top_service_item h3 {
  margin: 20px 0 0;
  font-size: 20px;
  font-weight: bold;
  color: #000;
  text-align: left;
}
.top_service_item ul {
  margin: 14px 0 0;
  font-size: 14px;
  text-align: left;
}
.top_service_item li {
  margin: 0 0 0 1.6rem;
  list-style: disc;
}



/* Case
***********************************************************/
.top_case {
  margin: 14vw 0 0;
  padding: 0 4vw;
}
.top_case_wrapper {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.top_case_item {
  margin: 3vw 0 0;
  padding: 40px 0 ;
  border-top: 1px solid #083a71;
  width: 47.5%;
}
.top_case_item h3 {
  margin: 20px 0 0;
  font-size: 20px;
  font-weight: bold;
  color: #000;
  text-align: center;
  letter-spacing: 2px;
}
.top_case_item h4 {
  margin: 30px 0 0;
  padding: 0 16px;
  font-size: 14px;
  font-weight: bold;
  color: #083a71;
  text-align: center;
  border: 1px solid #083a71;
  display: inline-block;
}
.top_case_item .top_case_tag {
  margin: 30px 0 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px;
}
.top_case_item .top_case_tag li {
  font-size: 12px;
  padding: 2px 10px 4px;
  color: #083a71;
  background: #eef3f8;
}
.top_case_outline {
  margin: 40px 0 0;
  padding: 20px;
  border: 20px solid #eef3f8;
  box-sizing: border-box;
  text-align: left;
  font-size: 14px;
}
.top_case_outline h5 {
  color: #000;
  letter-spacing: 2px;
  font-weight: bold;
}
.top_case_outline p {
  margin: 3px 0 0;
}
.top_case_outline p + h5 {
  margin: 22px 0 0;
  padding: 22px 0 0;
  border-top: 1px solid #d2d9e0;
}
.top_case_info {
  margin: 30px 0 0;
  display: flex;
  border-right: 1px solid #d2d9e0;
  justify-content: space-between;
}
.top_case_info_item {
  padding: 10px 20px;
  border-left: 1px solid #d2d9e0;
  text-align: left;
}
.top_case_info_item h5 {
  font-size: 14px;
  color: #000;
  font-weight: bold;
  letter-spacing: 2px;
}
.top_case_info_item p {
  font-size: 14px;
}



/* Strength
***********************************************************/
.top_strength {
  margin: 14vw 0 0;
  padding: 0 4vw;
}
.top_strength_wrapper {
  margin: 3vw 0 0;
  border-bottom: 1px solid #083a71;
}
.top_strength_item {
  padding: 30px;
  border-top: 1px solid #083a71;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 40px;
}
.top_strength_item p:first-child {
  font-size: 42px;
  color: #083a71;
  font-weight: bold;
  font-family: 'Roboto';
}
.top_strength_item h3 {
  font-size: 22px;
  color: #000;
  font-weight: bold;
  text-align: left;
  width: 460px;
}
.top_strength_item p:last-child {
  font-size: 16px;
  text-align: left;
  flex: 1;
}



/* News
***********************************************************/
.top_news {
  margin: 0 auto;
  padding: 10vw 4vw 0;
  box-sizing: border-box;
}
.news_wrapper {
  margin: 20px auto 0;
  box-sizing: border-box;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 80px;
}
.news_item {
  position: relative;
}
.news_item a {
  opacity: 100;
}
.news_item p:first-child {
  margin: 0 0 0 auto;
  width: 93%;
  overflow: hidden;
}
.news_item p:first-child img {
  transition:1s all;
  width: 100%;
  height: 16vw;
  object-fit: cover;
}
.news_item a:hover p:first-child img {
  transform:scale(1.1,1.1);
  transition:0.3s all;
}
.news_item p:nth-child(2) {
  writing-mode: vertical-rl;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 12px;
  color: #083a71;
}
.news_item h3 {
     margin: -2vw 0 0 7%;
     padding: 16px 16px;
     color: #000;
     font-weight: bold;
     background: #fff;
     width: 80%;
     text-align: left;
     position: relative;
     box-sizing: border-box;
}
.news_item a:hover h3 {
     text-decoration: underline;
}





/*全体（1100px以下）
***********************************************************/
@media screen and (max-width:1100px) {

.top_consultant {
  background: url(../images/bg_consultant.png) repeat-x center top -20vw;
}
.top_consultant_name {
  display: block;
}
}




/*全体（820px以下）
***********************************************************/
@media screen and (max-width:820px) {

#mv {
  padding: 60vw 20px;
}
#mv p:first-child {
  letter-spacing: 1px;
  font-size: 14px;
}
#mv h2 {
  padding: 4vw 0;
  font-size: 12vw;
  letter-spacing: 4px;
  line-height: 1.2;
}
#mv h2 + p {
  font-size: 12px;
}
#mv a.more {
  margin: 8vw 0 0;
  padding: 0 6vw 3px 0;
}
#mv a.more:hover {
  padding: 0 0 3px;
  opacity: 1;
}
#mv p.cr {
    display: none;
}
#mv p.sd {
     padding: 0 0 80px;
     position: absolute;
     left: 50%;
     bottom: -30px;
     transform: translateX(-50%);
     -webkit-transform: translateX(-50%);
     -ms-transform: translateX(-50%);
     font-size: 12px;
}
#mv p.sd::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 70px;
  background: #083a71;
  animation: sdl 3s cubic-bezier(1, 0, 0, 1) infinite;
}

/* 共通 */
.title_top {
  align-items: flex-end;
}
.title_top h2 {
  font-size: 38px;
  letter-spacing: 3px;
  text-align: left;
  line-height: 0.8;
}
.title_top h2 span {
  margin: 20px 0 0;
  display: block;
  font-size: 12px;
}
.title_top h2 span.br3 {
  margin: 0;
}
.more {
  font-size: 12px;
}

/* Business */
.top_business {
  margin: 80px 0 0;
  padding: 0 20px;
}
.top_business_item {
  margin: 60px 0 0; 
  display: block;
}
.top_business_item:first-child {
  margin: 40px 0 0;
}
.top_business_item img {
  width: 100%;
}
.top_business_item_txt {
  width: 100%;
  text-align: left;
}
.top_business_item_txt h3 {
  margin: 14px 0 0;
  font-size: 18px;
}
.top_business_item_txt h4 {
  font-size: 12px;
  letter-spacing: 1px;
}
.top_business_item_txt p {
  margin: 20px 0 0;
  font-size: 14px;
}

/* About */
.top_about {
  margin: 80px 0 0;
  padding: 0 20px;
}
.top_about img {
  margin: 40px auto 0;
}
.top_about_txt {
  margin: 0 auto;
  max-width: 1000px;
}
.top_about_txt p {
  font-size: 14px;
}
.top_about_txt .more {
  margin: 3vw 0 0 auto;
  text-align: right;
  width: 80px;
  display: block;
}

/* slide */
.top_slide {
  margin: 80px 0 0;
}
.scroll-infinity__item {
  width: calc(100vw / 6);
}

/* Consultant */
.top_consultant {
  margin: 100px 0 0;
  padding: 40px 20px 0;
  background: url(../images/bg_consultant.png) repeat-x center top -40vw;
}
.top_consultant_wrapper {
  margin: 0;
}
.top_consultant_item {
  margin: 40px 0 0;
}
.top_consultant_name h3 {
  line-height: 1.4;
  font-size: 18px;
}
.top_consultant_name span {
  font-size: 10px;
}
.top_consultant_item p {
  margin: 10px 0 0;
  font-size: 12px;
}
.top_consultant_wrapper:nth-child(2)  {
  justify-content: space-between;
  gap: 3vw;
}
.top_consultant_wrapper:nth-child(2) .top_consultant_item {
  width: 47%;
}
.top_consultant_wrapper:last-child {
  gap: 3vw;
  flex-wrap: wrap;
}
.top_consultant_wrapper:last-child .top_consultant_item {
  width: 47%;
}

/* Service */
.top_service {
  margin: 80px 0 0;
  padding: 0 20px;
}
.top_service_wrapper {
  margin: 0;
  display: block;
}
.top_service_item {
  margin: 60px auto 0;
  width: 80%;
}
.top_service_item:first-child {
  margin: 40px auto 0;
}
.top_service_item h3 {
  font-size: 18px;
}
.top_service_item ul {
  margin: 10px 0 0;
  font-size: 14px;
}

/* Case */
.top_case {
  margin: 80px 0 0;
  padding: 0 20px;
}
.top_case_wrapper {
  display: block;
}
.top_case_item {
  margin: 40px 0 0;
  padding: 20px 0 ;
  width: 100%;
}
.top_case_item h3 {
  margin: 10px 0 0;
  font-size: 16px;
  line-height: 1.6;
}
.top_case_item h4 {
  margin: 20px 0 0;
}
.top_case_item .top_case_tag {
  margin: 20px 0 0;
  gap: 10px;
}
.top_case_outline {
  margin: 30px 0 0;
  padding: 14px;
  border: 14px solid #eef3f8;
  line-height: 1.6;
  font-size: 13px;
}
.top_case_outline p {
  margin: 10px 0 0;
}
.top_case_outline p + h5 {
  margin: 16px 0 0;
  padding: 16px 0 0;
}
.top_case_info {
  display: block;
  border-top: 1px solid #d2d9e0;
}
.top_case_info:first-child {
  margin: 60px 0 0;
}
.top_case_info + .top_case_info {
  margin: 0;
  border-top: none;
}
.top_case_info_item {
  padding: 10px 20px;
  border-bottom: 1px solid #d2d9e0;
  display: flex;
  justify-content: space-between;
  gap: 40px;
}
.top_case_info_item h5 {
  font-size: 12px;
}
.top_case_info_item p {
  font-size: 12px;
  text-align: right;
}

/* Strength */
.top_strength {
  margin: 80px 0 0;
  padding: 0 20px;
}
.top_strength_wrapper {
  margin: 30px 0 0;
}
.top_strength_item {
  padding: 10px 0 26px;
  display: block;
}
.top_strength_item p:first-child {
  font-size: 42px;
}
.top_strength_item h3 {
  font-size: 18px;
  text-align: center;
  width: 100%;
}
.top_strength_item p:last-child {
  margin: 14px 0 0;
  font-size: 13px;
}

/* News */
.top_news {
  margin: 80px 0 0;
  padding: 0 20px;
}
.news_wrapper {
  display: block;
}
.news_item {
  margin: 40px auto 0 !important;
  width: 100%;
}
.news_item p:first-child {
  width: 90%;
}
.news_item p:first-child img {
  height: 50vw;
}
.news_item h3 {
     margin: -7vw 0 0 7%;
     padding: 16px 16px;
     width: 80%;
}
.year-list span {
    margin: 6px;
    padding: 5px 10px !important;
    font-size: 14px;
}
.year-list a {
    margin: 6px;
    padding: 5px 10px !important;
    font-size: 14px;
}

}



@media screen and (max-width:600px) {
  .top_consultant {
    background: url(../images/bg_consultant.png) repeat-x center top -70vw;
  }
}
