@charset "utf-8";
/* CSS Document */

/********************************
  共通設定
********************************/
#nav_ktspecial li {
    background: -moz-linear-gradient(top,#fff 0%,#CCC) !important;
    background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#ccc)) !important;
}

table.pickuplist{
	width: 100%;
	text-align:center;
}
table.pickuplist a{
	display:block;
	text-decoration:none;
	background:url(img/linkicon.gif);
}
table.pickuplist a:hover{
	background:#dfdfdf;
	color:#333;
}
table.pickuplist td{
	padding:5px;
	border:1px solid #CCC;
}
.odd{
	background:#f8f8f8;
}

tr.title_miku{	background:#9cc;	}
.odd_miku{	background:#e2f0f0;}
table.pickuplist.style_miku tr a{ color:#266; }

tr.title_rinren{	background:#ffbd46;	}
.odd_rinren{	background:#ffffdc;}
table.pickuplist.style_rinren tr a{ color:#ff6500; }

tr.title_ruka{	background:#e9a9ae;	}
.odd_ruka{	background:#fcf5f6;}
table.pickuplist.style_ruka tr a{ color:#c35555; }

tr.title_meiko{	background:#800000;color:#fff;	}
.odd_meiko{	background:#f5ecee;}
table.pickuplist.style_meiko tr a{ color:#C00; }

tr.title_kaito{	background:#97b8f3;	}
.odd_kaito{	background:#edf3fd;}
table.pickuplist.style_kaito tr a{ color:#00f; }

.datewrap{
	position:relative;
	width:960px;
	height:50px;
}
.date{
	position:absolute;
	bottom:0;
	right:0;
	width:100px;
	text-align:right;
	padding:5px 10px;
}
.link{overflow:hidden;padding:0;width:960px;}
.link a{display:block;float:left;margin:5px;}

.evens{background:#ececec;}

a:hover img{ 
opacity:0.6;
filter: alpha(opacity=60);
}
.blackver{
	background:#212121;
	padding:5px;
	color:#fff;
}
#header_second {
    position: relative;
    z-index: 19;
    -webkit-box-shadow: 0px 2px 4px -1px rgba(0,0,0,0.2);
            box-shadow: 0px 2px 4px -1px rgba(0,0,0,0.2);
}
#page-top-button {
	display: none !important;
}

/********************************
  メインビジュアル
********************************/
#page {
    font-family: 'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',Arial,sans-serif !important;
}

/********************************
  メインビジュアル
********************************/
.mainvisual-box {
	background-image: -webkit-gradient(linear, left top, right top, from(#a20909), color-stop(#e62121), to(#a20909));
	background-image: -webkit-linear-gradient(left, #a20909, #e62121, #a20909);
	background-image: -o-linear-gradient(left, #a20909, #e62121, #a20909);
	background-image: linear-gradient(90deg, #a20909, #e62121, #a20909);
}
.mainvisual-box2019 {
	background-color: #fdd835;
}


.mainvisual-box-in {
	width: 960px;
	min-width: 960px;
	margin: 0 auto;
	padding: 14px 0 14px 0;
}

.mainvisual-box-in img {
	display: block;
	margin: 0 auto;
}

/********************************
  シェア欄
********************************/
.share-area {
	text-align: right;
	background: #333;
}

.share-inbox {
    width: 960px;
    min-width: 960px;
    display:inline-block;
    margin: 0 auto -20px auto;
    padding: 10px 0 0 0;
}

.share-inbox {
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-moz-justify-content:flex-end;
	-webkit-box-pack:end;
	-ms-flex-pack:end;
	    justify-content:flex-end;
}

.share-inbox li {
    display: inline;
    padding: 0 5px;
}

.share-inbox li img {
    width: 30px;
    height: auto;
}

/********************************
  メインコンテンツ
********************************/
.main-box {
	padding: 20px 0px 60px 0px;
	background: #333;
}

.main-box-in {
	width: 960px;
	min-width: 960px;
	margin: 0 auto;
}

.main-box p {
	font-size: 17px;
	color: #FFF;
	text-align: center;
}

.main-box p:nth-of-type(2) {
	font-size: 14px;
	margin: 5px 0 20px 0;
}

.main-box p:nth-of-type(4) {
	margin: 0 0 5px 0;
	font-size: 18px;
}

.main-box p:nth-of-type(4) span {
	background: #ff70ea;
	color: #FFF;
	font-size: 16px;
	margin-right: 5px;
	padding: 0px 5px;
}

/********************************
  テーブル
********************************/
.pickuplist {
	width: 960px;
	background:#fff;
	color:#333;
	border-collapse: collapse;
}
.pickuplist thead tr:nth-child(odd) {
	background-color: #ECECEC;
}
.pickuplist tr:nth-child(odd) {
  background-color: #ffffff;
}
.pickuplist tr:nth-child(even) {
  background-color: #ECECEC;
}
.pickuplist a {
	color: #e74e33;
}

/********************************
  テーブルの間のボタン
********************************/
.tenpo-button {
	width: 50%;
	position: relative;
	margin: 20px 0 20px auto;
	padding: 10px 0 10px 0;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	color: #fdd835;
	display: block;
	background: #e74e33;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}
.tenpo-button2019 {
	width: 50%;
	position: relative;
	margin: 20px 0 20px auto;
	padding: 10px 0 10px 0;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	color: #333333;
	display: block;
	background:#fdd835;
	border-radius: 4px;
	-webkit-border-radius: 4px;
	-moz-border-radius: 4px;
}

.tenpo-button:hover {
	opacity: 0.7;
}

.tenpo-button:before {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: 20px;
	width: 0;
	height: 0;
	margin-top: -9px;
	border: 8px solid transparent;
	border-left: 12px solid #fdd835;
}

/********************************
  画像リンク
********************************/
.link-box {
	text-align: center;
	margin: 0px 0 30px 0;
}

.link-box a {
	margin: 0 10px 0 0;
}

/********************************
  リンク
********************************/
.return-box {
	text-align: center;
}
.return-box a {
	color: #FFF !important;
}

.return-box a:hover {
	opacity: 0.5 !important;
}

.flag-border {
	border:1px solid transparent;
}

.pc {
	display: block !important;
}

.sp {
	display: none !important;
}

.final-button:hover,
.start-button:hover {
	opacity: 0.7;
}
.final-button {
    display: inline-block;
    position: fixed;
    bottom: 20px;
    right: 70px;
	display: inline-block;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	text-align:center;
	line-height: 40px;
	vertical-align: middle;
    background-color: #3b9bff;
    -webkit-box-shadow: 2px 2px 5px rgba(0,0,0,0.3);
            box-shadow: 2px 2px 5px rgba(0,0,0,0.3);
    text-decoration: none;
    text-align: center;
    color: #fff;
    font-size: 13px;
    z-index: 5000;
}

.start-button {
    display: inline-block;
    position: fixed;
    bottom: 20px;
    right: 20px;
	display: inline-block;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	text-align:center;
	line-height: 40px;
	vertical-align: middle;
    background-color: #f47d42;
    -webkit-box-shadow: 2px 2px 5px rgba(0,0,0,0.3);
            box-shadow: 2px 2px 5px rgba(0,0,0,0.3);
    text-decoration: none;
    text-align: center;
    color: #fff;
    font-size: 13px;
    z-index: 5000;
}

#sidebar {
	display: none !important;
}

.loading-box {
	position: fixed;
	top: 50%;
	right: 50%;
	color: #fff;
	margin-top: -15px;
	margin-right: -75px;
	z-index: 9001;
	font-size: 24px;
}

.loading-layer {
  position: fixed;
  top:0px;
  left:0px;
  width:100%;
  height:100%;
  background-color:#000000;
  z-index: 9000;
  opacity: 0.7;
}

.fixed {
  position: fixed;
  width: 100%;
  height: 100%;
}

/********************************
  読み込み中メッセージ
********************************/
.loading-message {
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    color: #FFF;
}

.loading-message span {
	font-size: 14px;
	font-weight: bold;
}

.page-loading {
	position: fixed;
	font-size: 18px;
	text-align: center;
	right: 0;
	left: 0;
	bottom: 20px;
	width: 50%;
	margin: 0 auto;
	color: #FFF;
	font-weight: bold;
	background: #000;
	padding: 10px 5px;
	border-radius: 4px;
	opacity: 0.8;
	z-index: 4999;
}

.page-loading span {
	font-size: 14px;
	font-weight: bold;
}
.artist-button {
	text-align:right;
	margin: 0 0 15px 0;
}
.artist-button a {
	display: inline-block;
	background: #f47d41;
	color: #FFF;
	padding: 10px 0;
	width: 32%;
	text-align:center;
	border-radius: 4px;
	font-size: 14px;
	font-weight: bold;
	position: relative;
}
.artist-button a:before {
    display: block;
    content: "";
    position: absolute;
    top: 50%;
    right: 5px;
    width: 0;
    height: 0;
    margin-top: -6px;
    border: 6px solid transparent;
    border-left: 8px solid #ffffff;
}
.artist-button a:hover {
	opacity: 0.7;
}
/********************************
  タブレット設定
********************************/
@media screen and (min-width: 721px) and (max-width: 959px) {
	body {
		width: 100%;
	}

	.mainvisual-box-in,
	.main-box-in,
	.share-inbox {
		width: 97%;
		min-width: 97%;
	}

	.share-inbox {
		padding-bottom: 20px;
	}

	.mainvisual-box-in img {
		width: 95%;
	}

	#header {
		display: none !important;
	}

	#header_second {
		padding: 5px 5px 5px 5px !important;
	}

	header#sp > .right {
		width: 15% !important;
		padding: 4px 15px 2px 4px !important;
	}

	table.pickuplist {
		width: 100% !important;
	}

	.link-box {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		    -ms-flex-pack: justify;
		        justify-content: space-between;
	}

	.link-box a {
		margin: 0;
		width: 49%;
	}

	.link-box a img {
		width: 100%;
	}

	#footer_contents{
		width:90%;
		margin:0 auto;
	}

	.f-left,.f-left_l,
	.f-left_s,.f-right,
	.f-right_l,.f-right_s,
	.f-left_ss,.f-right_ss,
	.f-left_ll,.f-right_ll{
		float:none;
		width:100% !important;
	}
	.tenpolist div{
		width:92%;
	}
	#topicpath{
		width:90%;
	}

	#footer dl.eventinfo{
		line-height:16px;
		float:none;
		margin:0;
		width:100%;
	}
	#footer dl.eventinfo dd a{
		padding:10px;
		border-top:1px solid #CCC;
	}
	#footer dl.eventinfo dd a:first-child{
		border-top:none;
	}
	
	.tenpo-button {
		font-size: 2vw;
	}

	table.pickuplist {
		font-size: 1.5vw;
	}

	.main-box p {
		font-size: 2.2vw;
	}

	.main-box p:nth-of-type(2) {
		font-size: 1.9vw;
	}

	.main-box p:nth-of-type(4) {
		font-size: 2.2vw;
	}

	.main-box p:nth-of-type(4) span {
		font-size: 2vw;
	}

	.return-box {
		font-size: 2vw;
	}
	
	.final-button,
	.start-button {
		display: none !important;
	}
	
	.page-loading {
		width: 60%;
		font-size: 2vw;
	}
	
	.page-loading span {
		font-size: 1.6vw;
	}
	
	.tenpo-button:before {
		right: 5px;
		margin-top: -6px;
		border: 6px solid transparent;
		border-left: 8px solid #fdd835;
	}
	#topicpath {
		width: 100%;
	}
	.artist-button a {
		font-size: 1.5vw;
	}
	.artist-button a:before {
		right: 2px;
		margin-top: -5px;
		border: 5px solid transparent;
		border-left: 7px solid #ffffff;
	}
}

/********************************
  スマホ設定
********************************/
@media screen and (max-width: 720px) {
	.mainvisual-box {
		width: 100%;
	}
	
	a {
		-webkit-tap-highlight-color:rgba(0, 0, 0, 0.4) !important;
	}
	.pc {
		display: none !important;
	}
	.sp {
		display: block !important;
	}
	#page {
		width: 100%;
	}
	#header_second {
		display: block;
		padding: 5px 5px 5px 5px !important;
	}
	.mainvisual-box-in {
		width: 95%;
		min-width: 95%;
	}
	.main-box-in {
		width: 96%;
		min-width: 96%;
	}
	.mainvisual-box-in {
		padding: 0;
	}

	.mainvisual-box-in img {
		width: 100%;
	}

	.main-box p:nth-of-type(1),
	.main-box p:nth-of-type(2) {
		font-size: 3.2vw;
		text-align: left;
		margin: 0 0px 8px 0px;
		color: #FFF;
	}
	
	.main-box p:nth-of-type(3) {
		font-size: 3.2vw;
		text-align: left;
		margin: 0 0px 20px 0px;
		color: #FFF;
	}

	.main-box p {
		color: #333;
		font-size: 3.2vw;
	}
	.tenpo-button {
		width: 100%;
		margin: 18px 0px 20px 0px;
		font-size: 4vw;
		padding: 10px 5px;
		-webkit-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
	    -webkit-box-shadow: 0px 1px 4px rgba(0,0,0,0.35),0px 0px 2px rgba(0,0,0,0.16);
	            box-shadow: 0px 1px 4px rgba(0,0,0,0.35),0px 0px 2px rgba(0,0,0,0.16);
		background: #f56b04;
		color: #FFF;
	}
	.main-box {
		padding: 10px 0px 100px 0px;
	}

	table.pickuplist {
		width: 100%;
		font-size: 3.2vw;
		border-radius: 4px;
		-webkit-border-radius: 4px;
		-moz-border-radius: 4px;
		margin-top: 5px;
	    -webkit-box-shadow: 0px 1px 4px rgba(0,0,0,0.35),0px 0px 2px rgba(0,0,0,0.16);
	            box-shadow: 0px 1px 4px rgba(0,0,0,0.35),0px 0px 2px rgba(0,0,0,0.16);
	}
	
	table.pickuplist thead tr:nth-child(odd) {
		background-color: #ffffff;
	}
	
	table.pickuplist tbody tr td {
		border: none;
	}
	table.pickuplist thead tr td:nth-of-type(1),
	table.pickuplist thead tr td:nth-of-type(4) {
		display: none;
		width: 0px;
	}
	
	table.pickuplist thead tr {
		display: -ms-grid;
		display: grid;
		-ms-grid-columns: 50% 50%;
		    grid-template-columns: 50% 50%;
		margin: 10px;
	}

	table.pickuplist thead tr td:nth-of-type(2),
	table.pickuplist thead tr td:nth-of-type(3) {
		width: 100%;
		-webkit-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
		border: none;
	}
	
	table.pickuplist tbody tr:last-child {
		margin-bottom: 5px;
	}
	
	table.pickuplist thead tr td:nth-of-type(2) {
		padding-right: 10px;
		text-align: right;
	}

	table.pickuplist tbody tr td:nth-of-type(2) a {
		color: #ff6c00;
	}

	table.pickuplist tbody tr td:nth-of-type(2) a:hover {
		color: #ff6c00;
		background:#ffffff;
	}

	table.pickuplist tbody tr td:nth-of-type(2) a,
	table.pickuplist tbody tr td:nth-of-type(3) span {
		padding-left:1.8em;
		position:relative;
	}

	table.pickuplist thead tr td:nth-of-type(2):before,
	table.pickuplist tbody tr td:nth-of-type(2) a:before,
	table.pickuplist thead tr td:nth-of-type(3):before,
	table.pickuplist tbody tr td:nth-of-type(3) span:before {
		background: #ff6c00;
		color: #FFF;
		margin: 0 5px 0 0;
	}
	
	table.pickuplist thead tr td:nth-of-type(2):before,
	table.pickuplist thead tr td:nth-of-type(3):before {
		padding: 3px 3px;
	}

	table.pickuplist tbody tr td:nth-of-type(2) a:before,
	table.pickuplist tbody tr td:nth-of-type(3) span:before {
		padding: 0px 3px;
	}


	table.pickuplist thead tr td:nth-of-type(2):before {
		content: "曲";
	}

	table.pickuplist tbody tr td:nth-of-type(4) {
		font-size: 2.5vw;
	}
	table.pickuplist tbody tr td:nth-of-type(4):before {
		content: "共通番号 = ";
	}
	
	table.pickuplist tbody tr td:nth-of-type(2) a:before {
		content: "曲";
		position:absolute;
		left:0;
		top:0;
	}

	table.pickuplist thead tr td:nth-of-type(3):before {
		content: "歌";
	}

	table.pickuplist tbody tr td:nth-of-type(3) span:before {
		content: "歌";
		position:absolute;
		left:0;
		top:0;
	}

	table.pickuplist a,
	table.pickuplist span {
		display: inline-block;
	}

	table.pickuplist thead tr td:nth-of-type(3) {
		padding-left: 10px;
		text-align: left;
	}

	table.pickuplist tbody tr {
		border-top: 1px solid #CCC;
		margin: 0px 5px;
		padding: 3px 0px;
		display: -ms-grid;
		display: grid;
		-ms-grid-columns: 11% 89%;
		    grid-template-columns: 11% 89%;
	}
	table.pickuplist tbody tr td:nth-of-type(1) {
		-ms-grid-row: 1;
		-ms-grid-row-span: 3;
		grid-row: 1/ 4;
		-ms-grid-column: 1;
		-ms-grid-column-span: 1;
		grid-column: 1 / 2;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-align: center;
		-webkit-box-align: center;
		align-items: center;
		-ms-justify-content: center;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		    justify-content: center;
		padding: 0;
		background: #fecda9;
		padding: 2px 2px;
	}	
	table.pickuplist tbody tr td:nth-of-type(2),
	table.pickuplist tbody tr td:nth-of-type(3) {
		text-align: left;
		-ms-grid-column: 2;
		-ms-grid-column-span: 1;
		grid-column: 2 / 3;
		padding:1px 2px 1px 5px;
	}

	table.pickuplist tbody tr td:nth-of-type(4) {
		text-align: left;
		-ms-grid-column: 2;
		-ms-grid-column-span: 1;
		grid-column: 2 / 3;
		padding:2px 2px 0px 5px;
	}
		
	table.pickuplist tbody tr td:nth-of-type(2) {
		-ms-grid-row: 1;
		-ms-grid-row-span: 1;
		grid-row: 1/ 2;
	}
	table.pickuplist tbody tr td:nth-of-type(3) {
		-ms-grid-row: 2;
		-ms-grid-row-span: 1;
		grid-row: 2/ 3;
	}
	table.pickuplist tbody tr td:nth-of-type(4) {
		-ms-grid-row: 3;
		-ms-grid-row-span: 1;
		grid-row: 3/ 4;
	}
	.pickuplist tr:nth-child(even) {
		background-color: #ffffff;
	}
	.flag-border {
		border: 1px solid transparent;
	}

	.return-box a {
		color: #FFF !important;
		margin: 0 0 8px 0;
		display:inline-block;
	}

	.return-box {
		font-size: 4.2vw;
		margin: 0 0 0 0;
	}

	.link-box {
		text-align: center;
		margin: 0px 0 20px 0 !important;
	}

	.link-box a img:nth-of-type(1) {
		margin: 0 0 10px 0;
	}

	.share-main-change {
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap : wrap;
		flex-wrap : wrap;
		background: #fdd835;
	}
	.share-area {
		width: 100%;
		-webkit-box-ordinal-group:-1;
		-webkit-flex-order:-1;
		-moz-flex-order:-1;
		-moz-order:-1;
		-ms-order:-1;
		-ms-flex-order:-1;
		    order:-1;
		background: #fdd835;
	}
	
	.share-inbox {
		width: 100% !important;
		min-width: 100% !important;
		margin: 0px auto 0 auto;
		padding: 10px 0px 0px 0px;
	}
	
	.share-box li img {
		width: 7vw;
	}

	.share-box li {
		padding: 0 4px;
	}

	.main-box p:nth-of-type(4) {
		margin: 0 0 8px 0;
		font-size: 3.2vw;
	}

	.main-box p:nth-of-type(4) span {
		background: #ff70ea;
		color: #FFF;
		font-size: 3.2vw;
		margin-right: 5px;
		padding: 2px 5px;
	}
	
	.final-button,
	.start-button {
		display: none !important;
	}

	.loading-message {
	    text-align: center;
	    font-size: 5vw;
	    color: #333;
	    margin: 5px 0 0 0;
	}

	.loading-message span {
		font-size: 4vw;
	}
	
	.page-loading {
		width: 90%;
		font-size: 4vw;
	}
	
	.page-loading span {
		font-size: 3vw;
	}
	
	.tenpo-button:before {
		right: 5px;
		margin-top: -6px;
		border: 6px solid transparent;
		border-left: 8px solid #FFF;
	}
	
	#topicpath {
		width: 100%;
	}
	.artist-button {
		margin: 0 0 20px 0;
	}
	.artist-button a {
		width: 100%;
		font-size: 3.5vw;
	}
	.artist-button a:before {
		right: 2px;
		margin-top: -5px;
		border: 5px solid transparent;
		border-left: 7px solid #ffffff;
	}
}

/* grid非対応ブラウザ用 */
@supports not ((display: -ms-grid) or (display: grid)) {
	@media screen and (max-width: 720px) {
		table.pickuplist tbody tr {
			display: -webkit-box !important;
			display: -ms-flexbox !important;
			display: flex !important;
			-ms-flex-wrap:wrap !important;
			        flex-wrap:wrap !important;
		}

		table.pickuplist thead tr{
			display: -webkit-box !important;
			display: -ms-flexbox !important;
			display: flex !important;
		}
		
		table.pickuplist tbody tr td:nth-of-type(1) {
			margin-bottom: 3px !important;
		}
		
		table.pickuplist thead tr td:nth-of-type(2),
		table.pickuplist thead tr td:nth-of-type(3) {
			display: block !important;
		}
		
		table.pickuplist {
			table-layout: fixed !important;
		}
		
		table.pickuplist tbody tr td {
			display: block !important;
			width: 100% !important;
		}
	}
}

@media screen and (min-width: 0\0) and (min-resolution: +72dpi) and (max-width: 720px) {
		table.pickuplist tbody tr {
			display: -webkit-box !important;
			display: -ms-flexbox !important;
			display: flex !important;
			-ms-flex-wrap:wrap !important;
			        flex-wrap:wrap !important;
		}

		table.pickuplist thead tr{
			display: -webkit-box !important;
			display: -ms-flexbox !important;
			display: flex !important;
		}
		
		table.pickuplist tbody tr td:nth-of-type(1) {
			margin-bottom: 3px !important;
		}
		
		table.pickuplist thead tr td:nth-of-type(2),
		table.pickuplist thead tr td:nth-of-type(3) {
			display: block !important;
		}
		
		table.pickuplist {
			table-layout: fixed !important;
		}
		
		table.pickuplist tbody tr td {
			display: block !important;
			width: 100% !important;
		}
}