@charset "utf-8";
/* ==================================================

		ページ全般の共通 PC・SP

================================================== */

/* --------------------------------------------------
		body
-------------------------------------------------- */
body {
 font-family: 'Noto Sans JP', sans-serif;
}

@font-face {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 100;
	src: url('../fonts/NotoSansJP-Thin.woff') format('woff'),
      url('../fonts/NotoSansJP-Thin.otf') format('opentype');
}
@font-face {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 300;
	src: url('../fonts/NotoSansJP-Light.woff') format('woff'),
      url('../fonts/NotoSansJP-Light.otf') format('opentype');
}
@font-face {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 400;
	src: url('../fonts/NotoSansJP-Regular.woff') format('woff'),
      url('../fonts/NotoSansJP-Regular.otf') format('opentype');
}
@font-face {
	font-family: 'Noto Sans JP';
	font-style: normal;
	font-weight: 500;
	src: url('../fonts/NotoSansJP-Medium.woff') format('woff'),
      url('../fonts/NotoSansJP-Medium.otf') format('opentype');
}

/* --------------------------------------------------
		.clearfix
-------------------------------------------------- */
.clearfix:after {
	height: 0;
	clear: both;
	visibility: hidden;
	display: block;
	content: ".";
}

/* --------------------------------------------------
		link
-------------------------------------------------- */
.ldeco01 a:link,
.ldeco01 a:visited {
 color: #464646;
 text-decoration: underline;
 text-underline-offset: 3px;
 opacity: 1;
}
.ldeco02 a:link,
.ldeco02 a:visited {
 text-decoration: none;
}
.ldeco03 a:link,
.ldeco03 a:visited,
.ldeco04 a:link,
.ldeco04 a:visited {
 color: #ffffff;
 text-decoration: none;
}
.ldeco05 a:link,
.ldeco05 a:visited {
 color: #464646;
 text-decoration: none;
 opacity: 1;
}
.ldeco01 a:hover {
 text-decoration: none;
}
.ldeco02 a:hover,
.ldeco03:hover,
.ldeco04 a:hover,
.ldeco05 a:hover {
 transition: opacity 0.5s;
 opacity: 0.7;
}

/* --------------------------------------------------
		parts
-------------------------------------------------- */
p,
div {
 padding: 0;
 margin: 0;
}
.section {
 padding: 0;
 margin: 0;
 border: none;
}

/*	横位置
-------------------------------------------------- */
.centered {
 text-align: center;
}
.leftjustified {
 text-align: left;
}
.rightjustified {
 text-align: right;
}

/*	flex
-------------------------------------------------- */
.col01 {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: center;
}
.col02 {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: space-between;
}
.col03 {
 display: -webkit-flex;
 display: -moz-flex;
 display: -ms-flex;
 display: -o-flex;
 display: flex;
 justify-content: flex-start;
}
.colwrap {
 flex-wrap: wrap;
}
.colai01 {
 align-items: center;
}
.colai02 {
 align-items: baseline;
}
.colai03 {
 align-items: end;
}
.colai04 {
 align-items: flex-start;
}
.colfd01 {
 flex-direction: row-reverse;
}

/*	float
-------------------------------------------------- */
.fl {
 float: left;
}
.fr {
 float: right;
}

/*	txt
-------------------------------------------------- */
.sup {
 font-size: 10px;
 vertical-align: super;
 display: inline !important;
 padding: 0 3px 0 1px;
}
.supb {
 font-size: 10px;
 font-weight: 500 !important;
 vertical-align: super;
 display: inline !important;
 padding: 0 3px 0 1px;
}

/*	bak
-------------------------------------------------- */
.bak-blue {
 border: 5px solid #e5ecf0;
 background: #f3f7f9;
}

/*	color
-------------------------------------------------- */
.color-w {
  color: #ffffff !important;
}

/*	各ボタンの位置
-------------------------------------------------- */
.pickup .button-range,
.coll .button-range,
#pl-movie .button-range,
#ar .button-range,
#pl-art .button-range{
 text-align: center;		
}
.member_btn {
 text-align: right !important;
}

/* ==================================================

		ページ全般の共通 PC

================================================== */
@media screen and (min-width:741px) {

/* --------------------------------------------------
		SPの要素を非表示
-------------------------------------------------- */
.spDisp {
	display: none !important;
}

/* --------------------------------------------------
		body
-------------------------------------------------- */
body {
 font-weight: 300;
}
.fw100 {
 font-weight: 100;
}
.fw400 {
 font-weight: 400;
}
.fw500 {
 font-weight: 500;
}

/* --------------------------------------------------
		クリア
-------------------------------------------------- */
 .pccolcl {
  display: block;
}
 .pcflcl {
  float: none;
}

/* --------------------------------------------------
		parts
-------------------------------------------------- */
#top .inner {
 width: 1086px;
 margin: 0 auto;
}
.inner {
 width: 1140px;
 margin: 0 auto;
}
p,
div,
li {
 font-size: 18px;
 letter-spacing: 0.5px;
}

/*	icon
-------------------------------------------------- */
.icon-red {
 margin: -3px 15px 0 0;
}
.icon-red span {
 font-size: 12px;
 color: #ffffff;
 background: #ff0101;
 padding: 0 8px 0 11px;
 margin-top: -1px;
}

/* --------------------------------------------------
		h
-------------------------------------------------- */
#top h1 {
 margin-top: 80px;
 /*font-size: 39px;*/
 font-size: 50px;
 font-weight: 500;
 letter-spacing: 1.2px;
}
/*#top h1 .b01 {
 font-size: 64px;
}
#top h1 .b02 {
 font-size: 39px;
 display: block;
}*/
#second h1 {
/*font-size: 52px;*/
font-size: 48px;
}
#second h1 span {
 font-size: 17px;
 letter-spacing: 0.2px;
 line-height: 1.3;
 display: block;
 margin-top: -8px;
}
#top h2 span {
 font-size: 48px;
 display: inline-block;
 position: relative;
}
#second h2 span {
 font-size: 42px;
 display: inline-block;
 position: relative;
}
#top h2 span:before,
#second h2 span:before {
 content: '';
 position: absolute;
 left: 50%;
 bottom: -28px;
 display: inline-block;
 width: 40px;
 height: 3px;
 -moz-transform: translateX(-50%);
 -webkit-transform: translateX(-50%);
 -ms-transform: translateX(-50%);
 transform: translate(-50%);
 background-color: #ff0101;
}
#top h2.line1 span:before,
#second h2.line1 span:before {
 bottom: -21px;
}
#top h3 .tit {
 font-size: 20px;
}
#top h3 .tit .cap {
 font-size: 14px;
 letter-spacing: 0.3px;
 display: block;
}

