@charset "UTF-8";
/* ===================================================================

	Reset CSS

=================================================================== */
@import url(https://fonts.googleapis.com/earlyaccess/roundedmplus1c.css);
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;
}

body {
	line-height: 1;
}

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

nav ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

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

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}
/* change colours to suit your needs */
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

/* change colours to suit your needs */
mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 0;
	padding: 0;
}

input, select {
	vertical-align: middle;
}

/* Custom reset
------------------------------------------------------------------- */
* {
	-webkit-text-size-adjust: 100%;
	box-sizing: border-box;
}

button,
input[type="submit"] {
	cursor: pointer;
	-webkit-appearance: none;
}

button:focus,
input [type="submit"]:focus {
	outline: none;
}

ul {
	list-style: none;
}

ol {
	padding-left: 1.5em;
}

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

/* Font
------------------------------------------------------------------- */
* {
	font-family: "Rounded Mplus 1c","Meiryo", "メイリオ", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Helvetica, sans-serif, "icons";
	text-shadow: 0px 0px 1px rgba(0, 0, 0, 0.1);
}

/* HTML & Body
------------------------------------------------------------------- */
html {
	font-size: 62.5%;
}

body {
	line-height: 2;
	text-align: center;
	color: #333333;
	background: #fff;
}

/* Anchor
------------------------------------------------------------------- */
a:link,
a:visited {
	color: #333333;
	text-decoration: none;
}

a:hover,
a:active {
	color: #666666;
	text-decoration: underline;
}

a:focus {
	outline: none;
}

/* Alpha
------------------------------------------------------------------- */
a:hover,
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover {
	transition: all .5s;
	opacity: 0.6;
}

/* PC・スマホ共通設定
--------------------------------------------------------------------*/

/* header
--------------------------------------------------------------------*/
.site_header {
	background: #fff;
	width: 100%;
}
.site_header .header_body {
	position: relative;
}
.site_header .site_logo {
	font-size: 0;
	line-height: 0;
}
.site_header .header_right {
	display: none;
}
.header_tel li {
	display: table;
	margin-bottom: 5px;
}
.header_tel li span {
	display: table-cell;
	vertical-align: middle;
	background: #b0b0b0;
	color: #fff;
	width: 50px;
	height: 15px;
	font-size: 1rem;
	text-align: center;
	border-radius: 2px;
}
.header_tel li p {
	display: table-cell;
	vertical-align: middle;
	font-weight: bold;
	font-size: 2rem;
	line-height: 1;
	padding-left: 10px;
}
.header_tel li:last-of-type {
	margin: 0;
}
.contact_info .info_tel {
	font-size: 0;
	line-height: 0;
}

/* スマホ対応 */
.drawer-open .drawer-overlay {
	z-index: 5;
	width: 100% !important;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}
.drawer-open .drawer-nav {
	z-index: 6;
	width: 100% !important;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}
.drawer-open .drawer-hamburger {
	padding: 13px 10px 7px !important;
	width: 30px;
	height: 30px;
	top: 0;
	right: 0 !important;
	z-index: 7;
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}
.drawer-open .drawer-hamburger-icon {
	background-color: transparent !important;
}
.drawer-open .drawer-hamburger-icon:before, .drawer-open .drawer-hamburger-icon:after {
	background-color: #fff !important;
}
.drawer-open .drawer-hamburger-label {
	display: none !important;
}

