@charset "UTF-8";
/* GENERAL ---------------------------------------------*/
* {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    -webkit-box-shadow: none;
    box-shadow: none;
    outline: none;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}
body {
    font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Arial, Meiryo, sans-serif;
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-overflow-scrolling: touch;
    text-rendering: auto;
    font-feature-settings: "palt"1;
    color: #000;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.85;
    letter-spacing: 0.1em;
    background: #fff;
    min-width: 1100px;
	overflow-x: hidden;
}
.noto {
    font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Arial, Meiryo, sans-serif;
}
.mincho {
    font-family: 'Noto Serif JP', serif;
}
.didot {
	font-family: linotype-didot, serif;
}
img {
    vertical-align: bottom;
}
a {
    color: #000;
}
.inner {
    width: 1000px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: auto;
}
.inner1400 {
    width: 1400px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin: auto;
}
.flex {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.obfit,
.obfit img {
    object-fit: cover;
    font-family: 'object-fit: cover;';
}
.inline {
	display: inline-block;
}


/* RESPONSIVE ---------------------------------------------*/
.sp,
.spin{
    display: none !important;
}
@media (max-width: 1399px) {
    .inner1400 {
    width: 100%;
    margin: auto;
    }
    .inner1400 img {
    max-width: 100%;
    margin: auto;
    }
}
@media (max-width: 750px) {
    body {
    width: 100%;
    min-width: unset;
    font-size: 3.467vw;
    line-height: 1.85;
    }
    .sp {
    display: block !important;
    }
    .spin {
    display: inline-block!important;
    }
    .pc {
    display: none !important;
    }
    .inner {
    width: 100%;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0 5.333vw;
    }
    .body_voice_child .inner {
    width: 100%;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0 6.667vw;
    }
    .inner1400 {
    width: 100%;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    }
    .w100 {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    }
    img {
    width: 100%;
    vertical-align: middle;
    height: auto;
    }
}





/* header
--------------------------------------------------------------*/
header {
	position: relative;
	width: 100%;
}
header .pc_header {
    align-items: center;
    justify-content: space-between;
    width: 1100px;
    margin: 0 auto 0;
    padding: 73px 0 20px 0;
    z-index: 100;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateY(0%) translateX(-50%);
    -webkit- transform: translateY(0%) translateX(-50%);
}
header .header_logo {
    width: 240px;
    height: 55px;
}
@media (max-width: 750px) {
	header .header_logo {
	width: 36vw;
	height: auto;
	}
	header .pc_header {
	width: 100%;
	padding: 25px 0 0 20px;
	}
}



/* ハンバーガーアイコン
--------------------------------------------------------------*/
.burger_wrap {
    width: 12vw;
    height: 12vw;
    position: fixed;
    top: 1.867vw;
    right: 2.133vw;
    z-index: 0;
    background: #e60012;
    transition: 1s;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
}
.burger {
    width: 4.267vw;
    height: 3.733vw;
    position: fixed;
    display: flex;
    align-items: center;
    top: 0;
    right: 6.133vw;
    z-index: 9999;
    padding: 0.533vw 0;
    margin: 5.867vw  0 0 0;
}
/* 真ん中の線 */
.burger .line {
    width: 100%;
    height: 0.533vw;
    background: #fff;
    transition: 0.6s;
    z-index: 10;
}
/* 上の線 */
.burger::before {
    content: "";
    position: absolute;
    width: 4.267vw;
    height: 0.533vw;
    top: 0;
    right: 0;
    background: #fff;
    transition: 0.6s;
    z-index: 10;
}
/* 下の線 */
.burger::after {
    content: "";
    position: absolute;
    width: 4.267vw;
    height: 0.533vw;
    bottom: 0;
    right: 0;
    background: #fff;
    transition: 0.6s;
    z-index: 10;
}
.burger-active::before {
    transform: rotate(135deg);
    top: 0;
    bottom: 0;
    margin: auto;
}
.burger-active::after {
    transform: rotate(-135deg);
    top: 0;
    bottom: 0;
    margin: auto;
}
.burger-active > .line {
    transform: scale(0);
}
/* メニュー */
.navigation {
    width: 90vw;
    height: 100%;
    background: #f8f8f8;
    position: fixed;
    right: -100vw;
    transition: 0.6s;
    top: 0;
    z-index: 200;
    padding: 8vw 0;
}
.navigation.nav-active {
    right: 0;
    height: 100%;
    overflow: auto;
    box-shadow: 0.533vw 0.533vw 1.067vw gray;
}
.navigation .nav_logo {
	width: 40vw;
	height: auto;
	margin: 0 0 0 30px;
}
.navigation .nav_logo .st0 {
	fill: #000;
}
.navigation .ul_menu li a:hover {
    opacity: 1;
}
.navigation .ul_menu {
    margin: 2.667vw auto 6.667vw;
    width: 68vw;
    flex-direction: column;
}
.navigation .ul_menu span {
    margin: -1em 0 0 1.35em;
    display: block;
}
.navigation .ul_menu li {
    font-size: 13px;
    border-bottom: 1px solid #e5e5e5;
}
.navigation .ul_menu li a {
    width: 100%;
    font-weight: 600;
    display: block;
    padding: 2.667vw 0;
}
@media (max-width: 750px) {
	.navigation .ul_menu li {
	font-size: 3.467vw;
	}
	.navigation .ul_menu li a {
	padding: 2.667vw 0;
	}
	.navigation .ul_menu .li_mail{
	border: 1px solid #e5e5e5;
	margin: 20px 0 0 0;
	text-align: center;
	}
	.navigation .ul_menu .li_mail a{
	color: #fff;
	background: #000;
	}
}


/* logo */
.logo_sp img {
    height: 30px;
    width: auto;
}
.logo_sp a {
    padding: 15px 25px;
    line-height: 1;
    display: block;
}



/* aside　sticky
--------------------------------------------------------------*/
aside .sticky {
    position: -webkit-sticky;
    position: sticky;
    top: 110px;
    z-index: 10;
}

/* aside
--------------------------------------------------------------*/
.main_side_wrap main {
    width: 700px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.main_side_wrap aside {
    width: 235px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
.main_side_wrap {
    justify-content: space-between;
}

@media (max-width: 750px) {
	.main_side_wrap main {
	width: 100%;
	}
	.main_side_wrap aside {
	width: 100%;
	}
	.main_side_wrap {
	flex-wrap: wrap;
	}
	.body_service_corporate .main_side_wrap,
	.body_service_individual .main_side_wrap {
	flex-direction: column-reverse;
	}
}


aside {
    margin: 45px 0 70px 0;
}
aside a {
	display: block;
}
aside a:hover {
	opacity: 1;
}
aside .title {
	line-height: 50px;
	border-bottom: 1px solid #ccc;
	font-size: 20px;
	margin: 0 0 10px 0;
}
aside .list li {
	position: relative;
	padding: 0.15em 0 0.15em 1.2em;
}
aside .list li:before {
	position: absolute;
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 10px;
	background: #ccc;
	top: 55%;
	left: 0;
	transform: translateY(-50%) translateX(0%);
	-webkit- transform: translateY(-50%) translateX(0%);
}
aside .list li.current:before {
	background: #e70011;
}
aside .list li.current a {
	color: #e70011;
}
aside .list li.sub_cat {
	margin: 0 0 0 1.5em;
	padding: 0.15em 0 0.15em 1.2em;
}
aside .side02 {
	margin: 20px 0 30px 0;
}
aside .side02 .title {
	margin: 0 0 20px 0;
}
aside .side03 {
	font-size: 12px;
}
aside .side03 a {
	padding: 10px 0 5px 0;
	border-bottom: 1px solid #e8e8e8;
	align-items: flex-start;
	line-height: 1.5;
}
aside a:hover {
	color: #e70011;
}
aside .side03 a .obfit {
	overflow: hidden;
    position: relative;
    border: 1px solid #e5e5e5;
	margin: 0 5px 0 0;
}
aside .side03 a img {
	width: 50px;
	height: 50px;
	transition-duration: 0.3s;
}
aside .side03 a:hover img {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -o-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
	transition-duration: 0.3s;
}
aside .side03 .wrap {
	flex:1;
	margin: -1px 0 0 0;
}
aside .side03 .kiji_title {
	letter-spacing: 0;	
}
aside .side03 .date {
	color: #666;
}

@media (max-width: 750px) {
	aside {
	margin: 0 0 8vw 0;
	}
	aside .title {
	line-height: 10.667vw;
	font-size: 4vw;
	}
}




/* MV
--------------------------------------------------------------*/
.key-visual {
	background: #000;
}
.key-visual .mv_wrap {
	position: relative;
}
.key-visual .mv_bg {
	position: relative;
	right: 50px;
}
.key-visual .mv_logo {
	position: absolute;
	top: 400px;
	left: 405px;
}
.key-visual .mv_copy {
	position: absolute;
	top: 287px;
	left: 40px;
	-webkit- transform: translateY(-50%) translateX(0%);
}
@media (max-width: 750px) {
	.key-visual {
	}
	.key-visual .mv_wrap {
	}
	.key-visual .mv_bg {
	position: relative;
	right: 0;
	}
	.key-visual .mv_logo {
	position: absolute;
	top: 0;
	left: 0;
	transform: unset;
	}
	.key-visual .mv_copy {
	position: absolute;
	top: 287px;
	left: 40px;
	-webkit- transform: translateY(-50%) translateX(0%);
	}
}
.mv {
    height: 350px;
}
.body_news .mv {
    background: url(../img/news/mv.jpg)no-repeat;
    background-position: center;
    background-size: cover;
    position: relative;
    background: #000;
}
.body_under .mv {
    background: url(../img/news/mv.jpg)no-repeat;
    background-position: center;
    background-size: cover;
    position: relative;
}
@media (max-width: 750px) {
	.mv {
	height: 42.667vw;
	}
}


/* ページタイトル */
.page_title {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateY(10%) translateX(-50%);
    -webkit- transform: translateY(10%) translateX(-50%);
    letter-spacing: 0.1em;
    text-align: center;
    line-height: 40px;
    color: #fff;
}
.page_title .en {
    font-size: 36px;
	font-weight: 600;
}
.page_title .ja {
    font-size: 13px;
}
@media (max-width: 750px) {
	.page_title {
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(10%) translateX(-50%);
	-webkit- transform: translateY(10%) translateX(-50%);
	letter-spacing: 0.1em;
	text-align: center;
	line-height: 5.333vw;
	}
	.page_title .en {
	font-size: 5.333vw;
	}
	.page_title .ja {
	font-size: 2.933vw;
	}

}



/* トップページ　コンテンツ
--------------------------------------------------------------*/
.sec_information {
	background: #000;
}
.sec_kodawari {
	background: #000;
}
.sec_kodawari .wrap {
	position: relative;
	z-index: 0;
}
.sec_kodawari .text {
	position: relative;
}
.sec_kodawari .photo {
	position: absolute;
}

.sec_sns {
	background: #cc0000;
}

.sec_shop {
	background: #000;
	color: #fff;
}
.sec_shop .bg {
	padding: 120px 0 0 0;
	background: url(../img/cmn/bg_yuge.jpg) repeat-y;
	background-position: top center;
	background-size: auto;
	position: relative;
}
.sec_shop a {
	display: block;
	color: #fff;
}
.sec_shop .btn {
	border: 1px solid #fff;
	color: #000;
	background: #fff;
	text-align: center;
	line-height: 60px;
}
.sec_shop .btn:hover {
	letter-spacing: 0.3em;
}
.sec_shop .link_wrap {
	justify-content: space-between;
}
.sec_shop .link_wrap .btn {
	width: 49.5%;
}
.sec_shop .center {
	text-align: center;
}
.sec_shop .ul01 {
	flex-wrap: wrap;
	margin: 30px 0 0 0;
}
.sec_shop .ul01 > li {
	position: relative;
	justify-content: space-between;
	width: 100%;
	margin: 0 0 70px 0;
}
.sec_shop .shop_box {
	width: 414px;
	margin: 95px 0 0 0;
}
.sec_shop .shop_box .name {
	font-size: 28px
}
.sec_shop .shop_box .sub {
	font-size: 20px
}
.sec_shop .shop_box .address {
	margin: 10px 0 0 0;
}
.sec_shop .shop_box .lead {
	margin: 0 0 35px 0;
}
.sec_shop .men_l {
	margin: 0 0 0 -140px;
}
.sec_shop .men_r {
	margin: 0 -140px 0;
}
.sec_shop .btn_map {
	margin: 20px 0 30px 0;
	color: #cc0000;
	position: relative;
	font-weight: 600;
	width: 173px;
}
.sec_shop .btn_map:hover {
	letter-spacing: 0.2em;
}
.sec_shop .btn_map:after {
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    border-style: solid;
    border-width: 1px 1px 0 0;
    border-color: white;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) translateX(0%) rotate(45deg);
    -webkit- transform: translateY(-50%) translateX(0%) rotate(45deg);
}
.sec_shop .btn_map:before {
    position: absolute;
    content: "";
    width: 44px;
    height: 44px;
    background: #cc0000;
    border-radius: 100px;
    top: 50%;
    right: 0;
    transform: translateY(-50%) translateX(0%);
    -webkit- transform: translateY(-50%) translateX(0%);
}
.sec_shop .ul03 {
	padding: 90px 85px;
	justify-content: space-between;
}
.sec_shop .ul03 .text01 {
	position: relative;
	font-size: 20px;
	margin: -10px 0 12px 0;
	padding: 0 0 12px 0;
}
.sec_shop .ul03 .text01:after {
    position: absolute;
    content: "";
    width: 45px;
    height: 1px;
    background: #cc0000;
    border-radius: 100px;
    bottom: 0;
    left: 0;
}
.sec_shop .ul03 .text03 span {
	color: #666;
}
.sec_shop .ul03 > li:nth-child(2) {
	width: 490px;
}
.sec_shop .ul04 {
	flex-wrap: wrap;
	margin: 5px 0 0 0;
	align-items: baseline;
}
.sec_shop .ul04 > li {
	margin: 3px 0;
}
.sec_shop .ul04 > li:nth-child(odd) {
	width: 15%;
	text-align:justify;
	text-align-last:justify;
}
.sec_shop .ul04 > li:nth-child(even) {
	width: 85%;
	padding: 0 0 0 5px;
	color: #666;
}
.sec_shop .ul04 > li a {
	color: #666;
	font-size: 18px;
}
@media (max-width: 750px) {
	.sec_shop .bg {
	padding: 20px 0 0 0;
	background: url(../img/cmn/bg_yuge.jpg) repeat-y;
	background-position: top center;
	background-size: 130%;
	}
	.sec_shop .btn {
	line-height: 12vw;
	}
	.sec_shop .ul01 {
	margin: 10px 0 0 0;
	}
	.sec_shop .ul01 > li {
	margin: 0 0 13.333vw 0;
	flex-wrap: wrap;
	}
	.sec_shop .shop_box {
	width: 100%;
	margin: 0;
	position: relative;
	}
	.sec_shop .shop_box .name {
	font-size: 18px;
	}
	.sec_shop .shop_box .sub {
	font-size: 14px;
	}
	.sec_shop .shop_box .address {
	margin: 10px 0 0 0;
	font-size: 13px;
	}
	.sec_shop .shop_box .lead {
	margin: 0 0 25px 0;
	font-size: 13px;
	}
	.sec_shop .men_l {
	margin: 0;
	}
	.sec_shop .men_r {
	margin: 0;
	}
	.sec_shop .btn_map {
	margin: 10px 0 20px 0;
	width: 38.667vw;
	font-size: 3.467vw;
	}
	.sec_shop .btn_map:hover {
	letter-spacing: 0.2em;
	}
	.sec_shop .btn_map:after {
	position: absolute;
	content: "";
	width: 8px;
	height: 8px;
	border-style: solid;
	border-width: 1px 1px 0 0;
	border-color: #cc0000;
	top: 50%;
	right: 20px;
	transform: translateY(-50%) translateX(0%) rotate(45deg);
	-webkit- transform: translateY(-50%) translateX(0%) rotate(45deg);
	}
	.sec_shop .btn_map:before {
	display: none;
	}
	.sec_shop .ul03 {
	padding: 10.667vw 5.333vw 8vw 5.333vw;
	flex-direction: column;
	}
	.sec_shop .ul03 .text01 {
	font-size: 4.267vw;
	}
	.sec_shop .ul03 .text01:after {
	width: 5.333vw;
	}
	.sec_shop .ul03 {
	font-size: 3.467vw;
	}
	.sec_shop .ul04 {
	font-size: 3.467vw;
	}
	.sec_shop .ul03 > li:nth-child(2) {
	width: 100%;
	margin: 5.333vw 0 0 0;
	}
	.sec_shop .ul04 {
	flex-wrap: wrap;
	margin: 1.333vw 0 0 0;
	align-items: baseline;
	}
	.sec_shop .ul04 > li {
	margin: 0.8vw 0;
	}
	.sec_shop .ul04 > li:nth-child(odd) {
	width: 13.867vw;
	}
	.sec_shop .ul04 > li:nth-child(even) {
	width: 80%;
	padding: 0 0 0 1.333vw;
	letter-spacing: 0;
	}
	.sec_shop .ul04 > li a {
	color: #666;
	font-size: 4.8vw;
	}
	.sec_shop .box01 {
	position: absolute;
	}
	.sec_shop .box02 {
	padding: 8vw 0 2.667vw 44vw;
	position: relative;
	min-height: 66.667vw;
	}
	.sec_shop li:nth-child(even) .box02 {
	padding: 8vw 44vw 0 0;
	}
}

/* ポップアップ */
.modal{
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%;
    left: 0;
    color: #fff;
    z-index: 100;
}
.modal__bg{
    background: rgba(0,0,0,0.8);
    height: 100vh;
    position: absolute;
    width: 100%;
}
.modal__content{
    background: #fff;
    color: #000;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 85%;
    max-width: 1000px;
    max-height: 80vh;
    overflow-y: auto;
}
a.js-modal-close {
  position: absolute;
  right: 15px;
  top: 15px;
  width: 40px;
  height: 40px;
}
a.js-modal-close::before,
a.js-modal-close::after {
	display: block;content: "";
	width: 40px;
	height: 1px;
	background: #cc0000;
	position: absolute;
}
a.js-modal-close::before {
	transform: rotate(-45deg);
	top: 50%;
}
a.js-modal-close::after {
	transform: rotate(45deg);
	top: 50%;
}
@media (max-width: 750px) {
	.modal__content{
	background: #fff;
	color: #000;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%,-50%);
	width: 85%;
	max-width: 1000px;
	max-height: 80vh;
	overflow-y: auto;
	}
	a.js-modal-close {
	right: 2.667vw;
	top: 2.667vw;
	width: 5.333vw;
	height: 5.333vw;
	}
	a.js-modal-close::before,
	a.js-modal-close::after {
	width: 5.333vw;
	}
}
/**/

.sec_recruit {
  position: relative;
  z-index: 20;
  margin: 0!important;
}
.sec_recruit .shop_box {
	width: 590px;
	margin: 200px 0 0 0;
}
.sec_recruit .cont_title {
	margin: 0 0 30px 0;
}
.sec_recruit .men_r {
	margin: 0 -80px 35px;
}
.sec_recruit .btn {
	border: 1px solid #fff;
	text-align: center;
	line-height: 75px;
	width: 414px;
	background: unset;
	color: #fff;
}
.sec_recruit .btn:hover {
	background: #ffffff52;
	opacity: 1;
}
.recruit_bg {
	position: absolute;
	width: 100vw;
	padding: 320px 0;
	clip-path: polygon(0 calc(0% + 20vw), 100% 0, 100% 100%, 0 100%);
	background-color: #cc0000;
	left: 0;
	bottom: 0
}
@media (max-width: 750px) {
	.sec_recruit {
	position: relative;
	z-index: 20;
	margin: -10.667vw 0 0 0!important;
	}
	.sec_recruit .shop_box {
	width: 100%;
	margin: 8vw 0 0 0;
	}
	.sec_recruit .cont_title {
	margin: 0 0 2.667vw 0;
	}
	.sec_recruit .btn {
	line-height: 12vw;
	width: 100%;
	margin: 0 0 8vw 0;
	}
	.sec_recruit .btn:hover {
	background: #ffffff52;
	opacity: 1;
	}
	.recruit_bg {
	padding: 80vw 0;
	clip-path: polygon(0 calc(0% + 30vw), 100% 0, 100% 100%, 0 100%);
	}
}

.sec_about {
	background: #000;
	padding: 75px 0 50px 0;
	color: #fff;
	text-align: center;
}
.sec_about a {
	color: #fff;
}
.sec_about .title_about {
	margin: 0 0 30px 0;
}
.sec_about .name {
	font-size: 16px;
}
.sec_about .address {
	font-size: 16px;
	margin: 0 0 30px 0;
}
.sec_about .senseki {
	font-size: 16px;
	margin: -9px 0 20px 0;
}
.sec_about .senseki span {
	font-size: 22px;
}
.sec_about .wrap {
	position: relative;
}
.sec_about .illust {
	position: absolute;
	right: 0;
	bottom: 0;
}
.sec_about .ul_contact {
	padding: 0 160px;
	justify-content: space-between;
	margin: 0 0 30px 0;
}
.sec_about .ul_contact li a {
	border: 1px solid #fff;
	text-align: center;
	line-height: 65px;
	width: 330px;
	color: #fff;
	display: block;
}
.sec_about .ul_contact li a:hover {
	background: #ffffff52;
	opacity: 1;
}
@media (max-width: 750px) {
	.sec_about {
	padding: 8vw 0 1.333vw 0;
	}
	.sec_about .title_about {
	margin: 0 0 4vw 0;
	}
	.sec_about .name {
	font-size: 4vw;
	}
	.sec_about .address {
	font-size: 3.733vw;
	margin: 0 0 4vw 0;
	}
	.sec_about .senseki {
	font-size: 4vw;
	margin: 0px 0 20px 0;
	line-height: 5.333vw;
	}
	.sec_about .senseki span {
	font-size: 4.8vw;
	}
	.sec_about .wrap {
	position: relative;
	}
	.sec_about .illust {
	right: 2.867vw;
	top: -2vw;
	width: 18.667vw;
	}
	.sec_about .ul_contact {
	padding: 0;
	justify-content: space-between;
	margin: 0 0 3vw 0;
	}
	.sec_about .ul_contact li {
	width: 49%;
	}
	.sec_about .ul_contact li a {
	/* border: 1px solid #fff; */
	/* text-align: center; */
	line-height: 12vw;
	width: 100%;
	/* background: unset; */
	/* color: #fff; */
	/* display: block; */
	}
	.sec_about .ul_contact li a:hover {
	/* background: #ffffff52; */
	/* opacity: 1; */
	}
}


/* footer
--------------------------------------------------------------*/
footer .footer_bg {
    background: #ccc;
}

footer #copy {
    padding: 10px 0;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-align: center;
    border-top: 1px solid #e5e5e5;
}
footer #copy a {
	color: #000;
}
@media (max-width: 750px) {
	footer #copy {
	padding: 2.667vw 0;
	letter-spacing: 0em;
	font-size: 3.467vw;
	}
}