/* --------------------------------------------------
		.sketch-f
-------------------------------------------------- */
.sketch-f .sketchfab-embed-wrapper iframe {
 aspect-ratio: 16 / 9;
 width: 100%;
 height: 100%;
 z-index: 2;
 /*width: 1070px;
 height: 480px;*/
}

/* --------------------------------------------------
		.button
		会員制サイト用にbtn04、btn05を追加
-------------------------------------------------- */
.button-range .button {
 display: inline-block;
}
.button-range .button a {
 display: block;
 padding: 12px 56px 12px 34px;
}
.button-range .btn01 {
 font-size: 16px !important;
 background: #464646;
 border-radius: 40px;
}
.button-range .btn01 a span, 
.button-range .btn02 a span, 
.button-range .btn03 a span,
.button-range .btn04 a span,
.button-range .btn05 a span,
.button-range .btn06 a span	{
 position: relative;
}
.button-range .btn02 {
 font-size: 16px !important;
 font-weight: bold;
 letter-spacing: 0.3px;
 background: #ed8b05;
 border-radius: 40px;
}
.button-range .btn03 {
 font-size: 16px !important;
 font-weight: bold;
 letter-spacing: 0.3px;
 background: #efb402;
 border-radius: 40px;
}
/*　会員制サイト用にbtn04,05を追加 */ 
.button-range .btn04 {
 font-size: 16px !important;
 /*font-weight: bold;*/
 letter-spacing: 0.3px;
 background: #ed8b05;
 border-radius: 30px;
}
.button-range .btn05 {
 font-size: 16px !important;
 font-weight: bold;
 letter-spacing: 0.3px;
 background: #54a6a5;
 border-radius: 30px;
}
	
/*　クッションページ用にbtn06を追加 */ 
.button-range .btn06 {
 font-size: 26px !important;
 padding: 20px 50px;
 /*font-weight: bold;*/
 letter-spacing: 0.3px;
 background: #ed8b05;
 border-radius: 56px;
}
	
.btn01 a span::after,
.btn04 a span::after,
.btn05 a span::after,
.btn06 a span::after{
 content: "";
 background: url(/med/virtual-exhibition/common/images/arrow_btn01.png) no-repeat right center / 100%;
 width: 20px;
 height: 6px;
 margin-left: 9px;
 position: absolute;
 bottom: 7px;
}
.btn02 a span::after, 
.btn03 a span::after {
 content: "";
 background: url(/med/virtual-exhibition/common/images/icon_nav01.png) no-repeat right center / 100%;
 width: 14px;
 height: 17px;
 margin-left: 11px;
 position: absolute;
 bottom: 3px;
}

	
/* --------------------------------------------------
		.bread
-------------------------------------------------- */
.bread {
 background: #f5f5f5;
}
.bread .bread-inner li {
 font-size: 14px;
 letter-spacing: 0.2px;
}
.bread .bread-inner li:after {
  content: ">";
  margin: 0 5px 0 6px;
}
.bread .bread-inner li:last-of-type:after {
  display: none;
}

/* --------------------------------------------------
		footer
-------------------------------------------------- */
footer {
 padding: 10px 0 11px !important;
 border-top-color: #adadad !important;
}
footer .container .links li {
 letter-spacing: 1.1px;
}
footer .container .links li a {
 line-height: 1.3 !important;
}
#second footer .copyright {
 position: relative;
 top: 1px;
}

/* --------------------------------------------------
		#pagetop
-------------------------------------------------- */
#pagetop {
 text-align: center;
 position: fixed;
 right: 17px;
 bottom: 82px;
 transition: 0.5s;
 opacity: 0;
 visibility: hidden;
}
#pagetop.active {
 opacity: 1;
 visibility: visible;
}
#pagetop .contact {
 margin-bottom: 216px;
 padding-right: 3px;
}

/* --------------------------------------------------
		.titcap
-------------------------------------------------- */
.titcap {
 font-size: 14px;
 line-height: 1.75;
 padding: 0 50px;
}

/* --------------------------------------------------
		#second .intro
-------------------------------------------------- */
.intro {
 /*width: 1070px;*/
 width: 1200px;
 margin: 0 auto;
}
.intro .txt {
 letter-spacing: 0.2px;
 line-height: 1.65;
}
.intro .intro-inner{
 z-index: 4;
}
.intro .intro-inner .tit {
 font-size: 20px;
 letter-spacing: 0.7px;
 margin-left: -12px;
}
.intro .intro-inner .intro-box li {
 font-size: 16px;
 line-height: 1.65;
}
.intro .intro-inner .intro-box li:after {
  content: "|";
  margin: 0 5px 0 8px;
}
.intro .intro-inner .intro-box li:last-of-type:after {
  display: none;
}

/* --------------------------------------------------
		#second .tab
-------------------------------------------------- */
.tab {
 border-bottom: 1px solid #e3e3e3;
}
.tab .tab-inner {
 padding: 0 96px;
 margin-bottom: -1px;
}
.tab .tab-inner li {
 font-size: 24px;
 width: 277px;
 border-top: 4px solid #54a6a5;
 border-left: 1px solid #e3e3e3;
 border-right: 1px solid #e3e3e3;
 border-bottom: 1px solid #ffffff;
 display: table;
 margin: 0 5px;
}
.tab .tab-inner li a {
 height: 87px;
 display: table-cell;
 vertical-align: middle;
}
.pl {
 padding-top: 75px !important;
 margin-top: -75px !important;
}

