@charset "UTF-8";
/* CSS Document */
/*
Version : 1.6
*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200;300;400;500;600;700&display=swap');

/*------------------------------------------------------
　基準レイアウト
------------------------------------------------------*/
body {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 18px;
  font-weight: 300;
  /*color:#333;*/
  color: #000;
  width: 100%;
  padding: 0;
  margin: 0;
}
header {
  /* text-align: center; */
  overflow: hidden;
}

section {
  padding: 5.8em 0 5.8em 0;
  text-align: center;
}

h1{
	font-family: 'Noto Serif JP', serif;
	color: #fff;
	text-align: center;
	font-weight: 600;
	letter-spacing: 1rem;
	text-shadow: 1px 1px 4px #6598B5;

}

h2{
	font-family: 'Noto Serif JP', serif;
	color: #fff;
	text-align: center;
	font-weight: 600;
	    letter-spacing: 0.5rem;
    line-height: 3rem;
}
h4 {
  text-align: left;
	font-family: 'Roboto Condensed', sans-serif;
	 color: #4B4B4B;
 font-size: 200%;
 letter-spacing: 0.3rem;
	    margin-block-start: 0em;
    margin-block-end: 0em;

}
h3 {
 color: #fff;
	font-size: 150%;
	font-weight: normal;
	 letter-spacing: 0.5rem;
    line-height: 3rem;
}
main {
  overflow: hidden;
}
dd {
  margin-inline-start: 0px;
}
ul {
  padding-inline-start: 0px;
}


@media screen and (max-width: 768px) {
section{
    padding: 3em 0 4em;
	}}
@media screen and (max-width: 570px) {


		h2{
		font-size: 95%;
			letter-spacing: 0.3rem;
line-height: 2rem;
	}
	
	h3{
		font-size: 105%;
		letter-spacing: 0.3rem;
 line-height: 1.8rem;
	}
	
	h4{
		font-size: 140%;
	}
	

}





.notes{font-size: 80%; color:#990000;}
.txt-right{text-align: right;}
.txt-left{text-align: left;}
.txt-center{text-align: center;}
.sp_hidden {
  display: block;
}
.sp_hidden02 {
  display: block;
}
.pc_hidden {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp_hidden {
    display: none;
  }
  .pc_hidden {
    display: block;
  }
	
	.sp_hidden02 {
  display: none;
}
}
.kv {
  width: 100%;
  display: block;
  overflow: hidden;
  background-color: #000;
	position: relative;

}

.kv h1{
	font-size: 280%;
	position: absolute;
	width: 100%;
	bottom: 55%;
    left: 52%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);

}
.kv_town img {
  width: 100%;
  height: auto;
	
}
.kv_img{
	position: absolute;
	/*ここ全部消すとなくなってしまう　0%って書くことに意味あり*/
    bottom: 0;
    left: 60%;
    transform: translateX(-60%);
    -webkit-transform: translateX(-60%);
    -ms-transform: translateX(-60%);
}
.kv_img img{
	width: 70%;
	height: auto;
}

@media screen and (max-width: 1080px) {
	.kv h1{
		bottom: 53%;
		font-size: 250%;
	}
}

@media screen and (max-width: 767px) {
	
	.kv h1{
		bottom: 53%;
		font-size:250%;
	}
  .kv_town  {
    width: 150%;
    height: auto;
    margin-left: -23%;
  }
	
	.kv_img{
		 left: 50%;
 transform: translateX(-45%);
 -webkit-transform: translateX(-45%);
	}

	.kv_img img{
		width: 90%;
		height: auto;
	}
	
	
}
@media screen and (max-width: 570px) {
	
	.kv h1{
		bottom: 48%;
		font-size:200%;
	}
	
	  .kv_town  {
    width: 180%;
    height: auto;
    margin-left: -23%;
  }
}

.lead {
  background-color: #000;
	color: #fff;
}
.lead p{
	margin-top: 3rem;
	letter-spacing: 0.1rem;
}
.vgo_gra{
	width: 127px;
	height: 14px;
}
.lead h2 span{
	display: flex;
	justify-content: center;
	align-items: center;
	
}

h2 img{
	width: 72px;
	height: 38px;
	margin-right: 0.5rem;
}
.container {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 1rem;
}
.lead .container {
  position: relative;
}
.lead .container::before {
  content: '';
  display: inline-block;
  width: 148px;
  height: 147px;
  background-image: url("../images/mark02.svg");
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
margin-top: -10%;
 margin-left: -40%;
  position: absolute;
}
.lead .container::after {
  content: '';
  display: inline-block;
  width: 44px;
  height: 134px;
  background-image: url("../images/mark01.svg");
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-top: -55%;
  margin-left: 35%;
  position: absolute;
}

@media screen and (max-width: 767px) {
	h2 img{
	width: 10%;
	height: auto;
	margin-right: 0.5rem;
}
	
	  .container {
    max-width: unset;
    width: 90%;
    margin: auto;
  }

}
@media screen and (max-width: 570px) {
	  .vgo_gra {
    width: 40%;
    height: auto;
    z-index: 10;
  }
  .lead .container::after {
    margin-top: -120%;
    margin-left: 44%;
  }
  .lead .container::before {
    margin-top: 70%;
    margin-left: -55%;
  }
	

	.lead p{
		font-size: 90%;
	}
	
}

