@charset 'utf-8';

html {
}

body {
	width: auto;
	margin: 0 50px;
	padding: 30px 0 30px 0;
	font-size: 62.5%;  /* 10px */
}
body * {
	font-size: 3.2rem;
	font-family: 'Oswald', 'Roboto Condensed', sans-serif;
	line-height: 1.3;
}
.dark-mode {
	background-color: #000;
}


a {
	color: #0C66BB;
}
.dark-mode a {
	color: #3399F3;
}


hr {
	border-color: #DDD;
}


input[type='checkbox'],
input[type='radio'] {
 	transform: scale(2.0);
 	margin-top: 0;
 	margin-right: 10px;
 	margin-left: 10px;
}


.btn {
	font-size: 90%;
}

.modal-footer .btn {
	margin-top: 0;
}

#top {
	height: 30px;
}

.login-expiration-alert {
	text-align: right;
	color: #DF0024;
	opacity: 0.5;
	font-weight: bold;
}


.page-title {
	padding: 0;
	margin-bottom: 30px;
	border-bottom: 4px solid #CCC;
	font-weight: bold;
}


.nav {
	margin-top: 20px;
	margin-bottom: 20px;
}


.dark-mode .page-title {
	color: #FF0;
	border-bottom: 1px solid #CCC;
}
.dark-mode p {
	color: #FF0;
}
.dark-mode .modal p {
	color: inherit;
}
.dark-mode .nav {
	color: #999;
}


.dark-mode .table-striped,
.dark-mode .table-striped th,
.dark-mode .table-striped td {
	border-color: #555;
	color: #999;
}
.dark-mode .table-striped > tbody > tr:nth-child(2n+1) {
	background-color: #181818;
}
.dark-mode .table-bordered > thead > tr > th,
.dark-mode .table-bordered > thead > tr > td {
	border-bottom-width: 1px;
}
.dark-mode .modal .table-striped,
.dark-mode .modal .table-striped th,
.dark-mode .modal .table-striped td {
	border-color: #DDD;
	color: #666;
}
.dark-mode .modal .table-striped > tbody > tr:nth-child(2n+1) {
	background-color: #F9F9F9;
}
.dark-mode .modal .table-bordered > thead > tr > th,
.dark-mode .modal .table-bordered > thead > tr > td {
	border-bottom-width: 2px;
}


.song-list * {
	font-size: 2.4rem;
}
.song-progress-value {
	display: none;
}
.song-rating-stars {
	padding-left: 10px;
}
.song-difficulty-stars {
	padding-left: 10px;
}
.song-progress-bar {
	height: 30px;
	background-color: rgba(0, 176, 240, 1);
}
.song-star {
	width: 20px;
	height: 20px;
	color: #FF7F50;
	display: none;
}


.song-title {
	min-width: 30%;
}
.song-title:has(a) {
	color: #3399F3;
}
.song-title-link {
	font-weight: bold;
}
.song-artist {
	min-width: 20%;
}
.song-artist-link {
	font-weight: bold;
}
.song-genre {
	width: 15%;
}
.song-rating {
	width: 10%;
}
.song-difficulty {
	width: 10%;
}
.song-progress {
	width: 10%;
}
.song-lyricsonly {
	width: 5%;
}
.song-lyricsonly-value {
	display: none;
}



.guest-mode .song-id {
	display: none;
}
.guest-mode .song-rating {
	display: none;
}
.guest-mode .song-difficulty {
	display: none;
}
.guest-mode .song-progress {
	display: none;
}
.guest-mode .song-lyricsonly {
	display: none;
}
.guest-mode .song-title {
	min-width: auto;
}
.guest-mode .song-artist {
	min-width: auto;
}
.guest-mode .song-genre {
	width: auto;
}



.alphabet-nav {
	list-style-type: none;
	font-size: 0;
	margin: 20px auto;
}
.alphabet-nav-item {
	display: inline;
}
.alphabet-nav-item-link {
	display: inline-block;
	width: 1.5em;
	height: 1.5em;
	margin-right: 0.1em;
	margin-bottom: 0.1em;
	padding: 0.02em;
	border: 1px solid #DDD;
	text-align: center;
	vertical-align: middle;
	font-size: 3.8rem;
	font-weight: bold;
}
.alphabet-nav-item-link:hover {
	border-top-width: 4px;
	border-left-width: 4px;
}
.dark-mode .alphabet-nav-item-link {
	border-color: #555;
}

form {
	margin-bottom: 20px;
}
.form-control {
	font-size: 2.2rem;
	height: auto;
	color: #000;
}

