@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Lusitana&family=Noto+Serif+JP:wght@400;500&display=swap');

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent
}

body {
	line-height: 1
}

ol,
ul {
	list-style: none
}

blockquote,
q {
	quotes: none
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none
}

:focus {
	outline: 0
}

ins {
	text-decoration: none
}

del {
	text-decoration: line-through
}

table {
	border-collapse: collapse;
	border-spacing: 0
}
html{
	
}
body {
	font: 16px/2 "Times New Roman","Lusitana", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Noto Serif JP","HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	color: #000;
	text-shadow: #eee 0 1px 0;
	font-weight: normal;
	background: #fff;
	
}

.clear {
	clear: both;
	display: block;
	overflow: hidden;
	visibility: hidden;
	width: 0;
	height: 0
}

.clearfix:after {
	clear: both;
	content: ' ';
	display: block;
	font-size: 0;
	line-height: 0;
	visibility: hidden;
	width: 0;
	height: 0
}

* html .clearfix,
*:first-child+html .clearfix {
	zoom: 1
}

a:focus {
	outline: 1px dotted
}

hr {
	border: 0 #ccc solid;
	border-top-width: 1px;
	clear: both;
	height: 0
}

img {
	border: 0;
	margin-bottom: 16px;
}

img.Set {
	margin-bottom: -8px;
}
a{
	transition: opacity 0.3s ease;
}

a:link {
	color: #000;
	text-decoration: none;
}

a:visited {
	color: #000;
	text-decoration: none;
}

a:hover,
a:visited:hover {
	color: #000;
	opacity: 0.5;
}

img a:hover,
a:visited:hover {
	text-decoration: none;
}

.clear {
	clear: both;
	display: block;
	overflow: hidden;
	visibility: hidden;
	width: 0;
	height: 0;
}

.clearspace {
	clear: both;
	display: block;
	overflow: hidden;
	visibility: hidden;
	width: 0;
	height: 32px;
}

.clearfix:after {
	clear: both;
	content: ' ';
	display: block;
	font-size: 0;
	line-height: 0;
	visibility: hidden;
	width: 0;
	height: 0
}

* html .clearfix,
*:first-child+html .clearfix {
	zoom: 1
}

a:focus {
	outline: 1px dotted
}

hr {
	border: 0 #ccc solid;
	border-top-width: 1px;
	clear: both;
	height: 0;
	margin: 0;
}

.Right {
	text-align: right;
}

.warning {
	color: #C00;
	font-size: 12px;
	margin: 20px 0 0 0
}

/*----------------------------------------------------------------------------------------------------*/

.GSystem {
	margin-left: auto;
	margin-right: auto;
	max-width: 1280px;
	margin-bottom: 32px;
	padding: 0 32px;
}

.Grid1,
.Grid2,
.Grid3,
.Grid4,
.Grid5,
.Grid6,
.Grid7,
.Grid8,
.Grid9,
.Grid10,
.Grid11,
.Grid12 {
	position: relative;
	margin: 0;
	padding: 0;
}

.Grid1 {
	width: 80px;
}

.Grid2 {
	width: 160px;
}

.Grid3 {
	width: 240px;
}

.Grid4 {
	width: 320px;
}

.Grid5 {
	width: 400px;
}

.Grid6 {
	width: 480px;
}

.Grid7 {
	width: 560px;
}

.Grid8 {
	width: 640px;
}

.Grid9 {
	width: 720px;
}

.Grid10 {
	width: 800px;
}

.Grid11 {
	width: 880px;
}

.Grid12 {
	width: 960px;
}

.Grid13 {
	width: 1040px;
}

.Grid14 {
	width: 1120px;
}

.Grid15 {
	width: 1200px;
}

.Grid16 {
	width: 1280px;
}

.Box1,
.Box2,
.Box3,
.Box4,
.Box5,
.Box6,
.Box7,
.Box8,
.Box9,
.Box10,
.Box11,
.Box12 {
	position: relative;
	margin: 0px;
	padding: 0;
}

.Box1 {
	width: 64px;
}

.Box2 {
	width: 144px;
}

.Box3 {
	width: 224px;
}

.Box4 {
	width: 304px;
}

.Box5 {
	width: 384px;
}

.Box6 {
	width: 464px;
}

.Box7 {
	width: 544px;
}

.Box8 {
	width: 624px;
}

.Box9 {
	width: 704px;
}

.Box10 {
	width: 784px;
}

.Box11 {
	width: 864px;
}

.Box12 {
	width: 944px;
}

.Box13 {
	width: 1024px;
}

.Box14 {
	width: 1104px;
}

.Box15 {
	width: 1184px;
}

.Box16 {
	width: 1264px;
}

.TopBox {
	margin-bottom: 64px;
}


.PadLeft1 {
	padding-left: 80px;
}

.PadLeft2 {
	padding-left: 160px;
}

p,
dl,
hr,
h2,
h3,
h4,
h5,
h6,
ol,
ul,
pre,
table,
address,
fieldset {
	margin-bottom: 8px
}

h2,
h3,
h4 {
	line-height: 18px;
	margin: 32px 0 16px 0;
	font-weight: normal;
}

h4 {
	margin-bottom: 16px;
}

