@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap');
/*-------------
base
font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
-------------*/
body {
    font-family: 'Noto Sans JP', sans-serif;
    /*    background-color: #fbb03b;
  background-image: linear-gradient(50deg, #D52B54 25%, transparent 25%, transparent 75%, #D52B54 75%, #D52B54), linear-gradient(-50deg, #D52B54 25%, transparent 25%, transparent 75%, #D52B54 75%, #D52B54);
  background-size: 100px 115px;*/
    font-family: "Hiragino Kaku Gothic ProN", "メイリオ", sans-serif;
    font-weight: 300;
    font-size: 14px;
    line-height: 1.6em;
    letter-spacing: 0.1em;
    margin: 0px;
    color: #333;
    
}
.title_container{
    background-image: url(cmcopy_bg.png);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
}
.title_bg{
	max-width: 900px; 
	height: auto; 
	width: 100%;
	padding: 50px 0;
}
@media screen and (max-width: 991px) {
	.title_container{
		background-size: 1200px;
}
	.title_bg{
	max-width: 700px; 
	padding: 50px 0;
}
}
@media screen and (max-width: 575px) {
	.title_container{
		background-size: 900px;
}
	.title_bg{
	max-width: 500px; 
	padding: 40px 0;
}
}
.container-fluid{
	padding: 0;
}
@media screen and (max-width: 575px) {
/*	body {
  background-image: linear-gradient(50deg, #D52B54 25%, transparent 25%, transparent 75%, #D52B54 75%, #D52B54), linear-gradient(-50deg, #D52B54 25%, transparent 25%, transparent 75%, #D52B54 75%, #D52B54);
  background-size: 55px 65px;
}*/
}
a {
    color: #C50000;
    text-decoration: none;
}
a:hover {
    color: #D52B54 !important;
    text-decoration: none;
}
p {
	line-height: 1.8em;
	font-size: 16px;
	letter-spacing: 0.5px;
	font-weight: 300;
	text-align: justify;
  text-justify: inter-ideograph;
}
.web-ad p{
	text-align: left !important;
	text-justify: none !important;
}
@media screen and (max-width: 767px) {
	p {
	font-size: 1.1em;
	letter-spacing: 0.3px;
}
}
@media screen and (max-width: 575px) {
	p {
	font-size: 1em;
	letter-spacing: 0.3px;
		line-height: 1.6em;
}
}
h5{
	font-size: 1.2em;
	font-weight: 600;
}
footer{
    background-color: #fff;
    text-align: center;
    color: #000;
    vertical-align: middle;
}
.footer-t{
	font-size: 1.2em;
}
@media screen and (max-width: 575px) {
	.footer-t{
	font-size: 1em;
}
	.footer-text-center{
		text-align: center;
	}
}
ul{
	margin: 0;
	padding: 0.5em 0.2em 0.5em 1em;
}
li{
    list-style-position: outside;	
}
.style-ub{
	background-color: #FFF55F;
	font-weight: 600;
}
/*-------------
table
-------------*/
.gp-name{
	font-size: 2em;
	text-align: left;
	padding: 1em;
}

.award td{
	padding: 1em 0.5em;
	font-size: 1.2em;
	line-height: 1.3em;
}
.award th{
    font-weight: 300;
    text-align: right;
    vertical-align: top !important;
	padding: 1em 0.5em;
	white-space: nowrap;
	font-size: 1.2em;
	line-height: 1.3em;
}
.award h3{
	border-top: 1px dotted #000;
}
@media screen and (max-width: 991.98px) {
	.gp-name{
	text-align: center;
	padding: 1em 0em;
		line-height: 1.3em;
}
}
@media screen and (max-width: 767.98px) {
	.gp-name{
	font-size: 2em;
		letter-spacing: 1.5px;
}
}
@media screen and (max-width: 575px) {
	.gp-name{
	font-size: 1.8em;
	text-align: center;
		letter-spacing: 1px;
	padding: 1em 0em;
		line-height: 1.3em;
}
	.award td{
	padding: 0.5em 0 0.5em;
		font-size: 1em;
		line-height: 1.6em;
		display: table !important;
}
.award th{
	padding: 0.5em 0;
	font-size: 1em;
	text-align: left;
	display: table !important;
}
	td{
			margin: 0.2em 0 1em;
	}
	th, td{
	display: block !important;
	
}
}
table.formTable{
	width: 100% !important;
}
.formTable th{
	width: 100% !important;
	display: block;
	background-color: #C50000;
	color: #fff;
	padding: 0.5em;
	text-align: left;
	font-weight: 300;
	
	
}
.formTable td{
	width: 100% !important;
	display: block;
	padding: 0.5em;
	
}
/*-------------
button
-------------*/
input.button4 {
	font-size: 1.2em;
	font-weight: normal;
	padding: 10px 30px;
	background-color: #C50000;
	color: #fff;
	border-style: none;
	line-height: 1em;
	border-radius: 3px;        /* CSS3草案 */
	-webkit-border-radius: 3px;    /* Safari,Google Chrome用 */
	-moz-border-radius: 3px;
}

