@charset "UTF-8";
/* Author: Hosaka */
/* ---------------------------------------------------
	common
------------------------------------------------------ */
.acms-entry .entry-container {margin: 0;}
.entry {border: none; width: 100%; min-height: 768px; max-width: 100%; margin: 0 auto;}
.entry-title {text-align: center; font-size: 30px; line-height: 1.2; font-weight: 500;}
.acms-grid, .acms-grid-r {margin: 0;}
.entry-column {color: #231815;}
.entry-column tr:nth-child(odd) {background: none;}

.acms-admin-form .acms-admin-form-select, .acms-admin-form select { -moz-appearance: none; -webkit-appearance: none;}

.acms-entry [class*=column-eximage], .acms-entry [class*=column-media], .acms-entry [class*=column-video], .acms-entry [class*=column-youtube] {padding-left: 0; padding-right: 0;}

.entry-column em {/*font-style: italic;*/ font-style: normal; font-weight: bold; text-decoration: underline;}

.message-back-link {display: inline-block; margin: 50px auto; text-align: center; border: none; padding: 10px 20px;}

.tcol-red {color: red;}
.tcol-orange {color: orange;}
.tcol-yellow {color: yellow;}
.tcol-green {color: darkgreen;}
.tcol-blue {color: blue;}
.tcol-purple {color: purple;}

.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;}


@media screen and (max-width: 767px) {
    .acms-entry .entry-container {margin: 0; padding: 0 10px;}
    .entry {width: 100%; min-height: auto; margin: 50px auto 25px;}
	
/*	.txt-lll {font-size: 1.1875em;}
	.txt-ll {font-size: 1.125em;}
	.txt-l {font-size: 1.0625em;}
	.txt-s {font-size: 0.9375em;}
	.txt-ss {font-size: 0.875em;}
	.txt-sss {font-size: 0.75em;}*/
	
	.coating .txt-lll > .txt-ll {font-size: 1em;}
	
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .acms-entry [class*=column-eximage], .acms-entry [class*=column-media], .acms-entry [class*=column-video], .acms-entry [class*=column-youtube]{padding: 0 40px;}
}