h5 {
	font-size: 13px;
	margin-top: 16px;
}

p {
	text-shadow: none;
}

ol {
	list-style: decimal
}

ul {
	list-style: none;
	margin-bottom: 16px;
}

li {
	margin: 2px 0;
	font-size: 13px;
	line-height: 21px;
}

.Name {
	font-size: 42px;
	font-weight: bold;
}

.NextTitle {
	font-size: 26px;
	font-weight: bold;
}

.Sub {
	font-size: 13px;
	font-weight: normal;
	margin: 16px 0;
}

.Small {
	font-size: 13px;
	font-weight: normal;
}

.Navi {}

.Navi ul {
	margin: 0;
	padding: 4px 0 0 0;
	list-style: none;
	border-top: solid 1px #eee;
}

.Navi li {
	display: inline;
	margin-right: 16px;
	padding: 0;
}


.NaviHTM {}

.NaviHTM ul {
	margin: 0;
	padding: 4px 0 0 0;
	list-style: none;
	border-top: solid 1px #eee;
	text-align: right;
}

.NaviHTM li {
	display: inline;
	padding: 0;
	font-size: 1.25em;
	line-height: 2em;
}

.Next .FormBox {
	width: 350px;
	border: 1px solid #f1f1f1;
	padding: 16px;
	background: #fcfcfc;
	-webkit-box-shadow: rgba(0, 0, 0, .4) 0 2px 3px;
	-moz-box-shadow: rgba(0, 0, 0, .4) 0 2px 3px;
	margin-bottom: 16px;
	moz-border-radius: 6px;
	-webkit-border-radius: 6px;
	border-radius: 6px;
}

.FormBox h2,
h3 {
	color: #000;
}

.FormBox h2 {
	font-size: 16px;
	margin: 0 0 16px 0;
}

.FormBox h3 {
	font-size: 13px;
	margin: 16px 0 0 0;
}


/*.FormBox p		{ font-size: 13px; lineheight: 21px; margin-top: 16px;}*/

/*twitter*/
#followBtn {
	position: fixed;
	right: 0;
	z-index: 100;
}







/**/
.Left {
	text-align: left;
}

.Center {
	text-align: center;
}

.Right {
	text-align: right;
}

.BtnBox {
	padding: 16px 8px 64px 0;
}
.BtnBox iframe{
	vertical-align: text-top;
}
footer .BtnBox iframe{
	vertical-align: sub;
}
.pcD{
	display: block;
}
.spD{
	display: none;
}

@media screen and (max-width: 1340px) {

	.Grid12 {
		width: 660px;
	}
	.Grid16 {
		width: 980px;
		margin: 0 auto;
	}
	.Box3 {
		width: 224px;
	}
	.Box8 {
		width: 484px;
	}
	.Box12 {
		width: 724px;
	}
	.Box16 {
		width: 964px;
		max-width: 100%;
	}
}
@media screen and (max-width: 1040px) {
	.Grid12 {
		width: 560px;
	}
	.Grid16 {
		width: 780px;
		max-width: 100%;
		margin: 0 auto;
	}
	.Box3 {
		width: 224px;
	}
	.Box8 {
		width: 354px;
	}
	.Box12 {
		width: 524px;
	}
	.Box16 {
		max-width: 100%;
		width: 764px;
		
	}
}
@media screen and (max-width: 780px) {
	.pcD{
		display: none;
	}
	.spD{
		display: block;
	}
	.GSystem {
		padding: 0 18px;
	}
	.Box5{
		width: 216px;
	}
}




/* ReportPage -------------------------------*/
.RepPage h1 {
	margin: 32px 0 16px 0;
	font-weight: normal;
	color: #aaa;
}

.RepPage h2 {
	color: #000;
}

.RepPage h3 {
	font-size: 16px;
	font-weight: normal;
}

.Reppage h4 {
	font-size: 16px;
	margin-bottom: 32px;
}

.RepPage p.Intro {
	font-size: 16px;
	font-weight: bold;
	margin-bottom: 32px;
}

.RepPage p {
	font-size: 13px;
	line-height: 26px;
}

.RepPageList {
	width: 272px;
	padding: 8px 16px;
	text-shadow: none;
	background: #fcfcfc;
	-webkit-box-shadow: rgba(0, 0, 0, .4) 0 2px 3px;
	-moz-box-shadow: rgba(0, 0, 0, .4) 0 2px 3px;
	margin-bottom: 16px;
	moz-border-radius: 6px;
	-webkit-border-radius: 6px;
	border-radius: 6px;
}

.RepPageList h3,
h4 {
	font-size: 16px;
	margin: 12px 0;
	font-weight: normal;
	color: #aaa;
}

.RepPageList ul {
	list-style: none;
}

.RepPageList li {
	margin: 0;
	padding: 6px 0 2px 0;
	font-size: 13px;
	line-height: 21px;
	font-weight: bold;
	border-top: 1px solid #eee;
}

.RepPageList li .Date {
	padding-left: 216px;
	font-size: 11px;
	font-weight: normal;
	color: #777;
}

.OutLink {
	text-align: right;
}

.OutLink ul {
	list-style: none;
}

.OutLink li {
	display: inline;
	margin-left: 32px;
	font-size: 13px;
}


