@charset "UTF-8";

/*--------------------------------------------------------
解像度1200px以下
--------------------------------------------------------*/
@media
only screen and (max-width : 1200px){
	.site-header,
	.global-nav,
	.main-body,
	.main-body-und,
	.site-footer{
		min-width: 0;
	}

	.site-header-in,
	.global-nav-in,
	.main-body-in,
	.main-body-und-in,
	.site-footer-in{
		width: 96%;
		margin: auto;
	}
	
	.main-image-in,
	.main-image-in-text,
	.main-image-in-text .main-image-in-text-cont,
	.main-image-in-text.wide .main-image-in-text-cont{
		width: 100%;
	}

	.col1 .section-wrap,
	.col1 .breadcrumbs,
	.col1 .section-wrap.wide .section-in,
	.col1 .section-wrap.wide{
		width: auto;
	}
	
	.col1 .breadcrumbs-in,
	.col1 .float-area{
		width: 96%;
		margin-right: auto;
		margin-left: auto;
	}
	
	/*吹き出し*/
	.bubble{
		width: 70%;
	}
	
	.talker{
		width: 25%;
	}
	
	.bubble .bubble-in:after,
	.bubble .bubble-in:before{
		top: 30px;
	}
	
	.together .bubble,
	.together .talker{
		width: 100%;
	}
	
	.together .talker b{
		max-width: 25%;
	}
	
}/*解像度1200px以下*/


/*--------------------------------------------------------
解像度737px以上950px以下
--------------------------------------------------------*/
@media (min-width: 737px) and (max-width: 950px){
	
	
	.col1 .banner-list li{
		display: list-item;
		margin-left: 0;
	}

}/*解像度737px以上950px以下*/