/* ---------------------------------------------------
	グループ用調整
------------------------------------------------------ */
.acms-grid > * {width: 100%; max-width: 1200px; margin: auto; padding-right: 320px !important;}
.shop .acms-grid > * {padding-right: 0 !important;}
.bg-gray,
.bg-gray-white {width: 100%; max-width: 100%; background: #F5F2E8; padding: 100px 320px 100px 0;}
.bg-gray-niigata {width: 100%; max-width: 100%; background: url("../img/common/niigata.svg") no-repeat #F5F2E8; background-size: 418px; background-position: calc(50% - 160px) 50%; padding: 50px 320px 50px 0;}
.bg-gray > *,
.bg-gray-niigata > *,
.bg-gray-white > * {width: 100%; max-width: 880px; margin: auto;}
.bg-gray-white > * {background: #FFF; margin-bottom: 0;}
.bg-gray-white > h2 {background: none;}
.bg-gray-white > h2 + p {border-radius: 40px 40px 0 0; padding-top: 40px !important;}
.bg-gray-white > hr:first-of-type + * {border-radius: 40px 40px 0 0; padding-top: 40px !important;}
.bg-gray-white > h2 + p + hr:first-of-type + * {border-radius: 0; padding-top: 0px !important;}
.bg-gray-white > *:last-child {border-radius: 0 0 40px 40px; padding-bottom: 40px !important;}
.bg-gray-white > .clearHidden {display: none;}

.bg-gray.no-pd {padding-top: 0; padding-bottom: 0;}
.bg-gray.no-pd > * {margin-bottom: 0;}
.bg-gray.no-pd + .bg-gray-white {padding-top: 40px;}

.bg-gray + .bg-gray-white {padding-top: 0;}

.bg-image {width: 100%; max-width: 100%; padding: 0 calc(50% - 340px) 0 0 !important;}
.bg-image > hr {display: none;}
.bg-image [class*=column-media] {width: 100%;}
.bg-image [class*=column-media] img {width: 100%;}

.lay-w730 {max-width: calc(730px + 320px); margin-left: auto; margin-right: auto;}


@media screen and (max-width: 1000px) {
	.acms-grid > * {padding-right: 0 !important;}
	.shop .acms-grid > * {padding-right: 0 !important;}
	.shop .acms-grid > .entry-container {padding-right: 10px !important;}
	.bg-gray,
	.bg-gray-niigata {padding: 50px 0 50px 0; background-position: 50% 50%; background-size: contain;}
	.bg-gray > *,
	.bg-gray-niigata > * {width: 100%; max-width: 880px;}
	.bg-gray-white > * {max-width: calc(100% - 20px);}
	
	.lay-w730 {max-width: calc(100% - 20px); margin-left: auto; margin-right: auto;}
}

@media screen and (max-width: 767px) {
    .acms-entry [class*=column-eximage], .acms-entry [class*=column-media], .acms-entry [class*=column-video], .acms-entry [class*=column-youtube]{padding: 0 10px !important;}
	
}


/* ---------------------------------------------------
	汎用ユニット
------------------------------------------------------ */

/* 見出し大 */
.entry-column h2 {font-weight: 700; font-style: normal; font-size: 38px; line-height: 1.5; color: #000; margin: 0 auto 50px; padding: 0 0 30px; border-left: none; letter-spacing: 0.1em; position: relative;}
.entry-column h2::after {content: ""; display: inline-block; position: absolute; left: 50%; bottom: 0; width: 85px; border-top: 5px solid #F8B500; transform: translateX(-50%); }
.entry-column .acms-grid > h2::after {left: calc(50% - 160px);}

.entry-column h2.green {font-size: 45px; color: #45B035; font-weight: bold; letter-spacing: 0.1em; text-align: center; padding-bottom: 0; margin-bottom: 30px;}
.entry-column h2.green::after {display: none;}
.entry-column h2.orange {font-size: 48px; color: #DC4F03; font-weight: bold; letter-spacing: 0.08em; text-align: center; padding-bottom: 0;}
.entry-column h2.orange::after {display: none;}
.entry-column h2.orange-line {font-size: 48px; color: #DC4F03; font-weight: bold; letter-spacing: 0.08em; text-align: center;}
.entry-column h2.orange-line::after {content: ""; display: inline-block; position: absolute; left: 50%; bottom: 0; width: 100%; max-width: 600px; height: 20px; border-top: none; background: url("../img/common/bg-h2.svg") no-repeat bottom center/contain; transform: translateX(-50%); }
.entry-column .acms-grid > h2.orange-line::after {left: calc(50% - 160px);}

.coating .entry-column h2.orange-line {font-size: 38px; color: #4C4948;}
.coating .entry-column h2.orange {line-height: 1.1;}


/* 見出し中 */
.entry-column h3 {font-weight: 500; font-style: normal; font-size: 32px; line-height: 1.5; color: #000; margin: 0 auto 30px; padding: 0; background: none; letter-spacing: 0.1em;}

.entry-column h3.blue-large {font-weight: 700; font-style: italic; font-size: 68px; line-height: 1.2; color: #182D7B; margin: 0 auto 30px; padding: 0; background: none; letter-spacing: 0.15em; text-align: center;}

.entry-column h3.bg-white {font-weight: 700; font-style: normal; font-size: 38px; line-height: 1.2; color: #000; margin: 0 auto 30px; padding: 0; background: none; letter-spacing: 0.1em; text-align: center;}
.entry-column h3.bg-white span {display: flex; justify-content: center; align-items: center; height: 65px; padding: 0; background: #FFF; text-align: center; margin: auto; position: relative; width: 100%; max-width: 600px;}
.entry-column h3.bg-white span::before {content: ""; display: inline-block; position: absolute; top: 0; left: 0; width: 16px; height: 65px; background: url("../img/common/icon_h3_01.svg") no-repeat top left/contain;}
.entry-column h3.bg-white span::after {content: ""; display: inline-block; position: absolute; top: 0; right: 0; width: 16px; height: 65px; background: url("../img/common/icon_h3_02.svg") no-repeat top right/contain;}

.coating .entry-column h3.bg-white {font-weight: 700; font-style: normal; font-size: 60px; line-height: 1.2; color: #DC4F03; margin: 0 auto 30px; padding: 0; background: none; letter-spacing: 0.1em; text-align: center;}
.coating .entry-column h3.bg-white span {display: flex; justify-content: center; align-items: center; height: 65px; padding: 0; background: #FFF; text-align: center; margin: auto; position: relative; width: 100%; max-width: 600px;}
.coating .entry-column h3.bg-white span::before {content: ""; display: inline-block; position: absolute; top: 0; left: 0; width: 16px; height: 65px; background: url("../img/common/icon_h3_01.svg") no-repeat top left/contain;}
.coating .entry-column h3.bg-white span::after {content: ""; display: inline-block; position: absolute; top: 0; right: 0; width: 16px; height: 65px; background: url("../img/common/icon_h3_02.svg") no-repeat top right/contain;}

.entry-column h3.lr-3line {font-weight: 700; font-size: 28px; line-height: 1.2;  margin: 0 auto 30px; padding: 0; background: none; letter-spacing: 0.15em; text-align: center;}
.entry-column h3.lr-3line span {display: flex; justify-content: center; align-items: center; padding: 0; text-align: center; margin: auto; position: relative; width: 100%; max-width: 730px;}
.entry-column h3.lr-3line span::before {content: ""; display: inline-block; position: absolute; top: 50%; left: 0; width: 120px; height: 11px; background: url("../img/common/icon_h3_3line.svg") no-repeat top left/contain; transform: translateY(-50%);}
.entry-column h3.lr-3line span::after {content: ""; display: inline-block; position: absolute; top: 50%; right: 0; width: 120px; height: 11px; background: url("../img/common/icon_h3_3line.svg") no-repeat top right/contain; transform: translateY(-50%);}

/* 見出し小 */
.entry-column h4 {font-weight: 400; font-style: normal; font-size: 24px; line-height: 1.4; color: #000; padding: 0; margin: 0 auto 20px; position: relative;}
.entry-column h4::before {content: ""; display: none;}

.entry-column h4.line {font-weight: 700; font-style: normal; font-size: 26px; line-height: 1.6; color: #000; padding: 0; margin: 0 auto 20px; position: relative; text-align: center;}
.entry-column h4.line span {display: inline-block; border: 3px solid #000; text-align: center; margin: auto; padding: 20px 40px;}

/* 小見出し */
.entry-column h5 {font-weight: 400; font-style: normal; font-size: 22px; line-height: 1.4; padding: 0; margin: 0 auto 20px;}

/* 本文 */
.entry-column p {line-height: 1.8; font-weight: 500; margin: 0 auto 40px; padding: 0;}
.entry-column p.w750 {max-width: calc(750px + 320px); letter-spacing: 0;}
.entry-column p.w730 {max-width: calc(730px + 320px); letter-spacing: 0;}
.entry-column p.w680 {max-width: calc(680px + 320px); letter-spacing: 0;}
.entry-column p.bg-red {width: 100%; max-width: 730px; background: #DC4F03; border-radius: 20px; font-size: 38px; font-weight: bold; color: #FFF; line-height: 1.6; text-align: center; padding: 40px 0; letter-spacing: 0.15em;}
.entry-column .bg-gray-white > p {padding: 0 100px; margin: 0 auto; padding-bottom: 40px;}
[class*=bg-] > p.w750 {max-width: 750px;}
[class*=bg-] > p.w730 {max-width: 730px;}
[class*=bg-] > p.w680 {max-width: 680px;}
.entry-column p .mainte {background: #DC4F03; color: #FFF;}

/* リスト */
.entry-column ul, .entry-column ol {padding: 0; margin: 0;}
.entry-column ul li, .entry-column ol li {padding: 0; margin: 0; font-size: 18px; font-size: 112.5%; line-height: 1.8;}

.entry-column ul { margin-bottom: 40px; list-style: none;}
.entry-column ul li { padding-left: 25px; background: url(../images/common/ico-li@2x.png) no-repeat 0 5px; background-size: 20px 20px;}

.entry-column ol {counter-reset: oldef; margin-bottom: 40px; list-style: none;}
.entry-column ol li { padding-left: 30px; position: relative;}
.entry-column ol li::before { counter-increment: oldef; content: counter(oldef); color: #000; font-family: "Noto Sans JP", sans-serif; font-style: normal; font-weight: 700; font-size: 20px; display: block; width: 25px; position: absolute; top: 0; left: 0; text-align: center; line-height: 1.5;}

.column-map-auto, .column-map-left {margin-bottom: 40px;}

/* ユニット内のボタン */
.btn-link{position: relative; display: block; width: 360px; max-width: 100%; padding: 25px 50px; border: 1px solid #000; color: #000; font-weight: bold; text-align: left; text-decoration: none; background-color: #FFF;}
.btn-link::after {content: ""; position: absolute; top: 50%; right: 40px; display: block; width: 9px; height: 15px; margin-top: -5px; background: url(../images/common/ico-arrow-cr@2x.png) no-repeat center; background-size: 100%;}
.entry-column .btn-link:hover,.entry-column .btn-link:active,.entry-column .btn-link:focus{text-decoration: none;}


@media screen and (max-width: 767px) {
    h2.entry-title {font-size: 28px; margin: 0 auto 20px; padding: 0 10px;}
    .entry-column h2 {font-size: 28px; margin: 0 auto 20px; padding: 0 10px 10px;}
	.entry-column h2.green {font-size: 32px; margin-bottom: 20px;}
	.entry-column h2.orange {font-size: 32px;}
	.entry-column h2.orange-line {font-size: 32px; padding-bottom: 15px;}
	.entry-column h2.orange-line::after {width: calc(100% - 20px); max-width: 600px;}
	.coating .entry-column h2.orange-line {font-size: 28px;}
/*    .entry-column h2 br {display: none;}*/
	.entry-column .acms-grid > h2::after {left: 50%;}
	.entry-column .acms-grid > h2.orange-line::after {left: 50%;}
    .entry-column h3 {font-size: 24px; margin: 0 auto 20px; padding: 0 10px;}
	.entry-column h3.blue-large {font-size: 34px; letter-spacing: 0.1em;}
	.entry-column h3.bg-white {font-size: 24px; max-width: calc(100% - 20px);}
	.entry-column h3.bg-white span {height: 50px; width: 100%; max-width: 600px;}
	.entry-column h3.bg-white span::before {width: 12px; height: 50px;}
	.entry-column h3.bg-white span::after {width: 12px; height: 50px;}
	.coating .entry-column h3.bg-white {font-size: 32px; max-width: calc(100% - 20px);}
	.coating .entry-column h3.bg-white span {height: 50px; width: 100%; max-width: 600px;}
	.coating .entry-column h3.bg-white span::before { width: 12px; height: 50px;}
	.coating .entry-column h3.bg-white span::after { width: 12px; height: 50px;}
	.entry-column h3.lr-3line {font-size: 24px; margin: 0 auto 20px; padding: 0 10px; letter-spacing: 0.1em;}
	.entry-column h3.lr-3line span { width: 100%; max-width: 100%;}
	.entry-column h3.lr-3line span::before {position: relative; top: 50%; left: 0; width: 30px; height: 11px; background: url("../img/common/icon_h3_3line.svg") no-repeat top left/cover; transform: translateY(-50%); margin-right: 15px;}
	.entry-column h3.lr-3line span::after {position: relative; top: 50%; right: 0; width: 30px; height: 11px; background: url("../img/common/icon_h3_3line.svg") no-repeat top right/cover; transform: translateY(-50%); margin-left: 15px;}
    .entry-column h4 {padding: 0 10px; font-size: 20px; }
    .entry-column h4::before {left: 0; top: 50%; width: 15px;}
	.entry-column h4.line span {padding: 20px 15px; font-size: 22px;}
    .entry-column h5 {padding: 0 10px; font-size: 22px; margin: 0 auto 10px;}
    .entry-column p {padding: 0 10px !important; margin-bottom: 20px;}
	.entry-column p.bg-red {width: calc(100% - 20px); border-radius: 10px; font-size: 20px; padding: 20px 0; }
	.entry-column .bg-gray-white > p {padding: 0 10px; padding-bottom: 20px !important;}
	.company .entry-column p.w750 span {font-size: 16px;}
    
    .entry-column ul,
    .entry-column ol { margin-bottom: 40px; padding: 0 10px;}
    
    .column-map-auto, .column-map-left {margin-bottom: 20px;}
    
    .entry-column p iframe {width: 100%;}
    .gmap iframe {width: 100%;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
}




/* ---------------------------------------------------
	流れ用：数字付き見出し
------------------------------------------------------ */
.entry-column h3.tit-flow {border-left: none; counter-increment: flow; position: relative; padding-left: 54px; font-weight: bold; line-height: 1.4;}
.entry-column h3.tit-flow::before {content: counter(flow); position: absolute; top: 50%; left: 0; min-width: 40px; height: 40px; text-align: center; line-height: 40px; color: #FFF; font-size: 24px; font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: bold; background: #06799E; margin-top: -20px;}
/*.entry-column h3.tit-flow::before {content: counter(flow, decimal-leading-zero); position: absolute; bottom: 0; left: 0; min-width: 44px; height: 44px; text-align: center; line-height: 44px; color: #00469C; font-size: 44px; font-family: Arial, Helvetica, "sans-serif"; font-weight: bold;} */

@media screen and (max-width: 767px) {
.entry-column h3.tit-flow {padding-left: 59px;}
.entry-column h3.tit-flow::before {top: 50%; left: 5px;} 
}

/* ---------------------------------------------------
	テキストリンク
------------------------------------------------------ */
.txt-link {justify-content: flex-start; margin-bottom: 40px;}
.txt-link.row-l {justify-content: flex-start;}
.txt-link.row-c {justify-content: center;}
.txt-link.row-r {justify-content: flex-end;}
.txt-link .row_col {display: inline-block; margin-right: 60px; margin-bottom: 20px;}
.txt-link.row-l .row_col {text-align: left;}
.txt-link.row-c .row_col {text-align: center;}
.txt-link.row-r .row_col {text-align: right;}
.txt-link.num-1 .row_col {display: inline-block; width: 100%; margin-right: 0;}
.txt-link.num-2 .row_col {display: inline-block; width: 49%; margin-right: 2%;}
.txt-link.num-2 .row_col:nth-child(2n),
.txt-link.num-2 .row_col:last-child {margin-right: 0;}
.txt-link.num-3 .row_col {display: inline-block; width: 32%; margin-right: 2%;}
.txt-link.num-3 .row_col:nth-child(3n),
.txt-link.num-3 .row_col:last-child {margin-right: 0;}
.txt-link.num-4 .row_col {display: inline-block; width: 23.5%; margin-right: 2%;}
.txt-link.num-4 .row_col:nth-child(4n),
.txt-link.num-4 .row_col:last-child {margin-right: 0;}
.txt-link .row_col a { position: relative; display: inline-block; padding: 2px 0 2px 30px; color: #002BA2; line-height: 1.2; text-align: left; text-decoration: underline;}
.txt-link .row_col a::before { content: ""; position: absolute; top: 50%; left: 0; display: block; width: 20px; height: 20px; margin-top: -10px; margin-right: 10px; background: url("../images/common/ico-link@2x.png") no-repeat center; background-size: 100%;}
.txt-link .row_col.blank a::after { content: ""; display: inline-block; width: 16px; height: 16px; vertical-align: middle; margin-left: 10px; background: url(../images/common/ico-blank@2x.png) no-repeat center; background-size: cover;}
.txt-link .row_col a:hover {text-decoration: none;}

@media screen and (max-width: 767px) {
	.txt-link {padding: 0 10px; margin-bottom: 20px;}
	.txt-link.num-2 .row_col {width: 100%; margin-right: 0;}
	.txt-link.num-3 .row_col {width: 100%; margin-right: 0;}
	.txt-link.num-4 .row_col {width: 100%; margin-right: 0;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .txt-link{padding: 0 10px;}
}

/* ---------------------------------------------------
	ボタンリンク
------------------------------------------------------ */
.btnlink {justify-content: flex-start; margin-bottom: 60px;}
.btnlink.row-l {justify-content: flex-start; text-align: left;}
.btnlink.row-c {justify-content: center; text-align: center;}
.btnlink.row-r {justify-content: flex-end; text-align: right;}
.btnlink.num-1 {display: inline-block; width: 100%;}

.btnlink .row_col { width: auto; max-width: 100%; margin-bottom: 20px;}
.btnlink.num-1 .row_col {max-width: fit-content;}
.btnlink.row-l.num-1 .row_col {margin-right: auto;}
.btnlink.row-c.num-1 .row_col {margin-right: auto; margin-left: auto;}
.btnlink.row-r.num-1 .row_col {margin-left: auto;}
.btnlink.num-2 .row_col { width: 49%; max-width: 49%; margin-right: 2%;}
.btnlink.num-2 .row_col:nth-child(2n),
.btnlink.num-2 .row_col:last-child {margin-right: 0;}
.btnlink.num-3 .row_col { width: 32%; max-width: 32%; margin-right: 2%;}
.btnlink.num-3 .row_col:nth-child(3n),
.btnlink.num-3 .row_col:last-child {margin-right: 0;}
.btnlink.num-4 .row_col { width: 23.5%; max-width: 23.5%; margin-right: 2%;}
.btnlink.num-4 .row_col:nth-child(4n),
.btnlink.num-4 .row_col:last-child {margin-right: 0;}

.btnlink .row_col a {position: relative; display: inline-block; min-width: 0; width: 100%; max-width: 100%; padding: 25px 50px; border: 1px solid #000; color: #000; font-weight: bold; text-align: left; text-decoration: none; background-color: #FFF;}
.btnlink .row_col a::after { content: ""; position: absolute; top: 50%; right: 30px; display: block; width: 9px; height: 15px; margin-top: -5px; background: url(../images/common/ico-arrow-cr@2x.png) no-repeat center; background-size: 100%;}
.btnlink .row_col.blank a::after { content: ""; position: absolute; top: 50%; right: 30px; display: block; width: 16px; height: 16px; margin-top: -8px; background: url(../images/common/ico-blank@2x.png) no-repeat center; background-size: 100%;}
.btnlink .row_col a.icon-pdf,
.btnlink .row_col.blank a[href$=".pdf"],
.btnlink .row_col a.icon-doc,
.btnlink .row_col.blank a[href$=".doc"],
.btnlink .row_col.blank a[href$=".docx"],
.btnlink .row_col a.icon-xls,
.btnlink .row_col.blank a[href$=".xls"],
.btnlink .row_col.blank a[href$=".xlsx"],
.btnlink .row_col a.icon-ppt,
.btnlink .row_col.blank a[href$=".ppt"],
.btnlink .row_col.blank a[href$=".pptx"],
.btnlink .row_col a.icon-file {padding: 25px 40px 25px 70px;}
.btnlink .row_col a.icon-pdf::before,
.btnlink .row_col.blank a[href$=".pdf"]::before {content: ""; display: block; position: absolute; top: 50%; left: 30px; width: 23.5px; height: 30px; margin-top: -15px; background: url(../images/common/ico-pdf.png) no-repeat center; background-size: 100%;}
.btnlink .row_col a.icon-doc::before,
.btnlink .row_col.blank a[href$=".doc"]::before,
.btnlink .row_col.blank a[href$=".docx"]::before {content: ""; display: block; position: absolute; top: 50%; left: 30px; width: 23.5px; height: 30px; margin-top: -15px; background: url(../images/common/ico-doc.png) no-repeat center; background-size: 100%;}
.btnlink .row_col a.icon-xls::before,
.btnlink .row_col.blank a[href$=".xls"]::before,
.btnlink .row_col.blank a[href$=".xlsx"]::before {content: ""; display: block; position: absolute; top: 50%; left: 30px; width: 23.5px; height: 30px; margin-top: -15px; background: url(../images/common/ico-xls.png) no-repeat center; background-size: 100%;}
.btnlink .row_col a.icon-ppt::before,
.btnlink .row_col.blank a[href$=".ppt"]::before,
.btnlink .row_col.blank a[href$=".pptx"]::before {content: ""; display: block; position: absolute; top: 50%; left: 30px; width: 23.5px; height: 30px; margin-top: -15px; background: url(../images/common/ico-ppt.png) no-repeat center; background-size: 100%;}
.btnlink .row_col a.icon-file::before {content: ""; display: block; position: absolute; top: 50%; left: 30px; width: 19px; height: 28px; margin-top: -14px; background: url(../images/common/ico-shorui.png) no-repeat center; background-size: 100%;}

/* アンカーリンクの設定 */
.btnlink .row_col a[href^="#"] {padding: 20px 20px 30px; text-align: center;}
.btnlink .row_col a[href^="#"]::after {content: ""; position: absolute; top: auto; right: auto; left: 50%; bottom: 12px; display: block; width: 20px; height: 10px; margin-left: -10px; background: url(../images/common/ico-arrow-bb@2x.png) no-repeat center; background-size: 100%; transition: transform .2s;}
.btnlink .row_col a[href^="#"]:hover {opacity: 1;}
.btnlink .row_col a[href^="#"]:hover::after {transform: translateY(2px);}

@media screen and (max-width: 767px) {
    .btnlink {display: block; margin-bottom: 30px; padding: 0 10px;}
    .btnlink .row_col { width: 100%; max-width: 100%; margin-right: 0; margin-bottom: 10px;}
    .btnlink .row_col:last-of-type {margin-bottom: 0;}
	.btnlink.num-2 .row_col { width: 100%; max-width: 100%; margin-right: 0;}
	.btnlink.num-3 .row_col { width: 100%; max-width: 100%; margin-right: 0;}
	.btnlink.num-4 .row_col { width: 100%; max-width: 100%; margin-right: 0;}
    .btnlink .row_col a {padding: 20px 50px;}
    .btnlink .row_col a::after {right: 30px;}
    .btnlink .row_col.blank a::after {right: 25px;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .btnlink{padding: 0 10px;}
    .btnlink .row_col a{padding: 25px;}
    .btnlink .row_col a::after{right: 10px;}
    .btnlink .row_col.blank a::after{right: 10px;}
    /* ファイルアイコン */
    .btnlink .row_col a.icon-pdf, .btnlink .row_col.blank a[href$=".pdf"], .btnlink .row_col a.icon-doc, .btnlink .row_col.blank a[href$=".doc"], .btnlink .row_col.blank a[href$=".docx"], .btnlink .row_col a.icon-xls, .btnlink .row_col.blank a[href$=".xls"], .btnlink .row_col.blank a[href$=".xlsx"], .btnlink .row_col a.icon-ppt, .btnlink .row_col.blank a[href$=".ppt"], .btnlink .row_col.blank a[href$=".pptx"], .btnlink .row_col a.icon-file{padding: 25px 36px 25px 40px;}
    /* ー＊ー＊ー＊ー＊ー */
    .btnlink .row_col a.icon-pdf::before, .btnlink .row_col.blank a[href$=".pdf"]::before{left: 10px;}
    .btnlink .row_col a.icon-doc::before, .btnlink .row_col.blank a[href$=".doc"]::before, .btnlink .row_col.blank a[href$=".docx"]::before{left:10px;}
    .btnlink .row_col a.icon-xls::before, .btnlink .row_col.blank a[href$=".xls"]::before, .btnlink .row_col.blank a[href$=".xlsx"]::before{left: 10px;}
    .btnlink .row_col.blank a::after{right:10px}
    .btnlink .row_col a.icon-ppt::before, .btnlink .row_col.blank a[href$=".ppt"]::before, .btnlink .row_col.blank a[href$=".pptx"]::before{left: 10px;}
    .btnlink .row_col a.icon-file::before{left: 10px;}
}


/* ---------------------------------------------------
	コラム
------------------------------------------------------ */
.column_unit {width: 100%; margin: 0 auto 60px;}
.column_unit > .box {width: 100%; border: 1px solid #000; padding: 40px; box-sizing: border-box; background: #FFF; display: flex; justify-content: space-between; align-items: stretch; flex-wrap: nowrap;}
.column_unit > .box .txt {width: 100%;}
.column_unit > .box .txt p {margin-bottom: 0;}
.column_unit > .box .img {width: 30%; max-width: 360px; margin-left: 40px;}

/* 重要なコラムの設定 */
.column_unit.column_important > .box {border: 4px solid #B10404;}
.column_unit.column_important > .box .txt h2,
.column_unit.column_important > .box .txt h3,
.column_unit.column_important > .box .txt h4 {color: #B10404;}

@media screen and (max-width: 767px) {
    .column_unit {width: calc(100% - 20px); margin: 0 auto 30px;}
    .column_unit > .box {display: block; width: 100%; padding: 20px;}
    .column_unit > .box .txt {margin-bottom: 20px;}
    .column_unit > .box .txt p {padding: 0; margin-bottom: 0;}
    .column_unit > .box .img {width: 100%; max-width: 100%; margin-left: 0;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
}

/* ---------------------------------------------------
	コラム：注意文
------------------------------------------------------ */
.column_caution {width: 100%; border: 4px solid #B10404; padding: 40px; box-sizing: border-box; margin: 0 auto 60px;}
.column_caution h4 {color: #B10404;}
.column_caution > .box {display: flex; justify-content: space-between; align-items: stretch; width: 100%; margin-bottom: 40px;}
.column_caution > .box:last-child {margin-bottom: 0;}
.column_caution > .box .txt {}
.column_caution > .box .txt p {margin-bottom: 0;}
.column_caution > .box .txt.onimg {width: calc(100% - 35.8% - 40px);}
.column_caution > .box .img {width: 35.8%; max-width: 400px; margin-left: 40px;}

@media screen and (max-width: 767px) {
    .column_caution {width: calc(100% - 20px); padding: 20px; margin: 0 auto 30px;}
    .column_caution > .box {display: block; width: 100%; margin-bottom: 40px;}
    .column_caution > .box:last-child {}
    .column_caution > .box .txt {margin-bottom: 20px;}
    .column_caution > .box .txt p {padding: 0; margin-bottom: 0;}
    .column_caution > .box .txt.onimg {width: 100%;}
    .column_caution > .box .img {width: 100%; max-width: 100%; margin-left: 0;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .column_caution{width: calc(100% - 80px);}
    .entry-column .column_caution h4{width:100%;}
    .entry-column .column_caution p{padding: 0;}
}

/* ---------------------------------------------------
	コラム：標準
------------------------------------------------------ */
.column_standard {width: 100%; border: 1px solid #000; padding: 40px; box-sizing: border-box; margin: 0 auto 60px; background: #FFF;}
.column_standard h4 {}
.column_standard > .box {display: flex; justify-content: space-between; align-items: stretch; width: 100%; margin-bottom: 40px;}
.column_standard > .box:last-child {margin-bottom: 0;}
.column_standard > .box .txt {}
.column_standard > .box .txt p {margin-bottom: 0;}
.column_standard > .box .txt.onimg {width: calc(100% - 35.8% - 40px);}
.column_standard > .box .img {width: 35.8%; max-width: 400px; margin-left: 40px;}

@media screen and (max-width: 767px) {
    .column_standard {width: calc(100% - 20px); padding: 20px; margin: 0 auto 30px;}
    .column_standard > .box {display: block; width: 100%; margin-bottom: 40px;}
    .column_standard > .box:last-child {margin-bottom: 0;}
    .column_standard > .box .txt {margin-bottom: 20px;}
    .column_standard > .box .txt p {padding: 0; margin-bottom: 0;}
    .column_standard > .box .txt.onimg {width: 100%;}
    .column_standard > .box .img {width: 100%; max-width: 100%; margin-left: 0;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .column_standard{width: calc(100% - 80px);}
    .entry-column .column_standard h4{width:100%;}
    .entry-column .column_standard p{padding: 0;}
}
/* ---------------------------------------------------
	画像＋テキスト（左右配置）
------------------------------------------------------ */
.border-caution {width: 100%; border: 4px solid #B10404; padding: 40px; box-sizing: border-box; margin: 0 auto 60px;}
.border-standard {width: 100%; border: 1px solid #000; padding: 40px; box-sizing: border-box; margin: 0 auto 60px; background: #FFF;}
.pic_txt {margin-bottom: 60px;}
.border-caution .pic_txt,
.border-standard .pic_txt {margin-bottom: 0;}
.pic_txt .row_pic {width: 50%; max-width: 600px;}
.pic_txt .row_pic.row_pic_w30 {width: 30%; max-width: 360px;}
.pic_txt .row_pic.row_pic_w40 {width: 40%; max-width: 480px;}
.pic_txt .row_pic.row_pic_w60 {width: 60%; max-width: 720px;}
.pic_txt .row_pic.row_pic_w70 {width: 70%; max-width: 840px;}
.pic_txt.pic_right .row_pic {width: 50%; max-width: 600px; order: 10;}
.pic_txt.pic_right .row_pic.row_pic_w30 {width: 30%; max-width: 360px; order: 10;}
.pic_txt.pic_right .row_pic.row_pic_w40 {width: 40%; max-width: 480px; order: 10;}
.pic_txt.pic_right .row_pic.row_pic_w60 {width: 60%; max-width: 720px; order: 10;}
.pic_txt.pic_right .row_pic.row_pic_w70 {width: 70%; max-width: 840px; order: 10;}
.pic_txt .row_pic img {}
.pic_txt .row_pic img + img {margin-top: 20px;}
.pic_txt .row_txt {width: 46.667%; max-width: 560px;}
.pic_txt .row_txt.row_txt_w66 {width: 66.667%; max-width: 790px;}
.pic_txt .row_txt.row_txt_w56 {width: 56.667%; max-width: 670px;}
.pic_txt .row_txt.row_txt_w36 {width: 36.667%; max-width: 440px;}
.pic_txt .row_txt.row_txt_w26 {width: 26.667%; max-width: 320px;}
.pic_txt .row_txt p {margin-bottom: 0;}
.pic_txt .row_txt .txt_btn {margin-top: 40px; text-align: left;}
.pic_txt .row_txt .txt_btn a { position: relative; display: block; width: 360px; max-width: 100%; padding: 25px 50px; border: 1px solid #000; color: #000; font-weight: bold; text-align: left; text-decoration: none; background-color: #FFF;}
.pic_txt .row_txt .txt_btn a::after { content: ""; position: absolute; top: 50%; right: 40px; display: block; width: 9px; height: 15px; margin-top: -5px; background: url(../images/common/ico-arrow-cr@2x.png) no-repeat center; background-size: 100%;}

@media screen and (max-width: 767px) {
	.border-caution {padding: 10px; margin: 0 auto 30px; width: calc(100% - 20px);}
	.border-standard {padding: 10px;margin: 0 auto 30px; width: calc(100% - 20px);}
    .entry-column .content_row .row_txt h2{padding: 0;}
    .border-caution .pic_txt .row_txt{padding: 0;}
    .border-standard .pic_txt .row_txt{padding: 0;}
    .pic_txt {margin-bottom: 30px;}
    .pic_txt .row_pic {width: 100%; max-width: 100%; margin-bottom: 20px; text-align: center;}
    .pic_txt .row_pic.row_pic_w30 {width: 100%; max-width: 100%;}
    .pic_txt .row_pic.row_pic_w40 {width: 100%; max-width: 100%;}
    .pic_txt .row_pic.row_pic_w60 {width: 100%; max-width: 100%;}
    .pic_txt .row_pic.row_pic_w70 {width: 100%; max-width: 100%;}
    .pic_txt.pic_right .row_pic {width: 100%; max-width: 100%; order: 0;}
    .pic_txt.pic_right .row_pic.row_pic_w30 {width: 100%; max-width: 100%; order: 0;}
    .pic_txt.pic_right .row_pic.row_pic_w40 {width: 100%; max-width: 100%; order: 0;}
    .pic_txt.pic_right .row_pic.row_pic_w60 {width: 100%; max-width: 100%; order: 0;}
    .pic_txt.pic_right .row_pic.row_pic_w70 {width: 100%; max-width: 100%; order: 0;}
    .pic_txt .row_txt {width: 100%; max-width: 100%; padding: 0 10px;}
    .pic_txt .row_txt.row_txt_w66 {width: 100%; max-width: 100%;}
    .pic_txt .row_txt.row_txt_w56 {width: 100%; max-width: 100%;}
    .pic_txt .row_txt.row_txt_w36 {width: 100%; max-width: 100%;}
    .pic_txt .row_txt.row_txt_w26 {width: 100%; max-width: 100%;}
    .pic_txt .row_txt p {padding: 0;}
    .pic_txt .row_txt .txt_btn {margin-top: 40px; text-align: left;}
    .pic_txt .row_txt .txt_btn a {width: 100%; padding: 20px 50px;}
    .pic_txt .row_txt .txt_btn a::after {right: 30px;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .pic_txt .row_txt{padding: 0;}
    .entry-column .content_row{padding: 0 40px;}
    .entry-column .content_row h2{padding: 0; font-size: 30px;}
    .entry-column .content_row h3{padding:0; font-size: 28px;}
    .entry-column .content_row h4{width:100%;}
    .entry-column .content_row h5{padding: 0;}
    .entry-column .content_row p{padding: 0; font-size: 16px;}

    .border-caution{width:calc(100% - 80px); padding: 20px;}
    .entry-column .border-caution .content_row,.entry-column .border-standard .content_row{padding: 0;}
    .pic_txt .row_txt_w26 .txt_btn a{padding: 25px 16px;}
    .pic_txt .row_txt_w26 .txt_btn a::after{right: 20px;}
    
    .border-standard{width:calc(100% - 80px); padding: 20px;}
    .pic_txt .row_txt_w26 .txt_btn a{padding: 25px 16px;}
    .pic_txt .row_txt_w26 .txt_btn a::after{right: 20px;}
	
    .coating .entry-column .content_row{padding: 0;}
}

/* ---------------------------------------------------
	画像＋テキスト（画像に重ねて配置）
------------------------------------------------------ */
.pic_ontxt {margin-bottom: 60px;}
.pic_ontxt .img {width: 100%; position: relative;}
.pic_ontxt .txt {width: calc(100% - 100px); margin: -150px auto 0; background: rgba(238,238,238,0.9); padding: 50px; position: relative;}
.pic_ontxt .txt h3 {margin-top: 0; margin-bottom: 30px;}
.pic_ontxt .txt p {margin-bottom: 0;}

@media screen and (max-width: 767px) {
    .pic_ontxt {margin-bottom: 30px;}
    .pic_ontxt .img {width: 100%; position: relative;}
    .pic_ontxt .txt {width: calc(100% - 20px); margin: -50px auto 0; padding: 20px;}
    .pic_ontxt .txt h3 {margin-bottom: 20px;}
    .pic_ontxt .txt p {margin-bottom: 0;}
}

/* ---------------------------------------------------
	画像＋テキスト（縦：2分割）※センターから表示する
------------------------------------------------------ */
.box_row2 {justify-content: space-between; margin-bottom: 40px;}
.box_row2 h4 {margin-bottom: 10px;}
.box_row2 .row_col { width: 580px; max-width: 48.333%; margin-bottom: 40px;}
/*.box_row2 .row_col:nth-last-of-type(2),.box_row2 .row_col:nth-last-of-type(2) ~ .row_col {margin-bottom: 0;}*/
.box_row2 .row_col .col_pic { margin-bottom: 20px; text-align: center;}
.box_row2 .row_col .col_txt p {padding: 0;}

.coating .box_row2 {max-width: 730px;}
.coating .box_row2 .row_col {width: 325px; max-width: 44.5204%;}

@media screen and (max-width: 767px) {
  .box_row2 h4 {margin-bottom: 10px;}
  .box_row2 .row_col { width: 100%; max-width: 100%; margin-bottom: 20px;}
  .box_row2 .row_col .col_pic { margin-bottom: 15px;}
  .box_row2 .row_col + .row_col { margin-top: 30px;}
  .box_row2 .row_col .col_txt{padding: 0 10px;}
	
	.coating .box_row2 {max-width: 100%; padding: 0 10px;}
	.coating .box_row2 .row_col {width: 325px; max-width: 47%;}
  .coating .box_row2 .row_col + .row_col { margin-top: 0;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .box_row2 .row_col .col_txt{padding: 0;}
}

/* ---------------------------------------------------
	画像＋テキスト（縦：3分割）※センターから表示する
------------------------------------------------------ */
.box_row3 {justify-content: center; margin-bottom: 40px;}
.box_row3 h4 {margin-bottom: 10px;}
.box_row3 .row_col { width: 373px; max-width: 31.084%; margin-right: 3.37%; margin-bottom: 40px;}
.box_row3 .row_col:nth-of-type(3n) { margin-right: 0;}
.box_row3 .row_col:last-of-type { margin-right: 0;}
/*.box_row3 .row_col:nth-last-of-type(3),.box_row3 .row_col:nth-last-of-type(3) ~ .row_col {margin-bottom: 0;}*/
.box_row3 .row_col .col_pic { margin-bottom: 15px; text-align: center;}
.box_row3 .row_col .col_pic img {}
.box_row3 .row_col .col_txt p.stit {color: #45B035; font-size: 15px; font-weight: bold; margin-bottom: 15px;}
.box_row3 .row_col .col_txt h3 {color: #DC4F03; font-size: 28px; font-weight: bold; text-align: center; line-height: 1.5; margin-bottom: 20px; text-decoration: underline;}
.box_row3 .row_col .col_txt h4 {font-size: 15px; font-weight: bold; line-height: 1.6; margin-bottom: 15px;}
.box_row3 .row_col .col_txt p {margin: 0; line-height: 1.6; margin-bottom: 15px;}
.box_row3 .row_col .col_btn {margin-top: 20px; text-align: left;}
.box_row3 .row_col .col_btn a {display: inline-block; border: 1px solid #0EA7AC; padding: 20px 20px; text-decoration: none; width: 100%; min-width: 360px;}
.box_row3 .row_col .col_btn a::before {content: url(../images/common/ico-arrow-cr.png); margin-right: 10px;}

.bg-gray-niigata > .box_row3 .row_col {margin-bottom: 0;}

.maintenance .bg-gray .box_row3 {max-width: 750px;}

.member .box_row3 .row_col {width: 250px; margin-right: 65px;}
.member .box_row3 .row_col:nth-of-type(3n) { margin-right: 0;}
.member .box_row3 .row_col:last-of-type { margin-right: auto;}

.coating .box_row3 {max-width: calc(730px + 320px);}
.coating .box_row3 .row_col .col_txt h3 {text-decoration: none; font-size: 25px;}
.coating .box_row3 .row_col .col_txt p {max-width: 205px; margin: 0 auto; font-size: 18px; font-weight: 500; line-height: 1.666;}


@media screen and (max-width: 1280px) {
	.member .box_row3 .row_col {width: calc(100vw * (250 / 1280)); margin-right: calc(100vw * (45 / 1280));}
	.member .box_row3 .row_col:nth-of-type(3n) { margin-right: 0;}
}
@media screen and (max-width: 1000px) {
	.member .box_row3 .row_col {width: calc(100vw * (250 / 1000)); margin-right: calc(100vw * (34 / 1000));}
	.member .box_row3 .row_col:nth-of-type(3n) { margin-right: 0;}
}

@media screen and (max-width: 767px) {
    .box_row3 {margin-bottom: 50px;}
    .box_row3 h4 {margin-bottom: 10px; font-size: 24px;}
    .box_row3 .row_col {width: 100%; max-width: 100%; margin-right: 0;}
    .box_row3 .row_col:last-of-type { margin-bottom: 0;}
    .box_row3 .row_col .col_pic {margin-bottom: 15px;}
    .box_row3 .row_col .col_txt {padding: 0;}
	.box_row3 .row_col .col_txt p.stit {font-size: 15px; margin-bottom: 15px;}
	.box_row3 .row_col .col_txt h3 {font-size: 24px; margin-bottom: 15px;}
	
	.bg-gray-niigata .box_row3 {margin-bottom: 0;}
	.bg-gray-niigata .box_row3 .row_col { width: 373px; max-width: 31.084%; margin-right: 3.37%; margin-bottom:0;}
	.bg-gray-niigata .box_row3 .row_col:last-of-type {margin-right: 0;}

    .entry-column .box_row2 h4{width: 100%;}
    .entry-column .box_row3 h4{width: calc(100% - 20px);}
    .entry-column .box_row4 h5{padding: 0 10px;}
	
	.member .box_row3 {padding: 0 10px;}
    .member .box_row3 .row_col {width: 49%; max-width: 49%; margin-right: 2%;}
    .member .box_row3 .row_col:nth-child(3n) { margin-right: 2%;}
    .member .box_row3 .row_col:nth-child(2n) { margin-right: 0;}
	.member .box_row3 .row_col:last-of-type { margin-right: auto;}
    .member .box_row3 .row_col .col_pic {margin-bottom: 10px;}
	.member .box_row3 .row_col .col_txt h4 {padding: 0; width: 100%; font-size: 14px;}
	.member .box_row3 .row_col .col_txt p {padding: 0 !important;}
	.member .box_row3 .row_col .col_txt p.stit {margin-bottom: 10px;}
	
	.coating .box_row3 {max-width: 100%;}
	.coating .box_row3 .row_col .col_txt h3 {font-size: 25px;}
	.coating .box_row3 .row_col .col_txt p {max-width: 100%; font-size: 18px;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .box_row3 .row_col .col_txt{padding: 0;}
    .entry-column .box_row3 h4{width:100%;}
}


/* ---------------------------------------------------
	画像＋テキスト（縦：4分割）※センターから表示する
------------------------------------------------------ */
.box_row4 { justify-content: center; margin-bottom: 40px;}
.box_row4 h5 {font-size: 15px; margin-bottom: 15px;}
.box_row4 p {font-size: 15px; line-height: 1.6;}
.box_row4 .row_col { width: 22.5%; margin-right: 3.33%; margin-bottom: 40px;}
.box_row4 .row_col:nth-of-type(4n) { margin-right: 0;}
.box_row4 .row_col:last-of-type { margin-right: 0;}
/*.box_row4 .row_col:nth-last-of-type(4),.box_row4 .row_col:nth-last-of-type(4) ~ .row_col { margin-bottom: 0;}*/
.box_row4 .row_col .col_pic { margin-bottom: 15px; text-align: center;}
.box_row4 .row_col .col_pic img {}

@media screen and (max-width: 767px) {
    .box_row4 {margin-bottom: 50px; justify-content: space-between;}
    .box_row4 h5 {font-size: 20px; margin-bottom: 10px; margin-left: 0; margin-right: 0; text-align: left;}
    .box_row4 .row_col {width: 100%; max-width: 100%; margin-right: 0;}
    .box_row4 .row_col:last-of-type { margin-bottom: 0;}
    .box_row4 .row_col .col_pic {margin-bottom: 15px;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .box_row4 .row_col .col_txt h5{padding: 0;}
}


/* ---------------------------------------------------
	テーブル（ｗ100％）
------------------------------------------------------ */
/* デフォルトパーツ */
.column-table- { width: 100%; margin: 0 auto 40px;}

.column-table- table {width: 100%; border-spacing: 0; border-collapse: collapse; empty-cells: show; table-layout: fixed; background: #FFF;}
.column-table- table th, .column-table- table td { padding: 20px; border: 1px solid #CCCCCC; vertical-align: middle;}
.column-table- table th { width: 25%; background: #00316D; text-align: left; font-weight: bold; border-bottom: 1px solid #FFF; color: #FFF;}

@media screen and (max-width: 767px) {
    /* デフォルトパーツ */
    .column-table- { margin: 0 auto 20px;}
	.column-table- table th, .column-table- table td { padding: 10px; font-size: 1em;}
    .column-table- table th { width: 100%; border-bottom: none;}

    .column-table- table.js-table-unit-scroll-hint {table-layout: auto;}
    .column-table- table.acms-table-scrollable {table-layout: auto;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
    .column-table-{padding: 0 40px;}
    .acms-entry .entry-container{padding: 0;}
}


/* --------------------------------------------------- オプション --------------------------------------------------- */

/* ---------------------------------------------------
	スタッフ紹介
------------------------------------------------------ */
.staff-detail {display: flex; justify-content: flex-start; flex-wrap: wrap; max-width: 1200px; margin: 0 auto;}
.staff-detail::before, .staff-detail::after {display: none;}
.staff-detail .staff-img {text-align: center;}
 .entry-column .staff-detail .staff-name {font-size: 22px; text-align: center; margin-bottom: 10px; padding-top: 25px;}
 .entry-column .staff-detail .staff-name::before {display: none;}
.staff-detail .staff-name-en {font-size: 16px; text-align: center; margin-bottom: 5px;}
.staff-detail .staff-detail-list { width: 31.667%; max-width: 380px; margin-right: 2.5%; margin-bottom: 40px;}
.staff-detail .staff-detail-list:nth-of-type(3n) { margin-right: 0;}
.staff-detail .staff-detail-list:last-of-type { margin-right: 0;}
.staff-detail .staff-detail-list tr {border-bottom: 1px solid #000;}
.staff-detail .staff-detail-list th {padding: 20px 0 15px 0; margin-bottom: 20px; text-align: left; font-weight: bold; width: 110px;}
.staff-detail .staff-detail-list td {padding: 20px 0 15px 0; margin-bottom: 20px; text-align: left; width: 270px;}
.staff-detail .staff-detail-list .staff-txt-l th {display: block; width: 100%; padding-bottom: 0; margin-bottom: 0;}
.staff-detail .staff-detail-list .staff-txt-l td {display: block; width: 100%;}

@media screen and (max-width: 767px) {
    .staff-detail .staff-detail-list { width: 100%; max-width: 100%; margin-right: 0;}
    .staff-detail .staff-detail-list th {display: block; padding: 15px 0 15px 0; margin-bottom: 0; text-align: left; font-weight: bold; width: 100%; border-top: none;}
    .staff-detail .staff-detail-list td {display: block; padding: 15px 0 15px 0; margin-bottom: 20px; text-align: left; width: 100%; border-top: none;}
    .staff-detail .staff-detail-list .staff-txt-l th {padding-bottom: 15px; margin-bottom: 0;}
}

/* ---------------------------------------------------
	Q&A
------------------------------------------------------ */
.faq-group {max-width: 880px; margin: 0 auto 40px;}
.faq-group h2 {width: 100%; text-align: center; background: rgba(42,24,0,0.05); padding: 5px 0; cursor: pointer;}
.faq-group h2::after {content: ""; display: inline-block; width: 29px; height: 17px; background: url("../images/common/ico-arrow-bb@2x.png") no-repeat center; background-size: cover; transition: all 0.4s ease-in-out; -webkit-transform: rotate(0deg); transform: rotate(0deg); margin: 0 0 3px 20px;}
.faq-group h2.open::after {-webkit-transform: rotate(180deg); transform: rotate(180deg);}
.faq-group-contents {display: none;}
.faq-group-contents .faq-content {margin-bottom: 30px;}
.faq-content {max-width: 1200px; margin: 0 auto; margin-bottom: 40px;}
.faq-content .faq-q { position: relative; text-align: center; font-size: 38px; margin-bottom: 30px; font-feature-settings: "palt"; letter-spacing: 0.02em;}
.faq-content .faq-q::before { content: 'Q'; display: block; text-align: center;}
.faq-content .faq-a { position: relative; font-size: 22px; font-weight: 500; line-height: 1.7;}

@media screen and (max-width: 767px) {
	.faq-content .faq-q {font-size: 22px; margin-bottom: 20px;}
	.faq-content .faq-a {font-size: 18px;}
}

/* ---------------------------------------------------
	流れ・手順用
------------------------------------------------------ */
.custom-flow {counter-reset: flownum;}
.flow-box {position: relative; padding: 40px 10px;}
.flow-box:nth-child(2n) {background: rgba(42,24,0,0.05);}
.flow-box h2 {padding-left: 50px; position: relative; margin-bottom: 20px;}
.flow-box h2::before {counter-increment: flownum; content: counter(flownum,decimal-leading-zero); position: absolute; top: 0; left: 0; margin-top: 0; letter-spacing: 0.1em; font-size: 40px; font-family: "Times New Roman", Times, "serif"; font-weight: bold;}
.flow-content {display: flex; justify-content: space-between; width: 100%; max-width: 1200px; margin: 0 auto;}
.flow-content::before, .flow-content::after {content: ""; display: none;}
.flow-img {width: 28.334%; max-width: 340px;}
.flow-txt {width: 68.334%; max-width: 820px;}
.flow-content.no-img .flow-img {display: none;}
.flow-txt {width: 68.334%; max-width: 820px;}
.flow-content.no-img .flow-txt {width: 100%; max-width: 100%;}
.entry-column p.flow-txt {margin: 0;}
.flow-txt strong {font-weight: bold;}

@media screen and (max-width: 767px) {
.flow-box {position: relative; padding: 40px 0;}
.flow-content {display: block; width: 100%; max-width: 1200px;}
.flow-img {width: 100%; max-width: 100%; text-align: center; margin-bottom: 10px;}
.flow-txt {width: 100%; max-width: 100%;}
}

/* ---------------------------------------------------
	画像テキスト載せ
------------------------------------------------------ */
.unit-imgontxt {}

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

/* ---------------------------------------------------
	slider 共通
------------------------------------------------------ */
.slick-prev, .slick-next {background: none;}
.slick-prev::before, .slick-next::before {content: ""; display: none;}
/*.slide-5 {max-width: 1200px; margin: 0 auto;} 
.slide-5 .slick-next, .slide-5 .slick-prev {width: 30px; height: 54px; margin-top: -27px;}
.slide-5 .slick-prev {background: url("../images/common/ico-slider-prev@2x.png") no-repeat; left: -50px;}
.slide-5 .slick-next {background: url("../images/common/ico-slider-next@2x.png") no-repeat; right: -50px;}
.slide-5 .slick-slide img {max-width: 1000px; max-height: 660px;}

.slide-5-thumb {max-width: 1000px; margin: 0 auto 40px;}
.slide-5-thumb .slick-track {display: flex; justify-content: space-between;}
.slide-5-thumb .slick-track::before, .slide-5-thumb .slick-track::after {display: none;}
.slide-5-thumb .slick-slide {max-width: 216px;}
.slide-5-thumb .slick-next, .slide-5-thumb .slick-prev {width: 15px; height: 27px; top: 50%; margin-top: -14px;}
.slide-5-thumb .slick-prev {background: url("../images/common/ico-slider-prev.png") no-repeat; left: -30px;}
.slide-5-thumb .slick-next {background: url("../images/common/ico-slider-next.png") no-repeat; right: -30px;}*/

.slide-inft {max-width: 1000px; margin: 0 auto; display: none;} 
.slide-inft.slick-initialized {display: block;} 
.slide-inft .slick-next, .slide-inft .slick-prev {width: 30px; height: 54px; margin-top: -27px;}
.slide-inft .slick-prev {background: url("../images/common/ico-slider-prev@2x.png") no-repeat; left: -50px;}
.slide-inft .slick-next {background: url("../images/common/ico-slider-next@2x.png") no-repeat; right: -50px;}
.slide-inft .slick-slide img {max-width: 1000px; max-height: 660px;}

.slide-inft-thumb {max-width: 880px; margin: 0 auto 40px; display: none;} 
.slide-inft-thumb.slick-initialized {display: block;}
.slide-inft-thumb .slick-track {display: flex; justify-content: space-between;}
.slide-inft-thumb .slick-track::before, .slide-inft-thumb .slick-track::after {display: none;}
.slide-inft-thumb .slick-slide {max-width: 170px;}
.slide-inft-thumb .slick-next, .slide-inft-thumb .slick-prev {width: 15px; height: 27px; top: 50%; margin-top: -14px;}
.slide-inft-thumb .slick-prev {background: url("../images/common/ico-slider-prev.png") no-repeat; left: -30px;}
.slide-inft-thumb .slick-next {background: url("../images/common/ico-slider-next.png") no-repeat; right: -30px;}

.slide-inf {max-width: 1000px; margin: 0 auto 40px; display: none;} 
.slide-inf.slick-initialized {display: block;} 
.slide-inf .slick-next, .slide-inf .slick-prev {width: 30px; height: 54px; margin-top: -27px;}
.slide-inf .slick-prev {background: url("../images/common/ico-slider-prev@2x.png") no-repeat; left: -50px;}
.slide-inf .slick-next {background: url("../images/common/ico-slider-next@2x.png") no-repeat; right: -50px;}
.slide-inf .slick-slide img {max-width: 1000px; max-height: 660px;}

.slick-list:focus:focus::before {border: none;}
.slick-slide .slide-img-cap {margin-bottom: 20px;}


@media screen and (max-width: 767px) {
/*    .slide-5 {max-width: 100%; margin: 0 auto;} 
    .slide-5 .slick-next, .slide-5 .slick-prev {display: none !important; width: 80px; height: 15px; margin-top: -7px; top: 110px;}
    .slide-5 .slick-prev {background: url("../img/common/ico_slide_arrow_left.png") no-repeat; left: 0;}
    .slide-5 .slick-next {background: url("../img/common/ico_slide_arrow_right.png") no-repeat; right: 0;}
    .slide-5 .slick-slide img {max-width: 100%; max-height: 250px;}

    .slide-5-thumb {max-width: 100%; margin: 0 auto 40px;}
    .slide-5-thumb .slick-track {display: flex; justify-content: space-between; margin-bottom: 20px;}
    .slide-5-thumb .slick-track::before, .slide-5-thumb .slick-track::after {display: none;}
    .slide-5-thumb .slick-slide {max-width: 216px;}
    .slide-5-thumb .slick-next, .slide-5-thumb .slick-prev {top: 40%;}*/
    
    .slide-inft {max-width: 100%; margin: 0 auto;} 
    .slide-inft .slick-next, .slide-inft .slick-prev {display: none !important; width: 80px; height: 15px; margin-top: -7px; top: 110px;}
    .slide-inft .slick-prev {background: url("../img/common/ico_slide_arrow_left.png") no-repeat; left: 0;}
    .slide-inft .slick-next {background: url("../img/common/ico_slide_arrow_right.png") no-repeat; right: 0;}
    .slide-inft .slick-slide img {max-width: 100%; max-height: 270px;}

    .slide-inft-thumb {max-width: 100%; margin: 0 auto 40px;}
    .slide-inft-thumb .slick-track {display: flex; justify-content: space-between; margin-bottom: 20px;}
    .slide-inft-thumb .slick-track::before, .slide-inft-thumb .slick-track::after {display: none;}
    .slide-inft-thumb .slick-slide {max-width: 170px;}
    .slide-inft-thumb .slick-next, .slide-inft-thumb .slick-prev {top: 40%;}
    
    .slide-inf {max-width: 100%; margin: 0 auto 40px;} 
    .slide-inf .slick-next, .slide-inf .slick-prev {display: none !important; width: 80px; height: 15px; margin-top: -7px; top: 110px;}
    .slide-inf .slick-prev {background: url("../img/common/ico_slide_arrow_left.png") no-repeat; left: 0;}
    .slide-inf .slick-next {background: url("../img/common/ico_slide_arrow_right.png") no-repeat; right: 0;}
    .slide-inf .slick-slide img {max-width: 100%; max-height: 250px;}
    
    .slick-slide .slide-img-cap {margin-bottom: 10px; line-height: 1.6;}
}



/* ---------------------------------------------------
	企業理念・基本方針など
------------------------------------------------------ */
.custom-philosophy {text-align: center; margin-bottom: 80px;}
.custom-philosophy h3 {border: 1px solid #666; color: #333; display: inline-block; margin: 0 auto 30px; padding: 5px 30px;}
.custom-philosophy p {font-size: 1.555em;}

@media screen and (max-width: 767px) {
    .custom-philosophy {margin-bottom: 30px;}
    .custom-philosophy h3 {margin: 0 auto 20px;}
}

/* ---------------------------------------------------
	背景に画像を設置する
------------------------------------------------------ */
.max-width{width:100%; padding: 100px 0;}
.max-width .container{max-width:1200px; margin: auto;}
.max-width .container h3{line-height: 1.4}
.max-width .container .btn-link a{font-size: 20px; line-height: 1.2; display: block; width:360px; padding:22px 0; font-weight: 600;}

@media screen and (max-width: 767px) {
    .custom-philosophy {margin-bottom: 30px;}
    .custom-philosophy h3 {margin: 0 auto 20px;}
}

/* ---------------------------------------------------
	罫線
------------------------------------------------------ */
.hr_line {margin: 0; border-bottom: 1px solid #000;}

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

/* ---------------------------------------------------
	余白
------------------------------------------------------ */
.hr_margin{margin: 0 auto; border-bottom: none!important;}
.margin-s {padding-bottom: 20px;}
.margin-m {padding-bottom: 40px;}
.margin-l {padding-bottom: 60px;}

@media screen and (max-width:767px){
    .margin-s {padding-bottom: 10px;}
	.margin-m {padding-bottom: 20px;}
	.margin-l {padding-bottom: 30px;}
}

/* ---------------------------------------------------
	お問い合わせユニット
------------------------------------------------------ */
.contact-unit {}
.contact-unit .inner-box {max-width: 750px; background: #F9F6F1; border-radius: 8px; box-shadow: 0 0 10px rgba(0,0,0,0.6); margin: 0 auto 45px; padding: 60px 120px;}
.contact-unit .inner-box .contact-tit {font-size: 28px; letter-spacing: 0.04em; margin-bottom: 25px; line-height: 1;}
.contact-unit .inner-box .contact-tel {display: flex; justify-content: center; align-items: center; font-weight: bold; line-height: 1; margin-bottom: 25px;}
.contact-unit .inner-box .contact-tel .store-name {display: block; position: relative; font-size: 24px; font-weight: bold; letter-spacing: 0.1em; margin-right: 30px; background: #F8B500; line-height: 1; padding: 10px 5px 10px 10px;}
.contact-unit .inner-box .contact-tel .store-name::after {content: "";position: absolute; left: auto; right: -25px; bottom: 0;top: 0; width: 0px; height: 0px; margin: auto; border-style: solid; border-color: transparent transparent transparent #F8B500;border-width: 22px 0 22px 25px;}
.contact-unit .inner-box .contact-tel span:last-child {font-size: 56px; letter-spacing: 0.02em;}
.contact-unit .contact-btn01 {display: flex; justify-content: center; align-items: center;}
.contact-unit .contact-btn01 .link-online {margin-right: 45px;}
.contact-unit .contact-btn01 .link-online a,
.contact-unit .contact-btn01 .link-contact a {display: -ms-flexbox; display: flex; -ms-flex-pack: center; justify-content: center; -ms-flex-align: center; align-items: center; border-radius: 5px; width: 225px; height: 65px; font-size: 24px; font-weight: bold; letter-spacing: .0.05em;}
.contact-unit .contact-btn01 .link-online a:hover,
.contact-unit .contact-btn01 .link-contact a:hover {text-decoration: none;}
.contact-unit .contact-btn01 .link-online a{color: #4C4948; background: #64C846;}
.contact-unit .contact-btn01 .link-contact a {color: #F8B500; background: #4C4948;}
.contact-unit .contact-btn02 {text-align: center;}
.contact-unit .contact-btn02 a {width: 400px; height: 100px; display: flex; justify-content: center; align-items: center; font-size: 34px; font-weight: bold; letter-spacing: 0.15em; color: #4C4948; background: #F8B500; border-radius: 50px; box-shadow: 0 0 5px rgba(0,0,0,0.6); margin: auto;}

.is_tablet .contact-unit .inner-box .contact-tel {white-space: nowrap;}

@media screen and (max-width:767px){
	.contact-unit {}
	.contact-unit .inner-box {max-width: calc(100% - 30px); margin: 0 auto 45px; padding: 30px;}
	.contact-unit .inner-box .contact-tit {font-size: 20px; margin-bottom: 25px; line-height: 1.4; text-align: center; padding: 0;}
	.contact-unit .inner-box .contact-tel {margin-bottom: 15px; white-space: nowrap;}
	.contact-unit .inner-box .contact-tel .store-name {display: inline-block; font-size: 14px; margin-bottom: 0; padding: 8px 5px 8px 10px; margin-right: 20px;}
	.contact-unit .inner-box .contact-tel .store-name::after {border-width: 15px 0 15px 15px; right: -15px;}
	.contact-unit .inner-box .contact-tel span:last-child {display: block; font-size: 28px;}
	.contact-unit .contact-btn01 {margin-top: 20px;}
	.contact-unit .contact-btn01 .link-online {margin-right: 20px;}
	.contact-unit .contact-btn01 .link-online a,
	.contact-unit .contact-btn01 .link-contact a {width: 125px; height: 45px; font-size: 16px;}
	.contact-unit .contact-btn01 .link-online a{}
	.contact-unit .contact-btn01 .link-contact a {}
	.contact-unit .contact-btn02 {}
	.contact-unit .contact-btn02 a {width: 90%; max-width: 400px; height: 80px; font-size: 28px;}
}

/* ---------------------------------------------------
	インスタグラムユニット
------------------------------------------------------ */
.instagram-unit {margin-bottom: 40px;}
.instagram-unit .tit-instagram {text-align: center; margin-bottom: 25px;}
.instagram-unit ul.instagram_list {}
.instagram-unit ul.instagram_list li {padding-left: 0; background: none;}


@media screen and (max-width:767px){
	.instagram-unit ul.instagram_list {gap: 10px;}
}

/* ---------------------------------------------------
	ステップユニット
------------------------------------------------------ */
.step-unit {padding-bottom: 40px;}
.step-unit:last-child {padding-bottom: 0;}
.step-unit-a,
.step-unit-b,
.step-unit-c,
.step-unit-d {display: flex; justify-content: space-between; align-items: flex-start; max-width: 680px; margin: auto;}

.step-unit .step-num {width: 64px; height: 155px; background: #F8B500; position: relative; text-align: center; font-size: 16px; font-weight: bold; letter-spacing: 0.05em; margin-right: 34px; margin-bottom: 25px; line-height: 1.4; padding-top: 20px;}
.step-unit .step-num span {font-size: 38px;}
.step-unit .step-num::after {content: "";position: absolute;left: 0; right: 0; bottom: -24px; top: auto; width: 0px;height: 0px;margin: auto;border-style: solid;border-color: #F8B500 transparent transparent transparent;border-width: 24px 32px 0 32px;}

.step-unit .step-contents {width: 100%; max-width: 580px;}
.step-unit .step-contents h3 {font-size: 24px; font-weight: bold; line-height: 1.6; letter-spacing: 0.04em; margin-bottom: 25px;}
.step-unit .step-contents p {margin-bottom: 0}
.step-unit .step-contents h3 a,
.step-unit .step-contents p a {text-decoration: underline;}
.step-unit .step-contents h3 a:hover,
.step-unit .step-contents p a:hover {text-decoration: none;}

.step-unit-a {}

.step-unit-b {}
.step-unit-b .step-item-wrap {display: flex; justify-content: flex-start; align-items: stretch; flex-wrap: wrap;}
.step-unit-b .step-item {width: 100%; max-width: 250px; margin-right: 50px; margin-bottom: 40px;}
.step-unit-b .step-item:nth-child(2n) {margin-right: 0;}
.step-unit-b .step-item:nth-last-child(2),
.step-unit-b .step-item:last-child {margin-bottom: 0;}
.step-unit-b .step-item .img {margin-bottom: 15px;}
.step-unit-b .step-item .item-name {font-size: 15px; font-weight: bold; line-height: 1.2; color: #45B035; margin-bottom: 15px;}
.step-unit-b .step-item h4 {font-size: 15px; font-weight: bold; line-height: 1.6; margin-bottom: 15px;}
.step-unit-b .step-item .item-txt {font-size: 15px; line-height: 1.6; font-weight: 500; margin-bottom: 0;}

.step-unit-c {}

.step-unit-d {}
.step-unit-d .step-app {border-top: 1px solid #000; padding: 40px 0; display: flex; justify-content: flex-start; align-items:stretch;}
.step-unit-d .app-img {width: 100px; margin-right: 40px;}
.step-unit-d .app-link {}
.step-unit-d .app-link h3 {line-height: 1; margin-bottom: 20px;}
.step-unit-d .app-link ul {display: flex; justify-content: flex-start; align-items: center; margin-bottom: 0;}
.step-unit-d .app-link ul li {margin-right: 15px; padding: 0; background: none;}

@media screen and (max-width: 767px) {
	.step-unit {padding-left: 10px; padding-right: 10px;}
	
	.step-unit .step-num {width: 48px; height: 155px; font-size: 12px; margin-right: 15px; padding-top: 20px;}
	.step-unit .step-num span {font-size: 24px;}
	.step-unit .step-num::after {content: "";position: absolute;left: 0; right: 0; bottom: -18px; top: auto; width: 0px;height: 0px;margin: auto;border-style: solid;border-color: #F8B500 transparent transparent transparent;border-width: 18px 24px 0 24px;}

	.step-unit .step-contents {width: calc(100% - 63px);}
	.step-unit .step-contents h3 {font-size: 20px; line-height: 1.6;}
	
	.step-unit-b .step-item {margin-right: 0; margin-bottom: 40px;}
	.step-unit-b .step-item:nth-last-child(2) {margin-bottom: 40px;}
	.step-unit-b .step-item:last-child {margin-bottom: 0;}
	
	.step-unit-d .step-app {padding: 20px 0;}
	.step-unit-d .app-img {width: 100px; margin-right: 10px;}
	.step-unit-d .app-link {}
	.step-unit-d .app-link h3 {line-height: 1; margin-bottom: 10px;}
	.step-unit-d .app-link ul {margin-bottom: 0;}
	.step-unit-d .app-link ul li {margin-right: 10px; padding: 0; background: none;}
}


/* ---------------------------------------------------
	代表署名ユニット
------------------------------------------------------ */
.president-unit {display: flex; justify-content: flex-end; align-items: flex-end; width: 100%; max-width: 750px;}
.president-unit .position-name {font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 18px; text-align: right; letter-spacing: 0.1em; margin-bottom: 15px; padding-right: 5px;}
.president-unit .president-name {}
.president-unit .president-img {margin-left: 25px;}

@media screen and (max-width: 767px) {
	.president-unit {width: calc(100% - 20px);}
	.president-unit .position-name {font-size: 16px; margin-bottom: 10px;}
	.president-unit .president-name {}
	.president-unit .president-img {margin-left: 15px;}
}


/* ---------------------------------------------------
	会社概要ユニット
------------------------------------------------------ */
.company-table {}
.company-table .company-table-row {display: flex; justify-content: flex-start; align-items: stretch; font-size: 22px; font-weight: 500; line-height: 2; width: 630px; margin: auto;}
.company-table .company-table-th {width: 110px; text-align: justify; text-align-last: justify; margin-right: 30px;}
.company-table .company-table-td { width: auto; letter-spacing: 0; font-feature-settings: "palt";}

@media screen and (max-width: 767px) {
	.company-table {width: calc(100% - 20px);}
	.company-table .company-table-row {font-size: 16px; line-height: 1.6; width: 100%; margin: auto;}
	.company-table .company-table-th {width: 25%; text-align: left; text-align-last: left; margin-right: 0;}
	.company-table .company-table-td { width: 75%; margin-bottom: 10px;}
}


/* ---------------------------------------------------
	店舗情報ユニット
------------------------------------------------------ */
.store-unit {}
.store-unit .store-detail {display: flex; justify-content: flex-start; align-items: flex-start; margin-bottom: 40px; padding: 0 8.523%;}
.store-unit .store-info {width: 340px;}
.store-unit .store-logo {margin-bottom: 30px;}
.store-unit h3 {font-size: 32px; line-height: 1.375; font-weight: bold; margin-bottom: 25px; letter-spacing: 0;}
.store-unit .store-txt {font-size: 22px; line-height: 1.6; font-weight: 500; margin-bottom: 20px; letter-spacing: 0;}
.store-unit .store-qr {position: relative;}
.store-unit .store-qr::after {content: ""; display: inline-block; width: 97px; height: 81px; background: url("../img/common/icon-line-a@2x.png") no-repeat center center/contain;}
.store-unit .store-img {order: 2;}
.store-unit .store-map {padding: 0 8.523% 70px; border-bottom: 1px solid #000; margin-bottom: 80px;}
.store-unit:last-of-type .store-map {padding: 0 8.523% 0; border-bottom: none; margin-bottom: 80px;}
.store-unit .store-map iframe {width: 100%;}

@media screen and (max-width: 767px) {
	.store-unit {width: calc(100% - 20px);}
	.store-unit .store-detail {display: block; margin-bottom: 20px;}
	.store-unit .store-info {width: 100%;}
	.store-unit .store-logo {margin-bottom: 15px;}
	.store-unit h3 {font-size: 24px; margin-bottom: 15px;}
	.store-unit .store-txt {font-size: 16px; margin-bottom: 10px;}
	.store-unit .store-qr {position: relative;}
	.store-unit .store-qr::after {}
	.store-unit .store-img {order: 0; margin-bottom: 20px;}
	.store-unit .store-map {padding-bottom: 40px; margin-bottom: 40px;}
	.store-unit .store-map iframe {width: 100%; height: 300px;}
}


/* ---------------------------------------------------
	Bestyle line特典ユニット
------------------------------------------------------ */
.bestyle-line {}
.bestyle-line .num {position: absolute; top: 0; left: 0; background: #F8B500; color: #142A4E; display: flex; justify-content: center; align-items: center; width: 50px; height: 50px; border-radius: 3px; font-family: 'Roboto', sans-serif; font-size: 1.625em; font-weight: 500;}

.bestyle-line1-2 {display: flex; justify-content: space-between; align-items: stretch; margin-bottom: 40px;}
.bestyle-line1-2 .inner-box {position: relative; background: #FFF; border-radius: 15px; width: 47.728%; max-width: 420px; padding: 50px 0;}
.bestyle-line1-2 .inner-box .img {text-align: center; margin-bottom: 20px;}
.bestyle-line1-2 .inner-box h3 {font-size: 2.875em; font-weight: bold; color: #182D7B; line-height: 1.3; letter-spacing: 0.04em; text-align: center; margin-bottom: 15px;}
.bestyle-line1-2 .inner-box p {font-size: 1.375em; font-weight: bold; line-height: 1.7; text-align: center; margin-bottom: 0;}

.bestyle-line3 {position: relative; background: #FFF; border-radius: 15px; padding: 60px 75px 50px}
.bestyle-line3 .img {text-align: center; margin-bottom: 20px;}
.bestyle-line3 h3 {font-size: 2.875em; font-weight: bold; color: #182D7B; line-height: 1.3; letter-spacing: 0.04em; text-align: center; margin-bottom: 15px;}
.bestyle-line3 p {font-size: 1.375em; font-weight: bold; line-height: 1.7; text-align: center; margin-bottom: 40px;}
.bestyle-line3 .bestyle-scene {display: flex; justify-content: space-between; align-items: center; margin-bottom: 45px;}
.bestyle-line3 .bestyle-btn {text-align: center; margin-bottom: 35px;}
.bestyle-line3 .bestyle-caution {text-align: center; font-size: 16px; font-weight: 500; letter-spacing: 0.02em;}


@media screen and (max-width: 767px) {
	.bestyle-line {}
	.bestyle-line .num {width: 40px; height: 40px; font-size: 1.5em;}

	.bestyle-line1-2 {display: block; margin-bottom: 0;}
	.bestyle-line1-2 .inner-box {width: calc(100% - 20px); max-width: 420px; padding: 50px 0; margin: auto; margin-bottom: 20px;}
	.bestyle-line1-2 .inner-box .img {}
	.bestyle-line1-2 .inner-box h3 {font-size: 1.625em;}
	.bestyle-line1-2 .inner-box p {font-size: 1.175em;}

	.bestyle-line3 {width: calc(100% - 20px); padding: 50px 10px; margin: auto;}
	.bestyle-line3 .img {}
	.bestyle-line3 h3 {font-size: 1.625em;}
	.bestyle-line3 p {font-size: 1.175em; margin-bottom: 20px;}
	.bestyle-line3 .bestyle-scene {margin-bottom: 25px;}
	.bestyle-line3 .bestyle-scene > div {margin-right: 10px;}
	.bestyle-line3 .bestyle-scene > div:last-child {margin-right: 0;}
	.bestyle-line3 .bestyle-btn {text-align: center; margin-bottom: 25px;}
	.bestyle-line3 .bestyle-caution {text-align: left; font-size: 14px; margin-bottom: 0;}
}


/* ---------------------------------------------------
	Bestyle servicefrontユニット
------------------------------------------------------ */
.bestyle-servicefront {margin-bottom: 60px;}
.bestyle-servicefront .bf-bg {background: #14294E; border-radius: 60px; padding: 50px 90px 0;}
.bestyle-servicefront .bf-bg h2 {height: 120px; text-align: center; background: #45B035; position: relative; display: flex; justify-content: center; align-items: center; color: #FFF; font-size: 2em; line-height: 1.4; letter-spacing: 0.02em; margin-bottom: 40px; padding: 0;}
.bestyle-servicefront .bf-bg h2::before {content: ""; display: block; position: absolute; left: 0; right: auto; bottom: 0; top: 0; width: 0px; height: 0px; margin: auto; border-style: solid; border-color: transparent transparent transparent #14294E; border-width: 60px 0 60px 40px;}
.bestyle-servicefront .bf-bg h2::after {content: ""; display: block; position: absolute; left: auto; right: -20px; bottom: 0; top: 0; width: 0px; height: 0px; margin: auto; border-style: solid; border-color: transparent #14294E transparent transparent; border-width: 60px 40px 60px 0;}
.bestyle-servicefront .bf-bg h3 {text-align: center; font-size: 2.625em; font-weight: bold; line-height: 1.4; letter-spacing: 0.08em; color: #F8B500; margin-bottom: 20px;}
.bestyle-servicefront .bf-contents {display: flex; justify-content: space-between; align-items: stretch;}
.bestyle-servicefront .bf-contents .bf-item {margin-bottom: 60px; max-width: 320px;}
.bestyle-servicefront .bf-contents .bf-item .icon { text-align: center; margin-bottom: 20px;}
.bestyle-servicefront .bf-contents .bf-item h4 {text-align: center; font-size: 2em; font-weight: bold; line-height: 1.2; color: #F8B500; margin-bottom: 20px;}
.bestyle-servicefront .bf-contents .bf-item p {font-size: 1.125em; line-height: 1.7; margin-bottom: 0; color: #FFF;}
.bestyle-servicefront .bf-sample {}
.bestyle-servicefront .bf-sample h5 {text-align: center; color: #FFF; font-size: 1.5em; font-weight: bold; line-height: 1.6; letter-spacing: 0.05em; margin-bottom: 10px;}
.bestyle-servicefront .bf-sample .img { text-align: center;}

@media screen and (max-width: 767px) {
	.bestyle-servicefront {margin-bottom: 30px;}
	.bestyle-servicefront .bf-bg {border-radius: 40px; padding: 40px 10px 0;}
	.bestyle-servicefront .bf-bg h2 {height: 90px; font-size: 1em; margin-bottom: 20px;}
	.bestyle-servicefront .bf-bg h2::before {}
	.bestyle-servicefront .bf-bg h2::after {}
	.bestyle-servicefront .bf-bg h3 {font-size: 1.5em; margin-bottom: 20px;}
	.bestyle-servicefront .bf-contents {display: block;}
	.bestyle-servicefront .bf-contents .bf-item { margin: auto; margin-bottom: 20px; max-width: 320px;}
	.bestyle-servicefront .bf-contents .bf-item .icon { text-align: center; margin-bottom: 15px;}
	.bestyle-servicefront .bf-contents .bf-item h4 { font-size: 1.5em; margin-bottom: 15px;}
	.bestyle-servicefront .bf-contents .bf-item p {font-size: 1em; line-height: 1.6;}
	.bestyle-servicefront .bf-sample {}
	.bestyle-servicefront .bf-sample h5 {font-size: 1em;}
	.bestyle-servicefront .bf-sample .img { text-align: center; padding: 0 30px;}
}


/* ---------------------------------------------------
	オンライン相談：なんにでもご利用できます
------------------------------------------------------ */
.use-online {margin: 0 auto 40px;}
.use-online ul {margin: 0; padding: 0; display: flex; justify-content: center; align-items: stretch; flex-wrap: wrap;}
.use-online ul li {margin: 0; padding: 0; background: none; margin-bottom: calc(100vw * (50 / 1920)); margin-right: calc(100vw * (50 / 1920)); display: flex; justify-content: center; align-items: center; text-align: center; font-size: 28px; font-weight: bold; letter-spacing: 0.05em; width: 210px; height: 210px; border-radius: 20px; background-color: #F8B500; font-feature-settings: "palt";}
.use-online ul li:nth-child(3n) {margin-right: 0;}

@media screen and (max-width: 767px) {
	.use-online ul {padding: 0 10px;}
	.use-online ul li {margin-bottom: 10px; margin-right: 10px; font-size: 20px; width: 170px; height: 170px; max-width: 48.5%; border-radius: 20px;}
	.use-online ul li:nth-child(3n) {margin-right: 10px;}
	.use-online ul li:nth-child(2n) {margin-right: 0;}
}

/* ---------------------------------------------------
	オンライン相談：店舗情報ユニット
------------------------------------------------------ */
.store-online {margin: 0 auto 40px;}
.store-online .inner {display: flex; justify-content: space-between; align-items: stretch; flex-wrap: wrap; max-width: 650px; margin: auto;}
.store-online .store-online-item {min-width: 280px; max-width: 50%; margin-bottom: 80px;}
.store-online .store-online-item .so-logo {margin-bottom: 30px;}
.store-online .store-online-item h3 {margin-bottom: 20px; font-size: 32px; font-weight: 700; letter-spacing: 0;}
.store-online .store-online-item p {margin-bottom: 0; font-size: 22px; font-weight: 500; letter-spacing: 0;}

@media screen and (max-width: 767px) {
	.store-online {margin: 0 auto 40px; padding: 0 10px;}
	.store-online .store-online-item {min-width: 280px; max-width: 100%; margin-bottom: 40px;}
	.store-online .store-online-item .so-logo {margin-bottom: 15px;}
	.store-online .store-online-item h3 {margin-bottom: 15px; font-size: 28px; padding-left: 0;}
	.store-online .store-online-item p {padding-left: 0;}
}


/* ---------------------------------------------------
	コーティング：
------------------------------------------------------ */
.coating_row2 {justify-content: space-between; margin-bottom: 40px; max-width: calc(730px + 320px);}
.coating_row2 .row_col {width: 347px; max-width: 47.534%; margin-bottom: 0; background: #F8B500; border-radius: 25px; padding: 35px;}
.coating_row2 h4 {color: #182D7B; font-size: 45px; font-weight: bold; margin-bottom: 40px; background: linear-gradient(to bottom, transparent 0%, transparent 65%, #FFF 65% ); text-align: center; line-height: 1.2;}
.coating_row2  p {color: #182D7B; font-size: 21px; font-weight: 500; line-height: 1.75; padding: 0; margin-bottom: 0;}

@media screen and (max-width: 767px) {
	.coating_row2 {justify-content: space-between; margin-bottom: 40px; max-width: calc(100% - 20px);}
	.coating_row2 .row_col {width: 100%; max-width: 100%; margin-bottom: 20px; border-radius: 20px; padding: 20px;}
	.coating_row2 .row_col + .row_col {margin-bottom: 0;}
	.coating_row2 h4 {font-size: 40px; margin-bottom: 20px;}
	.coating_row2 p {font-size: 20px;}
}

@media screen and (max-width: 844px) and (orientation:landscape) {
}


/* ---------------------------------------------------
	PC・スマホ画像入れ替え
------------------------------------------------------ */
.pcsp-img {text-align: center;}

@media screen and (max-width: 767px) {
	.pcsp-img .sp-img {padding: 0 10px;}
}