/*------------------------------------------------- ------------------------------------------------- 20130719 UTalk�̂���� */
/* index.html */
#HTMBox {
	padding: 0;
	margin-left: 160px;
	width: 224px;
	height: 64px;
	position: absolute;
}

#HTM a {
	height: 64px;
	overflow: hidden;
	background-image: url(../images/common/htm-btn.gif);
	display: block;
	text-indent: -5000px;
	text-decoration: none;
}

#HTM-Btn a {
	width: 224px;
	background-position: 0 0;
}

#HTM-Btn a:hover {
	background-position: 0 -64px;
}

/* howtomake/ */
.HTMTop {
	margin-top: 116px;
}

.HTMCnt h2 {
	font-size: 2em;
	line-height: 1.75em;
}

.HTMCnt p {
	margin-bottom: 16px;
}

.HTMYouTube {
	margin: 72px 0 0px 80px;
}



p.MovText {
	margin-top: 8px;
	font-size: 12px;
	line-height: 20px;
}



/*------------------------------------------------- -------------------------------------------------
add new2023*/
/* common */
body.noscroll {
	width: 100%;
	position: fixed;
	overflow-y: scroll;
}
  



.flex1 {
	display: flex;
	flex-wrap: wrap;
}

.flex1.sb {
	justify-content: space-between;
}

.flex1.fe {
	justify-content: flex-end;
}

.mAuto {
	margin: 0 auto;
}

.relative{
	position: relative;
}

a:focus, *:focus { outline:none; }

#container {
	opacity: 0;
	overflow: visible !important;
	position: relative;
	top: 5%;
	background: none;
	z-index: 3;
}

.menu {
	display: block;
	position: fixed;
	z-index: 50000;
	top: 36px;
	right: 36px;
	width: 60px;
	height: 40px;
	max-width: 60px;
}

.menu .menu-trigger {
	display: inline-block;
	transition: all 0.2s;
	box-sizing: border-box;
	position: relative;
	width: 60px;
	padding: 5px 0;
	height: 40px;
}

.menu .menu-trigger span {
	display: inline-block;
	transition: all 0.2s;
	box-sizing: border-box;
	position: absolute;
	height: 4px;
	background-color:#000;
	border-radius: 4px;
}

.menu .menu-trigger span:nth-of-type(1) {
	top: 0px;
	width: 60px;
	left: 0px;
}

.menu .menu-trigger span:nth-of-type(2) {
	right: 0px;
	bottom: 18px;
	width: 60px;
}

.menu .menu-trigger span:nth-of-type(3) {
	right: 0px;
	bottom: 0px;
	width: 60px;
}

.menu .menu-trigger.active span {
	display: inline-block;
	transition: all 0.2s;
	box-sizing: border-box;
	position: absolute;
}

.menu .menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(14px) rotate(-45deg);
	transform: translateY(14px) rotate(-45deg);
	top: 4px;
}

.menu .menu-trigger.active span:nth-of-type(2) {
	width: 0;
	height: 0;
}

.menu .menu-trigger.active span:nth-of-type(3) {
	bottom: 4px;
	-webkit-transform: translateY(-14px) rotate(45deg);
	transform: translateY(-14px) rotate(45deg);
}

@media screen and (max-width: 780px) {
	.menu {
		display: block;
		top: 18px;
		right: 18px;
		width: 30px;
		height: 18px;
		margin-bottom: 0px;
	}
	.menu .menu-trigger {
		width: 30px;
		padding: 0;
		height: 18px;
	}
	
	.menu .menu-trigger span {
		height: 1px;
		border-radius: 1px;
	}
	
	.menu .menu-trigger span:nth-of-type(1) {
		top: 0px;
		width: 30px;
		left: 0px;
	}
	
	.menu .menu-trigger span:nth-of-type(2) {
		right: 0px;
		bottom: 9px;
		width: 30px;
	}
	.menu .menu-trigger span:nth-of-type(3) {
		right: 0px;
		bottom: 0px;
		width: 30px;
	}
	.menu .menu-trigger.active span:nth-of-type(1) {
		top: -6px;
	}

	
	.menu .menu-trigger.active span:nth-of-type(3) {
		bottom: -5px;
	}


}

/*header*/
header{
	margin-top: 32px;
	width: 100%;
}
.header__Area{

}
.header__Nav--Logo img{
	max-width: 216px;
}
.header__Nav{
	transition: 0.5s ease;
	opacity: 0;
	visibility: hidden;
	position: fixed;
	top:0;
	left: 0;
	width: 100vw;
	height: 100vh;
	padding: 36px 0 0 0;
	box-sizing: border-box;
	background: #fff;
	text-align: center;
	overflow-y: scroll;
	z-index: 100;
}
.header__Nav nav{
	margin-top: 36px;
}
.header__Nav nav li{
	font-size: 36px;
	line-height: 1.4;
	margin-bottom: 36px;
}
.header__Nav nav li a{
	display: block;
	transition: all 0.3s ease;
	text-decoration: none;
}
.header__Nav nav li:hover a{
	opacity: 0.7;
}
.header__Nav nav .minLi{
	font-size: 18px;
	padding: 32px 0;
	margin-bottom: 0;
	border-bottom: 1px solid #DDDDDD;
}