button {
	/* iOSでボタンの見映えをリセット */
	/*
	-webkit-appearance: none;
	*/
	margin: 15px 5px 15px 0;
	padding: 5px 15px;
	border-radius: 5px;
	font-weight: bold;
}

.search-button {
	margin: 0;
}


.currently-sorted-by {
	text-decoration: underline;
}


.utility-button {
	position: fixed;
	z-index: 100;

	display: flex;
	justify-content: center;
	align-items: center;

	width: 62px;
	height: 62px;

	font-size: 32px;
	font-weight: bold;
	color: #FFF;
	cursor: pointer;
	border-radius: 7px;

	opacity: 0.4;
}
.utility-button:hover {
	opacity: 1;
}

.bottom-link-button,
.top-link-button {
	right: 30px;
	background-color: #3399F3;
}
.bottom-link-button .utility-button-icon,
.top-link-button .utility-button-icon {
	color: #FFF;
}
.bottom-link-button {
	bottom: calc(30px + (62px + 20px) * 1);
}
.top-link-button {
	bottom: 30px;
	bottom: calc(30px + (62px + 20px) * 0);
}
.bottom-link-button .utility-button-icon,
.top-link-button .utility-button-icon {
	width: 24px;
	height: 24px;
}
.bottom-link-button .utility-button-icon {
	transform: rotate(180deg);
}





.in-page-link {
	scroll-behavior: smooth;
}





.loading-overlay {
	display: none;
	width: 100vw;
	min-height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10000;
	background: rgba(0,0,0,0.1) url(/__shared/images/icon-loading-2.svg) 50% 50% no-repeat;
}





@keyframes flicker {
	0%, 100% {
		opacity: 1;
	}
	50% {
		opacity: 0.1;
	}
}


@media print {

	.no-print {
		display: none;
	}

	.nav {
		display: none;
	}

	a[href]:after {
		content: '' !important;
	}
	abbr[title]:after {
		content: '' !important;
	}

	.auto-page-break {
		page-break-after: auto;
	}

}


/*
@media only screen and (max-width: 896px) {
*/
@media only screen and (max-width: 919px) {

	body {
		margin: 10px 0;
		padding: 0 10px;
	}
	body * {
		font-size: 2rem;
	}

	input[type='checkbox'],
	input[type='radio'] {
		/*
	 	transform: scale(1.5);
	 	*/
	 	height: 1rem;
	}

	.page-title {
		margin-bottom: 15px;
		padding-bottom: 10px;
		font-size: 2.4rem;
	}
	.page-title * {
		font-size: inherit;
	}

	.nav {
		margin-top: 15px;
		margin-bottom: 15px;
	}

	.alphabet-nav-item-link {
		font-size: 2.4rem;
	}


	.utility-button {
		width: 50px;
		height: 50px;
		font-size: 2.5rem;
	}
	.bottom-link-button {
		bottom: calc(15px + (50px + 15px) * 1);
		right: 15px;
	}
	.top-link-button {
		bottom: calc(15px + (50px + 15px) * 0);
		right: 15px;
	}


	table {
		/*
		width: 100%;
		*/
	}
	.scroll {
		overflow: auto;  /* tableをスクロールさせる */
		white-space: nowrap;  /* tableのセル内にある文字の折り返しを禁止 */
	}
	.scroll::-webkit-scrollbar{  /* tableにスクロールバーを追加 */
		height: 5px;
	}
	.scroll::-webkit-scrollbar-track{  /* tableにスクロールバーを追加 */
		background: #F1F1F1;
	}
	.scroll::-webkit-scrollbar-thumb {  /* tableにスクロールバーを追加 */
		background: #BCBCBC;
	}

	.song-list * {
		font-size: 2.1rem;
	}
	.song-list th,
	.song-list td {
		padding: 3px 3px !important;
	}

	.song-genre {
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
	.song-genre wbr {
		display: none;
	}
	.song-rating-stars {
		display: none;
	}
	.song-difficulty-stars {
		display: none;
	}


	.form-control {
		font-size: 2rem;
		padding: 3px 5px;
	}

	textarea {
		font-size: 1.5rem !important;
	}

}

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

	.alphabet-nav-item-link {
		width: 1.7em;
		height: 1.7em;
		padding-top: 0.1em;
	}

	.utility-button {
		opacity: 0.25;
	}

	.song-list * {
		line-height: 1.5;
	}
	.song-title {
		max-width: 60vw;
		overflow: hidden;
		text-overflow: ellipsis;
	}

}