/* --------------------------------------------------
		#second .tbcont
-------------------------------------------------- */
/*	.movie
-------------------------------------------------- */
.tbcont .movie .movie-inner {
 padding: 0 36px;
}
.tbcont .movie .movie-inner .mov {
 width: 501px;
}
.tbcont .movie .movie-inner .movie-box {
 margin-top: 15px;
}
.tbcont .movie .movie-inner .movie-box .tit {
 font-weight: bold;
 line-height: 1.5;
}
.tbcont .movie .movie-inner .movie-box .txt {
 font-size: 14px;
}

/*	.photo
-------------------------------------------------- */
.tbcont .photo .photo-inner {
 padding: 0 150px;
}

/*  .slider   */
.tbcont .photo .photo-inner .slider {
 margin-bottom: 50px;
}
.tbcont .photo .photo-inner .slider li {
 position: relative;
}
.tbcont .photo .photo-inner .slider li .icon {
 position: absolute;
 right: 17px;
 bottom: 15px;
 z-index: 1;
 cursor: pointer;
}

/*  .modal   */
.tbcont .photo .photo-inner .modal {
 width: 100%;
 height: 100%;
 position: fixed;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 display: none;
 z-index: 9999;
}
.tbcont .photo .photo-inner .modal p {
 position: absolute;
 top: 50%;
 left: 50%;
 text-align: center;
 transform: translate(-50%, -50%);
 width: 75%;
 max-width: 1140px;
}
.tbcont .photo .photo-inner .modal p img {
 width: 100%;
}
.tbcont .photo .photo-inner .modal-close__wrap {
 position: absolute;
 right: 5%;
 top: 6%;
}
.tbcont .photo .photo-inner .modal-close {
 background: transparent;
 border-color: transparent;
 padding: 0;
 margin: 0;
 cursor: pointer;
 width: 75px;
 display: block;
 height: 38px;
}
.tbcont .photo .photo-inner .modal-close span {
 position: relative;
 width: 100%;
 height: 3px;
 background: #ffffff;
 display: block;
}
.tbcont .photo .photo-inner .modal-close span:nth-child(1) {
 transform: rotate(45deg);
}
.tbcont .photo .photo-inner .modal-close span:nth-child(2) {
 transform: rotate(-45deg);
 top: -4px;
}
.tbcont .photo .photo-inner .overlay {
 position: fixed;
 width: 100%;
 height: 100%;
 background: #000000;
 /*opacity: .6;*/
 opacity: .8;
 display: none;
 z-index: 9998;
 top: 0;
 left: 0;
 right: 0;
}
.tbcont .photo .photo-inner .overlay.open,
.tbcont .photo .photo-inner .modal.open {
 display: block;
}

/*	.art
-------------------------------------------------- */
.tbcont .art .art-inner {
 padding: 0 150px;
}
.tbcont .art .art-inner .img {
 width: 228px;
}
.tbcont .art .art-inner .art-box {
 width: 612px;
 padding-left: 40px;
}
.tbcont .art .art-inner .art-box .tit {
 font-weight: bold;
 line-height: 1.5;
}
.tbcont .art .art-inner .art-box .tit span {
 font-weight: 300;
 display: block;
}
.tbcont .art .art-inner .art-box .txt {
 font-size: 14px;
 line-height: 1.7;
}

/*	.cata
-------------------------------------------------- */
#second .tbcont .cata .cata-inner {
 padding: 0 24px;
}
#second .tbcont .cata .cata-inner li {
 padding: 0 30px;
}
#second .tbcont .cata .cata-inner li:first-of-type {
 padding-left: 0;
}
#second .tbcont .cata .cata-inner li:last-of-type {
 padding-right: 0;
}
#second .tbcont .cata .cata-inner li .txt {
 letter-spacing: 0;
 line-height: 1.5;
 width: 228px;
 margin-left: -7px;
}
#second .tbcont .cata .lands li .txt {
 width: 324px;
}
#second .tbcont .cata .cata-inner li .txt::before {
 content: "・";
}

/*  .dr   */
#second .tbcont .cata .dr {
 padding: 0 150px;
}
#second .tbcont .cata .dr .img {
 width: 445px;
}
#second .tbcont .cata .dr .txt {
 width: 565px;
 padding-left: 40px;
}
#second .tbcont .cata .dr .txt p {
 font-size: 16px;
 line-height: 1.6;
}

/*  .conc   */
#second .tbcont .cata .conc {
 padding: 0 150px;
}
#second .tbcont .cata .conc .txt {
 font-size: 20px;
}

/* --------------------------------------------------
		#second .uti
-------------------------------------------------- */
.uti {
 border-top: 1px solid #e3e3e3;
}
.uti .uti-inner {
 padding: 0 24px;
}
.uti .uti-inner li {
 width: 534px;
 padding: 0 30px;
}
.uti .uti-inner li .txt {
 font-size: 16px;
 letter-spacing: 0.2px;
 line-height: 1.9;
}

/* --------------------------------------------------
	.ar
-------------------------------------------------- */ 
.tbcont .ar .ar-inner {
 padding: 0;
}
.tbcont .ar .ar-inner .img {
 width: 345px;
}
.tbcont .ar .ar-inner .ar-box {
 width: 455px;
} 

.tbcont .ar .ar-inner .ar-box .tit {
 font-weight: bold;
 line-height: 1.5;
} 
.tbcont .ar .ar-inner .ar-box .txt {
 font-size: 14px;
} 
	