.noscroll .header__Nav{
	opacity: 1;
	visibility: visible;
}

/*page header*/
header h1.pankuzu{
	font-size: 24px;
	font-weight: 400;
	line-height: 1.2;
}
header h1.pankuzu img{
	max-width: 128px;
	margin-bottom: 0;
}
header h1.pankuzu span{
	display: inline;
	position: relative;
	margin-left: 12px;
	top: -2px;
}

footer {
	position: relative;
}

footer::before {
	position: relative;
	content: "";
	display: block;
	width: 100vw;
	height: 1px;
	background: #DDDDDD;
	left: calc((100vw - 100%)* 0.5 * -1);
}

.footer__Logo {
	width: 216px;
	align-self: flex-end;
	margin-bottom: 0px;
}

.footer__Logo img {
	max-width: 100%;
	margin: 0;
	vertical-align: bottom;
}

.footer__Nav {
	align-self: flex-end;

}

.footer__Nav ul {
	display: flex;
	margin: 0;
	align-items: baseline;
}

.footer__Nav ul li {
	font-size: 36px;
	margin-left: 72px;
}

.footer__Nav ul li.minLi {
	font-size: 18px;
}

.footer__Nav--Bottom {
	width: 100%;
	margin-top: 72px;
	margin-bottom: 72px;
}

.footer__Nav--Bottom ul {
	display: flex;
	margin: 0;
	align-items: baseline;
}

.footer__Nav--Bottom ul li.minLi {
	font-size: 18px;
	margin-right: 72px;
}

.FBnr {
	display: flex;
	justify-content: space-between;
	margin-bottom: 54px;
}

.FBnr li {
	width: 23%;
	padding: 0;
	border: 1px solid #DDDDDD;
}

.FBnr li a {
	display: block;
}

.FBnr li img {
	width: 100%;
	vertical-align: bottom;
	margin: 0;
}

.FCopy {
	text-align: center;
	color: #aaa;
	text-shadow: none;
	font-size: 18px;
	line-height: 20px;
}

@media screen and (max-width: 1340px) {
	header{
		max-width: 980px;
		margin-left:auto;
		margin-right:auto;
	}
	/*page header*/
	header h1.pankuzu{
		font-size: 20px;
	}
	.footer__Nav ul li {
		font-size: 28px;
		margin-left: 72px;
	}
	
	.footer__Nav ul li.minLi {
		font-size: 20px;
	}
	.footer__Nav--Bottom ul li.minLi {
		font-size: 20px;
	}
	.FCopy {
		font-size: 16px;
	}
}
@media screen and (max-width: 1040px) {
	header{
		max-width: 760px;
	}
	/*page header*/
	header h1.pankuzu{
		font-size: 17px;
		padding-right: 60px;
		line-height: 1.7;
	}
	
	.footer__Nav ul li {
		font-size: 24px;
		margin-left: 36px;
	}
	
	.footer__Nav ul li.minLi {
		font-size: 18px;
		
	}
	.footer__Nav--Bottom ul li.minLi {
		font-size: 18px;
		margin-right: 36px;
	}
}
@media screen and (max-width: 780px) {
	header{
		margin-top: 18px;
		max-width: 100%;
	}
	/*page header*/
	header h1.pankuzu{
		font-size: 12px;
	}
	header h1.pankuzu img{
		max-width: 64px;
	}
	.header__Area{

	}
	.header__Area h1 img{
		max-width: 90px;
		margin-bottom: 8px;
	}

	.header__Nav--Logo img{
		max-width: 90px;
	}
	.header__Nav nav{
		margin-top: 24px;
	}
	.header__Nav nav li{
		font-size: 24px;
		margin-bottom: 18px;
	}

	.header__Nav nav .minLi{
		font-size: 15px;
		padding: 16px 0;
	}

	.spBlock{
		display: block;
	}
	footer .flex1.fe{
		justify-content: center;
	}
	.footer__Logo{
		margin: 0 auto 32px auto;
		text-align: center;
	}
	.footer__Logo img{
		max-width: 90px;
	}
	.footer__Nav ul{
		justify-content: center;
		flex-wrap: wrap;
		text-align: center;
	}
	.footer__Nav ul li {
		display: inline-block;
		font-size: 24px;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 32px;
	}
	.footer__Nav ul li.minLi {
		width: 100%;
		display: block;
		font-size: 15px;
		margin-bottom: 0px;
	}
	.footer__Nav ul li.minLi a{
		width: 100vw;
		margin-left: -18px;
		display: block;
		padding: 18px 0;
		border-bottom: 1px solid #EEEEEE;
	}
	.footer__Nav--Bottom{
		margin-top: 0;
	}
	.footer__Nav--Bottom ul{
		
		justify-content: center;
		flex-wrap: wrap;
		text-align: center;
	}
	.footer__Nav--Bottom ul li.minLi {
		width: 100%;
		margin: 0;
		display: block;
		font-size: 15px;
		
	}
	.footer__Nav--Bottom ul li.minLi a{
		width: 100vw;
		margin-left: -18px;
		display: block;
		padding: 18px 0;
		border-bottom: 1px solid #EEEEEE;
	}
	.FBnr {
		display: block;
	}
	
	.FBnr li {
		width: 216px;
		margin: 0 auto 16px auto;
		padding: 0;
		border: 1px solid #DDDDDD;
	}
	
	.FBnr li a {
		display: block;
	}
	.FCopy {
		font-size: 11px;
	}
}