.drawer-nav {
	background: #058ee5;
}
.sp_nav {
	padding-bottom: 63px;
	text-align: left;
	background: #fff;
}
.sp_nav .nav_ttl {
	padding: 0 15px;
	line-height: 50px;
	color: #fff;
	background: #262261;
	height: 50px;
}
.sp_nav .nav_item {
	border-bottom: solid 1px #ddd;
}
.sp_nav .nav_item a {
	position: relative;
	display: block;
}
.sp_nav .nav_item a:hover {
	text-decoration: none !important;
}
.sp_nav .nav_main a {
	padding: .9em 15px;
}
.sp_nav .nav_main img {
	width: 16px;
	margin-right: 3px;
	vertical-align: -3px;
}
.sp_nav .nav_sub {
	border-top: solid 1px #ddd;
	overflow: hidden;
}
.sp_nav .nav_sub .nav_item {
	width: 50%;
	float: left;
}
.sp_nav .nav_sub .nav_item:nth-child(2n+1){
	border-right: solid 1px #ddd;
}
.sp_nav .nav_sub a {
	padding: .7em 15px;
	font-size: 1.3rem;
}
.nav_company_info {
	padding: 15px 20px;
	background: #f5f3ee;
	text-align: center;
}
.nav_company_info .info_ttl {
	color: #262261;
	font-size: 1.8rem;
}
.nav_company_info .nav_company_info_item {
	border-bottom: dotted 1px #ddd;
	box-sizing: border-box;
	font-size: 1.4rem;
	padding: 15px 10px;
}
.nav_company_info .nav_company_info_item .nav_company_name {
	font-size: 1.9rem;
	line-height: 1.2;
}
.nav_company_info .nav_company_info_item .nav_company_name2 {
	font-size: 1.7rem;
	line-height: 1.3;
}
.nav_company_info .nav_company_info_item .nav_info_tel {
	margin-top: 10px;
	color: #262261;
	font-weight: bold;
	font-size: 2.1rem;
	line-height: 1;
}
.nav_company_info .nav_company_info_item .nav_info_tel img {
	width: 20px;
	margin-right: 5px;
	vertical-align: -2px;
}
.nav_company_info .nav_company_info_item .nav_info_mail {
	margin: 12px 0 0 0;
}
.nav_company_info .nav_company_info_item .nav_info_mail a {
	font-size: 1.6rem;
}
.nav_company_info .nav_company_info_item .nav_info_mail img {
	width: 19px;
	margin-right: 4px;
	vertical-align: -4px;
}
.nav_company_info .nav_company_info_item .nav_info_mail .btn_more {
	width: 100%;
}
.nav_company_info .nav_company_info_item .nav_info_tel2 {
	margin: 12px 0 0 0;
}
.nav_company_info .nav_company_info_item .nav_info_tel2 a {
	font-size: 1.6rem;
}
.nav_company_info .nav_company_info_item .nav_info_tel2 img {
	width: 16px;
	margin-right: 5px;
	vertical-align: -2px;
}
.nav_company_info .nav_company_info_item .nav_info_tel2 .btn_more {
	width: 100%;
}
.nav_company_info .nav_company_info_item:last-of-type {
	border: 0;
}

/* nav
--------------------------------------------------------------------*/
.global_nav {
	display: none;
}
.global_nav .nav_set {
	margin-left: auto;
	margin-right: auto;
	width: 960px;
	overflow: hidden;
}
.global_nav .nav_item {
	width: 182px;
	height: 75px;
	display: table;
	float: left;
}
.global_nav .nav_item a {
	line-height: 30px;
	vertical-align: middle;
	width: 100%;
	display: table-cell;
	border-bottom: 2px solid #262261;
	line-height: 1.6;
}
.global_nav .nav_item a:hover {
	text-decoration: none;
	color: #058ee5;
	border-color: #83cfff;
}
.global_nav .nav_item a.current {
	text-decoration: none;
	color: #058ee5;
	border-color: #83cfff;
	background-size: 4px;
}
.global_nav .nav_item a p {
	border-right: solid 1px #ddd;
	font-size: 1.6rem;
	font-weight: 500;
}
.global_nav .nav_item a p span {
	display: block;
	color: #1696e7;
	font-size: 1rem;
	font-weight: bold;
}
.global_nav .nav_personal a > p {
	border-left: solid 1px #ddd;
}
.global_nav .nav_gifu {
	width: 232px;
}

/* footer
--------------------------------------------------------------------*/
.site_footer {
	background: #f5f3ee;
	font-size: 1.2rem;
}
.site_footer .pagetop a {
	display: block;
}
.footer_info .h2_sub_ttl {
	color: #058ee5;
	line-height: 1;
}
.company_info_left .info_tel {
	color: #262261;
}
.company_info_right .info_mail a {
	font-size: 1.6rem;
}
.company_info_right .info_mail .btn_more {
	width: 100%;
}
.footer_mid {
	background: #fff;
}
.footer_mid .footer_logo {
	font-size: 0;
	line-height: 0;
}
.footer_nav {
	border-top: solid 2px #262261;
}
.footer_nav .nav_set {
	overflow: hidden;
}
.footer_btm {
	background: #262261;
}
.footer_sub_nav .nav_set {
	overflow: hidden;
}
.footer_sub_nav .nav_item {
	display: inline-block;
}
.footer_sub_nav .nav_item:first-child {
	margin-left: 0;
}
.footer_sub_nav .nav_item a {
	color: #fff;
}