/* --------------------------------------------------
		スペース
-------------------------------------------------- */
.mt05 { margin-top: 5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt45 { margin-top: 45px !important; }
.mt50 { margin-top: 50px !important; }
.mt55 { margin-top: 55px !important; }
.mt60 { margin-top: 60px !important; }
.mt65 { margin-top: 65px !important; }
.mt70 { margin-top: 70px !important; }
.mt75 { margin-top: 75px !important; }
.mt80 { margin-top: 80px !important; }
.mt85 { margin-top: 85px !important; }
.mt90 { margin-top: 90px !important; }
.mt95 { margin-top: 95px !important; }
.mt100 { margin-top: 100px !important; }
.mt110 { margin-top: 110px !important; }
.mt150 { margin-top: 150px !important; }

.mb05 { margin-bottom: 5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb45 { margin-bottom: 45px !important; }
.mb50 { margin-bottom: 50px !important; }
.mb55 { margin-bottom: 55px !important; }
.mb60 { margin-bottom: 60px !important; }
.mb65 { margin-bottom: 65px !important; }
.mb70 { margin-bottom: 70px !important; }
.mb75 { margin-bottom: 75px !important; }
.mb80 { margin-bottom: 80px !important; }
.mb85 { margin-bottom: 85px !important; }
.mb90 { margin-bottom: 90px !important; }
.mb95 { margin-bottom: 95px !important; }
.mb100 { margin-bottom: 100px !important; }
.mb110 { margin-bottom: 110px !important; }
.mb150 { margin-bottom: 150px !important; }

.pt05 { padding-top: 5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt45 { padding-top: 45px !important; }
.pt50 { padding-top: 50px !important; }
.pt55 { padding-top: 55px !important; }
.pt60 { padding-top: 60px !important; }
.pt65 { padding-top: 65px !important; }
.pt70 { padding-top: 70px !important; }
.pt75 { padding-top: 75px !important; }
.pt80 { padding-top: 80px !important; }
.pt85 { padding-top: 85px !important; }
.pt90 { padding-top: 90px !important; }
.pt95 { padding-top: 95px !important; }
.pt100 { padding-top: 100px !important; }
.pt110 { padding-top: 110px !important; }
.pt150 { padding-top: 150px !important; }

.pb05 { padding-bottom: 5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
.pb45 { padding-bottom: 45px !important; }
.pb50 { padding-bottom: 50px !important; }
.pb55 { padding-bottom: 55px !important; }
.pb60 { padding-bottom: 60px !important; }
.pb65 { padding-bottom: 65px !important; }
.pb70 { padding-bottom: 70px !important; }
.pb75 { padding-bottom: 75px !important; }
.pb80 { padding-bottom: 80px !important; }
.pb85 { padding-bottom: 85px !important; }
.pb90 { padding-bottom: 90px !important; }
.pb95 { padding-bottom: 95px !important; }
.pb100 { padding-bottom: 100px !important; }
.pb110 { padding-bottom: 110px !important; }
.pb150 { padding-bottom: 150px !important; }
.pb250 { padding-bottom: 250px !important; }

.note { font-size: 14px; }

.pr30 { padding-right: 30px !important; }
.pl30 { padding-left: 30px !important; }
}


/* ==================================================

		ページ全般の共通 SP

================================================== */
@media screen and (max-width:740px) {

/* --------------------------------------------------
		PCの要素を非表示
-------------------------------------------------- */
.pcDisp {
	display: none !important;
}

/* --------------------------------------------------
		body
-------------------------------------------------- */
body {
 font-weight: 300;
}
.spfw100 {
 font-weight: 100;
}
.spfw400 {
 font-weight: 400;
}
.spfw500 {
 font-weight: 500;
}

/* --------------------------------------------------
		img
-------------------------------------------------- */
img {
 width: 100%;
	max-width: 100%;
	height: auto;
}

/* --------------------------------------------------
		クリア
-------------------------------------------------- */
 .spcolcl {
  display: block;
}
 .spflcl {
  float: none;
}

/* --------------------------------------------------
		parts
-------------------------------------------------- */
.inner {
 margin: 0 10px;
}
p,
div,
li {
 font-size: 14px;
 letter-spacing: 0.2px;
}
.spblock {
 display: block;
}

/*	icon
-------------------------------------------------- */
.icon-red {
 margin: 2px 15px 0 0;
}
.icon-red span {
 font-size: 12px;
 color: #ffffff;
 background: #ff0101;
 padding: 0 9px 0 11px;
}

/* --------------------------------------------------
		h
-------------------------------------------------- */
#top .vi h1 {
 /*font-size: 18px;*/
 font-size: 36px;
 font-weight: 400;
 letter-spacing: 0.3px;
}
/*#top .vi h1 .b01 {
 font-size: 36px;
}
#top .vi h1 .b02 {
 font-size: 24px;
 display: block;
 margin-top: -7px;
}*/
#second h1 {
 font-size: 36px;
}
#second h1 .img {
 width: 73%;
 margin: 0 auto;
}
#second h1 span {
 font-size: 14px;
 line-height: 1.4;
 display: block;
 margin-top: -4px;
}
#second h1 span img {
 width: 28%;
}
#top h2 span {
 font-size: 30px;
 display: inline-block;
 position: relative;
 line-height: 1.15;
}
#second h2 span {
 font-size: 26px;
 display: inline-block;
 position: relative;
}
#top h2 span:before {
 content: '';
 position: absolute;
 left: 50%;
 bottom: -18px;
 display: inline-block;
 width: 40px;
 height: 3px;
 -moz-transform: translateX(-50%);
 -webkit-transform: translateX(-50%);
 -ms-transform: translateX(-50%);
 transform: translate(-50%);
 background-color: #ff0101;
}
#second h2 span:before {
 content: '';
 position: absolute;
 left: 50%;
 bottom: -21px;
 display: inline-block;
 width: 40px;
 height: 3px;
 -moz-transform: translateX(-50%);
 -webkit-transform: translateX(-50%);
 -ms-transform: translateX(-50%);
 transform: translate(-50%);
 background-color: #ff0101;
}
#top h2.line1 span:before,
#second h2.line1 span:before{
 bottom: -16px;
}
#top h3 {

}
#top h3 .tit {
 font-size: 18px;
}
#top h3 .tit .cap {
 font-size: 14px;
 display: block;
}

/* --------------------------------------------------
		.sketch-f
-------------------------------------------------- */
.sketch-f .sketchfab-embed-wrapper iframe {
 aspect-ratio: 16 / 9;
 width: 100%;
 height: 100%;
 z-index: 2;
}