/*--------------------------------------------------------
解像度736px以下
--------------------------------------------------------*/
@media
only screen and (max-width : 736px){

	html,
	body,
	.containr{
		min-width: 0;
	}

	html{
		overflow-x: hidden;
		overflow-y: scroll;
	}

	html,body{
		width: 100%;
		-webkit-text-size-adjust: 100%;
		-ms-text-size-adjust: 100%;
	}

	textarea,input{
		max-width: 95%;
	}
	
	input[type="submit"],input[type="image"],
	input[type="reset"],input[type="button"],
	input[type="file"]{
		max-width: none;
	}
	
	blockquote{
		position: relative;
		margin: 2em 0;
		padding: 115px 20px 80px;
		background: #eee;
	}

	.site-header-in,
	.global-nav-in,
	.main-body-in,
	.main-body-und-in,
	.site-footer-in{
		width: 100%;
	}
	
	.col2 .main-conts,
	.col2 .sub-conts,
	.col2r .main-conts,
	.col2r .sub-conts{
		float: none;
		width: auto;
	}
	
	/*ヘッダー*/
	.site-header-conts,
	.site-title,
	.header-box{
		display: block;
	}
	
	.header-box{
		margin-top: 15px;
	}
	
	.site-header-conts{
		padding-top: 46px;
	}
	
	.no-gn .site-header-conts{
		padding-top: 0;
	}
	
	.site-header-conts{
		padding-bottom: 0;
	}
	
	.site-title{
		padding: 10px 15px 0;
		font-size: 1.4em;
		text-align:center;
	}

	.normal-screen .site-title{
		font-size: 2em;
	}

	.normal-screen .lp-catch{
		padding: 15px 15px 0;
		font-size: 1em;
	}

	.header-box{
		margin-left: -12px;
		text-align: center;
	}
	
	.site-header-in{
		position: relative;
	}
	.home .main-image{
		margin-top:-16px;
		margin-bottom:0;
	}


.header-box ul{
	margin-left:1.2em;
}
	
	/*グローバルナビ*/
	.global-nav{
		position: fixed;
		z-index:9999;
		top: 0;
		width: 100%;
		margin: 0;
		border: 0;
	}
	
	.global-nav ul{
		display: none;
		position: absolute;
		top: 41px;
		left: 0;
		z-index: 50;
		width: 80%;
		border: 0;
		background: #eeeeee;

	}
	
	.global-nav-panel{
		display: block;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 10px;
		background: #1b2e91;
		font-size:1.1em;
		color: #fff;
		cursor: pointer;
		text-align:center;
	}

	.global-nav-in li{
		display: list-item;
		width: auto;
		border-right: 0;
		border-bottom: 1px solid #ffffff;
		text-align: left;
	}
	
	.global-nav-in li ul{
		position: static;
		width: auto;
		margin-left: 1em!important;
		border-bottom: 0;
		background:#999;
	}
	
	.global-nav-in li ul li{
		width: 100%;
		border-right:0;
		border-bottom: 0;
	}
	
	.global-nav-in li a,
	.global-nav li ul li a{
		display:block;
		padding: 1em;
		padding-right: 2em;
		border-right:0;
		background: url(../images/icon/icon-gn-arw.png) right center no-repeat #eee;
		color:#666;
	}
	.global-nav li ul li ul{
		margin-left:1em;
	}
	.global-nav li ul li ul a{
	}

		/*Retina（高解像度）ディスプレイ用*/
		@media screen and (-webkit-min-device-pixel-ratio:2),
		(min-resolution: 2dppx){

			.global-nav-in li a,
			.global-nav li ul li a{
				background: url(../images/icon/icon-gn-arw@2x.png) right center no-repeat #eeeeee;
				-webkit-background-size: 27px 18px;
				background-size: 27px 18px;
			}

		}
		
	.global-nav-in li ul li:hover > a{
		background-color: #FFFFFF;
	}

	
	.section-wrap,
	.col1 .section-wrap.wide{
		padding: 0;
		border: 0;
	}
	
	.col1 .section-wrap{
		padding: 0;
	}
	
	.section-wrap .section-in,
	.col1 .section-wrap.wide .section-in,
	.float-area,
	.col1 .float-area{
		padding: 20px 15px 4px 15px;
	}

	.col1 .sub-conts .section-wrap .section-in{
		padding: 20px 15px 0 15px;
	}

	.section-wrap .section-in .section-title,
	.section-wrap .article-header .section-title{
		margin: -15px -15px 0;
		padding: 15px;
		font-size: 1.75em;
	}

	.sub-conts .section-wrap .section-in .section-title,
	.sub-conts .section-wrap .article-header .section-title,
	.col1 .sub-conts .section-wrap .section-in .section-title,
	.col1 .sub-conts .section-wrap .article-header .section-title{
		margin: 0 -20px 30px;
		padding: 10px 18px;
	}

	.main-body h1,
	.main-body h2,
	.main-body h3,
	.main-body h4,
	.main-body h5,
	.main-body h6{
		margin: 30px 0 20px;
	}
	

	.main-body h1,
	.main-body h2{
		font-size: 1.4em;
		padding:0;
		margin-top:-24px;
	}

	.main-body-und h1,
	.main-body-und h2,
	.main-body-und h3,
	.main-body-und h4,
	.main-body-und h5,
	.main-body-und h6{
		margin: 30px 0 20px;
	}
	

	.main-body-und h1,
	.main-body-und h2{
		font-size: 1.4em;
		padding-bottom:0;
	}
	
	/*パンくずリスト*/
	.breadcrumbs-in{
		margin-bottom: 1em;
		padding: 0 1em;
	}

	.breadcrumbs-in li:last-child{
		display: none;
	}
	.col1 .breadcrumbs-in{
		width: auto;
	}

	/*フッターナビ*/
	.foo-nav {font-size:0.9em;text-align: center;}

	.site-footer-nav{
		display: block;
		text-align: left;
	}

	.site-footer-nav li,
	.site-footer-nav li:first-child{
		display: list-item;
		margin-left: 20px;
	}

.copyright{
	margin: 0;
	padding: 24px 0 56px 0;
	background: #1b2e91;
	color: #fff;
	font-size:14px;
	text-align: center;
	font-size:0.8em;
}

.copyright small{
	font-size: 100%;
}


	.page-top img{
		width: 40px;
	}

	/*最新情報*/
	.news .news-thumb{
		float: none;
		text-align: center;
	}

	.main-body .news-title{
		font-size: 1.25em;
	}

	/*テーブル（左端がth、右側がtdの場合にスマホ表示で立て並びに変化）*/

table{
	width: 100%;
	margin: 8px 0;
	padding: 0;
}

th,
td{
	text-align:center;
}

	.table-block,
	.table-block thead,
	.table-block tbody,
	.table-block tfoot,
	.table-block tr,
	.table-block th,
	.table-block td{
		display: block;
	}
	
	
	.table-block th,
	.table-block td{
		float: left;
		width: 100%!important;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}

	.table-block:after{
		content : '';
		display : block;
		clear : both;
		height:0;
	}
	
	.table-scroll:before{
		content: "※はみ出ている場合、横にスクロールできます。"
	}

	/*ボタン*/
	.btn-area{
		text-align: center;
	}

	.btn{
		float: none;
		margin-right: 0;
		margin-left: 0;
	}

	.btn-area .btn {
		display: block;
		margin-right: auto;
		margin-left: auto;
	}

	.btn-green,
	.btn-blue,
	.btn-orange,
	.btn-red{
		padding: 12px 30px;
	}

.btn-blue{
	padding: 6px 12px;
	background: #1f8ae5;
	font-size: 0.9em;
	margin-left:20px;
}

.btn-blue-bg{
	padding: 6px 16px;
	background: #1b2e91;
	font-size: 1.1em;
	margin:0 10px 12px 10px;
}

	.btn-form01{
	padding: 16px 25px 16px 10px;
	font-size:1.05em;
	}

	.btn-form02{
		padding: 25px 20px;
	}
	.btn-mail{
		padding: 12px;
	}
	/*ソーシャルボタン*/
	.sns-list li{
		margin-right: 1em;
		margin-left: 0;
	}

	/*登場人物紹介２*/
	.col1 .cast-box02 .cast{
		min-height: 0;
	}

	.col1 .cast-box02 .cast-name,
	.col1 .cast-box02 .cast-profile{
		padding-left: 0;
	}

	.col1 .cast-box02 .cast .cast-headshot{
		width: 100%;
	}

	/*ランキング*/
	.rank-thumb{
		float: none;
	}
	
	.comparative-list01 .rank-thumb,
	.comparative-list02 .rank-thumb{
		display: inline-block;
		float: none;
	}
	
	/*関連記事*/
	.related-articles-thumbs02 li{
		float: none;
		width: auto;
		margin-left: 0;
	}
	
	.eye-catch{
		float: none;
		margin: 0 0 1em;
		text-align: center;
	}

	/*段組*/
	.col4-wrap,
	.col3-wrap,
	.col2-wrap{
		margin: 0 0 1em;
	}

	.col2-wrap{
		margin: -20px 0 1em;
	}

	.col4-wrap .col,
	.col4-wrap .col_2of4,
	.col4-wrap .col_3of4,
	.col3-wrap .col,
	.col3-wrap .col_2of3,
	.col2-wrap .col{
		float: none;
		margin-left: 0;
	}

	.col4-wrap .col,
	.col4-wrap .col_2of4,
	.col4-wrap .col_3of4,
	.col3-wrap .col,
	.col3-wrap .col_2of3,
	.col2-wrap .col{
		width: auto;
	}

.col .rslides img {
  display: block;
  height: auto;
  float: none;
  width: 100%;
  max-width:736px;
  height:auto;
  border: 0;
  }

.thumb-item {margin:0;}
.thumb-item-r {margin:0;}
.thumb-item-p {margin:0;}
.thumb-item-w {margin:0;}
.thumb-item-nav {margin:0;}
.thumb-item-nav-r {margin:0;}
.thumb-item-nav-p {margin:0;}
.thumb-item-nav-w {margin:0;}

.site-footer-nav {display:none;}
.floo {display:none;}

}

