@charset "utf-8";
/* CSS Document */

.dialogue .profile{
  display: flex;
  justify-content: flex-start;
}
.dialogue .profile figure{
  max-width: 100px;
}
.dialogue .profile figure img{
  border-radius: 50%;
}
.dialogue .profile .wrap{
  display: flex;
  justify-content: space-between;
  margin-left: 4%;
  width: 80%;
}
.dialogue .profile .wrap p{
  width: calc(100% - 140px);
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 180%;
  letter-spacing: 0%;
  margin-left: 0 !important;
  order: 1;
}
.dialogue .profile .wrap div{
  width: 110px;
  height: 56px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border-radius: 4px;
  order: 2;
  margin-bottom: 4px;
}
.dialogue .profile .wrap div img{
  width: 74px;
  height: 20px;
}
@media only screen and (max-width: 1024px){
  .dialogue .profile{  
    margin-left: 0;
  }
  .dialogue .profile figure{
    max-width: 100px !important;
  }
  .dialogue .profile .wrap{
    flex-direction: column;
    justify-content: flex-start;
    width: calc(100% - 120px);
  }
  .dialogue .profile .wrap p{
    width: 100%;
    order: 2;
    font-size: 1.4rem !important;
  }
  .dialogue .profile .wrap div{
    order: 1;
    width: 82px;
    height: 27px;
  }
  .dialogue .profile .wrap div img{
    width: 55px;
    height: 15px;
  }
}

/*=====================================================
  dialogue/case01/
=====================================================*/
.case01{}
.case01 #pageMain {
  background: #F2F2F7;
  padding-bottom: 80px;
}
@media only screen and (max-width:767px){
  .case01 #pageMain {
    padding-bottom: 35px;
  }
}
.case01 #pageMain #pageTtlMain {
  font-family: 'Zen Kaku Gothic New';
  width: 100%;
  height: 580px;
  overflow: inherit;
}
.case01 #pageTtlMain .ttlImgBox{
  height: 580px;
}
.case01 #pageTtlMain .ttlBox .contentsInner div{
  position: relative;
  /*border: 3px solid #f0f;*/
}
.case01 #pageMain #pageTtlMain .ttlBox {
  top: 140%;
  text-align: right;
}
@media only screen and (max-width: 767px) {
  .case01 #pageMain #pageTtlMain {
    height: 350px;
  }
  .case01 #pageMain #pageTtlMain .ttlBox {
    width: inherit;
    top: 615px;
  }
  .case01 #pageMain #pageTtlMain .ttlImgBox {
    
  }
  .case01 #pageMain #pageTtlMain .ttlImgBox img {
    padding-top: 70px;
    object-position: 40% 0;
  }
}
.case01.door #pageTtlMain .ttlBox h1 span{
  display: inline-block;
  position: relative;
  font-family: 'Zen Kaku Gothic New';
  font-style: normal;
  font-weight: 700;
  /*font-size: 64px;*/
  font-size: clamp(24px, calc(24px + (64 - 24) * ((100vw - 768px) / (1280 - 768))), 64px);
  line-height: 120%;
  color: #3071B9;
  writing-mode: vertical-rl;
  padding-top: 122px;
}
.case01.door #pageTtlMain .ttlBox h1 span::before{
  content:'';
  position: absolute;
  width: 0;
  height: 100px;
  left: 50%;
  top: 0px;
  border: 3px solid #3071B9;
}
@media only screen and (max-width: 767px) {
  .case01.door #pageTtlMain .ttlBox h1 span{
    font-size: 2.4rem;
    padding-top: 52px;
  }
  .case01.door #pageTtlMain .ttlBox h1 span::before{
    height: 40px;
    border: 1.5px solid #3071B9;
  }
}
#pageMain .contentsInner ul{
  display: flex;
  justify-content: center;
  gap: 140px;
  margin-top: 80px;
}
@media only screen and (max-width:767px){
  #pageMain .contentsInner ul{
    gap: 80px;
    margin-top: 40px;
  }
}
#pageMain .contentsInner ul li{
  text-align: center;
  position: relative;
  font-family: 'Zen Kaku Gothic New';
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 160%;
  letter-spacing: 0.25em;
  min-width: 260px;
}
@media only screen and (max-width:767px){
  #pageMain .contentsInner ul li{
    min-width: inherit;
    width: 40%;
    font-size: 1.1rem;
  }
}
#pageMain .contentsInner ul li:first-of-type::before,
#pageMain .contentsInner ul li:first-of-type::after{
  content: '';
  position: absolute;
  width: 1px;
  height: 138px;
  height: clamp(60px, 7.97vw, 138px);
  background: #333;
  top: 50%;
  left: calc(100% + 70px);
}
#pageMain .contentsInner ul li:first-of-type::before{
  transform: translate(-50%,-50%) rotate(45deg);
}
#pageMain .contentsInner ul li:first-of-type::after{
  transform: translate(-50%,-50%) rotate(-45deg);
}
@media only screen and (max-width:767px){
  #pageMain .contentsInner ul li:first-of-type::before,
  #pageMain .contentsInner ul li:first-of-type::after{
    height: clamp(60px, 7.97vw, 138px);
    left: calc(100% + 40px);
  }
}
#pageMain .contentsInner ul li span{
  display: block;
  padding: 20px 17px;
  max-width: 220px; 
  background: #FFF;
  border-radius: 8px;
  margin: 0 20px 8px 20px;
  /*border: 1px solid #f00;*/
}
#pageMain .contentsInner ul li img{
  width: auto;
}
@media only screen and (max-width:767px){
  #pageMain .contentsInner ul li span{
    padding: 24px 10px;
    border-radius: 3.56688px;
    margin: 0 10px 8px 10px;
  }
}