/* --------------------------------------------------
		.button
	会員制サイト用にbtn04、btn05を追加
	クッションページ用にbtn06を追加
-------------------------------------------------- */
.button-range .button {
 display: inline-block;
}
.button-range .button a {
 display: block;
 padding: 9px 56px 9px 34px;
}
.button-range .btn02 a, 
.button-range .btn03 a {
 padding: 9px 15px 9px 17px;
}
.button-range .btn04 a	{
 padding: 9px 35px 9px 17px;
}	

.button-range .btn01 {
 font-size: 14px !important;
 background: #464646;
 border-radius: 40px;
}
.button-range .btn01 a span, 
.button-range .btn02 a span, 
.button-range .btn03 a span,
.button-range .btn04 a span,
.button-range .btn05 a span,
.button-range .btn06 a span{
 position: relative;
}
.button-range .btn01 a span::after,
.button-range .btn04 a span::after,
.button-range .btn05 a span::after,
.button-range .btn06 a span::after{
 content: "";
 background: url(/med/virtual-exhibition/common/images/arrow_btn01.png) no-repeat right center / 100%;
 width: 20px;
 height: 6px;
 margin-left: 9px;
 position: absolute;
 bottom: 7px;
 right: -29px;
}
.button-range .btn02 {
 font-size: 13px !important;
 font-weight: bold;
 background: #ed8b05;
 border-radius: 40px;
}
.button-range .btn03 {
 font-size: 13px !important;
 font-weight: bold;
 background: #efb402;
 border-radius: 40px;
 padding-right: 17px;
}
.btn02 a span::after, 
.btn03 a span::after {
 content: "";
 background: url(/med/virtual-exhibition/common/images/icon_nav01.png) no-repeat right center / 100%;
 width: 12px;
 height: 15px;
 margin-left: 5px;
 position: absolute;
 bottom: 3px;
}

/*　会員制サイト用にbtn05を追加 */ 
.button-range .btn04 {
 font-size: 13px !important;
 /*font-weight: bold;*/
 background: #ed8b05;
 border-radius: 40px;
}
.button-range .btn05 {
 font-size: 14px !important;
 background: #54a6a5;
 border-radius: 40px;
}

/*　クッションページ用にbtn06を追加 */ 
.button-range .btn06 {
 font-size: 16px !important;
 /*font-weight: bold;*/
 background: #ed8b05;
 border-radius: 40px;
}
	
/* --------------------------------------------------
		footer
-------------------------------------------------- */
footer {
 border-top: 5px solid #ababab;
 padding-bottom: 23px;
}
footer:before {
 display: inline-block;
 height: 5px;
 left: 0;
 top: -5px;
 width: 30px;
}
footer .container .links {
 background: #d8d8d8;
 margin-bottom: 17px;
}
footer .container .links li {
 background-color: #d8d8d8;
 border-bottom: 1px solid #ababab;
}
footer .container .links li a {
 line-height: 1.34;
}
footer .container .copyright {
 margin: -1px 0 27px;
}
footer .container .copyright img {
 height: auto;
}

/* --------------------------------------------------
		#pagetop
-------------------------------------------------- */
.footer-pageTop {
 text-align: center;
}
.footer-pageTop-button {
 display: block;
}
.footer-pageTop-button:before {
 border: 0;
 content: "";
 display: inline-block;
 height: 22px;
 position: relative;
 width: 22px;
 border-right: solid 1px #111111;
 border-top: solid 1px #111111;
 -webkit-transform: rotate(-45deg);
 transform: rotate(-45deg);
}
.pageTop {
 display: none;
}

/* --------------------------------------------------
		.titcap
-------------------------------------------------- */
.titcap {
 font-size: 12px;
 line-height: 1.7;
}

/* --------------------------------------------------
		#second .intro
-------------------------------------------------- */
.intro {
 margin: 0 10px;
}
.intro .txt {
 line-height: 1.72;
}
.intro .intro-inner .tit {
 font-size: 18px;
 letter-spacing: 0.5px;
 margin-left: -10px;
}
.intro .intro-inner .intro-box li {
 font-size: 13px;
 line-height: 1.5;
}
.intro .intro-inner .intro-box li:after {
  content: "|";
  margin: 0 7px 0 8px;
}
.intro .intro-inner .intro-box li:last-of-type:after {
  display: none;
}

/* --------------------------------------------------
		#second .tab
-------------------------------------------------- */
.tab {
 border-bottom: 1px solid #e3e3e3;
}
.tab .tab-inner {
 margin-bottom: -1px;
}
.tab .tab-inner li {
 font-size: 17px;
 width: 24%;
 border-top: 4px solid #54a6a5;
 border-left: 1px solid #e3e3e3;
 border-right: 1px solid #e3e3e3;
 border-bottom: 1px solid #ffffff;
 display: table;
 margin: 0 2px;
}
.tab .tab-inner li a {
 height: 36px;
 display: table-cell;
 vertical-align: middle;
}
.pl {
 padding-top: 50px !important;
 margin-top: -50px !important;
}

/* --------------------------------------------------
		#second .tbcont
-------------------------------------------------- */
/*	.movie
-------------------------------------------------- */
.tbcont .movie .movie-inner .mov {
 width: 100%;
}
.tbcont .movie .movie-inner .mov:nth-child(even){
 margin-top: 40px;	
}
.tbcont .movie .movie-inner .movie-box .tit {
 line-height: 1.4;
}
.tbcont .movie .movie-inner .movie-box .txt {
 font-size: 12px;
}

/*	.photo
-------------------------------------------------- */
/*  .slider   */
.tbcont .photo .photo-inner .slider li {
 position: relative;
}
.tbcont .photo .photo-inner .slider li .icon {
 position: absolute;
 right: 10px;
 bottom: 10px;
 z-index: 1;
 cursor: pointer;
 width: 15%;
}