/* お知らせ一覧　archive
--------------------------------------------------------------*/
.article_news {
	
}
.article_news .title_wrap {
	margin: 55px 0 40px 0;
	font-size: 30px;
	line-height: 1.2;
}
.article_news .detail {

}
.article_news .detail .text_box {
	flex: 1;
	position: relative;
	margin: 0 0 0 20px;
}
.article_news .detail .title {
	font-size: 14px;
	margin: 10px 0 0 0;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}
.article_news .detail .cat {
	font-size: 16px;
	display: inline-block;
	line-height: 30px;
	text-align: center;
	border-radius: 50px;
	border: 1px solid #000;
	color: #000;
	background: #fff;
	padding: 0 30px;
}
.article_news .detail .cat.news {
	border: 1px solid #e60012;
	color: #e60012;
}
.article_news .detail .cat.media {
	border: 1px solid #f75505;
	color: #f75505;
}
.article_news .detail .cat.award {
	border: 1px solid #6d3d03;
	color: #6d3d03;
}
.article_news .detail .date {
	color: #666;
	font-size: 14px;
	line-height: 1;
	position: absolute;
	bottom: 0;
}
.ul_news {
    justify-content: space-between;
    flex-wrap: wrap;
	border-top: 1px solid #e5e5e5;
}
.ul_news > li {
	width: 100%;
	border-bottom: 1px solid #e5e5e5;
}
.ul_news > li a {
	display: block;
	padding: 30px 0;
    position: relative;
    background-size: 200% 100%;
    background-image: -webkit-linear-gradient(left, transparent 50%, #f5f5f557 50%);
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0) 50%, #f5f5f557 50%);
    -webkit-transition: background-position 0.7s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.5s ease;
    transition: background-position 0.7s cubic-bezier(0.19, 1, 0.22, 1) 0.1s, color 0.5s ease 0s, background-color 0.5s ease;
}
.ul_news > li a:hover {
    background-position: -100% 100%;
	opacity: 1;
}
.article_news .ul_news li .obfit {
	overflow: hidden;
	position: relative;
	border: 1px solid #e5e5e5;
}
.article_news .ul_news li .obfit img {
	transition-duration: 0.3s;
	width: 160px;
	height: 130px;
}
.article_news .ul_news li:hover .obfit img {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -o-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
	transition-duration: 0.3s;
}

