@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Comfortaa:wght@700&display=swap');

/* ----------------------------------------------------------------------------------------------------
*  reset
* --------------------------------------------------------------------------------------------------*/
/*====================================
RESET
======================================*/
html {
	overflow-y: scroll;
}

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

blockquote,
q {
	quotes: none;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
	margin: 0;
	font-weight: 500;
	display: block;
	font-size: 100%;
}

ul,
li {
	list-style: none;
	padding: 0;
	margin: 0;
}

dl,
dt,
dd {
	padding: 0;
	margin: 0;
}

table,
tr,
td {
	border: 0;
	padding: 0;
	margin: 0;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

a {
	text-decoration: none;
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

a:focus,
button:focus {
	cursor: pointer;
}

.js-focus-visible :focus:not(.focus-visible) {
	outline: 0;
}

a:hover {
	cursor: pointer;
}

input,
textarea,
select {
	vertical-align: middle;
}

button {
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}

img {
	vertical-align: bottom;
	border: 0;
	padding: 0;
	margin: 0;
	line-height: 0;
}

div {
	margin: 0;
	padding: 0;
}

caption,
th {
	font-weight: normal;
}


input,
select,
button,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	outline: none;
	border: none;
	border-radius: 0;
	padding: 0;
	font-family: inherit;
	font-size: inherit;
	font-weight: inherit;
}

*,
*:after,
*:before {
	box-sizing: border-box;
}

@media screen and (min-width: 769px) {
	button.focus-visible {
		opacity: 0.6;
	}
}

/* ----------------------------------------------------------------------------------------------------
*  基本
* --------------------------------------------------------------------------------------------------*/
html,
body {
	height: 100%;
	width: 100%;
}

html {
	font-size: 62.5%;
	overflow-y: scroll;
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
address,
ul,
ol,
li,
dl,
dt,
dd,
table,
th,
td,
img,
form {
	text-align: left;
}

/*ul{letter-spacing: -0.4em;}
.android ul{letter-spacing: -1em;}
ul li{letter-spacing: normal;}
*/

body a {
	text-decoration: none;
	color: inherit;
}

body {
	-webkit-text-size-adjust: 100%;
	width: 100%;
	font-size: 1.6rem;
	line-height: 1.8;
	font-family: '游ゴシック体', 'Yu Gothic', YuGothic, メイリオ, Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ＭＳ Ｐゴシック", sans-serif;
	word-wrap: break-word;
	overflow-wrap: break-word;
	-webkit-text-size-adjust: 100%;
	color: #393939;
	font-weight: 500;
}

.ie body {
	font-family: メイリオ, Meiryo, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ＭＳ Ｐゴシック", sans-serif;
}

p {
	/*	letter-spacing: 0.15em;*/
}

.font_en {
	font-family: 'Comfortaa', cursive;
}

img {
	width: 100%;
	height: auto;
}

@media screen and (min-width: 769px) {

	html,
	body {}

	body {
		padding-top: 94px;
		background: #F4F4F4;
	}
}

@media screen and (max-width: 768px) {
	html {
		-webkit-overflow-scrolling: touch;
	}

	body {
		font-size: 3.7vw;
		padding-top: 70px;
		line-height: 1.7;
	}

}



a,
a img,
.fade,
.pull_btn {
	transition: 0.3s ease-in-out;
	-webkit-transition: 0.3s ease-in-out;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.txtlink {
	text-decoration: underline;
}

@media screen and (min-width: 769px) {

	a:hover,
	a:hover img,
	.fade:hover,
	.fade a:hover {
		opacity: 0.6;
	}

	.nofade:hover,
	.nofade:hover img,
	.nofade a:hover,
	.nofade a:hover img {
		opacity: 1;
	}
}

table {
	width: 100%;
}


/*--読み込み時にtransitionが動作する問題--*/
.preload * {
	-webkit-transition: none !important;
	-moz-transition: none !important;
	-ms-transition: none !important;
	-o-transition: none !important;
	transition: none !important;
}

/* ----------------------------------------------------------------------------------------------------
*  box
* --------------------------------------------------------------------------------------------------*/
.wrap,
.wrap2,
.wrap3,
.wrap4 {
	width: 100%;
	margin: 0 auto;
	position: relative;
}

@media screen and (min-width: 769px) {
	body {
		min-width: 1260px;
	}

	.sp {
		display: none !important;
	}

	.wrap {
		width: 94%;
		max-width: 1120px;
	}

	.wrap2 {
		width: 96%;
		max-width: 1200px;
		padding: 0 0px;
	}

	.wrap3 {
		width: 95%;
		max-width: 840px;
	}

	.wrap4 {
		width: 80%;
		max-width: 640px;
	}
}

@media screen and (max-width: 768px) {
	.pc {
		display: none !important;
	}

	body {
		min-width: 100%;
	}

	main {
		width: 100%;
		overflow: hidden;
	}

	.wrap,
	.wrap2 {
		width: 92vw;
	}

	.wrap4 {
		width: 90%;
	}

	.sp100w {
		width: 100vw;
		/*margin-left: -4vw;*/
	}
}





/* ----------------------------------------------------------------------------------------------------
*  汎用
* --------------------------------------------------------------------------------------------------*/


/* ------------------------------
    clearfix
------------------------------ */
.cf:after {
	content: ".";
	display: block;
	height: 0;
	font-size: 0;
	clear: both;
	visibility: hidden;
}

.cf {
	display: inline-block;
}

/* Hides from IE Mac */
* html .cf {
	height: 1%;
}

.cf {
	display: block;
}

/* End Hack */

/* ------------------------------
   float
------------------------------ */
.aligncenter {
	display: block;
	margin: 0 auto;
}

.alignright {
	float: right;
}

.alignleft {
	float: left;
}

/* ------------------------------
   flex
------------------------------ */
.flex {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
}

.flex_wrap {
	flex-wrap: wrap;
}

.jc_start {
	justify-content: flex-start !important;
}

.jc_end {
	justify-content: flex-end !important;
}

.jc_center {
	justify-content: center !important;
}

.item_center {
	align-items: center;
}

.item_end {
	align-items: flex-end;
}

.flex_prev {
	flex-flow: row-reverse;
}

@media screen and (min-width: 769px) {
	.flex_pc {
		display: flex;
		flex-wrap: nowrap;
		justify-content: space-between;
	}

	.item_center_pc {
		align-items: center;
	}

}

@media screen and (max-width: 768px) {
	.flex_sp {
		display: flex;
		justify-content: space-between;
	}
}

/* ------------------------------
   drop
------------------------------ */
.drop1 {
	position: absolute;
	width: 158px;
}

.drop2 {
	position: absolute;
	width: 160px;
}

@media screen and (max-width: 768px) {
	.drop1 {
		width: 14.4vw;
	}

	.drop2 {
		width: 11.2vw;
	}
}

/* ------------------------------
   text
------------------------------ */
.taC {
	text-align: center !important;
}

.taR {
	text-align: right !important;
}

.taL {
	text-align: left !important;
}

.nowrap {
	display: inline-block;
	text-indent: 0;
}

.wnowrap {
	white-space: nowrap !important;
}

.bold {
	font-weight: 700;
}

.txt_bigger {
	font-size: 1.8rem;
}

.txt_smaller {
	font-size: 88%;
}

.kakko {
	display: inline-block;
	margin-left: -0.5em;
}

.txt_bl {
	color: #00A2FF;
}

.txt_red {
	color: #d90000;
}

.txt_darkred {
	color: #a11010;
}

@media screen and (min-width: 769px) {
	.txt_vertical {
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
	}
}

@media screen and (max-width: 768px) {
	.txt_bigger {
		font-size: 4vw;
	}

}

/* ------------------------------
   見出し-pagettl
------------------------------ */
.pttl {
	width: 100%;
	margin-bottom: 50px;
	position: relative;
	z-index: 2;
	background: #fff;
	display: flex;
	align-items: center;
	/*justify-content: center;*/
}

.pttl .ttl {
	display: flex;
	align-items: center;
	justify-content: center;
}

.pttl .ttl .txt {
	font-size: 3.5rem;
	letter-spacing: 0.05em;
	font-weight: bold;
	color: #0089D8;
	border-bottom: 3px solid #0089D8;
	text-align: center;
}

.pttl:after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 20px;
	left: 0;
}

@media screen and (min-width : 769px) {
	.pttl {
		min-height: 120px;
		padding-bottom: 50px;
	}

	.pttl .ttl {
		width: 80%;
	}

	.pttl:after {
		bottom: -15px;
		background: url(../img/weve_pttl.png) bottom repeat-x;
		background-size: 120px;
	}
}

@media screen and (max-width: 768px) {
	.pttl {
		min-height: 29.8vw;
		margin-bottom: 4vw;
		background: #0089D8;
		padding: 10vw 4vw;
		height: auto;
		margin-top: 2.6vw;
	}

	.pttl .ttl {}

	.pttl .ttl .txt {
		font-size: 5.3vw;
		color: #fff;
		border-bottom: 2px solid #fff;
		padding: 0 0.7em;
	}

	.pttl:after {
		height: 4vw;
		top: -2.6vw;
		background: url(../img/weve_pttl_sp.png) top repeat-x;
		background-size: 17.8vw;
	}

}

/* ------------------------------
    topic_path
------------------------------ */
.topic_path {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-wrap: wrap;
	font-size: 1.2rem;
	padding-bottom: 50px;
}

.topic_path li {
	position: relative;
	font-size: 1.4rem;
	line-height: 1;
	font-weight: bold;
	padding-right: 0.6em;
	margin-bottom: 0.5em;
}

.topic_path li a {}

.topic_path li+li {
	padding-left: 1.4em;
}

.topic_path li+li:before {
	content: ">";
	display: block;
	position: absolute;
	font-weight: bold;
	top: 0;
	left: 0;
}

@media screen and (min-width : 769px) {
	.topic_path li a:hover {
		text-decoration: underline;
	}

}

@media screen and (max-width : 768px) {
	.topic_path {
		font-size: 3.2vw;
		padding-bottom: 10.6vw;
	}

	.topic_path li {
		font-size: 3.2vw;
		line-height: 1;
		font-weight: bold;
	}
}

/* ------------------------------
   page_lead
------------------------------ */
.page_lead {
	padding-bottom: 80px;
}

@media screen and (max-width : 768px) {
	.page_lead {
		padding-bottom: 8vw;
	}
}

/* ------------------------------
    字下げ
------------------------------ */
.hang1,
.hangli1>li {
	padding-left: 1em !important;
	text-indent: -1em !important;
}

.hang1h,
.hangli1h>li {
	padding-left: 1.5em !important;
	text-indent: -1.5em !important;
}

.hang2,
.hangli2>li {
	padding-left: 2em !important;
	text-indent: -2em !important;
}

.kakko {
	display: inline-block;
	text-indent: -1em !important;
}


/* ------------------------------
    btn
------------------------------ */
/*--base--*/
.btnwrap {
	display: flex;
	justify-content: center;
}

.btn {
	display: flex;
	align-items: center;
	justify-content: center;
}


/*--btn1--*/
.btn1box {
	margin-top: 36px;
}

.btn1 {
	width: 247px;
	font-size: 1.7rem;
	line-height: 1.2;
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: #FFB741;
	color: #fff;
	padding: 0.5em 0.8em 0.4em;
	border-radius: 20px;
	font-weight: bold;
	position: relative;
}

.btn1 .ico {
	margin-left: 1em;
	width: 12px;
	height: 14px;
	background: url(../img/arw_btn1.svg) no-repeat;
	background-size: contain;
}

.btn1_w {
	width: 470px;
}

@media screen and (min-width: 769px) {}

@media screen and (max-width: 768px) {
	.btn1box {
		margin-top: 2.1vw;
	}

	.btn1 {
		width: 48.2vw;
		font-size: 3.2vw;
		padding: 0.45em 2.6vw 0.35em;
		border-radius: 20px;
	}

	.btn1 .ico {
		width: 2.1vw;
		height: 2.6vw;
		margin-bottom: 0.1em;
	}

	.btn1_w {
		width: 70%;
	}

}

/* ------------------------------
    bg
------------------------------ */
.bg_bl {
	background: #0e2851;
}

.bg_gl {
	background: #f5f5f5;
}

.bg_wh {
	background: #fff;
}

.bg_gra1 {
	background: #0b3981;
	/* Old browsers */
	background: -webkit-linear-gradient(top, #0b3981 0%, #0e2851 100%);
	background: linear-gradient(to bottom, #0b3981 0%, #0e2851 100%);
}

.bg_square {
	position: absolute;
}


/* ----------------------------------------------------------------------------------------------------
*  header
* --------------------------------------------------------------------------------------------------*/

header {
	width: 100%;
	height: 94px;
	position: fixed;
	z-index: 999;
	top: 0;
	transition: .3s;
	background: #fff;
}

/* 印刷時にヘッダーを非表示にする */
@media print {
	header {
		display: none;
	}
}

header .wrap {}

@media screen and (min-width: 769px) {
	header {
		min-width: 1260px;
	}

	header .wrap {
		max-width: 1220px;
		width: 100%;
		/*padding: 0 2px 0 25px;*/
		margin-top: 40px;
	}

}

@media screen and (min-width: 1360px) {
	header .wrap {
		max-width: calc(100% - 80px);
		position: relative;
	}
}

@media screen and (max-width: 768px) {
	header {
		height: 70px;
	}

	header .wrap {
		height: 70px;
		align-items: center;
		justify-content: center;
	}
}


/*----logo------------------------------*/
header .logo {}

header .logo img {
	width: 200px;
}

header .head_logobox {
	display: flex;
	align-items: center;
}

@media screen and (min-width: 769px) {
	header .head_logobox {
		padding-right: 15px;
	}

}

@media screen and (max-width: 768px) {
	header .head_logobox {
		align-items: flex-start;
		/*padding-bottom: 4px;*/
	}

	header .logo a {
		height: 26px;
		display: block;
	}

	header .logo img {
		width: 177px;
		vertical-align: top;
	}
}

/*----nav------------------------------*/
header .gnav li {
	line-height: 1;
	font-weight: bold;
	position: relative;
}

header .gnav>li>.btn {
	width: 100%;
	height: 100%;
	transition: .3s;
	letter-spacing: 0.12em;
}

header .gnav>li>.btn .ico {
	margin-left: 10px;
}

@media screen and (min-width: 769px) {
	header .gnav>li {
		height: 54px;
	}

	header .gnav1,
	header .gnav2 {
		width: 156px;
	}

	header .gnav0 {
		width: 200px;
	}


	/*
	header .gnav>li>.btn {
		border-top: 5px solid #0089D8;
		font-size: 1.6rem;
	}
*/
	header .gnav .btn .ico svg {
		width: 100%;
	}

	header .gnav>li.on>.btn {
		opacity: 1;
		background: #0089D8;
		color: #fff;
	}

	header .gnav>.gnav0.on>.btn {
		background: #d90000;
	}

	header .gnav>li>.btn .ico svg {
		stroke: #0089D8;
		transition: .3s;
	}

	header .gnav>.gnav0>.btn .ico svg {
		stroke: #d90000;
		transition: .3s;
	}

	header .gnav>li.on>.btn .ico svg {
		stroke: #fff;
	}

	header .gnav0 .ico {
		width: 14px;
	}

	header .gnav1 .ico {
		width: 8px;
	}

	header .gnav2 .ico {
		width: 16px;
	}

	/*
	header .gnav>li.gnav3>.btn,
	header .gnav>li.gnav4>.btn,
	header .gnav>li.gnav5>.btn {
		border-top: 5px solid #74D4FC;
	}
*/
	header .gnav>li.gnav0>.btn {
		border-top: 5px solid #d90000;
	}

	header .gnav>li.gnav3.on>.btn,
	header .gnav>li.gnav4.on>.btn,
	header .gnav>li.gnav5.on>.btn {
		background: #74D4FC;
		color: #393939;
	}

	header .gnav>li.gnav3 {
		width: 110px;
	}

	header .gnav>li.gnav4 {
		width: 120px;

	}

	header .gnav>li.gnav5 {
		width: 136px;
	}

	header .gnav_s {
		position: absolute;
		top: 54px;
		left: 0;
		width: 406px;
		transition: .3s;
		/*display: none;*/
		z-index: 999;
		height: 0;
		opacity: 0;
		overflow: hidden;
	}

	header .gnav5 .gnav_s {
		width: 230px;
	}

	header li.on .gnav_s {
		height: auto;
		opacity: 1;
	}

	header .gnav_s ul {
		background: #0089D8;
		padding: 20px 24px 30px;
		color: #fff;
	}

	header .gnav>li.gnav3 .gnav_s,
	header .gnav>li.gnav4 .gnav_s,
	header .gnav>li.gnav5 .gnav_s {
		width: 300px;
	}

	header .gnav>li.gnav3 .gnav_s ul,
	header .gnav>li.gnav4 .gnav_s ul,
	header .gnav>li.gnav5 .gnav_s ul {
		background: #74D4FC;
		color: #393939;
	}

	header .gnav_s li {
		padding-top: 0.8em;
		padding-right: 0;
		font-size: 1.6rem;
	}

	header .gnav_s li a {
		position: relative;
		padding: 5px 0 5px 16px;
	}

	header .gnav_s li a:before {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		top: 50%;
		transform: translateY(-50%);
		width: 5px;
		height: 5px;
		border-radius: 50%;
		background: #ffb741;
	}

	header .gnav_s li+li {
		margin-top: 8px;
	}

}


@media screen and (max-width: 768px) {
	header .gnav li {
		font-size: 3.2vw;
		font-weight: bold;
		position: relative;
	}

	header .gnav>li>.btn .ico {
		margin-left: 3vw;
	}

	.menu_opn {
		width: 100%;
		height: calc(100% - 100px);
		position: fixed;
		left: 0;
		top: 70px;
		z-index: 10;
		overflow-y: hidden;
		display: none;
	}

	.menu_opn.on {
		display: block;
		width: 100%;
		height: calc(100% - 70px);
		background: #fff;
	}

	.menu_opn.off {
		display: none;
	}

	/*.menu_bg{
		background: #fff;
		position: fixed;
		width: 100%;
		height: 100%;
		left: 0;
		top: 100px;
		z-index: -1;
		display: block;
	}*/

	.menu_opn .menu_inner {
		width: 100%;
		height: 100%;
		padding: 28px 6.4vw 40px;
		overflow-y: scroll;
	}

	.menu_opn .gnav {
		width: 100%;
		margin: 0 auto 8vw;
	}

	header .gnav>li {}

	header .gnav>li>.btn {
		background: #0089D8;
		color: #fff;
		border-radius: 2vw;
		height: 14vw;
		box-shadow: 1vw 1vw 0px 0px #ededed;
		font-size: 4.2vw;
		/*pointer-events: none;*/
	}

	header .gnav>li+li {
		margin-top: 2vw;
	}

	header .gnav>li>.btn .ico svg {
		stroke: #fff;
		transition: .3s;
	}

	header .gnav>li>.btn:hover .ico svg {
		stroke: #fff;
	}

	header .gnav0 .ico svg {
		width: 2.6vw;
	}

	header .gnav1 .ico svg {
		width: 2.6vw;
	}

	header .gnav .gnav2 {
		margin-top: 3vw;
	}

	header .gnav2 .ico svg {
		width: 4.2vw;
	}

	header .gnav>li.gnav3>.btn,
	header .gnav>li.gnav4>.btn,
	header .gnav>li.gnav5>.btn,
	header .gnav>li.gnav6>.btn,
	header .gnav>li.gnav7>.btn {
		background: #74D4FC;
		height: 10vw;
		font-size: 3.7vw;
	}

	header .gnav .gnav3 {
		margin-top: 5vw;
	}

	header .gnavli .btn {
		position: relative;
	}

	header .gnav>li.gnav6>.btn::before,
	header .gnav>li.gnav7>.btn::before {
		display: none;
	}

	header .gnav>li.gnav6>.btn {
		background: #FFB741;
	}
	header .gnav>li.gnav7>.btn {
		background: #83C443;
	}

	header .gnav>li.gnav6>.btn:hover,
	header .gnav>li.gnav7>.btn:hover {
		background: #74D4FC;
	}


	header .gnavli .btn:before {
		content: "";
		display: block;
		position: absolute;
		width: 2vw;
		height: 2vw;
		border: 2px solid #fff;
		border-top: none;
		border-left: none;
		top: 50%;
		transform: translateY(-50%) rotate(45deg);
		right: 4vw;
		margin-top: -0.5vw;
	}

	header .gnavli.on .btn:before {
		transform: translateY(-50%) rotate(225deg);
		margin-top: 0;
	}

	header .gnav_s {
		display: none;
	}

	header .gnav_s ul {
		display: flex;
		flex-wrap: wrap;
		padding-top: 2vw;
	}

	header .gnav_s li {
		width: 50%;
		border-bottom: 1px dotted #ccc;
	}

	header .gnav_s li.mid {
		display: none;
	}

	header .gnav_s li a {
		height: 100%;
		display: flex;
		align-items: center;
		text-align: center;
		justify-content: center;
		padding: 0.8em 0.3em;
		line-height: 1.2;
		font-size: 3vw;
	}

	header .gnav_s li:nth-of-type(even) {
		border-right: 1px dotted #ccc;
	}
}


/*--search--*/
.head_search {
	position: relative;
	display: flex;
	padding-top: 21px;
}

.head_search .inner {
	background: #FFB741;
	height: 33px;
	width: 33px;
	border-radius: 33px;
	padding: 0;
	display: flex;
	cursor: pointer;
	transition: .3s;
}

.search-glass {
	position: absolute;
	right: 0;
	top: 21px;
	width: 33px;
	height: 33px;
	border-radius: 50%;
	background: #FFB741;
	display: flex;
	justify-content: center;
	align-items: center;
	text-decoration: none;
	transition: .3s;
}

.head_search .inner .search-btn {
	display: block;
	width: 33px;
	height: 33px;
	border-radius: 50%;
	position: absolute;
	top: 21px;
	right: 0;
	background: transparent;
	z-index: -2;
}

.head_search.on .inner {
	width: 180px;
}

.head_search.on .inner>form .search-txt {
	width: 160px;
	padding-left: 20px;
}

/*
.head_search .inner:hover > .search-txt, .head_search.on .inner > .search-txt{
    width: 160px;
	padding-left: 20px;
}*/
.head_search.on .inner>.search-btn {
	z-index: 2;
}

.search-txt {
	border: none;
	background: none;
	outline: none;
	float: left;
	padding: 0;
	transition: .3s;
	line-height: 33px;
	width: 0px;
	color: #fff;
}

.head_search input::placeholder {
	color: #fff;
}

/* IE */
.head_search input:-ms-input-placeholder {
	color: #fff;
}

/* Edge */
.head_search input::-ms-input-placeholder {
	color: #fff;
}

.head_search img {
	width: 18px;
}

.head_search input:-webkit-autofill {
	background-color: transparent !important;
	box-shadow: 0 0 0 1000px #FFB741 inset;
	color: #fff !important;
	border-radius: 33px;
}


@media screen and (min-width: 769px) {
	.head_search {
		padding-top: 10px;
		padding-left: 8px;
	}

	.head_search button {
		top: 10px !important;
	}

	.head_search button:hover .search-glass,
	.head_search button:focus .search-glass {
		opacity: 0.6;
	}

}


@media screen and (max-width: 768px) {
	.head_search {
		position: absolute;
		display: flex;
		padding-top: 0;
		top: 24px;
		right: 0;
		font-size: 5vw;
	}

	.head_search .inner {
		height: 25px;
		width: 25px;
		padding: 0;
	}

	.search-glass {
		position: absolute;
		right: 0;
		top: 0;
		width: 25px;
		height: 25px;
	}

	.head_search .inner .search-btn {
		display: block;
		width: 0;
		height: 25px;
		top: 0;
		transition: 1s;
	}

	.head_search.on .inner .search-btn {
		width: 25px;
	}

	.head_search .inner .search-btn:hover {
		opacity: 0.6;
	}

	.head_search .inner:hover {
		width: 200px;
	}

	.head_search .inner:hover>.search-txt {
		width: 170px;
		padding-left: 15px;
	}

	.head_search .inner:hover>.search-btn {
		right: 0;
	}

	.search-txt {
		line-height: 25px;
		width: 0px;
		font-size: 1.4rem;
	}

	.head_search img {
		width: 12px;
	}


}


/*----snav------------------------------*/
.snav {}

@media screen and (min-width: 769px) {
	.snav {
		position: fixed;
		right: 0;
		top: 102px;
		width: 76px;
	}

	.snav a {
		color: #fff;
		background: #83C443;
		font-size: 1.25rem;
		letter-spacing: 0.1em;
		padding-right: 24px;
	}

	.snav a:hover {
		background: #74D4FC;
	}

	.snav1 {
		border-radius: 10px 0 0 0;
		padding-top: 22px;
		padding-bottom: 16px;

	}

	.snav2 {
		border-radius: 0 0 0 10px;
		padding-top: 18px;
		padding-bottom: 22px;
		border-top: 1px dotted #fff;
	}

	.snav a .ico {
		display: block;
		text-align: center;
		margin: 0 auto 10px;
		padding-left: 4px;
	}

	.snav_language a .globe_ico {
		display: block;
		text-align: center;
		margin: 0 auto 10px;
		padding-left: 4px;
	}

	.snav_login a .globe_ico {
		display: block;
		text-align: center;
		margin: 0 auto 10px;
		padding-left: 4px;
	}

	.snav a .ico img {
		width: 10px;
	}

	.snav_language a .globe_ico img {
		width: 14px;
	}

	.snav_login a .globe_ico img {
		width: 14px;
	}

	.safari .snav a .ico {}

	.snav a .txt_vertical {
		display: block;
		line-height: 1;
		margin: 0 auto;
		width: 17px;
	}

	.ie .snav a .txt_vertical {
		display: inline-block;
	}

}


@media screen and (max-width: 768px) {
	.snav {
		display: flex;
	}

	.snav li {
		width: 50%;
	}

	.snav a {
		color: #fff;
		background: #83C443;
		font-size: 3.2vw;
		letter-spacing: 0.1em;
		height: 10vw;
	}

	.snav a:hover {
		background: #74D4FC;
	}

	.snav1 {
		border-radius: 2vw 0 0 2vw;
	}

	.snav2 {
		border-radius: 0 2vw 2vw 0;
		border-left: 1px dotted #fff;
	}

	.snav a .ico {
		margin-right: 2vw;
		display: inline-block;
	}

	.snav_language a .globe_ico {
		margin-right: 2vw;
		display: inline-block;
	}



	.snav_login a .globe_ico {
		margin-right: 2vw;
		display: inline-block;
	}

	.snav a .ico img {
		margin-bottom: 1vw;
		width: 2.6vw;
	}

	.snav_language a .globe_ico img {
		margin-bottom: 1vw;
		width: 3.6vw;
	}



	.snav_login a .globe_ico img {
		margin-bottom: 1vw;
		width: 3.6vw;
	}

	.snav a .txt {
		line-height: 1;
	}

}

/*----snav - Login------------------------------*/
.snav_login {}

@media screen and (min-width: 769px) {
	.snav_login {
		position: fixed;
		right: 0;
		top: 102px;
		width: 76px;
	}

	.snav_login a {
		color: #fff;
		background: #FC8483;
		font-size: 1.25rem;
		letter-spacing: 0.1em;
		padding-right: 24px;
		text-align: center;
	}

	.snav_login a:hover {
		background: #74D4FC;
	}

	.snav_login1 {
		border-radius: 10px 0 0 10px;
		padding-top: 22px;
		padding-bottom: 24px;
		text-transform: uppercase;
		font-weight: bold;

	}

	.snav_login a .ico {
		display: block;
		text-align: center;
		margin: 0 auto 10px;
		padding-left: 4px;
	}

	.snav_login a .ico img {
		width: 10px;
	}

	.safari .snav_login a .ico {}

	.snav_login a .txt_vertical {
		display: block;
		line-height: 1.5;
		margin: 0 auto;
		width: 17px;
		position: relative;
		left: 20px;
	}

	.ie .snav_login a .txt_vertical {
		display: inline-block;
	}

	.cs--pc {
		font-weight: 300;
	}

}


@media screen and (max-width: 768px) {
	.snav_login {
		display: flex;
		justify-content: center;
		margin-top: 2vw;
	}

	.snav_login li {
		width: 100%;
	}

	.snav_login a {
		color: #fff;
		font-weight: bold;
		text-transform: uppercase;
		background: #FC8483;
		font-size: 3.2vw;
		letter-spacing: 0.1em;
		height: 10vw;
	}

	.snav_login a:hover {
		background: #74D4FC;
	}

	.snav_login1 {
		border-radius: 2vw;
	}

	.snav_login2 {
		border-radius: 0 2vw 2vw 0;
		border-left: 1px dotted #fff;
	}

	.snav_login a .ico {
		margin-right: 2vw;
		display: inline-block;
	}

	.snav_login a .ico img {
		margin-bottom: 1vw;
		width: 2.6vw;
	}

	.snav_login a .txt {
		line-height: 1;
	}

}

/*----snav - Language------------------------------*/
.snav_language {}

@media screen and (min-width: 769px) {
	.snav_language {
		position: fixed;
		right: 0;
		top: 350px;
		width: 76px;
	}

	.snav_language a {
		color: #fff;
		background: #FFB741;
		font-size: 1.25rem;
		letter-spacing: 0.1em;
		padding-right: 24px;
	}

	.snav_language a:hover {
		background: #74D4FC;
	}

	.snav_language1 {
		border-radius: 10px 0 0 10px;
		padding-top: 22px;
		padding-bottom: 24px;
		text-transform: uppercase;
		font-weight: bold;

	}

	.snav_language a .ico {
		display: block;
		text-align: center;
		margin: 0 auto 10px;
		padding-left: 4px;
	}

	.snav_language a .ico img {
		width: 10px;
	}

	.safari .snav_language a .ico {}

	.snav_language a .txt_vertical {
		display: block;
		line-height: 1;
		margin: 0 auto;
		width: 17px;
	}

	.ie .snav_language a .txt_vertical {
		display: inline-block;
	}

}


@media screen and (max-width: 768px) {
	.snav_language {
		display: flex;
		justify-content: center;
		margin-top: 2vw;
	}

	.snav_language li {
		width: 50%;
	}

	.snav_language a {
		color: #fff;
		font-weight: bold;
		text-transform: uppercase;
		background: #FFB741;
		font-size: 3.2vw;
		letter-spacing: 0.1em;
		height: 10vw;
	}

	.snav_language a:hover {
		background: #74D4FC;
	}

	.snav_language1 {
		border-radius: 2vw;
	}

	.snav_language2 {
		border-radius: 0 2vw 2vw 0;
		border-left: 1px dotted #fff;
	}

	.snav_language a .ico {
		margin-right: 2vw;
		display: inline-block;
	}

	.snav_language a .ico img {
		margin-bottom: 1vw;
		width: 2.6vw;
	}

	.snav_language a .txt {
		line-height: 1;
	}

}

/*----snav - Lower------------------------------*/
.snav-lower {}

@media screen and (min-width: 769px) {
	.snav-lower {
		position: fixed;
		right: 0;
		top: 280px;
		width: 76px;
	}

	.snav-lower a {
		color: #fff;
		background: #83C443;
		font-size: 1.25rem;
		letter-spacing: 0.1em;
		padding-right: 24px;
		font-weight: bold;
	}
	.snav-lower .snav-kids {
    	background: #FFB741;
	}

	.snav-lower a:hover {
		background: #74D4FC;
	}

	.snav-lower2 {
		position: fixed;
		right: 0;
		top: 518px;
		width: 76px;

	}
	.snav-lower2 a {
		color: #fff;
		background: #0089D8;
		font-size: 1.25rem;
		letter-spacing: 0.1em;
		padding-right: 24px;
		font-weight: bold;
	}

	.snav-lower2 a:hover {
		background: #74D4FC;
	}

	.snav-lower a .ico {
		display: block;
		text-align: center;
		margin: 0 auto 10px;
		padding-left: 4px;
	}



	.snav-lower a .ico img {
		width: 10px;
	}



	.safari .snav-lower a .ico {}

	.snav-lower a .txt_vertical {
		display: block;
		line-height: 1;
		margin: 0 auto;
		width: 17px;
	}
	.snav-lower2 a .txt_vertical {
		display: block;
		line-height: 1;
		margin: 0 auto;
		width: 17px;
	}

	.ie .snav-lower a .txt_vertical {
		display: inline-block;
	}

}


@media screen and (max-width: 768px) {
	.snav-lower {
		display: flex;
	}

	.snav-lower li {
		width: 50%;
	}

	.snav-lower a {
		color: #fff;
		background: #83C443;
		font-size: 3.2vw;
		letter-spacing: 0.1em;
		height: 10vw;
	}

	.snav-lower a:hover {
		background: #74D4FC;
	}

	.snav-lower1 {
		border-radius: 2vw 0 0 2vw;
	}

	.snav-lower2 {
		border-radius: 0 2vw 2vw 0;
		border-left: 1px dotted #fff;
	}

	.snav-lower a .ico {
		margin-right: 2vw;
		display: inline-block;
	}

	.snav-lower a .ico img {
		margin-bottom: 1vw;
		width: 2.6vw;
	}

	.snav-lower a .txt {
		line-height: 1;
	}

}

/*------------
sp ハンバーガー
------------*/
.is_gnavOpen {
	width: 100%;
	height: 100%;
	position: fixed;
}

/* gnav背景 */
.js_gnavLayer {
	display: none;
}

@media screen and (min-width: 769px) {
	header .bl_navTrigger {
		display: none;
	}
}

@media screen and (max-width: 768px) {

	header .bl_navTrigger,
	header .bl_navTrigger span {
		display: inline-block;
		transition: all .4s;
	}

	header .bl_navTrigger {
		position: fixed;
		top: 0;
		left: 0;
		width: calc(24px + 8vw);
		height: 70px;
		z-index: 999;
	}

	.is_gnavOpen header .bl_navTrigger {}

	header .bl_navTrigger .txt {
		position: absolute;
		font-size: 0.8rem;
		text-align: center;
		bottom: 14px;
		width: 100%;
	}

	header .bl_navTrigger span {
		width: 24px;
		height: 3px;
		position: absolute;
		left: 4vw;
		top: 40%;
		background: #707070;
	}

	header .bl_navTrigger span:nth-of-type(1) {
		margin-top: -10px;
	}

	header .bl_navTrigger span:nth-of-type(2) {
		margin-top: -2px;
	}

	header .bl_navTrigger span:nth-of-type(3) {
		margin-top: 6px;
	}

	header .bl_navTrigger.active span:nth-of-type(1) {
		transform: translateY(8px) rotate(-45deg);
	}

	header .bl_navTrigger.active span:nth-of-type(2) {
		display: none;
	}

	header .bl_navTrigger.active span:nth-of-type(3) {
		transform: translateY(-8px) rotate(45deg);
	}

	/* ハンバーガーメニューボタンアニメーション */
	@-webkit-keyframes active_menu_bar {
		100% {
			height: 0;
		}
	}

	@keyframes active_menu_bar {
		100% {
			height: 0;
		}
	}

}

/*----haeader-lang------------------------------*/
@media screen and (min-width: 769px) {
	header .header-lang {
		padding: 0;
		position: absolute;
		right: 0;
		top: -27px;
	}

	.header-lang ul {
		justify-content: flex-end;
		gap: 20px;
		align-items: center;
	}

	.header-lang ul li {
		line-height: 1;
		font-size: 1.4rem;
		font-weight: bold;
		position: relative;
	}

	.header-lang ul li a {
        display: flex;
        align-items: center;
        border: 1px solid #FFB741;
        padding: 3px 10px;	}

	.header-lang ul li a img {
		width: 20px;
		margin-left: 6px;
	}
}

@media screen and (max-width: 768px) {
	header .header-lang {
		display: none;
	}
}


/* ----------------------------------------------------------------------------------------------------
*  footer
* --------------------------------------------------------------------------------------------------*/
footer {
	width: 100%;
	position: relative;
	background: #74D4FC;
	padding-top: 75px;
	padding-bottom: 26px;
	margin-top: 163px;
}

.foot_wave {
	display: block;
	position: absolute;
	top: -27px;
	height: 27px;
	width: 100%;
	overflow: hidden;
}

.foot_wave:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	width: 120%;
	height: 27px;
	background: url(../img/wave_foot.png) top center repeat-x;
	background-size: contain;
	animation: footwave 3s infinite linear;
}

@keyframes footwave {
	0% {
		transform: translate(0, 6px);
	}

	50% {
		transform: translate(-30px, 0);
	}

	100% {
		transform: translate(-60px, 6px);
	}
}

.foot_logo {
	width: 211px;
	margin: 0 auto;
}

.foot_logo svg {
	fill: #fff;
}

.fnav {
	justify-content: center;
	color: #fff;
	font-size: 1.6rem;
	line-height: 1;
	margin-top: 30px;
	font-weight: bold;
}

.fnav li+li {
	padding-left: 1.4em;
	margin-left: 1.4em;
	border-left: 1px solid #fff;
}

.copy {
	line-height: 1;
	font-size: 2rem;
	color: #fff;
	font-weight: bold;
	margin-top: 102px;
}

@media screen and (min-width: 769px) {}

@media screen and (max-width: 768px) {
	footer {
		padding-top: 12.5vw;
		padding-bottom: 2.6vw;
		margin-top: 15vw;
	}

	.foot_wave {
		top: -3.7vw;
		height: 3.7vw;
	}

	.foot_wave:before {
		height: 3.7vw;
		background: url(../img/wave_foot.png) top center repeat-x;
		background-size: 8.8vw;
	}

	@keyframes footwave {
		0% {
			transform: translate(0, 1.6vw);
		}

		50% {
			transform: translate(-4.4vw, 0);
		}

		100% {
			transform: translate(-8.8vw, 1.6vw);
		}

	}

	.foot_logo {
		width: 49vw;
	}

	.fnav {
		font-size: 3.2vw;
		line-height: 1;
		margin-top: 11vw;
	}

	.fnav li {
		text-align: center;
	}

	.fnav li+li {
		padding-left: 0;
		margin-left: 0;
		border-left: none;
		margin-top: 4.2vw;
	}

	.copy {
		margin-top: 16vw;
		font-size: 2.6vw;
	}
}

/* ------------------------------
    YouTube動画レスポンシブ対応用のスタイル
------------------------------ */
@media screen and (max-width: 768px) {
	.youtube {
		position: relative;
		width: 100%;
		padding-top: 56.25%;
	}

	.youtube iframe {
		position: absolute;
		top: 0;
		right: 0;
		width: 100%;
		height: 100%;
	}
}