.w05{width:20%;}
.w15{width:40%;}
.w20{width:60%;}
.w40{width:60%;}
.w90{width:100%;}

.main-image .mv_txt {
  position: absolute;
  top: 50%;
  left: 50%;
  font-size:1.2em;
  color:#16269b;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
  }

.main-image .mv_txt span {font-size:1.4em;line-height:1.8;}

.footer_area {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background-color: rgba( 0, 0, 0, 0.1 );
}
.footer_area .footer_area_inner {
    position: relative;
    width: 80%;
    margin: 0px auto;
    padding: 10px 0;
	margin-right: 0px;
}
.footer_area .footer_area_inner .footer_area_inner_btn {
    width: 85%;
    padding: 11px 0;
    font-size: 1.4em;
    letter-spacing:1px;
    font-weight: bold;
    margin-left: 0;
	line-height: 1.3;
    
}
.inquiry_btn {
    background-color: #2750b6;
    -webkit-border-radius: 4px;
    display: inline-block;
    text-align: center;
    text-decoration: none;
	width: 75%;
    padding: 5px 0;
    font-size: 18px;
    font-weight: bold;
}
.inquiry_btn:link, .inquiry_btn:visited {
    color: #FFFFFF !important;
}
.footer_area_inner span{
	color: #fff;
}

iframe {margin-top:20px;}

}/*解像度736px以下*/