/*  .modal   */
.tbcont .photo .photo-inner .modal {
 width: 100%;
 height: 100%;
 position: fixed;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 display: none;
 z-index: 9999;
}
.tbcont .photo .photo-inner .modal p {
 position: absolute;
 top: 50%;
 left: 50%;
 text-align: center;
 transform: translate(-50%, -50%);
 width: 95%;
}
.tbcont .photo .photo-inner .modal p img {
 width: 100%;
}
.tbcont .photo .photo-inner .modal-close__wrap {
 position: absolute;
 right: 1%;
 top: 1%;
}
.tbcont .photo .photo-inner .modal-close {
 background: transparent;
 border-color: transparent;
 padding: 0;
 margin: 0;
 cursor: pointer;
 width: 70px;
 display: block;
 height: 60px;
}
.tbcont .photo .photo-inner .modal-close span {
 position: relative;
 width: 100%;
 height: 3px;
 background: #ffffff;
 display: block;
}
.tbcont .photo .photo-inner .modal-close span:nth-child(1) {
 transform: rotate(45deg);
}
.tbcont .photo .photo-inner .modal-close span:nth-child(2) {
 transform: rotate(-45deg);
 top: -4px;
}
.tbcont .photo .photo-inner .overlay {
 position: fixed;
 width: 100%;
 height: 100%;
 background: #000000;
 /*opacity: .6;*/
 opacity: .8;
 display: none;
 z-index: 9998;
 top: 0;
 left: 0;
 right: 0;
}
.tbcont .photo .photo-inner .overlay.open,
.tbcont .photo .photo-inner .modal.open {
 display: block;
}

/*	.art
-------------------------------------------------- */
.tbcont .art .art-inner .img {
 width: 45%;
 margin: 0 auto;
}
.tbcont .art .art-inner .art-box .tit {
 font-weight: bold;
 line-height: 1.5;
}
.tbcont .art .art-inner .art-box .tit span {
 font-weight: 300;
 display: block;
}
.tbcont .art .art-inner .art-box .txt {
 font-size: 12px;
}
.tbcont .art .art-inner .art-box .button-range {
 text-align: center;
}

/*	.cata
-------------------------------------------------- */
#second .tbcont .cata .cata-inner {
 /*justify-content: flex-start;*/
 justify-content: center;
}
#second .tbcont .cata .cata-inner li {
 width: 50%;
 padding: 0 3%;
}
#second .tbcont .cata .cata-inner li .txt {
 letter-spacing: 0;
 line-height: 1.5;
 margin-left: -7px;
}
#second .tbcont .cata .cata-inner li .txt::before {
 content: "・";
}

/*  .dr   */
#second .tbcont .cata .dr .txt p {
 font-size: 13px;
}
#second .tbcont .cata .dr .img {
 width: 80%;
 margin: 0 auto;
}

/*  .conc   */
#second .tbcont .cata .conc .txt {
 font-size: 15px;
 line-height: 1.3;
}

/* --------------------------------------------------
		#second .uti
-------------------------------------------------- */
.uti {
 border-top: 1px solid #e3e3e3;
}
.uti .uti-inner li {
 width: 49%;
 padding: 0 15px;
}
.uti .uti-inner li .txt {
 font-size: 13px;
 letter-spacing: 0.2px;
}

/* --------------------------------------------------
		スペース
-------------------------------------------------- */
.spmt05 { margin-top: 5px !important; }
.spmt10 { margin-top: 10px !important; }
.spmt15 { margin-top: 15px !important; }
.spmt20 { margin-top: 20px !important; }
.spmt25 { margin-top: 25px !important; }
.spmt30 { margin-top: 30px !important; }
.spmt35 { margin-top: 35px !important; }
.spmt40 { margin-top: 40px !important; }
.spmt45 { margin-top: 45px !important; }
.spmt50 { margin-top: 50px !important; }
.spmt55 { margin-top: 55px !important; }
.spmt60 { margin-top: 60px !important; }
.spmt65 { margin-top: 65px !important; }
.spmt70 { margin-top: 70px !important; }
.spmt75 { margin-top: 75px !important; }
.spmt80 { margin-top: 80px !important; }
.spmt85 { margin-top: 85px !important; }
.spmt90 { margin-top: 90px !important; }
.spmt95 { margin-top: 95px !important; }
.spmt100 { margin-top: 100px !important; }
.spmt110 { margin-top: 110px !important; }
.spmt100 { margin-top: 150px !important; }

.spmb05 { margin-bottom: 5px !important; }
.spmb10 { margin-bottom: 10px !important; }
.spmb15 { margin-bottom: 15px !important; }
.spmb20 { margin-bottom: 20px !important; }
.spmb25 { margin-bottom: 25px !important; }
.spmb30 { margin-bottom: 30px !important; }
.spmb35 { margin-bottom: 35px !important; }
.spmb40 { margin-bottom: 40px !important; }
.spmb45 { margin-bottom: 45px !important; }
.spmb50 { margin-bottom: 50px !important; }
.spmb55 { margin-bottom: 55px !important; }
.spmb60 { margin-bottom: 60px !important; }
.spmb65 { margin-bottom: 65px !important; }
.spmb70 { margin-bottom: 70px !important; }
.spmb75 { margin-bottom: 75px !important; }
.spmb80 { margin-bottom: 80px !important; }
.spmb85 { margin-bottom: 85px !important; }
.spmb90 { margin-bottom: 90px !important; }
.spmb95 { margin-bottom: 95px !important; }
.spmb100 { margin-bottom: 100px !important; }
.spmb110 { margin-bottom: 110px !important; }
.spmb100 { margin-bottom: 150px !important; }

.sppt05 { padding-top: 5px !important; }
.sppt10 { padding-top: 10px !important; }
.sppt15 { padding-top: 15px !important; }
.sppt20 { padding-top: 20px !important; }
.sppt25 { padding-top: 25px !important; }
.sppt30 { padding-top: 30px !important; }
.sppt35 { padding-top: 35px !important; }
.sppt40 { padding-top: 40px !important; }
.sppt45 { padding-top: 45px !important; }
.sppt50 { padding-top: 50px !important; }
.sppt55 { padding-top: 55px !important; }
.sppt60 { padding-top: 60px !important; }
.sppt65 { padding-top: 65px !important; }
.sppt70 { padding-top: 70px !important; }
.sppt75 { padding-top: 75px !important; }
.sppt80 { padding-top: 80px !important; }
.sppt85 { padding-top: 85px !important; }
.sppt90 { padding-top: 90px !important; }
.sppt95 { padding-top: 95px !important; }
.sppt100 { padding-top: 100px !important; }
.sppt110 { padding-top: 110px !important; }
.sppt100 { padding-top: 150px !important; }