@media (max-width: 750px) {
	.article_news .title_wrap {
	margin: 5.333vw 0 4vw 0;
	font-size: 4.267vw;
	}
	.article_news .detail {
	align-items: flex-start;
	}
	.article_news .detail .text_box {
	flex: 1;
	position: relative;
	margin: 0 0 0 5.333vw;
	}
	.article_news .detail .title {
	font-size: 13px;
	margin: 1.333vw 0 0 0;
	}
	.article_news .detail .cat {
	font-size: 3.2vw;
	line-height: 5.333vw;
	padding: 0 5px;
	letter-spacing: 0;
	}
	.article_news .detail .date {
	font-size: 3.2vw;
	position: unset;
	display: inline-block;
	margin: 0 0 0 1vw;
	}
	.ul_news {
	justify-content: space-between;
	flex-wrap: wrap;
	border-top: 1px solid #e5e5e5;
	}
	.ul_news > li {
	width: 100%;
	border-bottom: 1px solid #e5e5e5;
	}
	.ul_news > li a {
	padding: 4vw 0;
		}
	.ul_news > li a:hover {
	background-position: -100% 100%;
	opacity: 1;
	}
	.article_news .ul_news li .obfit {
	overflow: hidden;
	position: relative;
	border: 1px solid #e5e5e5;
	}
	.article_news .ul_news li .obfit img {
	height: 21.333vw;
	width: 26.667vw;
	}
}