/*--------------------------------------------------------
解像度480px以下
--------------------------------------------------------*/
@media
only screen and (max-width : 480px){
	
	.left,
	.right{
		float: none;
		margin-right: 0;
		margin-left: 0;
		text-align: center;
	}
	
	.sub-conts .fl-l,.sub-conts .fl-r{
		float:none;
		margin:0 0 1em;
	}
	
}/*解像度480px以下*/

/*--------------------------------------------------------
メインビジュアルサイズ別設定
--------------------------------------------------------*/

/*解像度1200px以下*/

@media
only screen and (max-width : 1200px){
	.site-header,
	.global-nav,
	.main-body,
	.main-body-und,
	.site-footer{
		min-width: 0;
	}
	
	.main-image-in-text{
		height:auto!important;
		max-height:500px;
		min-height:500px!important;
	}
	
	.main-image-in-text-box{
		width:100%;
		height:100%!important;
		max-height:500px;
		min-height:500px!important;
		-webkit-background-size: 100%;
		background-size: 100%;
		background-position:right bottom;
	}
	
	.main-image-in-text-box .contact-btn{
		margin-top:5px;
		bottom:30px;
		left:5%;
	}
	
	.main-image-in-text-cont{
		padding:60px 0 0;
		background-color: rgba(79, 90, 103, 0);/*PC表示での透過設定を無効化*/
		font-size:2em
	}
	.main-copy,.sub-copy{
		filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#4D4f5a67,endColorstr=#4D4f5a67);/*IE8の透過対策*/
		background-color: rgba(79,90,103,0.25);/*レスポンシブ時のメインコピーとサブコピーの透過設定*/
		text-align: left;
	}
	
	.main-copy:not(:target),.sub-copy:not(:target){
		filter: none;
	}
	
	.main-copy{
		width:100%;
		margin:0!important;
		padding:20px 40% 10px 5%;
		font-size:1.125em;/*メインコピーの基本フォントサイズ*/
	}
	.sub-copy{
		width:100%;
		margin:0!important;
		padding:0 40% 20px 5%;
		font-size:0.925em;/*サブコピーの基本フォントサイズ*/
	}

}/*解像度1200px以下*/

/*解像度1100px以下*/

@media
only screen and (max-width : 1100px){
	.main-image-in-text{
		height:auto!important;
		min-height: 458px!important;
		padding:0!important;
	}
	
	.main-image-in-text-box{
		min-height: 458px!important;
		padding:0!important;
	}
	
	.main-image-in-text-cont{
		padding:100px 0 0;
	}
}/*解像度1100px以下*/

/*解像度950px以下*/

@media
only screen and (max-width : 950px){

.main-image-in-text{
		height:auto!important;
		min-height: 395px!important;
		padding:0!important;
	}
	
	.main-image-in-text-box{
		min-height: 395px!important;
		padding:0!important;
	}
	
	.main-image-in-text-cont{
		padding:100px 0 0;
		font-size:1.425em;
	}
	
}/*解像度950px以下*/

/*解像度860px以下*/

@media
only screen and (max-width : 860px){
	.main-image-in-text{
		height:auto!important;
		min-height: 358px!important;
		padding:0!important;
	}
	
	.main-image-in-text-box{
		min-height: 358px!important;
		padding:0!important;
	}
	
	.main-image-in-text-cont{
		padding:80px 0 0;
	}
}/*解像度860px以下*/

/* PCで非表示
----------------------------------*/
@media screen and (min-width: 859px) {

.footer_area{display: none;}

}

/*解像度736px以下*/

@media
only screen and (max-width : 736px){
.main-image-in-text{
		height:auto!important;
		min-height: 306px!important;
		padding:0!important;
	}
	
	.main-image-in-text-box{
		min-height: 306px!important;
		padding:0!important;
	}
	
	.main-image-in-text-cont{
		padding:80px 0 0;
		font-size:1.25em;
	}
	
	.main-image-in-text-box .contact-btn{
		display:block;
		top:105%;
		left:0%;
		width:98%;
		margin:0 1%;
	}

.rank-thumb{
	float: none;
	text-align:center;
	margin:0 auto 16px auto;
}
.rank-thumb img {width:100%;height:auto;max-width:640px;}

	
}/*解像度736px以下*/

/*解像度700px以下*/