article#contents .section .ttlBox .date {
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 180%;
  margin-bottom: 32px;
}
article#contents .section .ttlBox h1{
  font-family: 'Zen Kaku Gothic New';
  font-weight: 700;
/*  font-size: 4.0rem;*/
  font-size: clamp(28px, calc(28px + (40 - 28) * ((100vw - 768px) / (1280 - 768))), 40px);
  line-height: 160%;
  margin-bottom: 24px;
  color: var(--textColorBlack);
}
article#contents .section .ttlBox h1 + .catch{
  font-weight: 700;
  font-size: clamp(20px, calc(20px + (24 - 20) * ((100vw - 768px) / (1280 - 768))), 24px);
  line-height: 180%;
  margin-bottom: 64px;
}
@media only screen and (max-width:767px){
  article#contents .section .ttlBox .date {
    margin-top: 48px;
  }
}

/* sec02------------------------------------------*/
.section#ac02 .col-2:last-of-type{
  margin-top: 32px;
}
@media only screen and (max-width: 1024px){
  .section#ac02 .col-2{
    flex-direction: column;    
  }
  .section#ac02 .col-2 > * {
    width: 100%;
  }
  .section#ac02 figure.sp-dsp-block.tb-dsp-block{
    margin-top: 24px;
  }
  .section#ac02 .col-2:last-of-type figure{
    order: 2;
  }
  .section#ac02 .col-2:last-of-type div{
    order: 1;
  }
}

/* プロフィール
------------------------------------------*/
#profileArea{
  background: #F8F8F8;
  padding: 20px 32px 24px;
  border-radius: 8px;
  margin-top: 40px;
}
#profileArea h2{
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 200%;
  position: relative;
  padding-left: 34px;
  margin-bottom: 26px;
}
#profileArea h2:before{
  content: '';
  position: absolute;
  background: url("/wx-mobility-lab/dialogue/img/dialogue_profile_icon.svg") no-repeat;
  width: 24px;
  height: 24px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
#profileArea .profileWrap{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2%;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 180%;
  letter-spacing: 0%;
}
#profileArea .profileInner{
  width: calc((96% - 1px) / 2);
}
#profileArea .profileInner:first-of-type{
  padding-right: 2%;
  border-right: 1px solid #e0e0e0;
}
#profileArea .profile figure{
  width: 100px;
}
#profileArea .profile .wrap {
  margin-left: 20px;
  width: calc(100% - 120px);
}
#profileArea .profile .wrap p{
  width: calc(100% - 120px);
}
#profileArea .profileText{
  margin: 10px 0 0 120px;
}
@media only screen and (max-width: 1024px){
  #profileArea .profileWrap{
    flex-direction: column;
  }
  #profileArea .profileInner{
    width: auto;
    padding: 0 0 24px 0;
    margin-bottom: 24px;
    border-bottom: 1px solid #e0e0e0;
    border-right: none !important;
  }
  #profileArea .profileInner:last-of-type{
    padding: 0;
    margin-bottom: 0;
    border-bottom: none;
  }
  #profileArea .profile .wrap p {
    width: 100%;
  }
  #profileArea .profileText{
    margin: 16px 0 0 0;
  }
}
/* メッセージ
------------------------------------------*/
#message{
  background: linear-gradient(124.18deg, rgba(112, 186, 244, 0.1) 4.25%, rgba(63, 13, 149, 0.1) 98.93%);
  border-radius: 8px;
  padding: 40px 55px; 
}
#message.profileWrap .profileInner + .profileInner{
  margin-top: 40px;
}
#message .profile{
  margin-left: 95px;
}
#message h2 span{
  height: 10em;
  writing-mode: vertical-rl;
  font-family: 'Zen Kaku Gothic New';
  font-weight: 700;
  font-size: 3.2rem;
  line-height: 120%;
  position: absolute;
  color: #3071B9;
  padding-top: 60px;
}
#message h2 span::before{
  content:'';
  position: absolute;
  width: 0;
  height: 40px;
  left: 50%;
  top: 0;
  border: 3px solid #3071B9;
}
#message h3,
#message p{
  margin-left: 95px;
}
#message .profile figure{
  max-width: 140px;
}
#message .profile .wrap p{
  font-size: 1.6rem;
}
@media only screen and (max-width:767px){
  #message{
    padding: 32px 16px; 
  }
  #message .profile{
    margin-left: 0;
  }
  #message h2 {
    height: 4em;
  }
  #message h2 span{
    height: auto;
    writing-mode: inherit;
    padding-top: 0px;
    padding-left: 24px;
    font-size: 1.6rem;
  }
  #message h2 span::before{
    width: 16px;
    height: 0;
    left: 0;
    top: 50%;
    border: 2px solid #3071B9;
  }
  #message h3,
  #message p{
    margin-left: 0;
  }  
}


/* fotterSnbNavi
---------------------------------------------------*/
/* 他の記事を見る */
.case01 #footerSubNavi #reference li.reference_dialogue_denso{
  display: none;
}

/* こちらもぜひご覧ください */
#footerSubNavi #moreInfo li.moreInfo_report,
#footerSubNavi #moreInfo li.moreInfo_keyword,
#footerSubNavi #moreInfo li.moreInfo_denso{
  display: none;  
}
/*
#footerSubNavi #moreInfo li.moreInfo_story{}
#footerSubNavi #moreInfo li.moreInfo_issue{}
#footerSubNavi #moreInfo li.moreInfo_innovation{}
#footerSubNavi #moreInfo li.moreInfo_keyword{}
#footerSubNavi #moreInfo li.moreInfo_report{}
#footerSubNavi #moreInfo li.moreInfo_denso{}
#footerSubNavi #moreInfo li.moreInfo_aboutrever{}
*/