/* TOPお知らせ一覧
--------------------------------------------------------------*/
.sec_topnews {
	padding: 65px 0 70px 0;
	background: url(../img/cmn/bg_news.jpg);
	background-size: cover;
}
.sec_topnews .link_btn a {
	position: relative;
	width: 130px;
	display: block;
}
.sec_topnews .link_btn a:hover {
	letter-spacing: 0.2em;
}
.sec_topnews .link_btn a:after {
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    border-style: solid;
    border-width: 1px 1px 0 0;
    border-color: white;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) translateX(0%) rotate(45deg);
    -webkit- transform: translateY(-50%) translateX(0%) rotate(45deg);
}
.sec_topnews .link_btn a:before {
    position: absolute;
    content: "";
    width: 44px;
    height: 44px;
    background: #000;
    border-radius: 100px;
    top: 50%;
    right: 0;
    transform: translateY(-50%) translateX(0%);
    -webkit- transform: translateY(-50%) translateX(0%);
}
.sec_topnews .ul01 {
	justify-content: space-between;
	margin: 0 0 35px 0;
}
.sec_topnews .ul02 {
	margin: 40px 0 0 0;
}
.sec_topnews .ul02 .cat_list {
	width: 240px;
	flex-direction: column;
}
.sec_topnews .ul02 .cat_list + li {
	width: 100%;
}
.sec_topnews .ul02 .tab {
	position: relative;
	padding: 0 0 0 16px;
	color: #ccc;
	line-height: 1;
	margin: 0 0 30px 0;
}
.sec_topnews .ul02 .tab:hover {
	cursor: pointer;
}
.sec_topnews .ul02 .tab.is-active {
	color: #666;
}
.sec_topnews .ul02 .tab:before {
	position: absolute;
	content: "";
	width: 6px;
	height: 6px;
	border-radius: 10px;
	background: #ccc;
	top: 55%;
	left: 0;
	transform: translateY(-50%) translateX(0%);
	-webkit- transform: translateY(-50%) translateX(0%);
}
.sec_topnews .ul02 .tab.is-active:before {
	background: #e70011;
}
@media (max-width: 750px) {
	.sec_topnews {
	padding: 8vw 0;
	}
	.sec_topnews .ul01 li {
	width: 100%;
	}
	.sec_topnews .link_btn {
	line-height: 16vw;
	margin: 4vw 9.333vw 0;
	}
	.sec_topnews .link_btn a {
	font-size: 3.467vw;
	display: block;
	width: 100%;
	text-align: center;
	background: #000;
	color: #fff;
	line-height: 12vw;
	}
	.sec_topnews .link_btn a:before {
    display: none;
	}
	.sec_topnews .link_btn img {
	margin: 0 0 1.333vw 5.333vw;
	width: 13.333vw;
	}
	.sec_topnews .ul01 {
	justify-content: space-between;
	margin: 0 0 15px 0;
	}
	.sec_topnews .ul02 {
	margin: 8vw 0 0 0;
	flex-direction: column;
	}
	.sec_topnews .ul02 .cat_list {
	width: 100%;
	flex-direction: row;
	justify-content: space-between;
	}
	.sec_topnews .ul02 .tab {
	margin: 0 0 5.6vw 0;
	padding: 0 0 0 4.267vw;
	}
	.sec_topnews .ul02 .tab:before {
	position: absolute;
	content: "";
	width: 1.6vw;
	height: 1.6vw;
	border-radius: 2.667vw;
	background: #ccc;
	top: 55%;
	left: 0;
	transform: translateY(-50%) translateX(0%);
	-webkit- transform: translateY(-50%) translateX(0%);
	}
	.sec_topnews .ul02 .tab.is-active:before {
	background: #e70011;
	}
}

