@charset "utf-8";

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,p,blockquote,th,td,main,figure{margin:0;padding:0}table{font-size:100%;font-family:inherit}fieldset,img{border:0}img,svg,video{vertical-align:middle}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:400}ol,ul{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%}q:before,q:after{content:''}abbr,acronym{border:0}select,input,textarea{font-size:100%}header,footer,nav,main,section,article,figure,aside,picture{display:block}.clearfix:after,.row:after{content:"";display:table;clear:both}.fl{float:left}.fr{float:right}@media screen and (min-width: 768px),print{.pc_fl{float:left}.pc_fr{float:right}}@media screen and (max-width: 767px){.sp_fl{float:left}.sp_fr{float:right}}.tal{text-align:left!important}.tac{text-align:center!important}.tar{text-align:right!important}@media screen and (min-width: 768px),print{.pc_tal{text-align:left!important}.pc_tac{text-align:center!important}.pc_tar{text-align:right!important}}@media screen and (max-width: 767px){.sp_tal{text-align:left!important}.sp_tac{text-align:center!important}.sp_tar{text-align:right!important}}.m00{margin:0!important}.mb00{margin-bottom:0!important}.mb05{margin-bottom:5px!important}.mb08{margin-bottom:8px!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}.mt00{margin-top:0!important}.mt05{margin-top:5px!important}.mt08{margin-top:8px!important}.mt10{margin-top:10px!important}.mt15{margin-top:15px!important}.mt20{margin-top:20px!important}.mt25{margin-top:25px!important}.mt30{margin-top:30px!important}.mt35{margin-top:35px!important}.mt40{margin-top:40px!important}.mt45{margin-top:45px!important}.mt50{margin-top:50px!important}@media screen and (min-width: 768px),print{.pc_m00{margin:0!important}.pc_mb00{margin-bottom:0!important}.pc_mb05{margin-bottom:5px!important}.pc_mb08{margin-bottom:8px!important}.pc_mb10{margin-bottom:10px!important}.pc_mb15{margin-bottom:15px!important}.pc_mb20{margin-bottom:20px!important}.pc_mb25{margin-bottom:25px!important}.pc_mb30{margin-bottom:30px!important}.pc_mb35{margin-bottom:35px!important}.pc_mb40{margin-bottom:40px!important}.pc_mb45{margin-bottom:45px!important}.pc_mb50{margin-bottom:50px!important}.pc_mt00{margin-top:0!important}.pc_mt05{margin-top:5px!important}.pc_mt08{margin-top:8px!important}.pc_mt10{margin-top:10px!important}.pc_mt15{margin-top:15px!important}.pc_mt20{margin-top:20px!important}.pc_mt25{margin-top:25px!important}.pc_mt30{margin-top:30px!important}.pc_mt35{margin-top:35px!important}.pc_mt40{margin-top:40px!important}.pc_mt45{margin-top:45px!important}.pc_mt50{margin-top:50px!important}}@media screen and (max-width: 767px){.sp_m00{margin:0!important}.sp_mb00{margin-bottom:0!important}.sp_mb05{margin-bottom:5px!important}.sp_mb08{margin-bottom:8px!important}.sp_mb10{margin-bottom:10px!important}.sp_mb15{margin-bottom:15px!important}.sp_mb20{margin-bottom:20px!important}.sp_mb25{margin-bottom:25px!important}.sp_mb30{margin-bottom:30px!important}.sp_mb35{margin-bottom:35px!important}.sp_mb40{margin-bottom:40px!important}.sp_mb45{margin-bottom:45px!important}.sp_mb50{margin-bottom:50px!important}.sp_mt00{margin-top:0!important}.sp_mt05{margin-top:5px!important}.sp_mt08{margin-top:8px!important}.sp_mt10{margin-top:10px!important}.sp_mt15{margin-top:15px!important}.sp_mt20{margin-top:20px!important}.sp_mt25{margin-top:25px!important}.sp_mt30{margin-top:30px!important}.sp_mt35{margin-top:35px!important}.sp_mt40{margin-top:40px!important}.sp_mt45{margin-top:45px!important}.sp_mt50{margin-top:50px!important}}.p00{padding:0!important}.pb00{padding-bottom:0!important}.pb05{padding-bottom:5px!important}.pb08{padding-bottom:8px!important}.pb10{padding-bottom:10px!important}.pb15{padding-bottom:15px!important}.pb20{padding-bottom:20px!important}.pb25{padding-bottom:25px!important}.pb30{padding-bottom:30px!important}.pb35{padding-bottom:35px!important}.pb40{padding-bottom:40px!important}.pb45{padding-bottom:45px!important}.pb50{padding-bottom:50px!important}.pt00{padding-top:0!important}.pt05{padding-top:5px!important}.pt08{padding-top:8px!important}.pt10{padding-top:10px!important}.pt15{padding-top:15px!important}.pt20{padding-top:20px!important}.pt25{padding-top:25px!important}.pt30{padding-top:30px!important}.pt35{padding-top:35px!important}.pt40{padding-top:40px!important}.pt45{padding-top:45px!important}.pt50{padding-top:50px!important}@media screen and (min-width: 768px),print{.pc_p00{padding:0!important}.pc_pb00{padding-bottom:0!important}.pc_pb05{padding-bottom:5px!important}.pc_pb08{padding-bottom:8px!important}.pc_pb10{padding-bottom:10px!important}.pc_pb15{padding-bottom:15px!important}.pc_pb20{padding-bottom:20px!important}.pc_pb25{padding-bottom:25px!important}.pc_pb30{padding-bottom:30px!important}.pc_pb35{padding-bottom:35px!important}.pc_pb40{padding-bottom:40px!important}.pc_pb45{padding-bottom:45px!important}.pc_pb50{padding-bottom:50px!important}.pc_pt00{padding-top:0!important}.pc_pt05{padding-top:5px!important}.pc_pt08{padding-top:8px!important}.pc_pt10{padding-top:10px!important}.pc_pt15{padding-top:15px!important}.pc_pt20{padding-top:20px!important}.pc_pt25{padding-top:25px!important}.pc_pt30{padding-top:30px!important}.pc_pt35{padding-top:35px!important}.pc_pt40{padding-top:40px!important}.pc_pt45{padding-top:45px!important}.pc_pt50{padding-top:50px!important}}@media screen and (max-width: 767px){.sp_p00{padding:0!important}.sp_pb00{padding-bottom:0!important}.sp_pb05{padding-bottom:5px!important}.sp_pb08{padding-bottom:8px!important}.sp_pb10{padding-bottom:10px!important}.sp_pb15{padding-bottom:15px!important}.sp_pb20{padding-bottom:20px!important}.sp_pb25{padding-bottom:25px!important}.sp_pb30{padding-bottom:30px!important}.sp_pb35{padding-bottom:35px!important}.sp_pb40{padding-bottom:40px!important}.sp_pb45{padding-bottom:45px!important}.sp_pb50{padding-bottom:50px!important}.sp_pt00{padding-top:0!important}.sp_pt05{padding-top:5px!important}.sp_pt08{padding-top:8px!important}.sp_pt10{padding-top:10px!important}.sp_pt15{padding-top:15px!important}.sp_pt20{padding-top:20px!important}.sp_pt25{padding-top:25px!important}.sp_pt30{padding-top:30px!important}.sp_pt35{padding-top:35px!important}.sp_pt40{padding-top:40px!important}.sp_pt45{padding-top:45px!important}.sp_pt50{padding-top:50px!important}}