/* Button
------------------------------------------------------------------- */
.btn {
	margin: auto;
	line-height: 1;
	text-align: center;
	text-decoration: none !important;
	border-radius: 5px;
	border: none;
	display: inline-block;
	cursor: pointer;
	outline: none;
	position: relative;
	transition: all .5s;
}
/* Default */
.btn_default {
	color: #fff !important;
	background: #bbc3b1;
}
/* main */
.btn_main {
	color: #fff !important;
	background: #262261;
}
/* Sub */
.btn_sub {
	color: #fff !important;
	background: #b5bec3;
}
/* Button Size */
.btn_xs {
	padding: 1px 5px;
	font-size: 1.1rem;
}
.btn_sm {
	padding: 5px 2em;
	font-size: 1.3rem;
}
.btn_md {
	padding: 18px 3em 15px;
	font-size: 1.4rem;
}
.btn_lg {
	padding: 22px 2em 18px;
	font-size: 1.8rem;
}
.btn_block {
	width: 100%;
	display: block;
}


/* スマホレスポンシブ
--------------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	body {
		font-size: 1.5rem;
		min-width: 320px;
	}
	a:hover,
	a:active {
		text-decoration: none;
	}
	.sm_none {
		display: none;
	}
/* スマホヘッダー */
	.site_header .header_body {
		padding: 10px 0 10px;
	}
	.site_header .site_logo {
		margin: 0 auto;
	}
	.site_header .site_logo img {
		max-width: 60%;
	}
	.contact_info {
		margin-top: 25px;
		padding-top: 25px;
		border-top: solid 1px #ddd;
	}
	.contact_info .info_tel {
		margin: auto;
		max-width: 240px;
	}
	.contact_info .info_mail {
		display: none;
	}

/* スマホナビ */
	.drawer-hamburger {
		padding: 6px 5px 8px 5px;
		text-align: left;
		color: #262261;
		width: 35px;
		position: absolute;
		top: 40px;
		right: 20px !important;
	}
	.drawer-hamburger .drawer-hamburger-icon {
		background-color: #262261;
		height: 3px;
		width: 30px;
	}
	.drawer-hamburger .drawer-hamburger-icon:before, .drawer-hamburger .drawer-hamburger-icon:after {
		background-color: #262261;
		height: 3px;
		width: 30px;
	}
	.drawer-hamburger .drawer-hamburger-label {
		margin-top: 20px;
		font-size: 1.1rem;
		font-weight: bold;
		line-height: 1;
		display: block;
	}