/* タブ */
.sec_topnews .panel{
    display:none;
}
.sec_topnews .tab.is-active{
    color: #333;
    transition: all 0.2s ease-out;
}
.sec_topnews .panel.is-show{
    display: block;
}
@media (max-width: 750px) {
	.sec_topnews .tab {
		
	}
}
/**/

.sec_topnews .ul_news {
	border: unset;
}
.sec_topnews .ul_news > li {
	width: 310px;
	border: unset;
}
.sec_topnews .ul_news > li a {
	display: block;
	background: unset;
	padding: 0;
}
.sec_topnews .obfit {
	overflow: hidden;
	position: relative;
	border: 1px solid #e5e5e5;
	margin: 0 0 20px 0;
}
.sec_topnews .obfit img {
	width: 310px;
	height: 214px;
	transition-duration: 0.3s;
}
.sec_topnews li:hover .obfit img {
    opacity: 1;
    -webkit-transform: scale(1.2);
    -moz-transform: scale(1.2);
    -o-transform: scale(1.2);
    -ms-transform: scale(1.2);
    transform: scale(1.2);
	transition-duration: 0.3s;
}
.sec_topnews .detail {
	margin: 10px 0;
	align-items: baseline;
}
.sec_topnews .title {
	font-size: 16px;
}
.sec_topnews .detail .cat {
	font-size: 13px;
	display: inline-block;
	line-height: 14px;
	color: #fff;
	background: #cc0000;
	text-align: center;
	padding: 0 5px;
}
.sec_topnews .detail .date {
	color: #666;
	font-size: 13px;
	line-height: 14px;
	width: 95px;
}
@media (max-width: 750px) {
	.sec_topnews .ul_news {
	margin: 0 9.333vw;
	}
	.sec_topnews .ul_news > li {
	width: 100%;
	}
	.sec_topnews .ul_news > li a {
	padding: 2.667vw 0;
	}
	.sec_topnews .ul_news > li a:before {
	width: 5.333vw;
	}
	.sec_topnews .obfit {
	margin: 0 0 4vw 0;
	}
	.sec_topnews .detail {
	flex-wrap: wrap;
	align-items: center;
	margin: 2.667vw 0 1.333vw 0;
	}
	.sec_topnews .detail .cat {
	font-size: 3.2vw;
	line-height: 1.5;
	width: unset;
	}
	.sec_topnews .detail .date {
	font-size: 3.2vw;
	width: 30%;
	}
	.sec_topnews .obfit img {
	width: 100%;
	height: 41.333vw;
	transition-duration: 0.3s;
	}
	.sec_topnews .title {
	font-size: 3.733vw;
	line-height: 1.6;
	}
}
.sec_topnews .ul_news2 {
	border-top: 1px solid #333;
	margin: 50px 0 0 0;
	position: relative;
}
.sec_topnews .ul_news2:after {
	position: absolute;
    content: "";
    width: 95px;
    height: 1px;
    background: #cc0000;
    bottom: 0px;
}
.sec_topnews .ul_news2 > li {
	border-bottom: 1px solid #333;
	width: 100%;
}
.sec_topnews .ul_news2 > li a {
	display: block;
	padding: 15px 0;
	-webkit-transition: all 0.4s ease;
    -moz-transition: all 0.4s ease;
    -o-transition: all 0.4s ease;
	transition: all 0.4s ease;
}
.sec_topnews .ul_news2 > li a:before {
	position: absolute;
	content: "";
	width: 95px;
	height: 1px;
	background: #cc0000;
	top: -1px;
}
.sec_topnews .ul_news2 > li a:hover {
	opacity: 0.7;
}
.sec_topnews .ul_news2 .title {
	margin: 0 0 0 15px;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	flex: 1;
}
@media (max-width: 750px) {
	.sec_topnews .ul_news2 {
	margin: 2.5vw 9.333vw 8vw;
	}
	.sec_topnews .ul_news2:after {
    width: 5.333vw;
	}
	.sec_topnews .ul_news2 > li a {
	padding: 0 0 2.667vw 0;
	}
	.sec_topnews .ul_news2 > li a:before {
	width: 5.333vw;
	top: -2.933vw;
	}
	.sec_topnews .ul_news2 .title {
	margin: 0;
	font-size: 3.733vw;
	}
}