input.button4:hover {
	background-color: #c4e8ef;
	color: #fff;
	-webkit-transition: all .3s;
	transition: all .3s;
}
@media screen and (max-width: 575px) {
	input.button4 {
	font-size: 1.2em;
	padding: 10px 30px;
		width: 100%;
		margin: 0 !important;
}

}
.button {
    display: inline-block;
    width: 100%;
    padding: 1em 0.5em;
    text-align: center;
    text-decoration: none;
    border-radius: 10px;
    outline: none;	
}

.button::before,
.button::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button,
.button::before,
.button::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.button {
    background-color: #C50000;
    color: #fff !important;
}
.button:hover {
	background-color: #D52B54;
	color: #fff !important;
}
.button2 {
    display: inline-block;
    padding: 0.5em 1em;
    text-align: center;
    text-decoration: none;
    border-radius: 10px;
    outline: none;
	font-size: 0.8em;
	letter-spacing: 1px;
	margin: -10px 0 0;
}

.button2::before,
.button2::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}.button2 {
    background-color: #C50000;
    color: #fff !important;
}
.button2:hover {
	background-color: #D52B54;
	color: #fff !important;
}
@media screen and (max-width: 575px) {
	.button2 {
    padding: 0.2em 0.5em;
	margin: 15px auto 0;
		display: block;
		width: 90%;
		font-size: 0.6em;
}
}
/*-------------
list
-------------*/

.toggle {
display: none;
}
.option {
position: relative;
margin-bottom: 0.5em;
}
.title,
.content {
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
transform: translateZ(0);
transition: all 0.3s;
}
.title {
border: solid 1px #ccc;
padding: 1em;
display: block;
}
.title::after,
.title::before {
content: "";
position: absolute;
right: 1.25em;
top: 1.25em;
width: 2px;
height: 0.75em;
background-color: #999;
transition: all 0.3s;
}
.title::after {
transform: rotate(90deg);
}
.content {
max-height: 0;
overflow: hidden;
}

.toggle:checked + .title + .content {
max-height: 1800px;
transition: all 1.5s;
}
.toggle:checked + .title::before {
transform: rotate(90deg) !important;
}
/*-------------
atm&win
-------------*/
.img-top{
	max-width: 1400px;
	width: 100%;
	height: auto;
}
/*-------------
summer
-------------*/
label{
	font-size: 1.5em;
	font-weight: 300 !important;
	line-height: 1em;
	letter-spacing: 5px;
	border-bottom: 1px dotted #000;
	border-top: 1px dotted #000;
	padding: 0.5em;
	margin: 0em 0 0em;
}