/* index.html */
.hero {
	margin-bottom: 144px;
}

.hero__Txt {
	Margin-top:-18px;
	font-size: 30px;
	margin-left: 54px;
}

.NextArea {}

.NextArea .titles {
	position: absolute;
	left: 0;
	top:0;
	writing-mode: vertical-rl;
	display: flex;
	flex-direction: column;
}

.NextArea .titles h2 {
	margin: 0;
	font-size: 120px;
	line-height: 1em;
	margin-right: auto;
	font-weight: normal;
}

.NextArea .titles .Sub {
	margin: 0;
	font-size: 30px;
	margin-right: 24px;
}

.NextArea .NextArea__Con {
	margin-left: auto;
}

.NextArea .NextArea__Con .NextArea__Con--Num {
	font-size: 36px;
	margin-bottom: 0px;
	line-height: 1.4;
	font-feature-settings: "palt";
}

.NextArea .NextArea__Con .NextArea__Con--Title {
	font-size: 48px;
	margin-bottom: 60px;
	line-height: 1.4;
	font-feature-settings: "palt";
}

.NextArea .NextArea__Con .NextArea__Con--Sub {
	font-size: 30px;
	font-feature-settings: "palt";
	margin-bottom: 60px;
}

.NextArea .NextArea__Con .NextArea__Con--Title+.NextArea__Con--Sub {
	margin-top: -50px;
}

.NextArea .NextArea__Con .Box8 {
	font-size: 21px;
	text-align: justify;
	letter-spacing: 0.01em;
}

.NextArea .NextArea__Con .Box8.Form {
	background: #EEEEEE;
	padding: 72px 0;
	position: relative;
}

.NextArea .NextArea__Con .Box8.Form::before {
	background: #EEEEEE;
	position: absolute;
	content: "";
	display: block;
	right: 100%;
	top: 0;
	height: 100%;
	width: 100vw;
}

.NextArea .NextArea__Con .Box8.Form::after {
	background: #EEEEEE;
	position: absolute;
	content: "";
	display: block;
	left: 100%;
	top: 0;
	height: 100%;
	width: calc((100vw - 100%)*0.5);
}

.NextArea .NextArea__Con .fb_iframe_widget span {
	vertical-align: middle !important;
}


.NextArea table {
	width: 100%;
	margin: 32px 0 8px 0;
	border: 0;
	border-spacing: 0;
}

.NextArea table th,
td {
	text-align: left;
	vertical-align: top;
	border-top: solid 1px #ddd;
	padding: 8px 0 2px 0;
}

.NextArea table th {
	width: 124px;
	font-size: 16px;
}

.NextArea table td {
	font-size: 21px;
}


.Report {
	margin-bottom: 32px;
}

.Report h3 {
	margin-bottom: 0;
}

.Report table {
	width: 100%;
	margin: 8px 0;
	border: 0;
	border-spacing: 0;
	border-bottom: solid 1px #eee;
}

.Report table tr:hover {
	background: #eeeeee;
}

.Report table tr td {
	text-align: left;
	font-size: 20px;
	line-height: 26px;
	vertical-align: top;
	border-top: solid 1px #eee;
	padding: 12px 0 16px 0;
}

.Report table tr td.Times {
	width: 7%;
	font-size: 18px;
}

.Report table tr td.Guest {
	width: 35%;
	font-weight: 500;
	font-size: 36px;
}

.Report table tr td.Guest .Small {
	font-size: 18px;
}

.Report table tr td.Title {
	width: 50%;
	font-size: 24px;
	font-feature-settings: "palt";
}
.Report table tr td.Title .Small{
	font-size: 15px;
}

.Staff {
	border-top: solid 1px #eee;
	padding: 8px 0;
	margin-bottom: 46px;
	width: 612px;
}

.Staff__Spec {
	display: flex;
}

.Staff__Spec .Links {
	display: flex;
}

.Staff__Spec .Links p {
	margin-right: 12px;
}

.Staff,
.Pic,
.Prf {
	position: relative;
	padding: 0;
}

.Staff .Pic {
	width: 180px;
	margin: 18px 36px 0 0px;
}

.Staff .Pic img {
	width: 100%;
}

.Staff .Prf {
	width: 382px;
	margin: 8px 0 0 8px;
}

.Staff .PrfBox {
	margin: 0;
	padding: 0;
}

.Staff .PrfBox h3 {
	font-size: 30px;
	margin: 18px 0 18px 0;
}

.Staff .PrfBox .Post {
	font-size: 18px;
	font-weight: normal;
	margin-bottom: 18px;
	line-height: 1.6;
}

.Staff .Prf p {
	font-size: 12px;
	line-height: 22px;
}
.Staff .Staff__Txt{
	text-align: justify;
	letter-spacing: 0.01em;
}



#jsArea {
	width: 624px;
	height: 624px;
}

#jsArea img {
	width: 100% !important;
	height: 100% !important;
	left: 0 !important;
}