/* Pagenavi(一覧ページ)
--------------------------------------------------------------*/
.pagenavi {
    display: inline-block;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    padding: 25px 0 75px 0;
}
.pagenavi span.pages {
	display:none;
}
.pagenavi span,
.pagenavi a {
    border-style: solid;
    border-width: 1px;
    border-color: #f1f1f1;
    background-color: #fff;
    float: left;
    color: #666;
    text-align: center;
    -moz-transition: all 0.26s ease;
    -o-transition: all 0.26s ease;
    -webkit-transition: all 0.26s ease;
    transition: all 0.26s ease;
    display: block;
    -moz-box-shadow: 0px 2px 0px 0px #f1f1f1;
    -webkit-box-shadow: 0px 2px 0px 0px #f1f1f1;
    box-shadow: 0px 2px 0px 0px #f1f1f1;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    padding: 0 17px!important;
    min-width: 46px;
    box-sizing: border-box;
    line-height: 40px;
    margin: 0 10px 10px 0;
}
.pagenavi span.current,
.pagenavi span:hover,
.pagenavi a.current,
.pagenavi a:hover {
    background-color: #e70011;
    color: #fff;
    opacity: 1;
}

@media (max-width: 750px) {
	/* Pagenavi(一覧ページ) */
	.pagenavi {
	padding: 8vw 0;
	}
}

