body, .header, .appeal {
    background-repeat: no-repeat;
    background-size: cover;
}

body{
    font-family: "Kosugi Maru", sans-serif;
    background-color: #f4f5f7;
}

input.input_w330 { width: 330px; }
input.input_w350 { width: 330px; }
input.input_w400 { width: 330px; }

.w20 {width: 20px;}
.w30 {width: 30px;}
.w40 {width: 40px;}
.w50 {width: 50px;}
.w60 {width: 60px;}
.w70 {width: 70px;}
.w80 {width: 80px;}
.w90 {width: 90px;}
.w100{width:100px;}
.w110{width:110px;}
.w120{width:120px;}
.w130{width:130px;}

.w400{width:400px;}
.w450{width:450px;}
.w500{width:500px;}
.w550{width:550px;}
.w600{width:600px;}

.w50per{width:50%;}
.w100per{width:100%;}

.textCenter{text-align: center;}

.pc_only{display: block;}
.sp_only{display: none;}

/* ==================================== 
	Loading
==================================== */ 
#loading {
  display: none;
	position: fixed;
	color: #fff;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	font-size: 0;
	text-align: center;
	z-index: 3000;
	margin: 0;
	background: rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(3px);
}
.loadingArea {
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	width: 100%;
	height: 100%;
}
.loadingAnims {
	position: absolute;
	display: flex;
	gap: 9px;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	height: fit-content;
	width: fit-content;
}
.loading_letter {
	background: #ffffff;
	width: 8px;
	height: 50px;
	margin: 5px;
	box-shadow: 0 0 4px #fff;
}
.delay_1 {animation: loadingAnim 0.6s   0s ease-in-out infinite alternate forwards;}
.delay_2 {animation: loadingAnim 0.6s 0.1s ease-in-out infinite alternate forwards;}
.delay_3 {animation: loadingAnim 0.6s 0.2s ease-in-out infinite alternate forwards;}

@keyframes loadingAnim {
  0% {transform: scaleY(0.3);box-shadow: 0 0 0 #fff;}
100% {transform: scaleY(1.0);box-shadow: 0 0 4px #fff;}
}

/* ウィンドウ表示時のカバー */
#coverAll, #coverAll_middle, #coverAll_top{
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.3);
	backdrop-filter: blur(3px);
}
#coverAll       {z-index: 200;}
#coverAll_middle{z-index: 300;}
#coverAll_top   {z-index: 400;}


/* ヘッダー */
.header {
    background-image: url(https://yonayona-kujira.jp/wp-content/uploads/2025/04/header_bg-scaled.jpg);
	color: #fff;
}
.header .header-in {
	position: relative;
}
.header-in {
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.wrap {
    width: 100%;
    margin: 0 auto;
}
.logo {
    text-align: center;
}
.logo-header img {
    width: auto;
    height: 300px;
	margin-left: 0px;
}
.logo-image span, .logo-image a {
    display: inline-block;
    max-width: 100%;
}
.tagline {
    position: absolute;
    display: block;
    bottom: 2%;
    width: 50%;
    left: 0;
    right: 0;
    margin: auto;
    margin-left: auto;
    text-align: center;
    font-size: 14px;
	text-shadow: 0 0 11px rgb(197 133 61);
}

/* フッター */
.footer {
    margin-top: 20px;
    padding: 8px;
	background-color: #cab07b;
}
.footer-bottom {
    margin-top: 3px;
    padding: 8px;
    position: relative;
    font-size: 14px;
}
.footer-bottom-logo img {
    height: 50px;
    width: auto;
}
.footer-bottom-content {
    text-align: right;
}
.footer-bottom-logo {
    bottom: 0;
}
.copyright {
    margin-top: 16px;
    color: #fff;
}

/* メインカラム */
.mainArea{
	display: flex;
	justify-content: center;
    flex-direction: column;
	width: 1040px;
    border-radius: 3px;
    position: relative;
    background-color: #fff;
	padding: 20px;
    margin: 20px auto;
}
.mainSec{
    min-width: 800px;
    max-width: 100%;
    padding: 36px 29px;
    border-radius: 3px;
    position: relative;
    background-color: #fff;
    z-index: 0;
    display: flex;
    flex-direction: column;
    gap: 50px;
}
/* サイドカラム */
.sidebar {
    width: 348px;
	padding: 5px;
    border-radius: 3px;
    background-color: #fff;
}


/* ポイント表示 */
.pointArea {
	display: flex;
    align-items: center;
    gap: 30px;
    justify-content: center;
	background: #cab07b;
	padding: 10px;
}

.nowPointArea {
    width: 300px;
    background: #fff;
    height: 50px;
    border-radius: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.nowPoint {
	font-family: auto;
    font-size: 28px;
}
.nowPoint:after {
    content: "pt";
    font-size: 21px;
    font-weight: bold;
    margin: 0 0 0 8px;
    color: #988254;
}







body {
	font-family: "Kosugi Maru" ,sans-serif;
}

a.site-name.site-name-text-link {
    z-index: 200;
    height: 100%;
    align-items: center;
}
img.kujiraImage {
	position: absolute;
	left: 48%;
	display: block;
	height: 300px
}
img.kujiraLogo {
	height: 220px;
	width: auto;
}

#mainArea {
	font-family: "Kosugi Maru" ,sans-serif;
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
	padding: 30px;
	background: #fff;
	border-radius: 10px;
}

.ads{
	margin: 0 auto 30px auto;
}



div.content-in {
    justify-content: center;
}

/*------------------------------------------------------------ 
ウィンドウ
------------------------------------------------------------*/  
.baseWindow {
	position: fixed;
	display: none;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	width: 98%;
	height: fit-content;
	max-width: 900px;
	padding: 10px 10px;
	background: #fff;
	border-radius: 5px;
	box-shadow: 0 0 3px rgba(0,0,0,0.2);
	z-index: 200;
	animation: fadeInUp 0.2s ease-out 1 forwards;
}
.baseWindow h2 {
	text-align: center;
	margin: 5px 0 0 0;
}
.baseWindow h3 {
	font-size: 20px;
	border-left: 10px solid #7594d4;
	line-height: 10px;
	margin: 15px 0;
}

.baseWindow form {
	display: flex;
	flex-direction: column;
}

.baseWindow label {
	border-left: 5px solid #9aadd4;
	line-height: 5px;
	margin: 30px 0 10px 8px;
	padding-left: 4px;
	font-weight: bold;
}
.baseWindow select {
	width: fit-content;
}
.baseWindow input[type="text"] {
	padding: 5px 10px;
	width: 100%;
}

.baseWindow input[type="number"] {
	padding: 5px 10px;
	text-align: center;
	width: 30%;
}

.baseWindow input[type="submit"] {
	text-align: center;
	border: 0;
}

.baseWindow .formBtnArea {
	display: flex;
	justify-content: space-between;
	width: 100%;
	margin: 30px auto 10px auto;
}
.baseWindow .formBtn {
	width: 180px;
	height: fit-content;
	padding: 10px;
	margin: 0;
	font-weight: normal;
	font-size: 19px;
}
.formBtnArea .cancelBtn{
	background: #de6464;
	text-align: center;
	color: #fff;
	border-radius: 5px;
}







@media only screen and (max-width: 767px){
	.pc_only{display: none;}
	.sp_only{display: block;}

	.header {
    height: 110px;
		margin: 0 auto 20px auto;
	}
	a.site-name.site-name-text-link {
    left: 0;
	}
	img.site-logo-image.header-site-logo-image {
    height: 90px;
	}
	#mainArea {
		width: 100%;
		padding: 5px;
		border-radius: 5px;
	}

}