/* ========================================================
	template.css => テンプレート用CSS
======================================================== */
html {
	font-size: 62.5%;
}
body {
	background-color: #fff;
	font-size: 1.6rem;
	line-height: 1.75;
	color: #000;
	word-wrap: break-word;
	overflow-wrap: break-word;

	font-family: dnp-shuei-mgothic-std, 'Noto Sans JP', sans-serif;
	font-weight: 600;
	font-style: normal;
	font-feature-settings: "palt";
	letter-spacing: 0.05em;
	-webkit-text-size-adjust: none;
	text-size-adjust: none;
}
@media screen and (max-width: 767px) {
	body {
		font-size: 1.4rem;
	}
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	line-height: 1.7;
}
a[href] {
	color: #000;
	text-decoration: underline;
	outline: none;
}
a[href]:hover {
	text-decoration: none;
}
a[href].a_reverse,
.a_reverse a[href] {
	text-decoration: none;
}
@media screen and (min-width: 768px) {
	a[href].a_reverse:hover,
	.a_reverse a[href]:hover {
		text-decoration: underline;
	}
}

img {
	max-width: 100%;
	height: auto;
}
label {
	cursor: pointer;
}
input, select, textarea, button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	max-width: 100%;
	margin: 0;
	border-radius: 0;
	vertical-align: middle;
	font-family: inherit;
	outline: none;
	font-size: 100%;
}
::-webkit-input-placeholder {
	color: #ccc;
}
:-ms-input-placeholder {
	color: #ccc;
}
::-moz-placeholder {
	color: #ccc;
}
select::-ms-expand {
	display: none;
}