/* Pagination(詳細ページ)
--------------------------------------------------------------*/
.pagination {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    padding: 0 0 80px 0;
    margin: 0 auto;
    width: 100%;
    box-sizing: border-box;
}
.pagination .btn-pager {
    letter-spacing: 0.15em;
    color: #333;
    background: #fff;
    display: block;
    text-align: center;
    width: 215px;
    padding: 5px 0;
    -moz-transition: all 0.26s ease;
    -o-transition: all 0.26s ease;
    -webkit-transition: all 0.26s ease;
    transition: all 0.26s ease;
    -moz-box-shadow: 0px 2px 0px 0px #f1f1f1;
    -webkit-box-shadow: 0px 2px 0px 0px #f1f1f1;
    box-shadow: 0px 2px 0px 0px #f1f1f1;
    border: 1px solid #f1f1f1;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    font-weight: 500;
    line-height: 2em;
}
.pagination .btn-pager.hidden {
    visibility: hidden;
}
.pagination .btn-pager:hover {
    background: #e70011;
    opacity: 1;
}
.pagination .btn-pager:hover {
    color: #fff;
    opacity: 1;
}
.pagination .btn-pager img {
    width: auto;
    height: 13px;
    margin: -3px 10px 0 0;
    vertical-align: middle;
}
.pagination .btn-pager.page-next img {
    margin-right: 0;
    margin-left: 10px;
}

@media (max-width: 750px) {
	/* Pagination(詳細ページ) */
	.pagination {
	position: relative;
	padding: 5.333vw 0px 16vw 0px;
	margin: 0 0 8vw 0;
	width: 100%;
	}
	.pagination a.btn-pager.page-back {
	position:absolute;
	bottom: 0px;
	margin: 0px 0px !important;
	width: 100% !important;
	}
	.pagination .btn-pager {
	margin: 0px 4vw 0px 0px;
	}  
	.pagination .btn-pager.page-next {
	float: right;
	margin-right: 0px;
	} 
}