h3{
	font-size: 1.5em;
	font-weight: 300 !important;
	line-height: 1.2em;
	letter-spacing: 5px;
	border-bottom: 1px dotted #000;
	border-top: 1px dotted #000;
	padding: 0.5em;
	margin: 1.5em 0 1em;
	position: relative;
}
audio {
	position: absolute;
	top: 18%;
	right: 0;
}
@media screen and (max-width: 991.98px) {
	audio {
	position: relative;

}
		h3{
	font-size: 1.3em;
		margin: 1em 0 1em;
}
}
@media screen and (max-width: 575px) {
	label{
	font-size: 1.1em;
		letter-spacing: 0px;
		padding: 0em;
}

}
h4{
	font-size: 1.3em;
	font-weight: 300 !important;
	line-height: 1em;
	letter-spacing: 2px;
	border-bottom: 1px dotted #000;
	border-top: 1px dotted #000;
	padding: 0.5em;
	margin: 0 0 1em;
	text-align: left;
}
h2{
    background-color: #C50000;
    color: white;
    letter-spacing: 5px;
    font-size: 24px;
    font-weight: 300 !important;
	line-height: 0.5em;
}
.acd h2{
    background-color: #fff;
	color: #000;
	border: #C50000 solid 2px;
    letter-spacing: 5px;
    font-size: 24px;
    font-weight: 300 !important;
	/*line-height: 0.5em;*/
	padding: 0.6em !important;
}
@media screen and (max-width: 767.8px) {
	h2{
	font-size: 1.5em;
	letter-spacing: 1px;
}
	.acd h2{
    letter-spacing: 0.5px;
    font-size: 20px;
    font-weight: 300 !important;
	line-height: 1em;
		padding: 0.4em !important;
}
	
}
.oubo{
    height: 60px;
    vertical-align: middle;	
	font-size: 18px;
	line-height: 40px;
	text-align: left;
	margin-left: 55px;
}
.oubo-m{
	font-size: 24px;
	text-align: center;
}
@media screen and (max-width: 992px) {
	.oubo{
    height: 60px;
    vertical-align: middle;	
	font-size: 18px;
	line-height: 1.2em;
	text-align: center;
	margin-left: 0;
		padding-top:40px;
		position: relative;
		top: 25px;
	}}
@media screen and (max-width: 767px) {
	.oubo{
    height: 60px;
    vertical-align: middle;	
	font-size: 18px;
	line-height: 38px;
	text-align: left;
	margin-left: 40px;
		top: 0;
}
.oubo-m{
	font-size: 18px;
}
}
.l-border-dot{
    border-left: 1px dotted #CCCCCC;
}

@media screen and (max-width: 767.9px) {
	.l-border-dot{
    border-left: none;
	border-top: 1px dotted #CCCCCC;
		padding-top: 15px;
}
	.p-t{
	font-size: 13px !important;
}
}
.ft-m{
	font-size: 2em;
	letter-spacing: 2px;
}
@media screen and (max-width: 767px) {
	.ft-m{
	font-size: 1.5em;
		letter-spacing: 0.2px;
}
}
.maru {
 height:40px;
 width:40px;
 border-radius:50%;
 line-height:40px;
 text-align:center;
	background-color: #C50000;
	color: #fff;
	font-size: 20px;
	position: absolute;
}
@media screen and (max-width: 991.98px) {
	.maru {
 
 text-align:center;
	position: absolute;
		margin-left: -20px;
}
}
@media screen and (max-width: 767px) {
	.maru {
 height:35px;
 width:35px;
 line-height:36px;
	font-size: 20px;
		margin-left: 0px;
}
}
.prepre{
	border: 2px solid #C50000;
	margin: 10px 5px 25px;
	padding: 0;
}
.prpr{
	font-size: 13px;
	letter-spacing: 0.5px;
}
.prepre img{
	object-fit: cover;
	height: 380px;
	width: 100%;
	margin: -1 0 0;
	padding: 0;
}
@media screen and (max-width: 767px) {
	.prepre img{
	height: 300px;
}
}
.bango{
	background-color: #C50000;
	color: white;
	padding: 1.5em 1.7em;
	position: absolute;
	font-size: 1.5em;
	margin-left: -0.75em;
}
@media screen and (max-width: 575px) {
	.bango{
	padding: 1.2em 1.5em;
	font-size: 1.3em;
	margin-left: -0.85em;
}
}
.sponser{
	font-size: small;
	font-weight: bold;
	letter-spacing: 0.5px;
}
.cel{
	padding: 2.5em;
}
@media screen and (max-width: 767px) {
	.cel{
	padding: 2em;
}
}

.shina{
	font-size: x-large;
	letter-spacing: 0.8px;
	font-weight: 600;
	line-height: 1.3em;
}
@media screen and (max-width: 575px) {
	.cel{
	padding: 1em;
}
	.shina{
	font-size: 1.5em;
	letter-spacing: 0.5px;
	line-height: 1.3em;
}
}
.spinfo p{
	font-size: 13px;
}
.memo p{
	font-size: 13px;
	margin-top: 1em;
}
.moshi{
	background-color: #C50000;
	color: #fff;
	padding: 1em;
	text-align: center;
	margin: 0 0 1em;
}
.ninzoo{
	background-color: #C50000;
	font-size: 0.7em;
	padding: 0.3em;
	color: #fff;
}





.bdr{
	background-color: #C50000;
	width: 100%;
	padding: 0.5em 1em;
	color: #fff;
	text-align: left;
	
}