button {
	cursor: pointer;
}
iframe {
	max-width: 100%;
	vertical-align: middle;
}

.hidden {
	display: none;
}
.slick-slider * {
	outline: none;
}

/* pc / sp
============================================================================================================ */
@media screen and (min-width: 768px), print {
	.sp {
		display: none !important;
	}
	.pc_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
	.pc_hidden {
		position: relative;
		overflow: hidden;
		display: block;
		height: 0;
	}
}
@media screen and (max-width: 767px) {
	.pc {
		display: none !important;
	}
	.sp_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
}
@media screen and (min-width: 371px) {
	.sps {
		display: none !important;
	}
}
@media screen and (max-width: 370px) {
	.sps_non {
		display: none !important;
	}
}

/* transition
============================================================================================================ */
@media screen and (min-width: 768px) {
	body.init a[href],
	body.init a[href]::before,
	body.init a[href]::after,
	body.init button,
	body.init button::before,
	body.init button::after,
	body.init .basic_trs,
	body.init .basic_trs::before,
	body.init .basic_trs::after,
	body.init .basic_trs *,
	body.init .basic_trs *::before,
	body.init .basic_trs *::after {
		transition: color 0.2s ease-in-out, background 0.2s ease-in-out, border 0.2s ease-in-out, opacity 0.2s ease-in-out;
	}
	body.init a svg {
		transition: fill 0.2s ease-in-out;
	}
}


/* font family
============================================================================================================ */
.ff_ja {
	font-family: dnp-shuei-mgothic-std, sans-serif;
	font-weight: 600;
	font-style: normal;
	font-feature-settings: "palt";
}
.ff_noto {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
}
.ff_en {
	font-family: din-2014-narrow, sans-serif;
	font-weight: 700;
	font-style: normal;
}
.ff_din {
	font-family: din-2014, sans-serif;
	font-weight: 600;
	font-style: normal;
}

/* font
============================================================================================================ */
.fwb {
	font-weight: 700;
}
.fwn {
	font-weight: 400;
}


/* display
============================================================================================================ */
.db {
	display: block;
}
.dib {
	display: inline-block;
}