.sppb05 { padding-bottom: 5px !important; }
.sppb10 { padding-bottom: 10px !important; }
.sppb15 { padding-bottom: 15px !important; }
.sppb20 { padding-bottom: 20px !important; }
.sppb25 { padding-bottom: 25px !important; }
.sppb30 { padding-bottom: 30px !important; }
.sppb35 { padding-bottom: 35px !important; }
.sppb40 { padding-bottom: 40px !important; }
.sppb45 { padding-bottom: 45px !important; }
.sppb50 { padding-bottom: 50px !important; }
.sppb55 { padding-bottom: 55px !important; }
.sppb60 { padding-bottom: 60px !important; }
.sppb65 { padding-bottom: 65px !important; }
.sppb70 { padding-bottom: 70px !important; }
.sppb75 { padding-bottom: 75px !important; }
.sppb80 { padding-bottom: 80px !important; }
.sppb85 { padding-bottom: 85px !important; }
.sppb90 { padding-bottom: 90px !important; }
.sppb95 { padding-bottom: 95px !important; }
.sppb100 { padding-bottom: 100px !important; }
.sppb110 { padding-bottom: 110px !important; }
.sppb100 { padding-bottom: 150px !important; }

.note { font-size: 12px; }

.sppr15 { padding-right: 15px !important; }
.sppl15 { padding-left: 15px !important; }
}

/* ==================================================
		
		【追記】会員制サイト関連

================================================== */

/* --------------------------------------------------
		会員制サイト化を機に変更・影響するパーツの微調整
-------------------------------------------------- */


/*	ページ全般の共通 PC・SP
-------------------------------------------------- */
.tab .tab-inner li{
  background-color: #fff;
}
.bgColor .intro,
.bgColor .intro a,
.bgColor .intro a:link,
.bgColor .intro a:hover,
.bgColor .intro a:visited {
  color: #ccc;
}
.bgColor .intro h1{
  color: #fff;
}
.iconMovie{
  position: relative;
}
.iconMovie i.icon_movie {
  position: absolute;
  top: 50%;
  left: 50%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
  opacity: 0.9;
  }
