@charset "utf-8";

/*■■■■■■■■■■■■■■■■■■■■■■■■
　全ページ共通CSS
　■■■■■■■■■■■■■■■■■■■■■■■■*/

:root {
	--main-bg-color: #FBF4E4;
	--nav-bg-color: #FCEDCB;
	--btn-bg-color: #F16D75;
}

/* ■■■■■■ Reset ■■■■■■ */
address, caption, cite, code, dfn, em, i, th, strong, var {
	font-style: normal;
}

blockquote, dd, div, dl, dt, h1, h2, h3, h4, h5, h6, li, ol, p, pre, span, td, th, ul {
	margin: 0;
	padding: 0;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: normal;
}

ol, ul {
	list-style: none;
}

q:before, q:after {
	content: '';
}

figure {
	margin: 0;
}

img {
	display: block;
}

article, aside, canvas, details, figcaption, figure, header, footer, hgroup, menu, nav, section, summary, main {
	display: block;
}

article, aside, footer, header, hgroup, nav, section, main {
	position: relative;
}

html {
	width: 100%;
	font-size: 62.5%;
	scroll-behavior: smooth;
}



/* ■■■■■■ 共通 ■■■■■■ */
*,
*:before,
*:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

html {
	margin: 0;
	padding: 0;
	position: relative;
	overflow-x: hidden;
	overflow-y: scroll;
	height: 100%;
	background: transparent !important;
}

body {
	background: #fff;
	position: relative;
	margin: 0;
	padding: 0;
	min-width: 320px;
	letter-spacing: 0;
	height: 100%;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.8125;
	color: #000;
	word-wrap: break-word;
	overflow-wrap: break-word;
	text-align: justify;
	text-justify: inter-ideograph;
	font-family: 'Hiragino Maru Gothic StdN', "Noto Sans JP", sans-serif;
}

main {
	padding-top: 77px;
}

a {
	color: unset;
	text-decoration: none;
	-webkit-transition: all .5s linear;
	-moz-transition: all .5s linear;
	-o-transition: all .5s linear;
	transition: all .5s linear;
}

a:hover {
	text-decoration: none;
	-webkit-transition: all .2s linear;
	-moz-transition: all .2s linear;
	-o-transition: all .2s linear;
	transition: all .2s linear;
	opacity: 0.7;
}

a:hover img,
input[type="image"]:hover {
	filter: Alpha(opacity=70);
	opacity: .7;
	-webkit-transition: all .2s linear;
	-moz-transition: all .2s linear;
	-o-transition: all .2s linear;
	transition: all .2s linear;
}

a img,
input[type="image"] {
	filter: ;
	opacity: 1;
	-webkit-transition: all .5s linear;
	-moz-transition: all .5s linear;
	-o-transition: all .5s linear;
	transition: all .5s linear;
}

img {
	border: 0;
	-ms-interpolation-mode: bicubic;
	vertical-align: top;
	max-width: 100%;
	height: auto;
}

form {
	margin: 0;
	padding: 0;
}

input[type="checkbox"],
input[type="radio"] {
	vertical-align: middle;
}

.mb0 {
	margin-bottom: 0 !important;
  }