/* object-fit
============================================================================================================ */
img.of {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
img.of.bg {
	pointer-events: none;
	user-select: none;
	z-index: -1;
}

/* hover
============================================================================================================ */
@media screen and (min-width: 768px), print {
	a.hv_wh,
	button.hv_wh,
	a .hv_wh,
	.hv_wh a {
		position: relative;
		display: inline-block;
		vertical-align: middle;
		overflow: hidden;
	}
	a.hv_wh::after,
	button.hv_wh::after,
	a .hv_wh::after,
	.hv_wh a::after {
		content: "";
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		background-color: rgba(255,255,255,0);
		z-index: 3;
	}
	body.init a.hv_wh::after,
	body.init button.hv_wh::after,
	body.init a .hv_wh::after,
	body.init .hv_wh a::after {
		transition: background 0.2s;
	}
	a[href].hv_wh:hover::after,
	button.hv_wh:hover::after,
	a[href]:hover .hv_wh::after,
	.hv_wh a[href]:hover::after {
		background-color: rgba(255,255,255,0.3);
	}
	a[href].hv_wh.a20:hover::after,
	button.hv_wh.a20:hover::after,
	a[href]:hover .hv_wh.a20::after,
	.hv_wh.a20 a[href]:hover::after {
		background-color: rgba(255,255,255,0.2);
	}
	a[href].hv_wh.a10:hover::after,
	button.hv_wh.a10:hover::after,
	a[href]:hover .hv_wh.a10::after,
	.hv_wh.a10 a[href]:hover::after {
		background-color: rgba(255,255,255,0.1);
	}

	body.init a[href] .hv_op {
		transition: opacity 0.2s;
	}
	a[href].hv_op:hover,
	a[href]:hover .hv_op,
	button.hv_op:hover,
	.hv_op a[href]:hover {
		opacity: 0.7;
	}
	a[href].hv_op.a20:hover,
	a[href]:hover .hv_op.a20,
	.hv_op.a20 a[href]:hover {
		opacity: 0.8;
	}
	a[href].hv_op.a10:hover,
	a[href]:hover .hv_op.a10,
	.hv_op.a10 a[href]:hover {
		opacity: 0.9;
	}
	a[href].hv_op.a50:hover,
	a[href]:hover .hv_op.a50,
	.hv_op.a50 a[href]:hover {
		opacity: 0.5;
	}
}

.hv_zoom {
	position: relative;
	display: block;
	overflow: hidden;
}
.hv_zoom > * {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
@media screen and (min-width: 768px), print {
	body.init a[href].hv_zoom > *,
	body.init a[href] .hv_zoom > * {
		transition: transform 0.6s, opacity .3s;
	}
	a[href]:hover .hv_zoom.s > * {
		transform: scale(1.03);
	}
	a[href]:hover.hv_zoom > *,
	a[href]:hover .hv_zoom > * {
		transform: scale(1.05);
	}
}


/* target
============================================================================================================ */
.target {
	display: block;
	position: relative;
	width: 1px;
}
@media screen and (min-width: 768px), print {
	.target.pt {
		top: -40px;
	}
}
@media screen and (max-width: 767px) {
	/* .target.pt {
		top: -80px;
	} */
}



/* w
============================================================================================================ */
.w {
	position: relative;
}
@media screen and (min-width: 768px), print {
	.w {
		width: 1020px;
		margin: 0 auto;
	}
	.mw {
		min-width: 1120px;
	}
}
@media screen and (max-width: 767px) {
}


/* spパディング
============================================================================================================ */
@media screen and (max-width: 767px) {
	.sp_pd {
		padding-left: 5vw !important;
		padding-right: 5vw !important;
	}
	.sp_full {
		margin-left: -5vw !important;
		margin-right: -5vw !important;
	}
	.sp_full_l {
		margin-left: -5vw !important;
	}
	.sp_full_r {
		margin-right: -5vw !important;
	}
}


/* header
============================================================================================================ */
#header {
	position: relative;
}
#header .logo {
	position: absolute;
	top: 20px;
	left: 4%;
	z-index: 100;
	text-align: center;
}
#header .logo svg {
	fill: #fff;
}
#header .logo svg .y {
	fill: #ffea00;
}
@media screen and (min-width: 768px), print {
	#header .logo > * {
		display: block;
	}
	#header .logo a {
		margin-top: 8px;
	}
	#header .logo a:hover {
		opacity: 0.5;
	}
	#header .consultation {
		position: fixed;
		right: 20px;
		top: 15px;
		z-index: 100;
	}
	#header .consultation ul a:hover {
		background-color: #fff;
	}
}
@media screen and (max-width: 767px) {
	#header .logo {
		top: 0;
		left: 0;
		right: 0;
		display: flex;
		justify-content: center;
		align-items: center;
		height: 50px;
	}
	#header .logo svg {
		width: 180px;
	}
	#header .logo a {
		margin-left: 8px;
	}
	#header .logo a svg {
		width: 150px;
	}

	/* nav_btn */
	#header .nav_btn {
		position: fixed;
		right: 0;
		top: 0;
		width: 50px;
		height: 50px;
		transform: translateX(100px);
		z-index: 1000;
	}
	#header .nav_btn::before {
		content: "";
		position: absolute;
		right: 0;
		top: 0;
		width: 90px;
		height: 90px;
		background-color: #ffea00;
		transform-origin: 0 0;
		transform: skewX(45deg);
		z-index: -1;
	}
	body.init #header .nav_btn {
		transition: transform 0.4s ease-in-out;
	}
	#header.open .nav_btn,
	#header .nav_btn.show {
		transform: translateX(0);
	}
	#header .nav_btn a {
		position: relative;
		display: block;
		height: 100%;
	}
	#header .nav_btn::after,
	#header .nav_btn a::before,
	#header .nav_btn a::after {
		content: "";
		position: absolute;
		left: 50%;
		top: 50%;
		width: 24px;
		margin-top: -1px;
		margin-left: -12px;
		border-top: 2px solid #000;
		pointer-events: none;
	}
	body.init #header .nav_btn::after,
	body.init #header .nav_btn a::before,
	body.init #header .nav_btn a::after {
		transition: all 0.3s ease-in-out;
	}
	#header .nav_btn a::before {
		transform: translateY(-7px);
	}
	#header .nav_btn a::after {
		transform: translateY(7px);
	}

	/* nav_btn open */
	#header.open .nav_btn::after {
		opacity: 0;
	}
	#header.open .nav_btn a::before {
		transform: translateY(0) rotate(45deg);
	}
	#header.open .nav_btn a::after {
		transform: translateY(0) rotate(-45deg);
	}

	/* nav_cover */
	#header .nav_cover {
		position: fixed;
		top: 70px;
		right: 0;
		left: 0;
		bottom: 0;
		background-color: rgba(0,0,0,.7);
		opacity: 0;
		pointer-events: none;
		z-index: 998;
	}
	.init #header .nav_cover {
		transition: opacity 0.3s ease-in-out;
	}
	#header.open .nav_cover {
		pointer-events: auto;
		opacity: 1;
	}

	/* nav */
	#header nav {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		max-height: 100vh;
		background-color: #ffea00;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		transform: translateY(-110%);
		pointer-events: none;
		z-index: 999;
	}
	body.init #header nav {
		transition: transform 0.4s ease-in-out;
	}
	/* open */
	#header.open nav {
		transform: translateY(0);
		pointer-events: auto;
	}

	#header nav > div {
		display: flex;
		justify-content: center;
		flex-direction: column;
		padding: 50px 0;
	}
	#header nav > div > * {
		width: 100%;
	}
	#header .nav_logo {
		margin-bottom: 30px;
		text-align: center;
	}
	#header .nav_logo a {
		display: block;
	}
	#header .nav_logo a + a {
		margin-top: 5px;
	}
	#header .gnav a {
		position: relative;
		display: block;
		padding: 12px;
		text-align: center;
		text-decoration: none;
		font-size: 1.8rem;
		line-height: 1.5;
		color: #000;
	}
	#header .gnav .ff_en {
		display: block;
		font-size: 1.3rem;
	}
	#header .consultation {
		height: 170px;
		padding: 20px 5vw;
		background-color: #000;
		color: #fff;
		text-align: center;
		font-weight: 700;
	}
	#header .consultation dt {
		margin-bottom: 15px;
		font-size: 1.6rem;
		line-height: 1.5;
	}
	#header .consultation ul {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	#header .consultation ul li {
		width: calc(50% - 8px);
	}
	#header .consultation ul a {
		display: flex;
		justify-content: center;
		align-items: center;
		height: 40px;
		background-color: #ffea00;
		border-radius: 5px;
		color: #000;
		text-decoration: none;
		font-size: 1.5rem;
		padding-left: 0.1em;
		letter-spacing: 0.1em;
	}
	#header .consultation ul a.line {
		background-color: #20c92f;
		color: #fff;
	}
	#header .consultation p {
		margin-top: 15px;
	}
	#header .consultation p a {
		font-size: 3.4rem;
		line-height: 1;
		color: #fff;
		text-decoration: none;
		letter-spacing: 0.08em;
	}
	#header .consultation p a span {
		font-size: 92%;
	}
}


