/*	news
============================== */
div.sns-share section h2, div.sns-share section h3, div.sns-share section div.sns-rig {
    padding: 5px 0 8px;
    letter-spacing: 0em;
}
body.news article .newsArea { position: relative; background:#FFF6C7; border:solid 1px #000; box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.08);}
.newsArea .contentsBlock {}

article { position: relative;}
.low.news div.sns-share { background-image: none; padding-top: 0;}


@media all and (min-width: 768px) {
	body.news #contentsArea { padding-bottom: 100px;}
	.tag:not(:first-of-type){ padding-top: 60px;}
	
	article { width: 1080px; margin:0 auto;}
	article .newsArea {width: 1080px; padding: 0; margin: 0 auto;
	border-radius: 40px;
    -webkit-border-radius: 40px;
    -moz-border-radius: 40px;}
	article div.sns-share section {
    padding: 0px 0px 25px;
    margin: 0 auto;
}

}
@media all and (max-width: 767px) {
	body.news #contentsArea { padding-bottom: 40px;}
	.tag:not(:first-of-type){ padding-top: 15px;}
	body.news div.wrap { margin: 2em auto 0;}
	article { width: 100%; margin: 0 auto;}
	article .newsArea{ padding: 0;
	border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;}
}

body.news article .title {font-weight: 500; text-align:center; border-bottom:solid 1px #000; background-color: #FFFBE3;}
body.news .date {
	font-family: "verveine", sans-serif;
	font-weight: 400;
	font-style: normal;
	letter-spacing: 0.05em;
	color: #000;
}
body.news article .title h2 {
	font-size: 1.6em;
	line-height: 1.5em;
	font-weight: 800;
}

body.news article h3{ 
	text-align: center;
	 color: #08914B;
	font-weight: 700;
}
body.news article h4{ 
	margin-bottom: 1.5em;
	line-height: 1.6em;
	text-align: center;
}
body.news article h4 span.under {
	background: linear-gradient(transparent 50%, rgba(238,159,158,0.6) 50%);
	color: #000;
    padding: 0 5px 5px;}

.comment h4 {
	font-weight: 700;
	font-size: 1.6em;
	line-height: 1.0em;
	position: relative;
	display: inline-block;
	padding: 0 0 0 35px;}
.comment h4:before {
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 25px;
  height: 2px;
  background-color: #9E4FD3;
	left:0;
}
.comment h4 .small { font-size: 0.8em;}

body.news article h5 { font-size: 0.9em;}


.phArea {text-align:center; }
.ph { margin:auto; position: relative;}
.ph p { position:relative; width:100%; height:0;
	border-radius: 8px;
    -webkit-border-radius: 8px;
    -moz-border-radius: 8px; }
.ph p span { position:absolute; display:block; left:0; top:0; width:100%; height:100%; background-position:center center; background-repeat:no-repeat; background-size:cover; text-indent:-9999px;}
#n_p_250408.phArea .ph p span {border: solid 1px #ccc;}

.product {color: #d22179; font-weight: bold; text-align: center; font-size: 1.1em; padding-top: 1em; line-height: 1.6em;}
.product .small {font-size: 0.8em;}
.productTxt { margin:1em 0;}

.borderBox {border: solid 1px #000; padding:1.5em; margin:2em auto 2em;}
.borderBox .txt {line-height: 1.6em;}


.endCam { position: relative;}
.endCam .endInfo {position: absolute; width: 100%; height:100%; background-color: rgba(255,255,255,0.8); top:0; left:0; display: table; }
.endCam .endInfo p {display: table-cell; vertical-align: middle; line-height: 1.5em;}
.endCam .endInfo p span.info { border: solid 1px #A12609; display: inline-block; padding:10px 15px 15px; background-color: rgba(255,255,255,0.8);}

.txtArea ul li {line-height: 1.88em;}

@media all and (min-width: 768px) {
	.newsBlock {padding:30px 0 0;}
	body.news article .title  { border-top-left-radius: 40px; border-top-right-radius: 40px; padding:15px 0 0; margin-bottom:0px;}
	body.news .date { font-size: 1.5em;}
	body.news article .title h2 { padding: 15px 0;}
	section.txtArea {width: 880px; margin: 0 auto 1.8em;}
	section.txtArea .add { margin-top: -25px; padding: 0 10px;}
	/*section.txtArea .txt {padding: 0 0 0.8em;}*/
	.borderBox p.txt {margin: 0 auto 0.25em; padding: 0.5px 0 1.6em;}
	
	
	body.news article h3 { font-size: 1.4em; line-height: 1.5em; text-align: center; margin-bottom: 1.4em;}
	body.news article h4 { font-size: 1.2em; line-height: 1.5em;}
	
	body.news article.info { margin-top: 3em;}
	
	.phArea { margin:0px auto 50px auto;}
	.phBox { padding-bottom: 2.0em;}

	.borderBox { width: 830px;}
	.txtArea h5 {width: 880px; margin: 0 auto; padding:0 0 1em; line-height: 1.5em; text-align: center;}
	.txtArea ul {width: 880px; margin: 0 auto 0.25em; padding: 0.25em 0;}
	
	.multiple { text-align: center; padding: 0;}
.multiple .phArea { display: inline-block; margin:0px 12px 25px; vertical-align: top;}
	
	.n_0319 .txtArea .cast, .n_0324 .txtArea .notesS, .n_0328 .txtArea .notesS{ text-align: center;}
	
	#n_p_250408.phArea {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	}
	#n_p_250408.phArea .ph { margin: 12px;}
	
	
}


@media all and (max-width: 767px) {
	body.news article .title {border-top-left-radius: 30px; border-top-right-radius: 30px; padding:5px 5px 0;}
	body.news .date { font-size: 1.2em; letter-spacing: 0.02em; padding: 0;}
	body.news article .title h2 {font-size:1.1em; line-height: 1.4em; padding: 8px 0;}
	.newsBlock {padding: 1em 1em 0;}
	/*section.txtArea { padding:0.5em 0 1em; font-size: 0.9em; line-height: 1.8em;}*/
	body.news article h3{ font-size: 1.1em; line-height: 1.5em; margin: 0.1em 0 1.5em;}
	section.txtArea .add { margin-top: -15px; padding: 0 10px;}
	/*section.txtArea .txt {padding: 0 0 0.8em; font-size: 1em;}*/
	
	body.news article h4 { font-size: 1.0em;}
	.txtArea .tableBlock h4 { margin-bottom: 0.5em;}
	
	.comment h4 {padding: 0 0 0 25px;}
	.comment h4:before {width: 20px;}
	
	.phArea { width:95%; margin:0 auto 20px; }
	#n_p_250408.phArea .ph { padding-bottom: 15px;}

	.ph { width:auto!important; height:auto!important; }
	.phBox { padding-bottom: 1.0em;}
	
	.borderBox {padding:1em; margin: 1.5em 0;}
	.borderBox .txt { font-size: 0.9em; margin: 0 0 0.6em; padding: 0.5px 0 0; }
	.borderBox .txt:not(:last-child) {padding: 0.5px 0 1.2em; }
	
	.endCam .endInfo {height:100vh;}
	
	body.news article div.sns-share section {
        width: 100%;
        padding: 0 0px 15px;
        margin: 0 auto;
    }
	
	.txtArea h5 {font-size: 0.9em; margin: 0 0 0.8em; line-height: 1.5em;}
	.txtArea ul {font-size: 0.9em; margin: 0 3% 0.6em; padding: 0 0 1.2em;}
	.txtArea ul li {line-height: 1.5em; padding-bottom:0.2em; }
	
}

/*	butten
============================== */
p.button a{
    text-align: center;
    margin: 0 auto;
	padding:0;
	font-weight: 700;
	color: #7B562C;
	transition:0.5s;
	background-color: #FBEEA0;
	background-image:  url(../img/btn_arrow.png);
	background-repeat: no-repeat;
	border:solid 2px #7B562C;
	display: table;
}
p.button a:hover {
filter: brightness(1.1);
}
p.button a span {vertical-align: middle;display: table-cell; line-height: 1.3em; letter-spacing: -.05em;}

@media all and (min-width: 768px) {
	p.button { padding-bottom: 2em;}
	p.button a { width: 300px; height: 70px;
	    border-radius: 35px;
    -webkit-border-radius: 35px;
    -moz-border-radius: 35px;
	background-position:right 13px center;
	background-size: 30px 30px;}
	p.button a span {padding-right: 20px; font-size: 1.3em;}
	
	p.button.tall a span { padding:25px 0 20px 10px;}
	.n_0319 .multiple {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;	
}
	.n_0319 .multiple .button { width:calc((100% - 30*2px)/3); }
	.n_0319 .multiple .button:not(:last-child) {
	margin-right:30px;
	}
	.n_0319 .multiple p.button a { width: 100%;}
	

	.n_0327 .multiple .button a {width: 220px;display: table; padding-left: 10px;}
	.n_0327 .multiple .button a span {    padding: 0px 30px 0px 0px; height: 65px; line-height: 1.2em;display: table-cell;
  vertical-align: middle;}
	.multiple .button { margin-bottom: 1em;}
	
}

@media all and (max-width: 767px) {
	p.button { padding-bottom: 1.5em;}
	p.button a { width: 240px; height: 52px;font-size: 1.0em;
	border-radius: 26px;
    -webkit-border-radius: 26px;
    -moz-border-radius: 26px;
	background-position:right 10px center;
	background-size: 24px 24px;}
	p.button a span {padding-right: 15px;}
	
	p.button.tall a span { padding: 20px 0 15px 10px;}
	.multiple .button { margin-bottom: 1em;}
}


/*	trailer
============================== */
@media all and (min-width: 768px) {
	.movieBox, .photoBox {width:750px; margin: 15px auto 25px auto; position: relative; }
	.movieBox div {width:750px;}
	.movieBox iframe {width:750px; height:422px;}
}
@media all and (max-width: 767px) {
	.movieBox, .photoBox {margin: 15px 0%; width:100%; position: relative;}
}


.disc li {
  text-align: left;
}


/*	table
============================== */

table {
 border-collapse:collapse;
 border-spacing:0;
 margin: 0 auto;
 letter-spacing: 0.05em;
}

table.border { border: solid 1px #fff; padding: 10px;}

table th ,
table td {
 padding-bottom: 0.5em;
}
table tr.space th ,
table tr.space td {
 padding-bottom: 0;
}
table th {
 text-align:left;
}
table td {
 text-align:left;
}
table th {
 font-weight: normal;
 white-space: nowrap;
 line-height: 2.5;
}

table th, table td {
 vertical-align: baseline;
	line-height: 1.5em;
}

.notes {padding-left:1em; text-indent:-1em; line-height: 1.5em; text-align: left; }
.txtArea .notes { line-height: 1.88em;}
.notesS {padding-left:1em; padding-bottom: 0.2em; text-indent:-1em; line-height: 1.5em; text-align: left; }
.notesTxt {
	padding: 0.5em 0 1em;}
.notesTxt h5 {padding-bottom: 0.5em;}
.notesTxt p  {line-height: 1.5em; display: inline-block; text-align: left;}
.n_1210 table, .n_1217_3 table, .n_1219 table, .n_1220 table, .n_0119 table { margin: 0 0;}
.n_0602 table th { text-align: right;}

.n_0801_1 table { margin-bottom: 1em;}
.n_0801_1 table th {
 width: 5em; text-align: right; padding-right: 0.5em;
}

.n_1203 .borderBox { margin: 0em auto 2em;}
.n_1203 .borderBox div:not(:last-child)  { margin-bottom: 1em;}
.n_1203 .borderBox div p:not(:last-child)  { margin-bottom: 0.5em;}

@media all and (min-width: 768px) {
	table {font-size:1em;}
	
	.tableBlock { margin: 0 auto;}
	.tableBlock table { margin: 0 0; }
	.tableBlock p {font-size:0.9em;}
	.n_1004 .tableBlock { width: 600px;}
	.n_1019 .tableBlock, .n_1126 .tableBlock { width: 500px;}
	.n_1119 .tableBlock { width: 400px;}
	
	.n_0801_1 .borderBox { width: 700px; padding: 1em 1em;}
	.n_0801_1 .borderBox p.txt { text-align: center;}
	
	.n_1203 .borderBox div { width: 380px; margin: 0 auto;}
	
	.notesS { font-size: 0.9em;}
	
	.txtArea .tableBlock {padding: 3px 0 2em;}
	.txtArea .tableBlock table th, .txtArea .tableBlock table td {padding-bottom: 0.4em;}
	
	table td.multi { line-height: 1.7em;}

}
@media all and (max-width: 767px) {
	table { font-size:0.9em; }
	
	.tableBlock table {width: 100%;}
	.tableBlock p {font-size:0.8em;}
	
	.notesTxt h5 { font-size: 0.9em;}
	.notesTxt p  {font-size: 0.9em;}
	.notes { font-size: 0.9em;}
	.notesS { font-size: 0.8em;}
	.txtArea .notes {line-height: 1.98em;}
	
	.n_0916 .borderBox table { margin: 1em 0em 0;}
	.n_0408 table th { letter-spacing: -0.05em;}
	.txtArea .tableBlock {
		/*font-size: 0.9em;*/
        margin: 0 0 1.5em;
        padding: 0.5px 3%;
		background-color: #F7F6F4;
		
	}
	.txtArea .tableBlock table {border-top: solid 2px rgba(194, 189, 181, 0.5);}
	.txtArea .tableBlock table th, .txtArea .tableBlock table td {line-height: 1.88em; padding-bottom: 0em; border-bottom: solid 2px rgba(194, 189, 181, 0.5);}
}

.infoBox { margin: 0 auto}
@media all and (min-width: 768px) {
	.infoBox { padding: 1em 0;} 
.n_0917_2 .infoBox {width: 700px}
}
@media all and (max-width: 767px) {
	.infoBox { padding: 0.5em 0;}
}

@media all and (max-width: 390px) {
	.prd {letter-spacing: -0.05em;}
}

article.n_0925 div.borderBox table {
	margin-top:1em;
}
@media all and (max-width: 767px) {
article.n_0925 div.borderBox table th,
article.n_0925 div.borderBox table td,
article.n_1015 div.borderBox table th,
article.n_1015 div.borderBox table td{
	display:block;
	text-align:center;
}
article.n_0925 div.borderBox table {
	margin-top:1em;
}
article.n_0925 div.borderBox table th {
	font-weight:bold;
}
article.n_0925 div.borderBox table th > span {
	display:none;
}
article.n_0925 div.borderBox table th {
	/*font-size:87.5%;*/
}
article.n_0925 div.borderBox table td {
	/*font-size:83%;*/
	margin-bottom:2em;
}

}

ol {
	margin-left: 2em; /* サイトに合せて調整 */
}

ol li {
	list-style-type: none;
	counter-increment: cnt;
	line-height: 1.5em;
}

ol li::before {
	content: "(" counter(cnt) ")";
	display:inline-block;
	margin-left:-2em; /* サイトに合せて調整 */
	width: 2em; /* サイトに合せて調整 */
}

/*	termsArea
============================== */
#termsArea li {line-height: 1.5em; padding-bottom: 0.5em;}
#termsArea h3 { text-align: center;}
#termsArea h3 span {background: linear-gradient(transparent 30%, #bfe1fc 20%); padding:0 18px 8px; display: inline-block; margin-bottom: 15px; line-height: 1.0em;
font-weight: 900;}
#termsArea .update { text-align: right; line-height: 1.5em; font-size: 0.9em;}
#termsArea .add { text-align: center; color: #ef1828; font-weight: bold; padding: 10px 0 15px;}
.agreeArea { text-align: center; }
#termsArea p, .agreeArea p {line-height: 1.5em;}
.termsBox p { padding-bottom: 0.5em;}
.agreeArea .agree { font-size: 1.1em; font-weight: bold; padding: 25px 0;}


.agreeArea .noteTxt { text-align: center; color: #ef1828; font-weight: bold;}

#terms {border:solid 1px rgba(0, 0, 0, 0.2); margin: 10px auto;}
.termsBox { padding: 20px 15px; line-height: 1.5em;} 

.termsBox .uline {
background:linear-gradient(transparent 85%, #bfe1fc 0%);
}
.termsBlock ul { padding-left: 1em; list-style-position: outside;
  list-style-type: disc;}
.termsBlock ul ul {list-style-type: none;}
.termsBlock dl { padding-bottom: 0.3em;}
.termsBlock dt,.termsBlock dd { line-height: 1.5em;}

@media all and (min-width: 768px) {
	#termsArea .read { padding-bottom: 45px; font-size: 1.1em;}
	#termsArea h3 span { font-size: 1.3em;}
	#terms {padding: 20px;}
	.txtArea #terms ul {width: auto;}
}
@media all and (max-width: 767px) {
	#termsArea .read { padding-bottom: 30px; font-size: 0.9em;}
	#termsArea h3 span { font-size: 1.1em;}
	#termsArea .termsBox { font-size: 0.9em;} 
	.agreeArea { font-size: 0.9em;} 
	.agreeArea .agree {padding: 15px 0;}
	#terms {padding: 10px;}
	.termsBox { padding: 20px 5px;}
	.termsBlock dt,.termsBlock dd { font-size: 0.9em;}
}


/**--スライダー--**/
.slider-wrapper {
  width: 100%; height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
	margin: 0 auto;
}

.slider {
  height: 400px;
  -webkit-overflow-scrolling: touch;
}

.slider > * {
  -webkit-transform: translateZ(0px);
}

/*.slider-wrapper::-webkit-scrollbar {
  display: none;
  height: 0 !important;
}*/
/*/ スクロールバー全体*/
.slider-wrapper::-webkit-scrollbar {
  width:6px;
  /*background:#eee;*/
}
/*/ 横スクロールバー全体*/
.slider-wrapper::-webkit-scrollbar:horizontal {
  /*height:10px;*/ display: none;
}
/*/ スクロールバー上下左右末端のボタン*/
.slider-wrapper::-webkit-scrollbar-button {
  width:6px;
  height:6px;
  /*background:#666;*/
}
/*/ ドラッグするツマミ部分*/
.slider-wrapper::-webkit-scrollbar-thumb {
  background:rgba(255, 161, 29, 1);
border-radius: 3px; 
-webkit-border-radius: 3px;
-moz-border-radius: 3px;
}
/*/ 右下角部分*/
.slider-wrapper::-webkit-scrollbar-corner {
  /*background:#ddd;*/
}

.agreeArea { padding-bottom: 1em;}
.agreeArea #button button{
  text-align: center;
    margin: 0 auto;
	padding:0;
	font-weight: 700;;
	color: #fff;
	font-size: 1.3em;
	transition:0.5s;
	background-image:  url(../img/btn_320.png);
	background-repeat: no-repeat;
	background-position:center center;
	background-size: contain;
	background-color: #fff;
	display: table;
	border: none;
}
.agreeArea #button button span {vertical-align: middle; display: block; line-height: 1.3em;}
.agreeArea #button button:hover {filter: brightness(1.1);}

.agreeArea #button button:disabled {opacity:0.55;}

.environment { padding-top: 2em;}
.environment div { padding-top: 1em;}

@media all and (min-width: 768px) {
	.agreeArea #button button {width: 320px; height: 80px;}
	.agreeArea #button button span{padding-left: 20px;}
	.environment dl dt, .environment dl dd  { display: inline-block;}
}

@media all and (max-width: 767px) {
	.agreeArea #button button{ width: 306px; height: 67px; font-size: 1.1em;}
	.agreeArea #button button span {padding-left: 10px;}
}