@media screen and (max-width: 1340px) {
	.hero {
		margin-bottom: 144px;
	}
	
	.hero__Txt {
		Margin-top:-12px;
		font-size: 23px;
		margin-left: 34px;
	}
	#jsArea {
		width: 484px;
		height: 484px;
	}
	.NextArea .titles h2 {
		font-size: 90px;
	}

	.NextArea .titles .Sub {
		margin: 0;
		margin-right: 24px;
		font-size: 24px;
	}


	.NextArea .NextArea__Con .NextArea__Con--Num {
		font-size: 24px;
	}

	.NextArea .NextArea__Con .NextArea__Con--Title {
		font-size: 32px;
	}

	.NextArea .NextArea__Con .NextArea__Con--Sub {
		font-size: 20px;
	}

	.NextArea .NextArea__Con .Box8 {
		font-size: 20px;
	}
	.NextArea table th {
		width: 108px;
		font-size: 16px;
	}

	.NextArea table td {
		font-size: 20px;
	}
	
	
	.Report table tr td {
		font-size: 18px;
	}
	
	.Report table tr td.Times {
		font-size: 16px;
	}
	
	.Report table tr td.Guest {
		font-size: 32px;
	}
	
	.Report table tr td.Guest .Small {
		font-size: 14px;
	}
	
	.Report table tr td.Title {
		font-size: 20px;
	}

	.Staff{
		max-width: 464px;
	}
	.Staff .Pic {
		width: 180px;
	}
	
	.Staff .PrfBox h3 {
		font-size: 26px;
	}
	
	.Staff .PrfBox .Post {
		font-size: 16px;
	}
	
}
@media screen and (max-width: 1040px) {
	.hero {
		margin-bottom: 96px;
	}
	
	.hero__Txt {
		Margin-top:-10px;
		font-size: 17px;
		margin-left: 24px;
	}
	#jsArea {
		width: 354px;
		height: 354px;
	}
	.NextArea .titles h2 {
		font-size: 72px;
	}

	.NextArea .titles .Sub {
		margin: 0;
		margin-right: 24px;
		font-size: 20px;
	}


	.NextArea .NextArea__Con .NextArea__Con--Num {
		font-size: 20px;
	}

	.NextArea .NextArea__Con .NextArea__Con--Title {
		font-size: 28px;
	}

	.NextArea .NextArea__Con .NextArea__Con--Sub {
		font-size: 17px;
	}

	.NextArea .NextArea__Con .Box8 {
		font-size: 17px;
		
	}
	.NextArea table th {
		width: 84px;
		font-size: 15px;
	}

	.NextArea table td {
		font-size: 17px;
	}
	
	
	.Report table tr td {
		font-size: 17px;
	}
	
	.Report table tr td.Times {
		width: 10%;
		font-size: 15px;
	}
	
	.Report table tr td.Guest {
		font-size: 28px;
	}
	
	.Report table tr td.Guest .Small {
		font-size: 14px;
	}
	
	.Report table tr td.Title {
		font-size: 18px;
	}

	.Staff{
		max-width: 344px;
	}
	.Staff .Pic {
		width: 180px;
	}
	
	.Staff .PrfBox h3 {
		font-size: 26px;
	}
	
	.Staff .PrfBox .Post {
		font-size: 16px;
	}
}
@media screen and (max-width: 780px) {
	.hero {
		margin-bottom: 96px;
	}
	
	.hero__Txt {
		margin-top: 36px;
		font-size: 15px;
		margin-left: 0px;
		font-size: clamp(11px, 4.15vw, 2.3rem);
	}
	.hero__Txt span{
		display: inline-block;
	}
	.hero .Box8{
		width: 100%;
	}
	#jsArea {
		width: calc(100vw - 36px);
		height: calc(100vw - 36px);
	}
	.NextArea .titles {
		width: 100%;
		position: static;
		writing-mode:horizontal-tb;
		display: block;
		margin-bottom: 36px;
	}
	.NextArea .titles h2 {
		font-size: 36px;
	}

	.NextArea .titles .Sub {
		margin:21px 0 0 0;
		font-size: 15px;
	}


	.NextArea .NextArea__Con .NextArea__Con--Num {
		font-size: 15px;
	}

	.NextArea .NextArea__Con .NextArea__Con--Title {
		font-size: 24px;
		margin-bottom: 19px;
		
	}

	.NextArea .NextArea__Con .NextArea__Con--Sub {
		font-size: 15px;
		margin-bottom: 18px;
	}
	.NextArea .NextArea__Con .NextArea__Con--Title+.NextArea__Con--Sub {
		margin-top: -9px;
	}

	.NextArea .NextArea__Con .Box8 {
		width: 100%;
		font-size: 15px;
	}
	.NextArea .NextArea__Con .Box12{
		width: 100%;
	}

	.NextArea table {
		display: block;
		width: 100%;
	}
	.NextArea table tbody{
		width: 100%;
		display: block;
	}
	.NextArea table tr{
		display: block;
		width: 100%;
		flex-direction: column;
	}
	.NextArea table th {
		display: block;
		width: 100%;
		font-size: 12px;
	}

	.NextArea table td {
		padding-top: 0;
		display: block;
		border: none;
		font-size: 17px;
	}
	.Report table tr {
		border-top: solid 1px #eee;
		display: flex;
		flex-wrap: wrap;
		width: calc(100vw - 36px);
	}
	.Report table tr th {
		border: none;
	}
	.Report table tr td {
		border: none;
		font-size: 17px;
		padding: 6px 0 8px 0;
	}
	
	.Report table tr td.Times {
		width: 100%;
		font-size: 11px;
		padding-bottom: 0;
	}
	.Report table tr td.Times br{
		display: none;
	}
	
	.Report table tr td.Guest {
		padding-top: 0;
		font-size: 18px;
		width: 35%;
		margin-right: 5%;
		align-self: flex-start;
	}
	
	.Report table tr td.Guest .Small {
		font-size: 11px;
		display: inline-block;
		line-height: 1.4;
		vertical-align: inherit;
	}
	
	.Report table tr td.Title {
		width: 60%;
		font-size: 18px;
		padding-top: 0;
		align-self: flex-start;
	}
	.Report table tr td.Title .Small {
		font-size: 11px;
		display: inline-block;
		line-height: 1.4;
		vertical-align: inherit;
	}
	.Report table tr td.Title .Small:empty{
		display: none;
	}
	.Staff{
		max-width: 100%;
		width: 100%;
		margin-bottom: 24px;
	}
	.Staff .Pic {
		margin: 18px 18px 0 0px;
	}
	
	.Staff .PrfBox h3 {
		font-size: 18px;
	}
	
	.Staff .PrfBox .Post {
		font-size: 15px;
	}
	.Staff .Staff__Txt{
		font-size: 12px;
	}
}