/* footer
============================================================================================================ */
#footer {
	position: relative;
	text-align: center;
	z-index: 100;
}
#footer .logo {
	padding: 60px 0 40px;
	background-color: #ffea00;
}
#footer .logo .lead {
	position: relative;
	display: inline-block;
	margin-bottom: 25px;
	padding: 0 15px;
	font-size: 2rem;
	line-height: 1.5;
	font-weight: 700;
	letter-spacing: 0.2em;
}
#footer .logo .lead::before,
#footer .logo .lead::after {
	content: "";
	position: absolute;
	top: 50%;
	height: 32px;
	margin-top: -16px;
	border-left: 4px solid #000;
}
#footer .logo .lead::before {
	left: -.2em;
	transform: rotate(-18deg);
}
#footer .logo .lead::after {
	right: 0;
	transform: rotate(18deg);
}
#footer .logo img {
	width: 320px;
}
#footer .logo .produce {
	margin-top: 10px;
}
#footer .logo .produce img {
	width: 308px;
}
@media screen and (min-width: 768px), print {
	#footer .logo .produce a:hover {
		opacity: 0.7;
	}
}
@media screen and (max-width: 767px) {
	#footer .logo {
		padding: 40px 0 30px;
	}
	#footer .logo .lead {
		margin-bottom: 20px;
		padding: 0 15px;
		font-size: 1.6rem;
		letter-spacing: 0.1em;
	}
	#footer .logo .lead::before,
	#footer .logo .lead::after {
		height: 22px;
		margin-top: -11px;
		border-left-width: 3px;
	}
	#footer .logo .lead::before {
		left: -.1em;
	}
	#footer .logo img {
		width: 240px;
	}
	#footer .logo .produce img {
		width: 231px;
	}
}

