@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

body{
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
}
h1,h2,h3,h4,h5,h6{
	color: #0F2A44;
    font-family: "M PLUS Rounded 1c", sans-serif;
    font-weight: 700;
	letter-spacing: .05em;
}
a, a::before, a::after{
	transition: all .6s;
}
.c-iconBtn{
	color: #3a4a4f;
}
.c-gnav>.menu-item>a .ttl{
	font-size: 16px;
}
.p-mainVisual__slideTitle{
	font-size: 2.2em;
	font-weight: 900;
	text-shadow: 1px 1px 0px rgba(255, 255, 255, 0.3),-1px -1px 0px rgba(255, 255, 255, 0.3),1px -1px 0px rgba(255, 255, 255, 0.3),-1px 1px 0px rgba(255, 255, 255, 0.3);
}
.p-mainVisual__slideText{
	font-size: 1.4em;
	text-shadow: 1px 1px 0px rgba(255, 255, 255, 0.3),-1px -1px 0px rgba(255, 255, 255, 0.3),1px -1px 0px rgba(255, 255, 255, 0.3),-1px 1px 0px rgba(255, 255, 255, 0.3);
}
@media (max-width: 600px) {
	.p-mainVisual__slideTitle{
		font-size: 1.4em;
	}
	.p-mainVisual__slideText{
		font-size: 1.2em;
	}
}

/*	footer	*/
#before_footer_widget .l-container{
	max-width: 100%;
	margin: 0;
	padding: 0;
}
.w-footer__box{
	text-align: center;
}
.ft-logo h1{
	font-size: 2em;
}
.ft_button a{
	display: inline-block;
	width: auto;
	height: 50px;
	background: #C62828;
	color: #fff;
	font-size: 1rem;
	line-height: 50px;
	padding: 0 4em 0 2em;
	border-radius: 3px;
	position: relative;
}
.ft_button a::after{
	content: '\f0e0';
	font-family: "Font Awesome 6 Free";
	position: absolute;
	right: 2em;
}
.ft_button a:hover{
	background: #163A5F;
}
.ft_button a:hover::after{
	right: 2.5em;
}
.ft_sns{
	display: flex;
	justify-content: center;
	gap: 15px;
}
.ft_sns li a{
	display: block;
	font-size: 12px;
	text-align: center;
}
.ft_sns li a::before{
	content: "\f3c0";
	display: block;
	font-family: "FontAwesome";
	width: 50px;
	height: 50px;
	font-size: 20px;
	line-height: 50px;
	text-align: center;
	border-radius: 25px;
	background: #1F4E79;
	color: #fff;
	margin: 0 auto;
}
.ft_sns li.instagram a::before{
	content: "\f16d";
	background: #CF2E92;
}
.ft_sns li.youtube a::before{
	content: "\f167";
	background: #c4302b;
}
.ft_sns li.line a::before{
	content: "\f3c0";
	background: #06c755;
}
.ft_sns li a:hover{
	color: #163A5F;
}
.ft_sns li a:hover::before{
	font-size: 25px;
	background: #163A5F;
}

/* 見出し */
h1.c-postTitle__ttl,
h1.c-pageTitle{
	color: #fff;
}
.ft-logo h1{
	color: #fff;
	font-size: 2.2em;
}
.post_content h2{
	color: #1F4E79;
	font-size: 2em;
	margin-left: 0;
	margin-right: 0;
}
.post_content h3{
	font-size: 1.6em;
}
.post_content h4{
	font-size: 1.4em;
}
.post_content h5{
	font-size: 1.2em;
}
.post_content h6{
	font-size: 1.1em;
}
@media (max-width: 600px) {
	.post_content h1{
		font-size: 2em;
	}
	.post_content h2{
		font-size: 1.8em;
	}
	.post_content h3{
		font-size: 1.4em;
	}
	.post_content h4{
		font-size: 1.2em;
	}
	.post_content h5{
		font-size: 1.1em;
	}
	.post_content h6{
		font-size: 1em;
	}
}

/* メールフォーム */
input, select, textarea{
	width: 100%;
}
.wpcf7 [type=submit]{
	display: table;
	max-width: 460px;
	color: #fff;
	background: #1F4E79;
	line-height: 50px;
	border-radius: 3px;
	margin: 0 auto;
	transition: all .6s;
}
.wpcf7 [type=submit]:hover{
	background: #163A5F;
}
.wpcf7 p{
	margin-bottom: 1.5em;
}
span.required{
	color: #fff;
	background: #C62828;
	font-size: 12px;
	border-radius: 3px;
	padding: 0 1em;
	margin-left: 1em;
}
span.any{
	color: #fff;
	background: #ccc;
	font-size: 12px;
	border-radius: 3px;
	padding: 0 1em;
	margin-left: 1em;
}