@media
only screen and (max-width : 700px){
	.main-image-in-text{
		min-height: 291px!important;
	}
	.main-image-in-text-box{
		min-height: 291px!important;
	}
	.main-image-in-text-cont{
		padding:120px 0 0;
		font-size:1.25em;
	}
	.main-copy{
		padding:10px 40% 10px 5%;
	}
	.sub-copy{
		padding:0 40% 10px 5%;
	}

}/*解像度700px以下*/

/*解像度620px以下*/

@media
only screen and (max-width : 640px){

.contact_tbl {width:100%;margin:16px auto 20px auto;}

}/*解像度640px以下*/

/*解像度540px以下*/

@media
only screen and (max-width : 540px){
	.main-image-in-text{
		min-height: 225px!important;
	}
	.main-image-in-text-box{
		min-height: 225px!important;
	}
	.main-image-in-text-cont{
		padding:80px 0 0;
		font-size:1.125em;
	}

.transparent-panel h2 {font-size:1.3em;}

}/*解像度540px以下*/

/*解像度480px以下*/

@media
only screen and (max-width : 480px){

.main-image-in-text{
		height:auto!important;
		min-height: 200px!important;
		padding:0!important;
	}
	.main-image-in-text-box{
		min-height: 200px!important;
		padding:0!important;
	}
	.main-image-in-text-cont{
		padding:80px 0 0;
		font-size:1em;
	}

.w05{width:20%;}
.w15{width:100%;}
.w20{width:100%;}
.w40{width:100%;}
.w90{width:100%;}

.main-image .mv_txt {
  position: absolute;
  top: 50%;
  left: 50%;
  font-size:0.9em;
  color:#16269b;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  margin:0;
  padding:0;
  }

.main-image .mv_txt span {font-size:1.1em;line-height:1.8;}

}/*解像度480px以下*/

/*解像度400px以下*/

@media
only screen and (max-width : 400px){
	.main-image-in-text{
		min-height: 166px!important;
	}
	.main-image-in-text-box{
		min-height: 166px!important;
	}
	.main-image-in-text-cont{
		padding:60px 0 0;
		font-size:0.825em;
	}

.header-box ul li img{
	margin-top:10px;
}

div.txt-rt{font-size:12px;text-align:center;margin:-16px auto 12px auto;}

div.txt-rt a.bt-news{
  display: block;
  float:none;
  text-decoration: none;
  height:30px;
  width: 110px;
  color:#577eef;
  line-height: 29px;
  text-align: center;
  border:solid 1px #577eef;
  border-radius: 20px;
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -o-transition: 0.3s;
  -ms-transition: 0.3s;
  transition: 0.3s;
  margin:auto;
}

.main-body h4 span {font-size:1.05em;}

}/*解像度400px以下*/

/*解像度320px以下*/

@media
only screen and (max-width : 320px){

	.main-image-in-text{
		min-height: 133px!important;
		padding:0!important;
	}
	.main-image-in-text-box{
		min-height: 133px!important;
		padding:0!important;
	}
	.main-image-in-text-cont{
		padding:30px 0 0;
		font-size:0.725em;
	}

}/*解像度320px以下*/



/*--------------------------------------------------------
登場人物紹介の帯部分サイズ毎設定
--------------------------------------------------------*/

/*解像度900px以下*/
@media
only screen and (max-width : 900px){
.cast-box02 .cast-name{
		top:135px;
}
}/*解像度900px以下*/

/*解像度860px以下*/
@media
only screen and (max-width : 860px){
.cast-box02 .cast-name{
		top:125px;
}
}/*解像度860px以下*/

/*解像度820px以下*/
@media
only screen and (max-width : 820px){
.cast-box02 .cast-name{
		top:115px;
}
}/*解像度820px以下*/

/*解像度780px以下*/
@media
only screen and (max-width : 780px){
.cast-box02 .cast-name{
		top:105px;
}
}/*解像度780px以下*/

/*解像度740px以下*/
@media
only screen and (max-width : 740px){
.cast-box02 .cast-name{
		top:90px;
}
}/*解像度740px以下*/

/*解像度736px以下*/
@media
only screen and (max-width : 736px){
.cast-box02 .cast-name{
		top:150px;
}
}/*解像度736px以下*/

/*解像度1200px以下*/
@media
only screen and (max-width : 1200px){
	.site-header,
	.global-nav,
	.main-body,
	.main-body-und,
	.site-footer{
		min-width: 0;
	}
.col1 .cast-box02 .cast-name{
	top:150px!important;
}
}/*ワンカラムの場合解像度1200px以下*/


@media screen and (min-width: 768px) {
	a[href^="tel:"] {
		pointer-events: none;
	}
}