/* pagetop
------------------------------------------------------------- */
#pagetop {
	position: fixed;
	overflow: hidden;
	bottom: 0;
	right: 0;
	width: 160px;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	padding-right: 20px;
	background-color: #000;
	color: #fff;
	font-size: 1.5rem;
	line-height: 1.2;
	letter-spacing: 0.2em;
	text-decoration: none;
	pointer-events: none;
	opacity: 0;
	z-index: 98;
}
#pagetop::before {
	content: "";
	position: absolute;
	top: 50%;
	right: 16px;
	width: 10px;
	height: 10px;
	margin-top: -5px;
	border-top: 3px solid;
	border-left: 3px solid;
	transform-origin: 0 0;
	transform: rotate(45deg);
	transition: none;
}
.init #pagetop {
	transition: opacity 0.3s, background .2s;
}
#pagetop.show {
	opacity: 1;
	pointer-events: auto;
}
#pagetop.abs {
	position: absolute;
	bottom: 100%;
}
@media print {
	#pagetop {
		display: none;
	}
}
@media screen and (min-width: 768px) {
	#pagetop:hover {
		background-color: #ffea00;
		color: #000;
	}
}
@media screen and (max-width: 767px) {
	#pagetop {
		transform-origin: 100% 100%;
		transform: scale(.85);
	}
}