/* スマホフッター */
	.site_footer {
		margin-top: 50px;
		padding-bottom: 52px;
	}
	.site_footer .pagetop a {
		padding: 5px;
		font-size: 3rem;
		line-height: 1;
		color: #fff;
		background: #262261;
	}
	.site_footer .pagetop a img {
		width: 35px;
		transform: rotate(-90deg);
	}
	.site_footer .footer_inner {
		padding: 0 15px;
	}
	.footer_info {
		padding: 30px 15px;
	}
	.footer_info h2 {
		font-size: 2rem;
	}
	.footer_info .h2_sub_ttl {
		font-size: 1.4rem;
	}
	.footer_info .company_info {
		margin-top: 15px;
	}
	.footer_info .company_info_left, .footer_info .company_info_right {
		border-top: solid 1px #ddd;
		box-sizing: border-box;
		font-size: 1.4rem;
		padding: 15px 10px;
	}
	.footer_info .company_info img {
		width: 20px;
		margin-right: 5px;
	}
	.footer_info .compnay_info .name_tel, .footer_info .company_info .name {
		margin-top: 15px;
		line-height: 1;
		font-size: 1.8rem;
	}
	.company_info_left .info_tel {
		font-size: 2.3rem;
		line-height: 1.3;
		font-weight: bold;
	}
	.company_info_right .info_mail {
		margin: 15px 0;
	}
	.company_info_right .info_mail img {
		vertical-align: -4px;
	}
	.footer_mid .footer_logo img {
		margin: 15px auto;
		max-width: 80%;
	}
	.footer_nav {
		border-bottom: solid 1px #ddd;
	}
	.footer_nav .nav_set {
		margin-bottom: -1px;
		border-top: solid 1px #ddd;
		max-width: none;
		align-items: stretch;
		display: flex;
		flex-wrap: wrap;
	}
	.footer_nav .nav_item {
		border-bottom: solid 1px #ddd;
		border-right: solid 1px #ddd;
		flex: 0 0 50%;
	}
	.footer_nav .nav_item:nth-child(2n) {
		border-right: 0;
	}
	.footer_nav .nav_item a, .footer_nav .moi a {
		padding: 1em 10px 1em 15px;
		font-size: 1.3rem;
		text-align: left;
		height: 70px;
		display: flex;
		align-items: center;
		line-height: 1.3;
	}
	.footer_nav .nav_item img, .footer_nav .moi img {
		width: 14px;
		margin-right: 5px;
	}
	.footer_nav .moi .moi_logo {
		width: 100px;
	}
	.footer_btm {
		padding: 15px 0 30px 0;
	}
	.footer_btm .footer_inner {
		padding: 0 15px;
	}
	.footer_sub_nav .nav_item {
		margin-left: 0.55em;
	}
	.footer_sub_nav .nav_item a {
		padding: 0.5em 0;
		display: inline-block;
	}
	.copy {
		color: #fff;
		display: block;
	}

	.nav_contact {
		background: #fff;
		box-shadow: 0 0 5px 3px raba(0,0,0,0.1);
		min-width: 320px;
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 500;
	}
	.nav_contact .nav_set {
		width: 100%;
		display: table;
		table-layout: fixed;
	}
	.nav_contact .nav_item {
		border-left: solid 1px #fff;
		display: table-cell;
	}
	.nav_contact .nav_item a {
		padding: 8px 0;
		font-size: 1.2rem;
		line-height: 1;
		text-align: center;
		vertical-align: middle;
		color: #fff;
		background: #262261;
		display: block;
	}
	.nav_contact .nav_item img {
		width: 35px;
		margin-right: 8px;
		vertical-align: -12px;
	}
	.nav_contact .nav_item:first-child {
		border-left: none;
	}

}