/*page*/
.page{
	position: relative;
}
.page .page__Titles{
	position: absolute;
	left:0;
	top:0;
	writing-mode: vertical-rl;
    display: flex;
    flex-direction: column;
}
.page .page__Titles h2 {
	margin: 0;
	font-size: 96px;
	line-height: 1em;
	margin-right: auto;
	font-weight: normal;
}

.page .page__Titles .Sub {
	margin: 0;
	font-size: 30px;
	margin-right: 24px;
    max-height: 700px;
}
.page .page__PostT{
	margin-top: 72px;
	padding-top: 216px;
	font-size: 48px;
	margin-bottom: 48px;
	font-weight: 500;
	font-feature-settings: "palt";
}
.page .page__PostT h3{
	line-height: 1.4;
}
.page .page__PostT .Sub{
	font-size: 30px;
    font-weight: normal;
    margin: 16px 0;
    color: #000;
}

.page .page__Num{
	font-size: 36px;
}
.page .page__About .Intro{
	font-size: 21px;
	font-weight: 500;
	text-align: justify;
}

.page .page__Img{
	position: absolute;
	right: calc(100% + 108px);
	top:12px;
	width: calc((100vw - 100%)*0.5 - 108px);
}
.page .page__Img img{
	width: 100%;
	max-width: 640px;
}
.page .page__Con{
	margin-top: 72px;
}
.page .page__Con p{
	font-size: 18px;
	text-align: justify;
	margin-bottom: 36px;
}

.PrevNextPost{
	display: flex;
	justify-content: space-between;
	margin-bottom: 84px;
}
.PrevNextPost .Prev{
	position: relative;
}
.PrevNextPost .Prev::before{
	position: absolute;
	top: calc(50% - 15px);
	right: calc(100% + 10px);
	content: "";
	display: block;
	height: 30px;
	width: 30px;
	border-top:1px solid #707070;
	border-left:1px solid #707070;
	transform: rotate(-45deg);
}
.PrevNextPost span{
	display: block;
	font-size: 18px;
	line-height: 1.3;
}
.PrevNextPost .Next{
	text-align: right;
	margin-left: auto;
	position: relative;
}
.PrevNextPost .Next::after{
	position: absolute;
	top: calc(50% - 15px);
	left: calc(100% + 10px);
	content: "";
	display: block;
	height: 30px;
	width: 30px;
	border-top:1px solid #707070;
	border-right:1px solid #707070;
	transform: rotate(45deg);
}
.PrevNextPost .Next span{
	display: block;
}

.PrevNextPost .name{
	font-size: 36px;
}

/*howto*/
.howto{
	margin-bottom: 72px;
}
.howto h2{
	font-feature-settings: "palt";
	line-height: 1.2;
	margin: 94px 0;
	font-size: 96px;
	font-weight: 400;
}

.howto .PFD-Btn {
	margin-top: 24px;
	text-align: right;
}
.howto .PFD-Btn a{
	margin-top: 24px;
}
.howto h3{
	font-feature-settings: "palt";
	line-height: 1.2;
	margin-top: 142px;
	margin-bottom: 60px;
	font-size: 48px;
	font-weight: 400;
}
.howto p{
	font-size: 18px;
	text-align: justify;
	margin-bottom: 36px;
}