/* consultation
------------------------------------------------------------- */
#footer .consultation {
	padding: 40px 0 60px;
	background-color: #000;
	color: #fff;
	text-align: center;
	font-weight: 500;
}
#footer .consultation dt {
	margin-bottom: 15px;
	font-size: 2.2rem;
	line-height: 1.5;
	padding-left: 0.1em;
	letter-spacing: 0.1em;
}
#footer .consultation ul {
	display: flex;
	justify-content: center;
	align-items: center;
}
#footer .consultation ul .btn {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 165px;
	height: 50px;
	background-color: #ffea00;
	border: 2px solid #ffea00;
	border-radius: 5px;
	text-decoration: none;
	font-size: 1.6rem;
	padding-left: 0.1em;
	letter-spacing: 0.1em;
}
#footer .consultation ul .btn.line {
	background-color: #10c357;
	border-color: #10c357;
	color: #fff;
}
#footer .consultation ul .tel {
	font-size: 3.6rem;
	line-height: 1;
	color: #fff;
	text-decoration: none;
	letter-spacing: 0.08em;
}
#footer .consultation ul .tel span {
	font-size: 92%;
}
@media screen and (min-width: 768px), print {
	#footer .consultation ul li + li {
		margin-left: 20px;
	}
	#footer .consultation ul .btn:hover {
		background-color: #000;
		color: #ffea00;
	}
	#footer .consultation ul .btn.line:hover {
		color: #10c357;
	}
}
@media screen and (max-width: 767px) {
	#footer .consultation {
		padding: 30px 0;
	}
	#footer .consultation dt {
		font-size: 1.6rem;
	}
	#footer .consultation ul {
		flex-wrap: wrap;
		justify-content: space-between;
	}
	#footer .consultation ul li {
		width: calc(50% - 7px);
	}
	#footer .consultation ul li:last-child {
		width: 100%;
		margin-top: 20px;
	}
	#footer .consultation ul .btn {
		width: 100%;
		height: 40px;
		font-size: 1.5rem;
	}
	#footer .consultation ul .tel {
		font-size: 3.4rem;
	}
}

/* small
------------------------------------------------------------- */
#footer small {
	display: block;
	padding: 20px;
	background-color: #191919;
	font-size: 1.3rem;
	color: #999999;
	text-align: center;
	letter-spacing: 0.05em;
	font-weight: 400;
}
@media screen and (max-width: 767px) {
	#footer small {
		padding: 15px;
		font-size: 1.2rem;
	}
}


/* container
============================================================================================================ */
#container {
	position: relative;
}
#container::before,
#container::after {
	content: "";
	display: table;
	clear: both;
}

/* ===================================================================================================================

	パーツ

=================================================================================================================== */

/* ul / ol
============================================================================================================ */
.dot_li > li {
	position: relative;
	padding-left: 1em;
}
.dot_li > li::before {
	content: "・";
	position: absolute;
	top: 0;
	left: 0;
}

.circle_li > li {
	position: relative;
	padding-left: 1.1em;
}
.circle_li > li::before {
	content: "●";
	position: absolute;
	top: 0;
	left: 0;
	color: #005f8b;
	transform-origin: 0;
	transform: scale(0.8);
}

.parentheses_li > li {
	position: relative;
	padding-left: 2.8em;
}
.parentheses_li > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.parentheses_li_h > li {
	position: relative;
	padding-left: 1.6em;
}
.parentheses_li_h > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}
.parentheses_li_hh > li {
	position: relative;
	padding-left: 2.2em;
}
.parentheses_li_hh > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.point_li > li {
	position: relative;
	padding-left: 1.2em;
}
.point_li > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.square_li > li {
	position: relative;
	padding-left: 0.8em;
}
.square_li > li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .8em;
	width: 5px;
	height: 5px;
	background-color: #14143c;
}
@media screen and (max-width: 767px) {
	.square_li > li::before {
		top: 0.6em;
	}
}

.num_li {
	margin-left: 1.4em;
	list-style: decimal;
}
.alphabet_li {
	margin-left: 1.8em;
	list-style: lower-latin;
}

.mt_li > li + li {
	margin-top: 0.8em;
}
@media screen and (max-width: 767px) {
	.sp_mt_li > li + li {
		margin-top: 0.8em;
	}
}

.inline_li > li {
	display: inline-block;
	margin-right: 0.3em;
}
