@charset "utf-8";
/* Author: Hosaka */
/* ---------------------------------------------------
	common
------------------------------------------------------ */
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, 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, a { margin: 0; padding: 0; border: 0; outline: 0; vertical-align: baseline; -webkit-box-sizing: border-box; box-sizing: border-box;}
ol, ul { list-style: none; }
i, cite, em, var, address, dfn {font-style: normal;}

body {font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; font-display: swap; font-size: 100%;}

.acms-container {max-width: 100%; padding-left: 0; padding-right: 0;}
.acms-container #adminBox {margin-bottom: 0;}
.slick-dots li.slick-active button {background: none;}

#wrapper {width: 100%; margin: 0 auto; overflow: hidden; position: relative;}

.container {width: 100%; max-width: 1200px; margin: 0 auto;}
.container:after {content: ""; clear: both; display: block;}

a {-webkit-transition: all ease 0.2s; -moz-transition: all ease 0.2s; -o-transition: all ease 0.2s; transition: all ease 0.2s; box-sizing: border-box;}
a:link, a:visited {color: #222; text-decoration: none;}
a:hover, a:visited {color: #222; text-decoration: none;}
a:hover {opacity: .7;}
.entry-column a:visited {color: #222;}
a[href^="tel:"] {pointer-events: none;text-decoration: none;}

img {max-width: 100%; height: auto; line-height: 1; vertical-align: bottom;}
img.max {width: 100%;}

p {line-height: 1.8; margin: 0;}

.flexbox {display: -ms-flexbox; display: -webkit-box; display: flex; flex-wrap: wrap; align-items: top; justify-content: space-between;}
.flexbox.mid {align-items: center;}
.flexbox.center {justify-content: center;}
.flexbox.reverse {flex-direction: row-reverse;}

.flL {float: left;}
.flR {float: right;}

.taL {text-align: left;}
.taC {text-align: center;}
.taR {text-align: right;}

.rel {position: relative;}

.mincho {font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;}
.gothic {font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;}

.w20 {width: 20%;}
.w30 {width: 30%;}
.w70 {width: 70%;}
.w80 {width: 80%;}
.w1200 {max-width: 1200px;}

.txt-lll {font-size: 1.375em;}
.txt-ll {font-size: 1.25em;}
.txt-l {font-size: 1.125em;}
.txt-s {font-size: 0.875em;}
.txt-ss {font-size: 0.75em;}
.txt-sss {font-size: 0.625em;}

.tcol-red {color: #E50012;}
.tcol-red-bold {color: #E50012 !important; font-weight: bold;}
.tcol-blue {color: #00F;}

.pc-only {display: block;}
.sp-only {display: none;}
.pc-block {display: block;}
.sp-block {display: none;}
.pc-inline {display: inline;}
.sp-inline {display: none;}


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

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

/* IE用対応 */
/*
_:-ms-fullscreen . {}
*/

@media screen and (max-width: 767px) {
/*背景固定する場合	html.is-fixed,
	html.is-fixed body {height: 100%;overflow: hidden;}*/
	body {/*zoom:.3; */overflow-x: hidden;}
	a:hover img {opacity: 1;}
	a[href^="tel:"] {pointer-events: auto;}
	.container {max-width: 100%;}
	p {line-height: 1.4;}
	.w1200 {width: auto;}
	.pc-only {display: none !important;}
	.sp-only {display: block;}
	.pc-block {display: none !important;}
	.sp-block {display: block;}
	.pc-inline {display: none !important;}
	.sp-inline {display: inline;}
	.pc-hidden {display: block;}
}
/* スマホ横の対応 */
@media screen and (orientation: landscape) {
}

/* ---------------------------------------------------
	bg-change
------------------------------------------------------ */
/*.bg-change01 { background-color: #FFF;}
.bg-change02 { background-color: #000;}
.bg-change03 { background-color: #00F;}*/

/* ---------------------------------------------------
	font-size-change
------------------------------------------------------ */
/*.is-fs-m {font-size: 120%;}
.is-fs-l {font-size: 140%;}*/

/* ---------------------------------------------------
	header
------------------------------------------------------ */
header{background: #FFF; padding-top: 66px; padding-bottom: 10px;}
header .header-content{width:100%; max-width: 1200px; margin: auto;}
header .header-content .up-menu{display: flex; justify-content: space-between; margin-bottom: 66px;}
header .header-content .up-menu h1.logo{width: 35.33%; max-width: 424px;}
header .header-content .up-menu h1.logo a:hover,header .header-content .up-menu h1.logo a:hover img{opacity: 1;}
header .header-content .up-menu .company-info{text-align: right; color: #1E295E;}
header .header-content .up-menu .company-info .tel{font-size: 1.75em; font-weight: bold; letter-spacing: 0.02em; line-height: 1.8;}
header .header-content .up-menu .company-info .tel span{font-weight: bold;}
header .header-content .up-menu .company-info .open-close{font-size: 0.875em; letter-spacing: 0.03em; line-height: 1.28; font-weight: bold;}
header .header-content .up-menu .company-info .mail{font-size: 0.9375; letter-spacing: 0.03em; line-height: 1.2; margin-top: 6px;}
header .header-content .up-menu .company-info .mail a{border: 1px solid #1E295E; border-radius: 3px; display: inline-block; padding: 3px 5px; color: #1E295E;}
header .header-content .up-menu .company-info .mail a::before{content: ""; display: inline-block; width: 16px; height: 10px; vertical-align: middle; margin-right: 6px; background: url("../images/mail_icon.png") no-repeat center/contain;}
header nav ul {display: flex; justify-content: space-between; width:78%; margin: auto;}
header nav ul li a{font-size: 1em; letter-spacing: 0.1em; line-height: 1.2; font-weight: bold; text-decoration: none; color: 000;}

@media screen and (max-width: 767px) {
	header{background: #FFF; padding-top: 10px; padding-bottom: 10px;}
	header .header-content{width:100%; max-width: 100%; height: 40px; margin: auto; position: relative;}
	header .header-content .up-menu{display: block; margin-bottom: 0;}
	header .header-content .up-menu h1.logo{width: 45.334%; max-width: 340px; margin-left: 10px;}
	header .header-content .up-menu h1.logo a:hover,header .header-content .up-menu h1.logo a:hover img{opacity: 1;}
	header .header-content .up-menu .company-info{display: none;}
	header nav ul {display: flex; justify-content: space-between; width:78%; margin: auto;}
	header nav ul li a{font-size: 1em; letter-spacing: 0.1em; line-height: 1.2; font-weight: bold; text-decoration: none; color: 000;}
}


.hollowed-btn a{border: solid 1px #FFF; border-radius:10px; color: #FFF; text-align: center; font-size: 1.25em; letter-spacing: 0.06em; line-height: 1.2; padding: 16px 0; text-decoration: none; display: inline-block;}

.blue-btn{padding: 22px;}
.blue-btn a{display: inline-block; background: #1F2586; color: #FFF; text-align: center; font-size: 1.25em; letter-spacing: 0.06em; line-height: 1.2; font-weight: bold; padding: 22px 40px; text-decoration: none; border-radius: 10px; position: relative;}
.blue-btn a::after{content: ""; display: inline-block; border-left: 16px solid #FFF; border-top:9px solid transparent; border-bottom: 9px solid transparent; margin-left: 6px; vertical-align: middle;}

@media screen and (max-width: 767px) {
	.blue-btn{padding: 20px;}
	.blue-btn a{font-size: 14px; letter-spacing: 0.04em; padding: 10px 45px 10px 30px; border-radius: 10px;}
	.blue-btn a::after{content: ""; display: inline-block; border-left: 12px solid #FFF; border-top:7px solid transparent; border-bottom: 7px solid transparent; margin-left: 6px; vertical-align: middle; position: absolute; top: 50%; right: 20px; transform: translateY(-50%);}
}

/* ---------------------------------------------------
	gnavi
------------------------------------------------------ */
.gnavi {}
.gnavi > ul {display: flex; justify-content: space-between; align-items: center; flex-wrap: nowrap; margin: 0; list-style: none; padding: 0;}
.gnavi > ul > li {margin: 0; padding: 0; list-style: none; color: #000; font-size: 16px; font-weight: bold; letter-spacing: 0.1em; white-space: nowrap; position: relative;}
.gnavi > ul > li:first-child {padding: 0 30px;}
.gnavi > ul > li > a {color: #000; font-size: 16px; font-weight: bold; white-space: nowrap; padding-bottom: 50px; position: relative; display: inline-block;}
.gnavi > ul > li:first-child > a::before {content: "▶"; display: inline-block;}
.gnavi > ul > li:first-child > a:hover::before {content: "▼"; display: inline-block;}
.gnavi > ul > li > a:hover {opacity: 1; color: #262A83;}
.gnavi > ul > li > a:hover::after {content: ""; display: block; position: absolute; width: 17px; height: 14px; background: url("../images/common/gnavi-arrow.png") no-repeat center center/contain; top: 1.5em;  left: 50%; transform: translateX(-50%);}

.gnavi > ul > li > ul {display: none; border-top: 6px solid #1F2586; background: #FFF; padding: 40px; position: absolute; top: 50px; text-align: center; box-shadow: 0 8px 10px 10px rgba(0,0,0,0.1); z-index: 9000;}
.gnavi > ul > li > ul.active {display: block;}
.gnavi > ul > li > ul > li {margin-bottom: 30px;}
.gnavi > ul > li > ul > li:last-child {margin-bottom: 0;}
.gnavi > ul > li > ul > li > a {text-decoration: none; color: #000; font-size: 16px; font-weight: bold; white-space: nowrap; padding: 0 10px;}
.gnavi > ul > li > ul > li > a:hover {text-decoration: underline; color: #1F2586;}

@media screen and (max-width: 767px) {
	.gnavi {display: none; width: 100vw; height: 100vh; background: rgba(255,254,255,0.95); position: fixed; top: 0; left: 0; z-index: 4000;}
	.gnavi > ul {display: block; padding: 80px 0 0 0; width: 100%;}
	.gnavi > ul > li {margin-right: 0; margin-left: 0;  padding: 0; border-bottom: 1px dotted #FFF;}
	.gnavi > ul > li > a {display: block; width: 100%; padding: 20px 0; text-align: center;}
	.gnavi > ul > li:first-child > a::before {content: "▼"; display: inline-block;}
	.gnavi > ul > li:first-child > a:hover::before {content: "▼"; display: inline-block;}
	.gnavi > ul > li > a:hover::after {content: ""; display: none;}
	
	.gnavi > ul > li > ul {display: block; border-top: none; background: #FFF; padding: 0; position: relative; top: 0; text-align: center; box-shadow: none; z-index: 9000;}
	.gnavi > ul > li > ul.active {display: block;}
	.gnavi > ul > li > ul > li {margin-bottom: 0;}
	.gnavi > ul > li > ul > li:last-child {margin-bottom: 0;}
	.gnavi > ul > li > ul > li > a {text-decoration: none; color: #000; font-size: 16px; font-weight: bold; white-space: nowrap; padding: 20px 0; display: block;}
	.gnavi > ul > li > ul > li > a:hover {text-decoration: underline; color: #1F2586;}
}


/* ---------------------------------------------------
	btn_menu
------------------------------------------------------ */

.btn_menu {display: none;}

@media screen and (max-width: 767px) {
.btn_menu {display: block; position: fixed; right: 10px; top: 10px; width: 40px; height: 40px; padding: 8px; cursor: pointer; text-align: center; z-index: 9999;}
.btn_menu .menu-trigger {display: inline-block; position: relative; width: 25px; height: 16px; box-sizing: border-box; transition: all .4s;}
.btn_menu .menu-trigger span {display: inline-block; transition: all .4s; box-sizing: border-box; position: absolute; left: 0; width: 100%; height: 2px; background-color: #000;}
.btn_menu .menu-trigger span:nth-of-type(1) {top: 0;}
.btn_menu .menu-trigger.active span:nth-of-type(1) {top: -3px;}
.btn_menu .menu-trigger span:nth-of-type(2) {top: 7px;}
.btn_menu .menu-trigger span:nth-of-type(3) {bottom: 0;}
.btn_menu .menu-trigger.active {-webkit-transform: rotate(180deg); transform: rotate(180deg);}
.btn_menu .menu-trigger.active span {}
.btn_menu .menu-trigger.active span:nth-of-type(1) {-webkit-transform: translateY(10px) rotate(-35deg); transform: translateY(10px) rotate(-35deg);}
.btn_menu .menu-trigger.active span:nth-of-type(2) {-webkit-transform: translateY(0) rotate(35deg); transform: translateY(0) rotate(35deg);}
.btn_menu .menu-trigger.active span:nth-of-type(3) {opacity: 0;}
.btn_menu .txt {color: #FFF; font-size: 12px; font-family: Arial, Helvetica, "sans-serif"; font-weight: bold; margin-top: 4px;}
}

/* ---------------------------------------------------
	h-container
------------------------------------------------------ */
/*.h-container {display: none; position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; background-color: #002BA2; z-index: 1500;}
.menu-box {width: 100%; width: 1200px; margin: 37vh auto 0;}
.menu-box ul {display: flex; justify-content: center; text-align: center; margin-bottom: 13vh;}
.menu-box ul li {position: relative; color: #FFF;}
.menu-box ul li:before {content: "/"; display: inline-block;}
.menu-box ul li:first-child:before {content: ""; display: none;}
.menu-box ul li a {display: inline-block; color: #FFF; padding: 0 25px;}

.menu-contact {width: 50%; max-width: 600px; margin: 0 auto;}
.menu-contact table {width: 100%; border-top: 1px solid #FFF; border-left: 1px solid #FFF;}
.menu-contact table td { border-right: 1px solid #FFF; border-bottom: 1px solid #FFF; vertical-align: middle; text-align: center; padding: 20px 0;}
.menu-contact .f-tit { color: #FFF; font-weight: bold; padding: 10px 0;}
.menu-contact .f-tel {margin: 0px 50px;}
.menu-contact .f-tel a {display: block; color: #FFF; font-size: 2em; position: relative; padding-left: 26px; font-family: Arial, Helvetica, "sans-serif";}
.menu-contact .f-tel a:before {content: ""; display: block; position: absolute; top: 50%; left: 0; margin-top: -15px; width: 23px; height: 30px; background: url(../images/header/ico-header-tel2@2x.png) no-repeat top center; background-size: cover;}
.menu-contact .f-mail {margin: 0px 20px;}
.menu-contact .f-mail a {display: flex; justify-content: center; align-items: center; background-color: #E2E911; color: #002BA2; font-size: 1.111em; font-weight: bold; text-align: center; width: 200px; height: 80px; position: relative;}
.menu-contact .f-mail a:before {content: ""; display: block; width: 20px; height: 15px; background: url(../images/header/ico-header-mail@2x.png) no-repeat top center; background-size: cover; margin-right: 10px;}

@media screen and (max-width: 767px) {
.h-container {}
.menu-box {width: 100%; width: 100%; margin: 120px auto 0;}
.menu-box ul {display: block; margin-bottom: 40px;}
.menu-box ul li {border-bottom: 1px solid #FFF;}
.menu-box ul li:before {content: ""; display: none;}
.menu-box ul li a {display: inline-block; color: #FFF; padding: 20px 0;}

.menu-contact {display: none;}
}*/

/* ---------------------------------------------------
	side-contact
------------------------------------------------------ */

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

/* ---------------------------------------------------
	下層ページタイトル
------------------------------------------------------ */
/* .pagetit {width: 100%; height: 190px; position: relative; background: #FFF; text-align: center; box-shadow: 0 5px 8px rgba(0,0,0,0.15);} */
.pagetit {width: 100%; position: relative; background: #FFF; text-align: center;}
.pagetit .page-title {margin: 0 auto; font-size: 40px; font-weight: bold; line-height: 1.5; color: #000; letter-spacing: 0.05em; padding-top: 60px;}
.pagetit .page-title-company {display: flex; justify-content: center; align-items: center; width: 100%; background: no-repeat top center/cover; height: 280px;}

@media screen and (max-width: 767px) {
	.pagetit {width: 100%; max-width: 100%;}
	.pagetit .page-title {font-size: 20px; padding-top: 30px;}
	.pagetit .page-title-company {height: 140px; font-size: 18px;}
}

/* ---------------------------------------------------
	パンくず
------------------------------------------------------ */
.topicpath { background: none; width: 100%; text-align: center; padding: 15px 0; margin-bottom: 0;}
.topicpath .acms-container {max-width: 1200px;}
.topicpath-list { width: 100%; padding: 0; text-align: left;}
.topicpath-item { float: none; display: inline-block; background: none; padding: 0; font-size: 15px; line-height: 1.2; font-weight: 200; }
.topicpath-item a {display: inline;}
.topicpath-item:first-child { padding: 0;}
.topicpath-item:before { display: inline-block; content: "/"; padding: 0 10px;}
.topicpath-item:first-child:before { display: inline-block; content: ""; padding: 0;}
.topicpath-link { font-size: 15px; font-weight: 200;}

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

/* ---------------------------------------------------
	pager
------------------------------------------------------ */
.pager {display: -ms-flexbox; display: -webkit-box; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; margin: 0 0 50px;}
.pager li,
.pager li > span, 
.pager li a {display: -ms-flexbox; display: -webkit-box; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center;}
.pager li {width: 50px; height: 50px; border: 1px solid #000; border-radius: 0; font-size: 20px; background: #FFF;}
.pager li.prev, .pager li.next {border: none; border-radius: 0; background: none;}
.pager li.cur {background: #1E295E; color: #FFF; border-radius: 0;}
.pager li > span {width: 100%; height: 100%;}
.pager li a {width: 100%; height: 100%; color: #000; text-decoration: none;}
.pager-link {background: #FFF; padding: 10px;}
.pager-link:active, .pager-link:focus, .pager-link:visited { color: #000;}
.pager-link:hover {background: #1E295E; color: #FFF; border-radius: 0; opacity: 1; }
.pager li.prev .pager-link, .pager li.next .pager-link,
.pager li.prev .pager-link:hover, .pager li.next .pager-link:hover {background: none; color: #000; }

.serial-nav {width: 100%; max-width: 1200px; margin: 0 auto 50px;}
.serial-nav a {display: block; padding: 15px 30px; color: #000; font-weight: bold;}
.serial-nav a:active, .serial-nav a:focus, .serial-nav a:hover, .serial-nav a:visited {color: #000;}
.serial-nav a:hover {text-decoration: none;}
.serial-nav-item a { border: 1px solid #000;}

@media screen and (max-width: 767px) {
.pager {margin: 0 0 25px;}
.pager li {margin-bottom: 10px;}
.serial-nav { display: flex; justify-content: space-between; padding: 0 10px;}
.serial-nav .serial-nav-item { width: 48%;}
}

/* ---------------------------------------------------
	子ブログindex
------------------------------------------------------ */

.koblog {width: 100%; max-width: 1200px; margin: 0 auto; padding: 50px 0; }
.koblog .koblog-card-wrap { display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-top: 30px; }
.koblog .koblog-card { width: 22.5%; margin-right: 3.33%; margin-bottom: 40px;}
.koblog .koblog-card:nth-child(4n) { margin-right: 0; }
.koblog .koblog-card .image {max-width: 270px; height: 180px; overflow: hidden; position: relative;}
.koblog .koblog-card .image img {position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: 100%; height: auto;}
.koblog .koblog-card .koblog-card-inner { display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: justify; -webkit-box-pack: justify; justify-content: space-between; -ms-flex-align: center; -webkit-box-align: center; align-items: center; margin-top: 15px; }
.koblog .koblog-card .date { -webkit-box-flex: 0; -ms-flex: none; flex: none; margin-right: 10px; font-size: 20px; font-size: 1.25rem; font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝",'Noto Serif JP', serif; line-height: 1; }
.koblog .koblog-card .category { -webkit-box-flex: 0; -ms-flex: none; flex: none; display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: center; -ms-flex-align: center; -webkit-box-align: center; align-items: center; height: 24px; min-width: 100px; padding: 0 10px; font-size: 14px; font-size: 0.875rem; color: #fff; background: #00469C; }
_:-ms-fullscreen, :root .koblog .koblog-card .category { padding-top: 4px; }
.koblog .koblog-card .text { margin-top: 10px; }


@media screen and (max-width: 767px) {
.koblog { padding: 60px 15px; }
.koblog .koblog-card-wrap { display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: center; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-top: 30px; }
.koblog .koblog-card { width: 100%; margin-bottom: 25px; }
.koblog .koblog-card:last-child { margin-right: 0; }
.koblog .koblog-card .koblog-card-inner { display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: justify; -webkit-box-pack: justify; justify-content: space-between; -ms-flex-align: center; -webkit-box-align: center; align-items: center; margin-top: 15px; }
.koblog .koblog-card img { width: 100%; }
.koblog .koblog-card .date { -webkit-box-flex: 0; -ms-flex: none; flex: none; margin-right: 10px; font-size: 18px; font-size: 1.125rem; font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "リュウミン R-KL", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝",'Noto Serif JP', serif; line-height: 1; }

.koblog .koblog-card .category { -webkit-box-flex: 0; -ms-flex: none; flex: none; display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: center; -ms-flex-align: center; -webkit-box-align: center; align-items: center; height: 24px; min-width: 100px; padding: 0 10px; font-size: 14px; font-size: 0.875rem; color: #fff; background: #00469C; }

.koblog .koblog-card .text { margin-top: 10px; }

.koblog .c-btn1 { margin-top: 25px; }
}

/* ---------------------------------------------------
	子ブログ shop用
------------------------------------------------------ */
.koblog.netshop {width: 100%; max-width: 1200px; margin: 0 auto; padding: 150px 0 100px; }
.koblog.netshop .netshop-tit {color: #249CAD; font-size: 28px; font-weight: bold; letter-spacing: 0.03em; border-bottom: 1px solid #249CAD; margin-bottom: 40px; padding-bottom: 5px;}
.koblog.netshop .koblog-card-wrap { display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-top: 30px; }
.koblog.netshop .koblog-card { width: 31.667%; max-width: 380px; margin-right: 2.5%; margin-bottom: 40px;}
.koblog.netshop .koblog-card:nth-child(3n) { margin-right: 0; }
.koblog.netshop .koblog-card .image {max-width: 380px; height: 380px; overflow: hidden; position: relative; border: 1px solid #9E9E9F;}
.koblog.netshop .koblog-card .image img {position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); min-width: 100%; min-height: 100%; width: auto; height: auto;}
.koblog.netshop .koblog-card .koblog-card-inner { display: block; margin-top: 30px; }
.koblog.netshop .koblog-card .category { display: inline-block; height: 25px; min-width: 80px; line-height: 25px; padding: 0 10px; font-size: 14px; font-weight: bold; color: #fff; background: #249CAD; border-radius: 5px; text-align: center;}
_:-ms-fullscreen, :root .koblog.netshop .koblog-card .category { padding-top: 4px; }
.koblog.netshop .koblog-card .tit { font-size: 22px; font-weight: bold; margin-top: 20px;}
.koblog.netshop .koblog-card .price { font-size: 20px; font-weight: 500;}

.netshop_tolink {padding: 20px 0; text-align: center;}


@media screen and (max-width: 767px) {
	.koblog.netshop {width: 100%; max-width: calc(100% - 20px); margin: 0 auto; padding: 50px 0; }
	.koblog.netshop .netshop-tit {font-size: 24px; margin-bottom: 30px;}
	.koblog.netshop .koblog-card-wrap { display: block; margin-top: 30px; }
	.koblog.netshop .koblog-card { width: 100%; max-width: 380px; margin-right: 0%; margin-bottom: 30px;}
	.koblog.netshop .koblog-card:nth-child(3n) { margin-right: 0; }
	.koblog.netshop .koblog-card .image {}
	.koblog.netshop .koblog-card .image img {}
	.koblog.netshop .koblog-card .koblog-card-inner { margin-top: 20px; }
	.koblog.netshop .koblog-card .category { display: inline-block; height: 25px; min-width: 80px; line-height: 25px; padding: 0 10px; font-size: 14px; font-weight: bold; color: #fff; background: #249CAD; border-radius: 5px; text-align: center;}
	.koblog.netshop .koblog-card .tit { font-size: 20px; font-weight: bold; margin-top: 15px;}
	.koblog.netshop .koblog-card .price { font-size: 18px; font-weight: 500;}
	
}

/* ---------------------------------------------------
	子ブログindex - news用
------------------------------------------------------ */

.koblog-news {width: 100%; max-width: 1200px; margin: 0 auto; padding: 50px 0; }
.koblog-news .koblog-card-wrap { display: block; margin-top: 30px; }
.koblog-news .koblog-card { width: 100%; display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; padding: 10px 0;}
.koblog-news .koblog-card .image {width: 100px; height: 100px; overflow: hidden; position: relative; margin-right: 20px;}
.koblog-news .koblog-card .image img {position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: 100%; height: auto;}
.koblog-news .koblog-card .koblog-card-inner { display: block; width: calc(100% - 120px); }
.koblog-news .koblog-card .meta { display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: start; -webkit-box-pack: start; justify-content: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; width: 100%;}
.koblog-news .koblog-card .category { -webkit-box-flex: 0; -ms-flex: none; flex: none; display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: center; -ms-flex-align: center; -webkit-box-align: center; align-items: center; height: 24px; min-width: 100px; padding: 0 10px; font-size: 14px; font-size: 0.875rem; color: #fff; background: #00469C; margin-right: 20px;}
_:-ms-fullscreen, :root .koblog-news .koblog-card .category { padding-top: 4px; }
.koblog-news .koblog-card .date { -webkit-box-flex: 0; -ms-flex: none; flex: none; margin-right: 10px; font-size: 20px; font-size: 1.25rem; line-height: 1; }
.koblog-news .koblog-card .text { margin-top: 10px;}


@media screen and (max-width: 767px) {
	.koblog-news {width: 100%; max-width: 100%; margin: 0 auto; padding: 30px 0; }
	.koblog-news .koblog-card-wrap { display: block; margin-top: 10px; padding: 0 10px;}
	.koblog-news .koblog-card { width: 100%; display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; padding: 10px 0;}
	.koblog-news .koblog-card .image {width: 100px; height: 100px; overflow: hidden; position: relative; margin-right: 10px;}
	.koblog-news .koblog-card .image img {position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: 100%; height: auto;}
	.koblog-news .koblog-card .koblog-card-inner { display: block; width: calc(100% - 110px); }
	.koblog-news .koblog-card .meta { display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: start; -webkit-box-pack: start; justify-content: flex-start; -ms-flex-wrap: wrap; flex-wrap: wrap; width: 100%;}
	.koblog-news .koblog-card .category { -webkit-box-flex: 0; -ms-flex: none; flex: none; display: -ms-flexbox; display: -webkit-box; display: flex; -ms-flex-pack: center; -webkit-box-pack: center; justify-content: center; -ms-flex-align: center; -webkit-box-align: center; align-items: center; height: 24px; min-width: 100px; padding: 0 10px; font-size: 14px; font-size: 0.875rem; color: #fff; background: #00469C; margin-right: 20px;}
	.koblog-news .koblog-card .date { -webkit-box-flex: 0; -ms-flex: none; flex: none; margin-right: 10px; font-size: 20px; font-size: 1.25rem; line-height: 1; }
	.koblog-news .koblog-card .text { margin-top: 10px;}
}

/* ---------------------------------------------------
	404
------------------------------------------------------ */
#article-404 {}
#article-404.entry-title {text-align: center; margin: 50px 0;}

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

/* ---------------------------------------------------
	お問い合わせ
------------------------------------------------------ */
.contact {}
.contact-box {width: 100%; max-width: 840px !important; margin: 0 auto;}
.contact-box p {font-feature-settings: "palt";}
.contact-box .tel-box {width: 680px; margin: 0 auto 40px; padding: 30px 0; border: 1px solid #000; text-align: center;}
.contact-box .tel-box h2 {margin-bottom: 0;}
.entry-column .contact-box ul li {background: none; padding: 0;}
.contact-box .contact-no { font-size: 40px;}
.contact-box .contact-no + p {margin-bottom: 0;}
.contact-box .fax {}
.contact-box .contact-no span,
.contact-box .contact-no span a {}
.contact-form, .contact-form-group {background: none;}
.contact-form-label {border-bottom: 1px solid #ccc;}
.contact-form-control {border-bottom: 1px solid #ccc;}
.contact-box input[type=date], .contact-box input[type=datetime-local], .contact-box input[type=datetime], .contact-box input[type=email], .contact-box input[type=month], .contact-box input[type=number], .contact-box input[type=password], .contact-box input[type=search], .contact-box input[type=tel], .contact-box input[type=text], .contact-box input[type=time], .contact-box input[type=url], .contact-box input[type=week] {padding: 5px;}
.contact-box select {min-height: 40px;}
.contact-box .acms-admin-form-radio {display: block; margin-bottom: 10px;}
.contact-box .radio-sub {display: inline-block; padding-left: 25px; margin-bottom: 10px;}
.form-btn-box {margin: 20px 10px;}
.contact-box .btn-attention-block-large { position: relative; display: block; width: 100%; padding: 25px 50px; border: none; color: #FFF; font-weight: bold; text-align: center; text-decoration: none; background: #1F2581; transition: all .25s ease; border-radius: 0; margin: auto;}
.contact-box .btn-attention-block-large:active, .contact-box .btn-attention-block-large:focus, .contact-box .btn-attention-block-large:hover {opacity: 0.8;}
.contact-box .btn-large { padding: 25px 30px; border-radius: 0;}
input, select { font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", Arial, Helvetica, Verdana, sans-serif; font-weight: 500;}

.contact-box .message-back-link {}
.contact-box .message-back-link a {color: #222;}

.label-any {margin: 0 5px; padding: 2px 8px; color: #fff; background: #666; border-radius: 3px; font-size: 12px; float: right;}
.label-required {float: right;}

@media screen and (max-width: 767px) {
.contact-box .tel-box {width: 94%;}
.contact-box .contact-no { font-size: 28px;}
.contact-box .fax { font-size: 20px;}
}

/* ---------------------------------------------------
	suggest
------------------------------------------------------ */


/* ---------------------------------------------------
	footer
------------------------------------------------------ */
.f-bnr-sec{margin-bottom: 106px;}
.f-bnr-sec .banner-wrap{max-width:1200px; display: flex; flex-wrap:wrap; justify-content: space-between; margin: auto;}
.f-bnr-sec .banner-wrap .img-box{width: calc((100% - 42px) / 3); margin-bottom: 26px;}
.f-bnr-sec .banner-wrap::after{content:""; display: inline-block; width: calc((100% - 42px) / 3); height: 0; order: 2;}

footer .footer-content{background: #3E3A39; padding-top: 46px; padding-bottom: 42px;}
footer .menu-wrap{display: flex; align-items:center; justify-content: center; margin-bottom: 50px;}
footer .footer-img{margin-right:70px;}
footer .footer-menu ul{display: flex; flex-wrap:wrap; justify-content: center; align-items: center;}
footer .footer-menu ul li:not(:last-of-type) a{border-right: 1px solid #FFF;}
footer .footer-menu ul li a{color: #FFF; font-size: 0.875em; letter-spacing: 0.03em; text-decoration: none; padding: 0 8px;}
footer .company-info{display: flex;/* justify-content: space-between;*/max-width: 1200px; margin: auto; margin-bottom: 30px;
  max-inline-size: max-content;margin-inline: auto;}
footer p.title,footer p.title + p{font-size: 0.875em; letter-spacing:0.03em; line-height:1.64; max-width:1020px; margin:auto;}
footer p,footer a{color: #FFF;}
footer .company-info .footer-img{margin-bottom: 26px;}
footer .title{margin-bottom: 12px;}
/*footer .company-info .mb-34{margin-bottom: 34px;}*/
footer .company-info .col:last-of-type .img-box{margin: 18px 0;}
footer .copy-right{text-align: center; margin-top: 32px; margin-bottom: 32px; color: #000;}
footer .copy-right small{font-size: 14px; letter-spacing: 0.03em;}
footer .company-info .honten{display: flex;}
footer .company-info .honten .mb-34_2{margin-left: 20px; margin-top: 0px;}
footer .title_area{padding-left: 90px;}

.acms-list-group{border:none;}
.acms-list-group-item{border:none;}
.headline a{font-weight: bold; padding: 0; font-size: 17px;}

footer .company-info .col{padding-right:48px; border-right:1px solid #FFF; margin-right:48px;}
footer .company-info .col:last-of-type{border-right:none; padding-right: 0; margin-right: 0;}

@media screen and (max-width: 767px) {
	.f-bnr-sec{margin-bottom: 0; padding: 30px 25px;}
	.f-bnr-sec .banner-wrap{max-width:100%; margin: auto;}
	.f-bnr-sec .banner-wrap .img-box{width: 49%; margin-bottom: 10px; margin-right: 2%;}
	.f-bnr-sec .banner-wrap .img-box:nth-child(2n){margin-right: 0;}
	.f-bnr-sec .banner-wrap::after{}

	footer .footer-content{padding-top: 35px; padding-bottom: 30px;}
	footer .menu-wrap{display: block; margin-bottom: 40px;}
	footer .footer-img{margin: 0 auto 30px; text-align: center;}
	footer .footer-menu ul{}
	footer .footer-menu ul li:not(:last-of-type) a{border-right: 1px solid #FFF;}
	footer .footer-menu ul li a{font-size: 10px; padding: 0 8px;}
	footer .company-info{display: block; max-width: 100%; margin: auto; margin-bottom: 20px; text-align: center; padding: 0 25px;}
	footer p.title,footer p.title + p{font-size: 12px; max-width:100%; margin:auto;}
	footer p,footer a{}
	footer .company-info .footer-img{margin-bottom: 26px;}
	footer .title{margin-bottom: 12px; text-align: center;}
	footer .company-info .mb-34{margin-bottom: 26px;}
	footer .company-info .col:last-of-type .img-box{margin: 18px 0;}
	footer .copy-right{text-align: center; margin-top: 10px; margin-bottom: 10px;}
	footer .copy-right small{font-size: 10px;}

	.acms-list-group{border:none;}
	.acms-list-group-item{border:none;}
	.headline a{font-weight: bold; padding: 0; font-size: 17px;}

	footer .company-info .col{padding-right:0; border-right:none; margin-right:0; border-bottom:1px solid #FFF; margin-bottom: 20px;}
	footer .company-info .col:last-of-type{border-right:none; padding-right: 0; margin-right: 0;}
  footer .company-info .honten{flex-direction: column; margin-top: -25px;margin-bottom: 20px;}
  footer .company-info .honten .mb-34_2{ max-width: 100%; margin: auto; margin-top: -22px;}
}


/* ---------------------------------------------------
	container-house
------------------------------------------------------ */
.container-house {}
.container-house h2#container-tit {border-radius: 0; background: #002064; font-size: 21px; letter-spacing: 0.05em; line-height: 40px; text-align: center; color: #fff;}

.container-house .box_row4 .row_col {margin-bottom: 23px;}
.container-house .box_row4 .row_col .col_pic {margin-bottom: 5px;}
.container-house .box_row4 h5 {font-size: 17px; font-weight: 700; letter-spacing: 0.05em; line-height: 38px; text-align: left; color: #1a1311; margin-bottom: 0;}

.container-house a[href*="contact/"] img {max-width: calc(100% - 20px);}

@media screen and (max-width: 767px) {
  .container-house .entry-column p.taC {text-align: left;}
  .container-house .entry .acms-entry .acms-grid .box_row4 {max-width: calc(100% - 20px);}
  .container-house .box_row4 .row_col {width: 45%;}
  .container-house .box_row4 h5 {font-size: 14px; line-height: 1.5;}
  .container-house .box_row4 .row_col:nth-last-of-type(4), .container-house .box_row4 .row_col:nth-last-of-type(4) ~ .row_col {margin-bottom: 23px;}
  .container-house .box_row4 .row_col:nth-last-of-type(2), .container-house .box_row4 .row_col:nth-last-of-type(1) {margin-bottom: 0 !important;}
}