/* PCレスポンシブ
--------------------------------------------------------------------*/
@media screen and (min-width: 600px), print {
	body {
		font-size: 1.5rem;
		width: 100%;
		min-width: 960px;
	}
	.pc-none {
		display: none;
	}
/* PCヘッダー */
	.site_header .header_body {
		padding: 0;
		border-bottom: none;
		margin-left: auto;
		margin-right: auto;
		width: 960px;
		overflow: hidden;
	}
	.site_header .site_logo {
		margin-top: 30px;
		width: 330px;
		float: left;
		overflow: hidden;
	}
	.site_header .site_logo img {
		width: 300px;
	}
	.site_header .header_right {
		margin-top: 50px;
		text-align: right;
		float: right;
		display: table;
	}
	.site_header .header_right .contact_info {
		margin-top: 25px;
	}
	.sub_nav {
		display: table-cell;
		vertical-align: middle;
		padding-right: 30px;
	}
	.sub_nav .nav_set {
		font-size: 0;
		line-height: 0;
		text-align: right;
		overflow: hidden;
	}
	.sub_nav .nav_set .nav_item {
		margin-left: 1em;
		font-size: 1.2rem;
		line-height: 1.5;
		display: inline-block;
	}
	.sub_nav .nav_set .nav_item:first-child {
		margin-left: 0;
	}
	.header_tel {
		display: table-cell;
		vertical-align: middle;
	}
	.header_tel li span {
		font-size: 1.5rem;
		line-height: 1.5;
	}
	.contact_info {
		margin-bottom: 5px;
		padding-top: 0;
		border-top: none;
		display: table-cell;
		vertical-align: middle;
	}
	.contact_info .info_tel {
		margin: 0;
		width: 187px;
		display: table-cell;
	}
	.contact_info .info_mail {
		padding-left: 20px;
		vertical-align: top;
		display: table-cell;
	}
	.contact_info .info_mail img {
		width: 18px;
		vertical-align: -4px;
		margin-right: 5px;
	}
	.contact_info .info_mail .btn_main {
		padding: 15px 0 14px;
		width: 150px;
	}
	.drawer-hamburger {
		display: none !important;
	}

/* PCナビ */
	.global_nav {
		margin-top: 20px;
		display: block;
	}
	.global_nav .nav_gifu {
		background-image: url(../images/gifu.png);
		background-size: contain;
		background-repeat: no-repeat;
		background-position: center;
		pointer-events: none;
	}
/* PCフッター */
	.site_footer {
		margin-top: 120px;
	}
	.site_footer .pagetop a {
		position: fixed;
		bottom: 0;
		right: 5px;
		z-index: 500;
	}
	.site_footer .pagetop a img {
		width: 50px;
		transform: rotate(-90deg);
	}
	.site_footer .footer_inner {
		margin-left: auto;
		margin-right: auto;
		width: 960px;
	}
	.footer_info {
		padding: 70px 0;
		margin-left: auto;
		margin-right: auto;
		width: 960px;
		overflow: hidden;
	}
	.footer_info h2 {
		font-size: 2.8rem;
	}
	.footer_info .h2_sub_ttl {
		font-size: 1.6rem;
	}
	.footer_info .company_info {
		margin: 60px 0 0 0;
		text-align: center;
		overflow: hidden;
		border-right: solid 1px #ddd;
		box-sizing: border-box;
	}
	.company_info_left {
		width: 638px;
		float: left;
		border-left: solid 1px #ddd;
		box-sizing: border-box;
		font-size: 1.4rem;
		padding: 0 28px;
	}
	.company_info_tel {
		float: left;
	}
	.company_info_tel .info_tel, .company_info_fax .info_tel  {
		font-weight: bold;
	}
	.company_info_tel .info_tel img, .company_info_fax .info_tel img {
		width: 30px;
		margin-right: 5px;
	}
	.company_info_fax {
		float: right;
	}
	.company_info_add {
		clear: both;
	}
	.company_info_right {
		width: 319px;
		float: left;
		border-left: solid 1px #ddd;
		box-sizing: border-box;
		font-size: 1.4rem;
		padding: 0 28px;
	}
	.company_info .name_tel {
		font-size: 2.5rem;
		line-height: 1;
		font-weight: bold;
	}
	.company_info .name {
		font-size: 1.9rem;
		line-height: 1.3;
	}
	.company_info_left .info_tel {
		font-size: 3.1rem;
		line-height: 1.3;
		margin: 10px 0;
	}
	.company_info_right .info_mail {
		font-size: 2.8rem;
		line-height: 1.3;
		margin: 15px 0;
	}
	.company_info_right .info_mail img {
		width: 20px;
		vertical-align: -4px;
		margin-right: 5px;
	}
	.footer_mid {
		padding-bottom: 35px;
	}
	.footer_nav {
		margin-left: auto;
		margin-right: auto;
		width: 960px;
	}
	.footer_mid .footer_logo {
		margin-right: 35px;
		margin-top: 50px;
		max-width: 334px;
		float: left;
	}
	.footer_mid .footer_logo img {
		width: 310px;
	}
	.footer_nav .nav_set {
		font-size: 0;
		line-height: 0;
		padding: 25px 0 0 80px;
	}
	.footer_nav .nav_item {
		text-align: left;
		margin-top: 1em;
		font-size: 1.4rem;
		line-height: 1.4;
		display: inline-block;
		float: left;
		width: 160px;
	}
	.footer_nav .nav_item img, .moi_arrow {
		width: 18px;
		padding-right: 5px;
		vertical-align: -3px;
	}
	.footer_nav .moi {
		text-align: left;
		margin-top: 15px;
		display: inline-block;
		float: left;
		width: 150px;
	}
	.footer_nav .moi_logo {
		width: 100px;
		padding-left: 5px;
		vertical-align: -18px;
	}
	.footer_nav .nav_item:nth-child(3n+2) {
		width: 130px;
	}
	.footer_nav .nav_item:nth-child(3n) {
		width: 230px;
	}
	.footer_btm {
		font-size: 1.1rem;
		padding: 25px 0 15px;
	}
	.footer_btm .footer_inner {
		margin-left: auto;
		margin-right: auto;
		width: 960px;
		overflow: hidden;
	}
	.footer_btm .btm_left {
		float: left;
		text-align: left;
		color: #fff;
		margin-top: 10px;
	}
	.footer_sub_nav .nav_item {
		margin-left: 2em;
	}
	.copy {
		display: block;
		margin-top: 5px;
	}
/* PC共通項目など */
	.nav_contact {
		display: none;
	}
	.md_none {
		display: none;
	}
	.btn_more {
		width: 300px;
	}
	.home_ttl {
		font-size: 3.4rem;
		line-height: 1.6;
	}


}
/*------------------------------------------------------------------*/