@media screen and (max-width: 1340px) {
	
	.page .page__Titles h2 {
		font-size: 90px;
	}
	
	.page .page__Titles .Sub {
		font-size: 24px;
	}
	.page .page__PostT{
		padding-top: 162px;
		font-size: 32px;
	}
	.page .page__PostT .Sub{
    	font-size: 18px;
	}
	.page .page__Num{
		font-size: 24px;
	}
	.page .page__About .Intro{
		font-size: 20px;
	}
	.page .page__Img{
		right: calc(100% + 54px);
		width: calc((100vw - 100%)*0.5 - 54px);
	}
	.page .page__Con{
	}
	.page .page__Con p{
		font-size: 20px;
	}
	.PrevNextPost .Prev{
		position: relative;
	}
	.PrevNextPost span{
		font-size: 20px;
	}
	
	.PrevNextPost .Next span{
		display: block;
	}
	
	.PrevNextPost .name{
		font-size: 24px;
	}
	/*howto*/
	.howto h2{
		margin: 74px 0;
		font-size: 90px;
	}
	
	.howto .PFD-Btn {
		margin-top: 20px;
		text-align: right;
	}
	.howto .PFD-Btn a{
		margin-top: 20px;
	}
	.howto h3{
		margin-top: 92px;
		margin-bottom: 50px;
		font-size: 32px;
	}
	.howto p{
		font-size: 20px;
	}
}
@media screen and (max-width: 1040px) {
	
	.page .page__Titles h2 {
		font-size: 72px;
	}
	
	.page .page__Titles .Sub {
		font-size: 20px;
	}
	.page .page__PostT{
		font-size: 28px;
	}
	.page .page__Num{
		font-size: 20px;
	}
	.page .page__About .Intro{
		font-size: 17px;
	}
	.page .page__Img{
		right: calc(100% + 32px);
		width: calc((100vw - 100%)*0.5 - 32px);
	}
	.page .page__Con{
	}
	.page .page__Con p{
		font-size: 17px;
	}
	.PrevNextPost{
		max-width: 640px;
		margin: 0 auto 84px auto;
	}
	.PrevNextPost .Prev{
		position: relative;
	}
	.PrevNextPost span{
		font-size: 15px;
	}
	
	.PrevNextPost .Next span{
		display: block;
	}
	
	.PrevNextPost .name{
		font-size: 20px;
	}
	/*howto*/
	.howto{
		margin-bottom: 54px;
	}
	.howto h2{
		margin: 54px 0;
		font-size: 72px;
	}
	
	.howto .PFD-Btn {
		margin-top: 20px;
	}
	.howto .PFD-Btn a{
		margin-top: 17px;
	}
	.howto h3{
		line-height: 1.2;
		margin-top: 72px;
		margin-bottom: 36px;
		font-size: 28px;
	}
	.howto p{
		font-size: 17px;
	}
}
@media screen and (max-width: 780px) {
	.page .page__Titles{
		position: static;
		writing-mode:horizontal-tb;
		display: block;
	}
	.page .page__Titles h2 {
		margin:48px 0 21px 0;
		font-size: 36px;
	}
	.page .page__Titles .Sub {
		font-size: 15px;
		margin-right: 0px;
	}
	.page .Box8{
		width: 100%;
	}
	.page .page__PostT{
		width: 100%;
		margin-top: 36px;
		padding-top: 0px;
		font-size: 24px;
		margin-bottom: 18px;
	}
	.page .page__PostT .Sub{
		font-size: 18px;
	}
	.page .page__Num{
		font-size: 15px;
	}
	.page .page__About .Intro{
		font-size: 15px;
	}
	
	.page .page__Img{
		margin-top: 18px;
		position: relative;
		right: auto;
		left: -18px;
		top:0;
		width: 70%;
	}
	.page .page__Con{
		margin-top: 18px;
	}
	.page .page__Con p{
		font-size: 15px;
	}
	
	.PrevNextPost{
		max-width: 90%;
		margin: 0 auto 54px auto;
		display: flex;
		justify-content: space-between;
		margin-bottom: 84px;

	}
	.PrevNextPost .Prev{
		max-width: 45%;
		position: relative;
	}
	.PrevNextPost .Prev::before{
		top: calc(50% - 8px);
		right: 100%;
		content: "";
		display: block;
		height: 15px;
		width: 15px;
	}
	.PrevNextPost span{
		display: block;
		font-size: 12px;
		line-height: 1.3;
	}
	.PrevNextPost .Next{
		max-width: 45%;
		position: relative;
	}
	.PrevNextPost .Next::after{
		top: calc(50% - 8px);
		left: 100%;
		content: "";
		display: block;
		height: 15px;
		width: 15px;
	}
	.PrevNextPost .Next span{
		display: block;
	}
	
	.PrevNextPost .name{
		font-size: 18px;
	}
	
	/*howto*/
	.howto{
		margin-bottom: 36px;
	}
	.howto .Box8{
		width: 100%;
		max-width: 100%;
	}
	.howto h2{
		margin: 48px 0 32px 0;
		font-size: 36px;
	}
	
	.howto .PFD-Btn {
		margin-top: 0px;
	}
	.howto .PFD-Btn a{
		margin-top: 15px;
	}
	.howto h3{
		margin-top: 54px;
		margin-bottom: 18px;
		font-size: 24px;
	}
	.howto p{
		font-size: 15px;
	}
}



.reF .container {
    background: none!important;
    margin: auto;
    max-width: 700px;
    width: 100%;
    padding: 0;
    border-radius: 0;
    box-sizing: border-box;
    border: none;
}