/* 詳細ページ
--------------------------------------------------------------*/
.page_single_detail {
	margin: 55px 0 0 0;
}
.page_single_detail .detail > .flex {
	align-items: center;
}
.page_single_detail .article_news .detail .date {
	position: relative;
	margin: 0 0 0 20px;
}
.page_single_detail .page_title {
	text-align: center;
	margin: 0 0 40px 0;
}
.page_single_detail .bg {
    background: url("../img/news/bg.jpg")no-repeat;
    background-size: cover;
    background-position: center;
    padding: 50px 0 100px 0;
}
.page_single_detail h2 {
    font-size: 18px;
    line-height: 1.4em;
    font-weight: 500;
    color: #e80011;
    border-bottom: 1px dotted #e80011;
    padding: 0 0 5px 0;
}
.page_single_detail h3 {
    font-size: 16px;
    line-height: 1.4em;
}
.page_single_detail .cat {
    margin: 0 auto;
}
.page_single_detail .box_wrap {
    background: #fff;
    border: 1px solid #ccc;
    padding: 52px 110px 0;
    margin: 0 50px;
}
.page_single_detail .block_detail {
    line-height: 2.6;
    margin: 0 0 50px 0;
}
.page_single_detail .block_detail p,
.page_single_detail h2,
.page_single_detail h3 {
    margin-bottom: 30px;
}
.page_single_detail .block_detail ol {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
  margin-bottom: 30px;
}
.page_single_detail strong {
    font-weight: bold;
}
 
.page_single_detail .block_detail li {
  margin-bottom: 10px;
  padding-left: 30px;
  position: relative;
}
.page_single_detail .block_detail li p {
  margin-bottom: 10px;
}
.page_single_detail .block_detail li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #e70011;
  color: #fff;
  display: block;
  float: left;
  line-height: 20px;
  margin-left: -30px;
  text-align: center;
  height: 20px;
  width: 20px;
  border-radius: 50%;
  font-weight: 600;
  margin-top: 5px;
}
.page_single_detail a {
   color: #e70011;
}
.page_single_detail .block_detail img {
    max-width: 100%;
    display: block;
    margin: 0 0 30px 0;
    height: auto;
}
.page_single_detail iframe {
	width: 100%;
}
.wp-caption-text {
	margin: -20px 0 31px 0;
	color: #666;
	font-size: 12px;
}

.page_single_detail .detail {
	flex-wrap: wrap;
}
.page_single_detail .detail .title {
	width: 100%;
	padding: 4px 0 25px 0;
	font-size: 24px;
	border-bottom: 1px solid #e5e5e5;
	margin: 0 0 45px 0;
}
figure {
	width: unset!important;
}

@media (max-width: 750px) {
	.page_single_detail {
	margin: 0;
	}
	.page_single_detail .page_title {
	margin: 0 0 5.333vw 0;
	}
	.page_single_detail .bg {
	background: url("../img/news/bg.jpg")no-repeat;
	background-size: cover;
	background-position: center;
	padding: 8vw 0 13.333vw 0;
	}
	.page_single_detail .box_wrap {
	background: #fff;
	border: 1px solid #ccc;
	padding: 0 5.333vw 0;
	margin: 0;
	}
	.page_single_detail .block_detail {
	line-height: 1.85;
	margin: 0;
	}
	.page_single_detail .block_detail p,
	.page_single_detail h2,
	.page_single_detail h3 {
	margin-bottom: 1em;
	}
	.page_single_detail h2 {
    font-size: 16px;
	}
	.page_single_detail h3 {
	font-size: 15px;
	}
	.page_single_detail article {
	padding: 5.333vw 0 0 0;
	}
	.page_single_detail .detail .title {
	font-size: 15px;
	margin: 0 0 10px 0;
	padding: 1.067vw 0 4vw 0;
	}
	.wp-caption-text {
	margin: -5.333vw 0 1em 0;
	}

	.page_single_detail .block_detail img{
	height:auto;
	width: 100%;
	}
	.page_single_detail .block_detail figure{
	height:auto;
	width: 100%!important;
	}
}


/* お問い合わせ基本
--------------------------------------------------------------*/
select, input, textarea {
    border: 1px solid #e8e8e8;
    width: 100%;
    box-sizing: border-box;
    background: #fbfbfb;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0;
    resize: vertical;
    padding: 16px 17px;
    min-height: 65px;
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
	color: #666;
}
::placeholder {
 color: #c4c3c3;
 font-size:  15px;
}
/* IE */
:-ms-input-placeholder {
 color: #c4c3c3;
 font-size:  15px;
}
/* Edge */
::-ms-input-placeholder {
 color: #c4c3c3;
 font-size:  15px;
}

@media (max-width: 750px) {
    select, input, textarea {
    width: 100%;
    font-size:  3.733vw;
    padding: 3.2vw 3.2vw 3.2vw 4.533vw;
    }
    ::placeholder {
    color: #c4c3c3;
    font-size: 3.733vw;
    }
    /* IE */
    :-ms-input-placeholder {
    color: #c4c3c3;
    font-size: 3.733vw;
    }
    /* Edge */
    ::-ms-input-placeholder {
    color: #c4c3c3;
    font-size: 3.733vw;
    }
	.btn_box {
    width: 100%;
    text-align: center;
	margin: 5.333vw 0 0 0;
	}
}