.tit_flex{
	display: flex;
	justify-content: center;
	align-content: center;
	margin-bottom: 0.5rem;
}
.unline{
	background-image: linear-gradient(to right, #F3EFA4, #B188BC);
		background-repeat: no-repeat;
	background-size: 100% 3%;
	background-position: right 10% bottom 10%;
}
.service {
  background: linear-gradient(#393A3B, #080404);
}

.service img:last-child{
	width: 641px;
	height: 627px;
	margin-top: 2rem;
}
.tit_flex img {
  width: 97px;
  height: 52px;
	margin-right: 0.8rem;
}
.service .container {
  position: relative;
}
.service .container::before {
  content: '';
  display: inline-block;
  width: 130px;
  height: 181px;
  background-image: url("../images/mark03.svg");
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-left: 30%;
  margin-top: -16%;
  position: absolute;
}

@media screen and (max-width: 950px) {
.service img:last-child{
	width: 90%;
	height: auto;
	}}


@media screen and (max-width: 767px) {
  .service img {
    width: 95%;
    height: auto;
  }
  .service .container::before {
   margin-left: 45%;
    margin-top: 10%;
  }
	.tit_flex img {
  width: 10%;
  height: auto;
	margin-right: 0.5rem;
}
	
}

.ico_flex{
	display: flex;
	 align-items: center;
}
.works {
  background-color: #D2D2D2;
  text-align: left;
}
.ico_flex img {
  width: 73px;
  height: 73px;
	 margin-right: 1.5rem;
}

@media screen and (max-width: 570px) {
  .ico_flex img {
    width: 10%;
    height: auto;
	  margin-right: 1rem;
  }
}



.works ul {
  display: flex;
  justify-content: space-between;
}
.works li:first-child img {
  width: 100%;
  height: auto;
}
.works li:last-child img {
  width: 100%;
  height: auto;
}
.works_detail {
  margin-left: 6rem;
}
.works p {
  width: 230px;
  padding: 0.1rem 0.5rem;
  font-weight: 600;
  border: solid 1px;
  font-size: 14px;
  text-align: center;
}
.works dt {
  font-size: 130%;
  font-weight: 600;
  letter-spacing: 0.3rem;
  line-height: 1.8rem;
}
.works dt span {
  font-weight: 600;
  color: #646464;
  font-size: 70%;
  letter-spacing: 0rem;
  display: block;
  line-height: 1.3rem;
}
.works dd {
  margin-top: 1rem;
  line-height: 1.5rem;
  font-size: 90%;
  font-weight: 500;
}
.works dd:last-child {
  margin-top: 2rem;
}
.works dd a {
  color: #fff;
  background-color: #000;
  padding: 0.3rem 0.8rem 0.4rem;
  letter-spacing: 0.1rem;
}
@media screen and (max-width: 767px) {
  .works_detail {
    margin-left: 0rem;
  }
}
@media screen and (max-width: 570px) {
  .works ul {
    display: block;
  }

  .works li:last-child img {
    width: 80%;
    height: auto;
    display: inline-block;
    margin-bottom: 2rem;
    margin-top: 1rem;
    padding: 0rem 2rem;
  }
  .works li {
    margin: 0 auto;
  }
}
.contact h4 {
  margin-block-start: 0em;
  margin-block-end: 0em;
}

.contact p {
  text-align: left;
  font-size: 90%;
  font-weight: 500;
  margin-left: 6rem;
  margin-block-start: 0em;
  margin-block-end: 0em;
}
.con_btn img {
  width: 33px;
  height: 11px;
  margin-right: 1rem;
}
.con_btn a {
  display: flex;
  align-items: center;
  background-color: #000;
  padding: 0.5rem 2rem 0.7rem;
  color: #fff;
  font-weight: 500;
  letter-spacing: 0.3rem;
  max-width: 200px;
  margin: 2rem auto 0rem;
}
@media screen and (max-width: 767px) {
  .contact p {
    margin-left: 0rem;
	      margin-top: 0.8rem;
  }
}

.fadeIn{
			animation: anime_a 2s;
	animation-delay: 1s;
}
@keyframes anime_a {
  0% {
    opacity: 0;
	  transform : translate(0, 50px);
  }
  100% {
    opacity: 1;
	  transform : translate(0, 0);
  }
}

.fadein {
	opacity : 0;
	transform : translate(0, 50px);
	transition : all 0.8s ease-out; 
	}

/* 画面内に入った状態 */
.fadein.scrollin {
	opacity : 1;
	transform : translate(0, 0);
	}
/* 画面内に入った状態 */
.fadein.scrollin {
	opacity : 1;
	transform : translate(0, 0);
	}


.fadein_l {
	opacity : 0;
	transform : translate(0, 50px);
	transition : all 0.8s ease-out; 
	animation-delay: 0.2s;
	}

/* 画面内に入った状態 */
.fadein_l.scrollin {
	opacity : 1;
	transform : translate(0, 0);
	}
/* 画面内に入った状態 */
.fadein_l.scrollin {
	opacity : 1;
	transform : translate(0, 0);
	}

/*------------------------------------------------------
　header
------------------------------------------------------*/
header.grd {
  background: linear-gradient(#acd4e2, #f4f4f4, #f4f4f4);
}
.release_img {
  width: 45%;
  margin-right: 1.5em;
}
.yotei_img {
  width: 8%;
}
.kv_container {
  max-width: 1700px;
  margin: 1.8em auto 0 auto;
  position: relative;
}
.kv_container .c_lp_bana {
  position: absolute;
  width: 21%;
  bottom: 20.5%;
  left: 24%;
  z-index: 9;
}
.kv_container .c_lp_bana:hover {
  opacity: 0.9;
}
@media screen and (max-width:768px) {
  .kv_container .c_lp_bana {
    position: unset;
    width: 320px;
  }
}
/* キャラクター位置 */
.swiper-container {
  position: relative;
  z-index: 5;
  right: 0 !important;
  top: 0 !important;
}
.swiper-container .swiper-slide {
  position: relative;
  z-index: 5;
  width: 100%;
  right: 0 !important;
  top: 0 !important;
}
h1.logo_position {
  position: absolute;
  content: "";
  top: -0.5em;
  left: 20.4%;
  /*top:1em;
  left:20%;*/
  transform: translate(37%, 8%);
  z-index: 999;
  width: 22%;
  height: auto;
}
.slide {
  position: relative;
  z-index: 5;
}
.bxslider {
  position: relative;
  z-index: 10;
}
.bx-wrapper {
  background-color: transparent !important;
  border: 0 !important;
  -webkit-box-shadow: 0 0 0 #ccc !important;
  box-shadow: 0 0 0 #ccc !important;
  margin-bottom: 0 !important;
}
/* キャラクター位置 */
.modakuro_bg {
  width: 100%;
  position: absolute;
  content: "";
  top: 1em;
  left: 10%;
  transform: translate(-9%, 40%);
  z-index: 2;
}
.slide_b {
  width: 100%;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  transform: translate(0, 0);
  z-index: 4;
}
.kage {
  width: 42%;
  position: absolute;
  content: "";
  top: 1em;
  left: 10%;
  transform: translate(96%, -3%);
  z-index: 2;
}
.modakuro_bg_h {
  width: 50%;
  position: absolute;
  content: "";
  top: 1em;
  left: 10%;
  transform: translate(5%, -30%);
  z-index: 1;
}
/* 切り替え */
.sp_wrap {
  display: none;
}
/*------------------------------------------------------
　共通
------------------------------------------------------*/

h2 span.t_big {
  font-size: 160%;
}
h2.k_title {
  letter-spacing: 5px;
  margin-bottom: 2.3em;
  line-height: 1px;
  color: #996633;
}
p {
  letter-spacing: 1px;
  line-height: 1.9em;
}
a {
  color: #3d2c2e;
  text-decoration: none;
}
img {
  width: 100%;
}
ul {
  list-style-type: none;
}
.bold500 {
  font-weight: 500;
}
.bold600 {
  font-weight: 600;
}
.color_tya {
  color: #996633;
  font-weight: 600;
}
.bg_gure {
  background: #f4f4f4;
  width: unset;
}
.flex_w {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
header .bg_gure .flex_w {
  align-items: center;
  padding: 1.7em 0 4em 0;
  /*padding:1.7em 0 0.9em 0;*/
}
.small_text {
  font-size: 80%;
}
.font_title {
  font-family: 'Noto Serif JP', serif;
}
span.test_dami {
  color: red;
  font-weight: 800;
}
.btn_style {
  padding: 1.5em 1.3em;
  background: #fff;
  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, .2);
  align-items: center;
  border: 1px solid #3d2c2e;
  position: relative;
  transition-duration: 0.2s;
}
.btn_style:hover {
  background: #3d2c2e;
  border: 1px solid #3d2c2e;
  color: #fff;
}
.btn_style:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 40px 40px;
  border-color: transparent transparent #3d2c2e transparent;
}
.btn_style span.ya_icon {
  position: absolute;
  bottom: 12px;
  right: 20px;
  display: inline-block;
}
.btn_style span.ya_icon:after {
  content: '';
  width: 6px;
  height: 6px;
  border: 0;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 4px;
  margin-top: -3px;
}
.contact_wrap {
  padding: 0;
}
.contact_wrap a:hover {
  text-decoration: none;
}
/* アイコン */
.fa-twitter-square {
  font-size: 160%;
  margin: 0 0.3em;
}
/* マージン 下*/
.mtp20 {
  margin-top: 20px;
}
.mbt20 {
  margin-bottom: 20px;
}
.mbt30 {
  margin-bottom: 30px;
}
.mbt40 {
  margin-bottom: 40px;
}
.mbt50 {
  margin-bottom: 50px;
}
.mbt60 {
  margin-bottom: 60px;
}
.mbt5em {
  margin-bottom: 5em;
}
.mbt10em {
  margin-bottom: 10em;
}
/* マージン 左*/
.mbl_18p {
  margin-left: 18%;
}
.sns_set {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.c_lp_bana {
  width: 290px;
  margin: 0 auto;
}
/*---------------------------------------------------
footer
---------------------------------------------------*/
footer {
  background: #000;
  color: #fff;
  padding: 2em 0 1em 0;
  font-size: 80%;
}
/*footer .container{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items:bottom;
  padding:1rem 0 0 0;
}

footer .f_logo {
  width: 16%;
  margin: 0 2rem 0 0;
}
footer dl{
  display:block;
  margin-right:2rem;
  margin-bottom: 0;
}

footer .copyright{
  font-size:80%;
  color:#fff;
  margin-top: auto;
}

@media all and (max-width:767px) {
    footer .container{
      display:block;
    }
      footer dl{
      margin-right:0;
      margin:0 auto 1rem auto;
    }
}
*/
/*------------------------------------------------------
　建築の“声”を聴く、まち歩き音声ガイドアプリ
------------------------------------------------------*/
.explanation_wrap h2 {
  color: #996633;
  font-size: 190%;
  /*margin-bottom: 1.2em;*/
}
.explanation_wrap h2 br {
  display: none;
}
.explanation_wrap a {
  border-bottom: 1px solid #3d2c2e;
  font-weight: 600;
}
.explanation_wrap a:hover {
  color: #996633;
  border-bottom: 1px solid #996633;
}
.explanation_wrap a i {
  margin-right: 5px;
}
.explanation_wrap p {
  margin-bottom: 1.8em;
  line-height: 2.5em;
}
.explanation_wrap p:last-child {
  margin-bottom: 0;
}
section.explanation_wrap {
  padding: 5.8em 0 5em 0;
  text-align: center;
}
/*------------------------------------------------------
　選べる2つのバージョン
------------------------------------------------------*/
.version_wrap h3 {
  font-size: 160%;
  font-family: 'Noto Serif JP', serif;
}
.version_wrap .small_text {
  margin-bottom: 3em;
}
/* ラーニング バージョン */
.version_wrap dl.l_version {
  /*width: 47%;*/
  width: 460px;
  margin-right: 2em;
  position: relative;
  overflow: hidden;
}
.version_wrap dl.l_version dt {
  padding: 0.9em 0;
  background: #669999;
  color: #fff;
  border-bottom: 3px solid #fff;
}
.version_wrap dl.l_version dd {
  background: #99cccc;
  padding: 1.4em 2em;
  text-align: left;
  font-size: 90%;
}
.version_wrap .version_text {
  margin-bottom: 50px;
}
.version_wrap dl.l_version::before {
  position: absolute;
  content: "";
  background: url(../images/bg_l_version.png) no-repeat;
  background-size: cover;
  bottom: -10px;
  right: -10px;
  width: 260px;
  height: 300px;
  z-index: 1;
  opacity: 0.8;
}
/* キャラクター バージョン */
.version_wrap dl.k_version {
  /*width: 48%;*/
  width: 460px;
  position: relative;
  overflow: hidden;
}
.version_wrap dl.k_version dt {
  padding: 0.9em 0;
  background: #cc9999;
  color: #fff;
  border-bottom: 3px solid #fff;
}
.version_wrap dl.k_version dd {
  background: #ffcccc;
  padding: 1.4em 2em;
  text-align: left;
  font-size: 90%;
}
.version_wrap dl.k_version::before {
  position: absolute;
  content: "";
  background: url(../images/bg_k_version.png) no-repeat;
  background-size: cover;
  bottom: -5px;
  right: 0;
  width: 220px;
  height: 290px;
  z-index: 1;
}
.version_wrap p {
  position: relative;
  z-index: 5;
}
.version_wrap .c_lp_bana_re {
  position: relative;
}
.version_wrap .c_lp_bana_re a:hover {
  opacity: 0.7;
}
.version_wrap .c_lp_bana_re .c_lp_bana {
  position: absolute;
  width: 250px;
  height: 50px;
  bottom: -18%;
  right: 17.5%;
}
dl.l_version .small_text, dl.k_version .small_text {
  margin-bottom: 0;
}
.version_wrap .container {
  position: relative;
  padding: 0 0 4.5em 0;
  /*width:50%!important;*/
}
.version_wrap .container::before {
  position: absolute;
  content: "";
  background: url(../images/sp_img01.png) no-repeat;
  background-size: contain;
  top: -18em;
  left: -150px;
  width: 200px;
  height: 420px;
  z-index: 1;
}
.version_wrap .container::after {
  position: absolute;
  content: "";
  background: url(../images/sp_img02.png) no-repeat;
  background-size: contain;
  right: -150px;
  width: 200px;
  height: 420px;
  z-index: 1;
  bottom: -24.5em;
}
@media screen and (max-width:990px) {
  .version_wrap .c_lp_bana_re .c_lp_bana {
    position: absolute;
    width: 250px;
    height: 50px;
    bottom: -18%;
    right: 12%;
  }
}
@media screen and (max-width:760px) {
  .version_wrap .c_lp_bana_re .c_lp_bana {
    position: unset;
    margin: 1em auto;
    width: 320px;
  }
}
/*------------------------------------------------------
　コース紹介
------------------------------------------------------*/
.course_wrap .flex_w {
  margin-top: 3em;
}
.course_wrap .flex_w dl h3 {
  color: #996633;
  letter-spacing: 1px;
  text-align: left;
  border-bottom: 1px solid #333;
  margin-bottom: 10px;
  padding: 0 0 5px 15px;
}
.course_wrap dl {
  width: 33%;
  margin-right: 8em;
}
.course_wrap dl:last-child {
  margin-right: 0;
}
.course_wrap dl dd {
  text-align: left;
}
.course_wrap dl dd ul {
  margin-left: 20px;
}
.course_wrap dl dd ul li {
  /*position: relative;*/
  line-height: 3em;
}
.course_wrap dl dd ul li i {
  margin-right: 5px;
  color: #996633;
}
/*------------------------------------------------------
　ナレーション／キャスト
------------------------------------------------------*/
.narration_cast h2 {
  /*margin-bottom:2.5em;*/
}
.narration_cast h3 {
  font-size: 170%;
  margin-bottom: 0.1em;
  letter-spacing: 1px;
}
.narration_cast dl {
  margin-bottom: 5em;
}
.narration_cast dl:last-child {
  margin-bottom: 0;
}
.narration_cast dl dt {
  width: 68%;
  height: auto;
  text-align: left;
  order: 2;
  /*padding:1em 0;*/
}
.narration_cast dl dd {
  width: 32%;
  height: auto;
  padding-right: 1.5em;
  /*padding-right:2.3em;*/
  box-sizing: border-box;
  order: 1;
}
.narration_cast dl.dl_list {
  display: flex;
  flex-wrap: wrap;
  margin: 1em 0 0 0;
  align-items: center;
}
.narration_cast dl.dl_list dt {
  /*width:6%;*/
  width: 8%;
  font-size: 80%;
  order: 1;
}
.narration_cast dl.dl_list dd {
  /*width:94%;*/
  width: 92%;
  font-size: 80%;
  border-left: 1px solid #3d2c2e;
  padding: 0 0 0 1%;
  box-sizing: border-box;
  order: 2;
}
.narration_cast .container {
  max-width: 960px;
}
.narration_cast .dd_list br {
  display: none;
}
/*------------------------------------------------------
　監修メッセージ
------------------------------------------------------*/
.k_message h2 {
  color: #996633;
  /*margin-bottom: 1em;*/
}
.k_name {
  font-size: 140%;
  text-align: right;
  font-family: 'Noto Serif JP', serif;
  padding-right: 6em;
  margin-bottom: 3em;
}
.k_name span {
  font-size: 60%;
  margin-right: 1em;
}
.k_name_text {
  font-size: 80%;
  text-align: left;
  font-family: 'Noto Serif JP', serif;
  border: 1px solid #996633;
  width: 60%;
  margin: auto;
  padding: 1.5em 2em;
  position: relative;
}
.k_name_text:before {
  content: "Profile";
  position: absolute;
  top: -18px;
  left: 38%;
  font-size: 150%;
  background: #fff;
  padding: 0 12px;
  transform: translate(38%, 5%);
  color: #996633;
}
.k_name_text_t {
  font-weight: 600;
  /*border-bottom:1px solid #ccc;*/
  padding: 5px;
}
.k_name_text ul {
  padding: 5px;
}
.k_message_text {
  /*width:90%;
  margin:auto;
  text-align:left;*/
  width: 81%;
  margin: auto;
  text-align: left;
  font-size: 90%;
}
.k_message_text p {
  /*line-height:2em;*/
  margin-bottom: 2em;
}
/*------------------------------------------------------
　performer_wrap
------------------------------------------------------*/
.performer_wrap h2 img {
  width: 230px;
}
.performer_wrap h2.k_title {
  margin-bottom: 1.5em;
}
.performer_wrap .container dl {
  text-align: left;
  margin: 2em auto 0 auto;
  max-width: 670px;
  border: 1px solid #cdc5c5;
  padding: 3%;
}
.performer_wrap .container dt {
  color: #926331;
  /*border-left: 6px solid #926331;*/
  /*padding-left: 10px;*/
  margin-bottom: 1.5em;
  font-size: 120%;
  text-align: center;
}
.performer_wrap .container dt p {
  line-height: 1.1em;
  font-weight: 500;
}
.performer_wrap .container dd {
  padding-left: 1em;
  line-height: 1.2em;
}
.performer_wrap .container dd .line_s {
  line-height: 1.6em;
}
.performer_wrap .container dd p span {
  font-size: 13px;
}
.performer_wrap a:hover {
  opacity: 0.7;
}
.performer_wrap .c_lp_bana {
  margin: 4em auto 0 auto;
}
/*------------------------------------------------------
　NEWS
------------------------------------------------------*/
.whatnew_wrap dl span.icon {
  background: #926331;
  color: #fff;
  padding: 0 8px 4px 7px;
  margin: 2px 10px 0 12px;
  font-size: 80%;
  width: 60px !important;
  height: 22px;
  text-align: center;
}
.whatnew_wrap {
  padding: 4em 0 1em 0;
  text-align: center;
}
.whatnew_wrap .container {
  max-width: 900px;
}
.whatnew_wrap dl {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  margin: 0 auto;
  justify-content: center;
}
.whatnew_wrap dl dt {
  display: flex;
  flex-flow: wrap;
  width: 22%;
  font-weight: 600;
  margin-top: 5px;
  position: relative;
}
.whatnew_wrap dl dd {
  width: 78%;
  text-align: left;
}
.whatnew_wrap dl dt .yeardate {
  width: 130px;
  text-align: left;
}
.whatnew_wrap dl dt::before {
  position: absolute;
  content: "";
  background: url(../images/whatnew.png)no-repeat;
  background-size: 100%;
  width: 100px;
  height: 100px;
  background-position: center;
  top: -70px;
  left: 27%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (max-width:975px) {
  .whatnew_wrap {
    width: 80%;
    margin: auto;
  }
  .whatnew_wrap dl dt {
    width: 100%;
    font-weight: 600;
    margin-bottom: 15px;
  }
  .whatnew_wrap dl dd {
    margin-bottom: 30px;
    width: 100%;
    text-align: left;
  }
  .whatnew_wrap dl dt::before {
    top: -70px;
    left: 6%;
  }
}
@media screen and (max-width:768px) {
  .whatnew_wrap {
    width: 90%;
  }
}
@media screen and (max-width:570px) {
  .whatnew_wrap {
    width: 95%;
  }
}
.news_wrap {
  position: relative;
  max-width: 1000px;
  margin: auto;
}
.news_wrap h2.k_title {
  letter-spacing: 5px;
  margin-bottom: 1.1em;
  line-height: 1px;
  color: #996633;
}
.news_wrap .sns_wrap_text {
  margin-bottom: 3em;
}
.news_wrap dl p {
  letter-spacing: 1px;
  line-height: 1.4em;
}
.news_wrap dt {
  display: flex;
  flex-flow: wrap;
}
.news_wrap dl span.icon {
  background: #926331;
  color: #fff;
  padding: 0 8px 4px 7px;
  margin: 2px 10px 0 12px;
  font-size: 80%;
  width: 60px !important;
  height: 22px;
  text-align: center;
}
section.news_wrap dl {
  display: flex;
  flex-flow: row wrap;
  width: 92%;
  margin: 0 auto;
  justify-content: center;
}
section.news_wrap dl dt {
  width: 20%;
  font-weight: 600;
  /*! margin-bottom: 12px; */
}
section.news_wrap dl dt .yeardate {
  width: 130px;
  text-align: left;
}
section.news_wrap dl dd {
  margin-bottom: 30px;
  width: 80%;
  text-align: left;
}
@media screen and (max-width:967px) {
  section.news_wrap dl dt {
    width: 100%;
  }
  section.news_wrap dl dd {
    width: 100%;
  }
}
@media screen and (max-width:570px) {
  section.news_wrap dl dt {
    margin-bottom: 5px;
  }
  .news_wrap dl span.icon {
    padding: 2px 8px 3px 7px;
  }
}
/*------------------------------------------------------
　SNS
------------------------------------------------------*/
.sns_wrap h2.k_title {
  font-size: 230%;
  margin-bottom: 0.8em;
}
.fa-line {
  font-size: 150%;
  margin-right: 5px;
}
.fa-instagram-square {
  font-size: 150%;
}
.sns_wrap_text {
  margin-bottom: 2em;
}
.sns_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
/*
.sns_list .twitter,
.sns_list .instagram{
  width: 45%;
  margin:3em auto 0 auto;
}*/
.sns_list .twitter, .sns_list .facebook {
  max-width: 480px;
  width: 43%;
  margin: 3em 2% 0 2%;
  /*margin:3em auto 0 auto;*/
}
blockquote, q {
  quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
  content: '';
  content: none;
}
/*------------------------------------------------------
　お問い合わせ
------------------------------------------------------*/
.contact_wrap .sub_title {
  font-size: 230%;
  /*margin-bottom:-0.3em;*/
  font-weight: 700;
  color: #996633;
}
.contact_wrap h2 {
  font-size: 100%;
  font-weight: 300;
  margin-bottom: 1em;
  font-family: 'Noto Sans JP', sans-serif;
}
.contact_wrap .flex_w a {
  margin-right: 2.5%;
}
.contact_wrap .flex_w a:last-child {
  margin-right: 0;
}
.form_send {
  border: 1px solid #ccc;
  padding: 2em 2em 2em 2em;
  background: #eee;
  margin-bottom: 1em;
}
/*------------------------------------------------------
　コンタクト
------------------------------------------------------*/
h2.main_title {
  letter-spacing: 5px;
  margin-bottom: 2em;
  color: #996633;
  font-size: 230%;
}
#contact section {
  padding: 0;
}
/* Thanks */
.contact_k #mailform .container {
  max-width: 1170px;
  padding: 0 1%;
  margin: 0 auto 44vh auto;
}
#contact header h1 {
  /* width: 15%; */
  text-align: left;
  padding: 0.6em 0.5em;
  box-sizing: border-box;
  display: inline-block;
}
header img {
  width: 50%;
}
#contact .se_contact dl {
  display: flex;
  flex-wrap: wrap;
  /*border-bottom:1px dotted #3d2c2e;*/
  padding-bottom: 1.5em;
  /*background: #eee;*/
}
#contact .se_contact dl:last-child {
  border-bottom: 0;
}
#contact .se_contact dl dt {
  width: 25%;
  text-align: right;
  padding: 0 2em 0 0;
  box-sizing: border-box;
  padding-bottom: 10px;
}
#contact .se_contact dl dd {
  width: 75%;
  text-align: left;
  padding: 0 2em 0 0;
  box-sizing: border-box;
  padding-bottom: 10px;
}
#contact .se_contact dl input {
  border: 1px solid #777;
  width: 100%;
  border-radius: 5px;
  padding: 5px 15px;
}
#contact .note_text {
  margin: 3em 0 4em 0;
}
#contact h3 {
  font-family: 'Noto Sans JP', sans-serif;
}
input::placeholder {
  color: #ccc;
}
label {
  padding: 0;
  margin: 0;
}
label span {
  color: #996633;
  font-size: 100%;
}
span.label_su {
  margin-top: -10px !important;
  display: block;
}
#contact .se_contact dl select {
  border: 1px solid #777;
  border-radius: 5px;
  padding: 12px 15px;
  color: #3d2c2e;
	width: 100%;
}
#contact .se_contact dl textarea {
  border: 1px solid #777;
  border-radius: 5px;
  padding: 5px 15px;
  color: #3d2c2e;
  width: 100%;
  height: 180px;
}
#mailform .form_wrap h3.sub_title {
  letter-spacing: 2px;
}
form {
  width: 80%;
  margin: auto;
}
.form_button {
  border: 1px solid #333;
  background: #000;
  color: #fff;
  padding: 0.5em 1em;
  text-align: center;
  width: 165px;
  margin: 5%;
  position: relative;
}
.form_button:hover {
  background: #fff;
  color: #333;
}
.form_button:before {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 25px 25px;
  border-color: transparent transparent #fff transparent;
}
.form_button span.ya_icon {
  position: absolute;
  bottom: 12px;
  right: 20px;
  display: inline-block;
}
.form_button span.ya_icon:after {
  content: '';
  width: 6px;
  height: 6px;
  border: 0;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 9px;
  margin-top: 1px;
}
.error {
  color: red;
  font-size: 80%;
}
.hissu {
  text-align: center;
  font-size: 80%;
  color: #996633;
  font-weight: 500;
  margin-bottom: 2em;
}
.contact_wrap .container {
  position: relative;
}
.contact_wrap .container .tyu_text {
  position: absolute;
  right: 8%;
  bottom: -6.5em;
  font-size: 14px;
  width: 300px;
}
@media screen and (max-width:768px) {
  .contact_wrap .container .tyu_text {
    bottom: unset;
    font-size: 14px;
    margin: 20% auto 0 auto;
  }
}
/*------------------------------------------------------
　パンくず
------------------------------------------------------*/
.pankuzu {
  text-align: center !important;
  margin-bottom: 3em;
}
.pankuzu ul li span {
  font-size: 80%;
  position: relative;
}
.pankuzu ul li span:after {
  content: '';
  width: 6px;
  height: 6px;
  border-top: solid 1px #222;
  border-right: solid 1px #222;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 38%;
  left: -15px;
}
@media screen and (max-width:1450px) {
  .version_wrap .container::after {
    background-size: 70%;
    right: -79px;
  }
  .version_wrap .container::before {
    background-size: 70%;
    left: -15px;
    top: -13em;
  }
}
@media screen and (max-width:1060px) {
  .narration_cast dl.dl_list dd br {
    display: none;
  }
  .narration_cast dl dt {
    padding: 0;
  }
}
@media screen and (max-width:990px) {
  .version_wrap .container::before {
    display: none;
  }
  .version_wrap .container::after {
    display: none;
  }
  .narration_cast dl.dl_list dt {
    font-size: 80%;
    border-right: 0;
    order: 1;
    text-align: center;
    padding-right: 10px;
    padding-top: 0;
    width: 5%;
  }
  .narration_cast dl.dl_list dd {
    border-left: 1px solid #333;
    font-size: 80%;
    padding-left: 10px;
    box-sizing: border-box;
    order: 2;
    width: 94%;
  }
}
@media screen and (max-width:960px) {
  .version_wrap dl.l_version {
    width: 45%;
    margin-right: 1em;
    position: relative;
    overflow: hidden;
  }
  .version_wrap dl.k_version {
    width: 45%;
    position: relative;
    overflow: hidden;
  }
  .course_wrap dl {
    margin-right: 3em;
    width: 40%;
  }
  h2.k_title {
    letter-spacing: 3px;
  }
  .k_name {
    padding-right: 3em;
  }
}
@media screen and (max-width:870px) {
  h2.k_title {
    line-height: unset;
  }
}
/*------ iPad mini ------------------------------------------------------------------------*/
@media screen and (max-width:768px) {
  /* キービジュアル */
  /* 切り替え */
  .sp_wrap {
    display: unset;
  }
  .pc_wrap {
    display: none;
  }
  /*------------------------------------------------------
  　KV
  ------------------------------------------------------*/
  .release_img {
    width: 80%;
    margin: 1em auto 0.6em auto;
    padding: 0;
  }
  .yotei_img {
    display: none;
  }
  .sp_yotei {
    background: #3d2c2e;
    padding: 0.2em 0.8em 0.3em 0.8em;
    border-radius: 3px;
    color: #fff;
    /*width: 80%;*/
    line-height: 2em;
    margin: 0 auto;
    font-size: 80%;
    display: inline-block;
  }
  header .bg_gure {
    /*margin-top:-30px;*/
    padding-bottom: 1.2em;
  }
  h1.logo_position {
    position: absolute;
    content: "";
    top: 4.3em;
    left: 0;
    transform: translate(0, 0);
    z-index: 999;
    width: 49%;
    height: auto;
  }
  .kage {
    width: 100%;
    position: absolute;
    content: "";
    bottom: 0;
    right: 10%;
    transform: translate(-10%, -1%);
    z-index: -1;
  }
  .modakuro_bg_h {
    width: 100%;
    position: absolute;
    content: "";
    top: -10%;
    left: -20%;
    transform: translate(0, 0);
    z-index: 1;
    opacity: 0.8;
  }
  .modakuro_bg {
    width: 100%;
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    transform: translate(0, 0);
    z-index: 2;
  }
  .slide_b {
    width: 100%;
    position: absolute;
    content: "";
    top: 0;
    right: 0;
    transform: translate(0, 0);
    z-index: 5;
  }
  .kv_bg {
    width: 100%;
    left: 0;
    transform: translate(0, 0);
    z-index: 9;
  }
  header .bg_gure .flex_w {
    display: unset;
    flex-wrap: unset;
    justify-content: unset;
    padding: 1.7em 0 0.9em 0;
  }
  .bx-wrapper {
    position: relative;
    z-index: 99;
  }
  #mailform .form_wrap .flex_w {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  .form_send {
    border: 1px solid #ccc;
    padding: 1em;
    background: #eee;
    margin-bottom: 1em;
  }
  .performer_wrap .container dl {
    text-align: left;
    margin: 2em auto 0 auto;
    width: 100%;
    border: 1px solid #cdc5c5;
    padding: 3%;
  }
  .flex_w {
    display: unset;
    flex-wrap: unset;
    justify-content: unset;
  }
  /*------------------------------------------------------
  監修メッセージ
  ------------------------------------------------------*/
  .k_name {
    padding-right: 2em;
  }
  .k_name_text {
    width: 100%;
  }
  .k_message_text {
    width: unset;
  }
  /*------------------------------------------------------
  footer
  ------------------------------------------------------*/
  footer {
    text-align: center;
  }
  /*footer .cp_wrap {
    margin-top: 20px;
    width: unset;
  }
  footer .f_logo {
    width: 20%;
    margin: 0 auto;
  }
  footer .f_company {
    line-height: unset;
    margin-right: 0;
    padding: 1em 2em;
  }
  footer .flex_w {
    display: unset;
    flex-wrap: unset;
    justify-content: unset;
  }*/
}
/*------ スマホ ------------------------------------------------------------------------*/
@media screen and (max-width:767px) {
  body {
    font-size: 16px;
	}
  /*------------------------------------------------------
  　共通
  ------------------------------------------------------*/
  p {
    letter-spacing: 0;
  }


  section {
    text-align: center;
  }
  /* 切り替え */
  /*.sp_wrap{
    display: unset;
  }
  .pc_wrap{
    display: none;
  }*/
  h2.k_title {
    letter-spacing: 2px;
    margin-bottom: 1em;
  }
  #contact .se_contact h2 {
    margin-top: 1em;
  }
  .version_wrap h2.k_title {
    margin-top: -1.2em;
  }
  .course_wrap h2.k_title {
    margin-top: -0.8em;
  }
  .sns_set .fa-twitter-square {
    margin: 0 5px 0 0;
  }
  /*------------------------------------------------------
  　建築の“声”を聴く、まち歩き音声ガイドアプリ
  ------------------------------------------------------*/
  .explanation_wrap h2 {
    color: #996633;
    font-size: 160%;
    margin-bottom: 1em;
    letter-spacing: 0;
    line-height: 1.8em;
  }
  .explanation_wrap h2 br {
    display: unset;
  }
  .explanation_wrap p {
    text-align: left;
    line-height: 2em;
  }
  .explanation_wrap p br {
    display: none;
  }
  /*------------------------------------------------------
  　選べる2つのバージョン
  ------------------------------------------------------*/
  .version_wrap .version_text {
    margin-bottom: 37px;
  }
  .version_wrap h3 {
    font-size: 140%;
  }
  /* ラーニング バージョン */
  .version_wrap dl.l_version {
    width: 100%;
    margin-bottom: 1em;
  }
  .version_wrap dl.l_version::before {
    /*background-size:90%;
    bottom: -160px;
    right: -25px;*/
    opacity: 0.7;
  }
  .version_wrap dl.l_version dd {
    background: #99cccc;
    padding: 1.2em;
    text-align: left;
  }
  .version_wrap dl.k_version dd {
    background: #ffcccc;
    padding: 1.2em;
    text-align: left;
  }
  /* キャラクター バージョン */
  .version_wrap dl.k_version {
    width: 100%;
  }
  .version_wrap dl.k_version::before {
    /*background-size:90%;
    bottom:-170px;
    right: -25px;*/
    opacity: 0.7;
  }
  .version_wrap .version_text br {
    display: none;
  }
  /*------------------------------------------------------
  　コース紹介
  ------------------------------------------------------*/
  .course_wrap dl {
    width: 100%;
    margin-right: 0;
  }
  .course_wrap dl dd ul {
    margin-left: 5px;
    /*margin-left: 23px;*/
  }
  .course_wrap .flex_w dl h3 {
    margin-top: 30px;
  }
  /*------------------------------------------------------
  　ナレーション／キャスト
  ------------------------------------------------------*/
  .narration_cast dl {
    display: flex;
    flex-wrap: wrap;
  }
  .narration_cast dl dt {
    width: 100%;
    order: 2;
    padding: 1em 0 0 0;
  }
  .narration_cast dl dd {
    width: 100%;
    order: 1;
    padding-right: 0;
  }
  .k_message p {
    text-align: left;
  }
  .k_message p.k_name {
    text-align: right;
    padding-right: 0.5em;
  }
  .k_message p br {
    display: none;
  }
  .narration_cast dl.dl_list {
    /*display:unset;
    flex-wrap:unset;*/
  }
  .narration_cast dl.dl_list dt {
    /*width:100%;*/
    font-size: 80%;
    border-right: 0;
    /*border-right: 1px solid #333;*/
    order: 1;
    text-align: center;
    padding-right: 10px;
    padding-top: 0;
    width: 5%;
  }
  .narration_cast dl.dl_list dd {
    /*width:94%;*/
    border-left: 1px solid #333;
    font-size: 80%;
    padding-left: 10px;
    box-sizing: border-box;
    order: 2;
    width: 94%;
  }
  .narration_cast .dd_list br {
    display: none;
  }
  /*------------------------------------------------------
  　performer_wrap
  ------------------------------------------------------*/
  .performer_wrap h2 img {
    /*width: 60%;*/
  }
  .k_name_text:before {
    left: 30%;
    transform: translate(30%, 5%);
  }
  /*------------------------------------------------------
   SNS
  ------------------------------------------------------*/
  .sns_wrap h2 img {
    width: 60%;
  }
  .sns_wrap h3 {
    font-size: 160%;
  }
  .sns_wrap p.sns_wrap_text {
    margin-bottom: 3em;
  }
  .sns_wrap ul {
    display: flex;
    font-size: 200%;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 1em;
  }
  .sns_wrap ul li {
    margin: 0 5%;
  }
  .fa-line {
    font-size: 180%;
  }
  .fa-twitter-square {
    font-size: 180%;
    margin: 0;
  }
  .fa-instagram-square {
    font-size: 180%;
  }
  .fa-facebook-square {
    font-size: 180%;
  }
  .sns_wrap h2.k_title {
    margin-bottom: 0.2em !important;
  }
  /*------------------------------------------------------
   コンタクト
  ------------------------------------------------------*/
  .btn_style {
    padding: 1em 0.3em;
    background: #fff;
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, .2);
    align-items: center;
    border: 1px solid #333;
    position: relative;
    transition-duration: 0.2s;
  }
  .bx-wrapper {
    position: relative;
    z-index: 99;
  }
  /*------------------------------------------------------
   コンタクト フォーム
  ------------------------------------------------------*/
  form {
    width: 96%;
    margin: auto;
  }
  #contact .note_text {
    text-align: left;
  }
  #contact .note_text br {
    display: none;
  }
  #contact header h1 {
    width: 30%;
    text-align: left;
    padding: 0.5em;
    box-sizing: border-box;
  }
  #contact header h1:hover {
    opacity: 0.6;
  }
  #contact .se_contact dl {
    display: unset;
    flex-wrap: unset;
  }
  #contact .se_contact .note_text br {
    display: none;
  }
  #contact .se_contact dl dt {
    width: 100%;
    text-align: left;
    padding: 0.2em 0;
    /*background:#3d2c2e;
    color:#fff;
    padding:0.2em 0.5em;*/
  }
  #contact .se_contact dl dd {
    width: 100%;
    margin-bottom: 2em;
    padding: 0;
    /*padding:0.2em 0.5em;*/
  }
  .contact_k .se_contact dl dt {
    /*background:#3d2c2e;
    color:#fff;*/
    padding: 0.3em 0.5em !important;
  }
  .contact_k .se_contact dl dd {
    padding: 0.2em 0.5em !important;
  }
  label br {
    display: none;
  }
  .hissu {
    padding-right: 0;
  }
  .form_button {
    border: 1px solid #333;
    color: #fff;
    padding: 0.5em;
    text-align: center;
    width: 142px;
    margin: 1%;
    position: relative;
  }
  #contact h2.main_title {
    margin-top: 1em;
  }
}



/*kvの画像アニメーション*/
.img-wrap {
  overflow: hidden;
  position: relative;
}

.img-wrap:before,
.img-wrap:after {
  animation: 2s cubic-bezier(.4, 0, .2, 1) forwards;
  background: #fff;
  content: '';
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  z-index: 1;
}

.img-wrap:before {
  animation-name: img-wrap-before;
  top: 0;
  bottom: 50%;
}

.img-wrap:after {
  animation-name: img-wrap-after;
  top: 50%;
  bottom: 0;
}

@keyframes img-wrap-before {
  100% {
    transform: translateX(100%);
  }
}

@keyframes img-wrap-after {
  100% {
    transform: translateX(-100%);
  }
}


/*お問い合わせのh2*/

h2.tit_sans{
	    font-family: 'Noto Sans JP', sans-serif;
	letter-spacing: 0rem;
    font-size: 160%;
	color: #000;

}

@media screen and (max-width: 570px){
	h2.tit_sans{
    font-size: 160%;
}

}