.iconMovie a:hover i.icon_movie{
  opacity: 1.0;
}
.ar2 .qr img{
 width: 90%;
 border: 20px solid #89aebd;
 box-shadow:0 0 5px #999;
}
.ar2 p.tit {
 font-weight: bold;
 font-style: italic;
 transform: rotate( -5deg );
}	
.ar2 p.tit span{
 background: linear-gradient(transparent 70%, #d9d6d6 70%);
}
.video.is_youtube .video-content {
  padding-top: 56.25%;
  position: relative;
  width: 100%;
}
.video.is_youtube .video-content iframe {
  height: 100%;
  right: 0;
  position: absolute;
  top: 0;
  width: 100%;
}
.ar-inner3 li{
 text-align: center;
}
.ar-inner3 a,
.ar-inner3 a:link,
.ar-inner3 a:hover,
.ar-inner3 a:visited {
  text-decoration: none;
}
.txt_ss{
  font-size: 13px;
}
.prod_type{
  margin-top: 12px;
  font-weight: 400;
}

/* SONIALのMovie会員サイト誘導枠 */
.member_video{
	margin: 50px auto 0;
	padding: 40px 0;
	background-color: #efefef;
}


/*	ページ全般の共通 PC
-------------------------------------------------- */ 
@media screen and (min-width:741px) {
.bgColor{
 background: rgb(17,22,38);
 background: linear-gradient(61deg, rgba(17,22,38,1) 0%, rgba(16,50,69,1) 71%, rgba(14,71,92,1) 100%);
}
.articleBox01{
 position: relative;
 display: flex;
 flex-direction: row;
 width: 100%;
}
.articleBox01-inner{
 width: 480px;
 min-width: 420px;
 z-index: 3;
 pointer-events: none;
}
#second .articleBox01-inner{
 margin-top: 30px;
}	
/*   .sketch-f  */
/*  会員制サイトを機に変更・影響するパーツの微調整
	枠いっぱいから2カラム化へ*/
.bgColor .sketch-f .sketchfab-embed-wrapper iframe {
 position: absolute;
 right: 0;
 width: 80%;
 /*width: 70%;*/
 /*width: 535px;
 min-height: 240px;*/
}
/* TOPのSketchfabだけ大きさ個別指定 */
.bgColor .index_sketch-f .sketchfab-embed-wrapper iframe {
 width: 70%;
}
.bgColor .sketch-f .sketchfab-embed-wrapper p{
 position: absolute;
 right: 0;
 bottom: 0;
}
/* .movie 会員制サイト化に伴い追加
	1本目だけ横幅いっぱい */
.tbcont .movie .movie-inner .movie-boxCol01{
 width: 100% !important;
 padding-left: 0 !important;
}
.movie-smc {
 padding-left: 36px !important;
 padding-right: 36px !important;
}
/*  .modal   */
.tbcont .cata-inner li {
 position: relative;
}
.tbcont .cata-inner li .icon {
 position: absolute;
 right: 20px;
 bottom: 15px;
 z-index: 1;
 cursor: pointer;
}
.tbcont .cata .modal {
 width: 100%;
 height: 100%;
 position: fixed;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 display: none;
 z-index: 9999;
}
.tbcont .cata .modal p {
 position: absolute;
 top: 50%;
 left: 50%;
 text-align: center;
 transform: translate(-50%, -50%);
 width: 75%;
 max-width: 1140px;
}
.tbcont .cata .modal p img {
 width: 100%;
}
.tbcont .cata .modal-close__wrap {
 position: absolute;
 right: 5%;
 top: 6%;
} 
.tbcont .cata .modal-close {
 background: transparent;
 border-color: transparent;
 padding: 0;
 margin: 0;
 cursor: pointer;
 width: 75px;
 display: block;
 height: 38px;
}
.tbcont .cata .modal-close span {
 position: relative;
 width: 100%;
 height: 3px;
 background: #ffffff;
 display: block;
}
.tbcont .cata .modal-close span:nth-child(1) {
 transform: rotate(45deg);
}
.tbcont .cata .modal-close span:nth-child(2) {
 transform: rotate(-45deg);
 top: -4px;
}
.tbcont .cata .overlay {
 position: fixed;
 width: 100%;
 height: 100%;
 background: #000000;
 /*opacity: .6;*/
 opacity: .8;
 display: none;
 z-index: 9998;
 top: 0;
 left: 0;
 right: 0;
}
.tbcont .cata .overlay.open, 
.tbcont .cata .modal.open {
 display: block;
}
/*   ページ内リンク　アンカー位置調整  */
.anchorLink {
  height: 0;
  margin-top: -80px;
  padding-top: 80px;
}
/*	.ar  */
.ar2 {
 width: 100%;
 margin: 50px 0 30px;
 border-top: 1px solid #f5f5f5;
 border-bottom: 1px solid #f5f5f5;
 background: linear-gradient(90deg, #f5f5f5 0%, #f5f5f5 48%, #fff 48%, #fff 100%);
}
.ar-inner2{
 display: flex;
 flex-direction: row;
 justify-content: space-around;
 align-items: center;
 width: 1400px;
 margin: 0 auto;
}
.ar-inner2-2{
 display: flex;
 padding: 30px 0 0 0;
 justify-content: space-around;
 flex-direction: row-reverse;
}	
.ar-inner2 .txt{
 padding: 0 20px 20px 40px;
}
.ar2 p.tit {
 font-size: 36px;
 line-height: 1.8;
}
.ar2 .photo img {
 min-width: 650px;
 height: auto;
 mix-blend-mode: multiply;
}
.ar2 .qr{
 width: 300px;
}
.ar-inner2 p.atten{
 width: 390px;
 padding: 50px 30px 30px 0;
}
.ar-inner3 li{
 width: 32%;
}

/* SONIALのMovie会員サイト誘導枠 */
.member_video_inner{
	padding: 0 40px;
}
.member_video_inner p.tit{
	font-size: 28px;
}	
}

/*	ページ全般の共通 SP
-------------------------------------------------- */ 
@media screen and (max-width:740px) {
.bgColor{
 background: rgb(17,22,38);
 background: linear-gradient(to bottom, rgba(14,71,92,1) 0%, rgba(16,50,69,1) 71%, rgba(17,22,38,1) 100%);
 background: -webkit-linear-gradient(top, rgba(14,71,92,1) 0%, rgba(16,50,69,1) 71%, rgba(17,22,38,1) 100%);
 background: -moz-linear-gradient(top, rgba(14,71,92,1) 0%, rgba(16,50,69,1) 71%, rgba(17,22,38,1) 100%);
}
.articleBox01{
 display: flex;
 flex-direction: column-reverse;
}
/*  .modal   */
.tbcont .cata-inner li {
 position: relative;
}
.tbcont .cata-inner li .icon {
 position: absolute;
 right: 20px;
 bottom: 10px;
 z-index: 1;
 cursor: pointer;
 width: 15%;
}
.tbcont .cata .modal {
 width: 100%;
 height: 100%;
 position: fixed;
 top: 50%;
 left: 50%;
 transform: translate(-50%, -50%);
 display: none;
 z-index: 9999;
}
.tbcont .cata .modal p {
 position: absolute;
 top: 50%;
 left: 50%;
 text-align: center;
 transform: translate(-50%, -50%);
 width: 95%;
}
.tbcont .cata .modal p img {
 width: 100%;
}
.tbcont .cata .modal-close__wrap {
 position: absolute;
 right: 1%;
 top: 1%;
} 
.tbcont .cata .modal-close {
 background: transparent;
 border-color: transparent;
 padding: 0;
 margin: 0;
 cursor: pointer;
 width: 70px;
 display: block;
 height: 60px;
}
.tbcont .cata .modal-close span {
 position: relative;
 width: 100%;
 height: 3px;
 background: #ffffff;
 display: block;
}
.tbcont .cata .modal-close span:nth-child(1) {
 transform: rotate(45deg);
}
.tbcont .cata .modal-close span:nth-child(2) {
 transform: rotate(-45deg);
 top: -4px;
}
.tbcont .cata .overlay {
 position: fixed;
 width: 100%;
 height: 100%;
 background: #000000;
 /*opacity: .6;*/
 opacity: .8;
 display: none;
 z-index: 9998;
 top: 0;
 left: 0;
 right: 0;
}
.tbcont .cata .overlay.open, 
.tbcont .cata .modal.open {
 display: block;
}
/*   ページ内リンク　アンカー位置調整  */
.anchorLink {
  height: 0;
  margin-top: -60px;
  padding-top: 60px;
}
/*   ページ内リンク　アンカー位置調整  */
.anchorLink {
  height: 0;
  margin-top: -80px;
  padding-top: 80px;
}
/*	.ar  */
.ar2 {
 margin: 30px 0;
 padding: 0;
 border-top: 1px solid #f5f5f5;
 border-bottom: 1px solid #f5f5f5;
}
.ar-inner2 {	
 display: block;
 text-align: center;	
}
.ar-inner2 .txt{
 padding: 30px 0;
 background-color: #f5f5f5;
}
.ar2 .qr{
 text-align: center;	
}
.ar2 .qr img {
 max-width: 280px;
 height: auto;
}
.ar2 p.tit {
 margin-bottom: 40px;
 font-size: 26px;
 line-height: 1.5;
}
.ar2 p.atten{
 margin: 30px 0 0 0;
}
.ar2 .photo{
 display: none;		
}
	
/* SONIALのMovie会員サイト誘導枠 */
.member_video_inner p.tit{
	font-size: 20px;
}	
}