.mb5 {
	margin-bottom: 5px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb15 {
	margin-bottom: 15px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb25 {
	margin-bottom: 25px !important;
}

.mb30 {
margin-bottom: 30px !important;
}

.mb35 {
	margin-bottom: 35px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb45 {
	margin-bottom: 45px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.mb55 {
	margin-bottom: 55px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb65 {
	margin-bottom: 65px !important;
}

.mb70 {
	margin-bottom: 70px !important;
}

.mb75 {
	margin-bottom: 75px !important;
}

.mb80 {
	margin-bottom: 80px !important;
}

.mb85 {
	margin-bottom: 88px !important;
}

.mb90 {
	margin-bottom: 90px !important;
}

.mb100 {
	margin-bottom: 100px !important;
}

.mincho {
	font-family: "ヒラギノ明朝 Pro W4", "Hiragino Mincho Pro", "HGS明朝B", "MingLiU", "SimSun", "ＭＳ Ｐ明朝", serif !important;
}

.times {
	font-family: Times, "Times New Roman", serif !important;
}

.ib {
	display: inline-block;
}


.inr {
	max-width: 1040px;
	padding: 0 5vw;
	margin: 0 auto;
}

.inr_1100 {
	max-width: 1140px;
	padding: 0 5vw;
	margin: 0 auto;
}
@media screen and (max-width: 800px) {
	main {
		padding-top: min(15vw, 77px);
	}

	.pc {
		display:  none !important;
	}
}
@media screen and (min-width: 801px) {
	.inr ,
	.inr_1100 {
		padding: 0 20px;
	}

	.smt {
		display: none !important;
	}
}

/* ■■■■■■ タイトル ■■■■■■ */
.ctitle {
	color: #002365;
	font-size: 2.4rem;
	font-weight: 600;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 4vw;
	margin-bottom: 15px;
	text-align: center;
}

.ctitle::before ,
.ctitle::after {
	content: "";
	display: block;
	width: 7vw;
	height: 1px;
	background-color: #002365;
}

@media screen and (max-width: 800px) {
	.ctitle {
		line-height: 1.4;
	}
}

@media screen and (min-width: 801px) {
	.ctitle {
		gap: 20px;
		text-align: left;
	}

	.ctitle::before ,
	.ctitle::after {
		width: 91px;
	}
}

/* ■■■■■■ ボタン ■■■■■■ */
.btn {
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 510px;
	margin: 0 auto;
	color: #fff;
	background-color: #002365;
	padding: 12px 10px;
	font-size: 2.4rem;
	font-weight: 600;
	border-radius: 8px;
}

@media screen and (min-width: 801px) {
	.btn.btn--orange {
		width: 400px;
		font-size: 1.6rem;
	}

	.btn.btn--orange::after {
		right: 14%;
	}
}

/* ■■■■■■ ヘッダー ■■■■■■ */
.header {
	height: 77px;
	position: fixed;
	width: 100%;
	top: 0;
	left: 0;
	z-index: 1000;
	background-color: #fff;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}


.header_inr {
	display: flex;
	justify-content: space-between;
	height: 100%;
	padding-left: 35px;
}

.header_logo {
	display: flex;
	align-items: center;
}

.header_nav {
	flex: 1;
	display: flex;
	justify-content: flex-end;
}

.header_nav ul {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}

.header_nav ul li {
	border-right: 1px solid #002365;
	padding: 0 20px;
}

.header_nav ul li:last-of-type {
	border-right: none;
}

.header_nav ul li a {
	color: #002365;
	font-weight: 600;
}

.header_btn {
	color: #fff;
	background-color: #E0952E;
	width: 200px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

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

	.header {
		height: min(15vw ,77px);
	}

	.header_inr {
		padding-left: 5vw;
	}

	.header_btn {
		width: 100%;
		padding: 10px;
	}

	.header_nav {
		display: block;
		position: fixed;
		width: 100%;
		top: min(15vw, 77px);
		bottom: 0;
		left: 0%;
		transition:  0.6s;
		background-color: #EBEFF5;
		visibility: hidden;
		opacity: 0;
	}

	.open .header_nav {
		visibility: visible;
		opacity: 1;
	}

	.header_nav ul {
		display: block;
	}

	.header_nav ul li {
		padding: 0;
		border-right: none;
	}

	.header_nav ul li a {
		font-size: 1.9rem;
		background-color: #fff;
		font-weight: 500;
		height: 60px;
		display: flex;
		align-items: center;
		padding: 10px 17% 10px 7%;
		position: relative;
		margin-bottom: 5px;
	}

	.header_nav li > a::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 7%;
		display: inline-block;
		vertical-align: middle;
		color: #000000;
		width: .5em;
		height: .5em;
		border: 0.2em solid #000000;
		border-left: 0;
		border-bottom: 0;
		box-sizing: border-box;
		transition: right 0.3s;
		transform: translateY(-50%) translateX(-50%) rotate(45deg);
	}

	.hamburger {
		display: block;
		width: min(15vw,80px);
		height: 100%;
		z-index: 11;
		position: relative;
		flex-shrink: 0;
	}

	.hamburger_btn {
		cursor: pointer;
		width:100%;
		height:100%;
		background-color: #E0952E;
		transition: background .6s;
	}

	.hamburger_btn_inr {
		transition: all .6s;
		width:100%;
		height:100%;
	}

	.hamburger_btn span {
		display: inline-block;
		transition: all .4s;
		position: absolute;
		left: 50%;
		top: 50%;
		transform: translate(-50%,-50%);
		height: 2px;
		border-radius: 2px;
		background-color: #fff;
		width: 20px;
	  }

	.hamburger_btn span:nth-of-type(1) {
		top: 40%;
	}

	.hamburger_btn span:nth-of-type(2) {
		top: 50%;
	}

	.hamburger_btn span:nth-of-type(3) {
		top: 60%;
	}

	.open .hamburger_btn .hamburger_btn_inr {
	  transform: rotate(360deg);
	}

	.open .hamburger_btn span:nth-of-type(1) {
		top: 50%;
		transform: translate(-50%,-50%) rotate(-45deg);
		width: 24px;
	}

	.open .hamburger_btn span:nth-of-type(2) {
	  opacity: 0;
	}

	.open .hamburger_btn span:nth-of-type(3){
		top: 50%;
		transform: translate(-50%,-50%) rotate(45deg);
		width: 24px;
	}
}

/* ■■■■■■ フッター ■■■■■■ */
.footer {
	background-color: #F3F1EA;
	padding: 35px 0 30px;
	font-size: 1.5rem;
}

.footer_inr {
	max-width: 890px;
	padding: 0 5vw;
	margin: 0 auto;
}

.footer_head {
	margin-bottom: 19px;
	text-align: center;
}

.footer_head p {
	text-align: center;
}

.footer_logo {
	width: 100%;
}

.footer_logo a {
	display: block;
	max-width: 345px;
	margin: 10px auto;
}

.footer_logo img {
	margin: 0 auto;
}

@media (min-width: 800px) {

	.footer {
		padding: 35px 0 40px;
	}

	.footer_inr {
		padding: 0 20px;
	}

	.footer_head {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 10px;
	}

	.footer_logo {
		display: flex;
		align-items: center;
		justify-content: center	;
		gap: 10px;
	}

	.footer_logo a {
		margin: 0;
	}

	.footer_logo img {
		margin: 0;
	}
}