@charset "UTF-8";
/* Author: c.nz ver.1.1.15 */
/* ---------------------------------------------------
	acms リセット
------------------------------------------------------ */
.acms-entry .entry-container {margin: 0;}
.entry {border: none; width: 100%; max-width: 100%; margin: 0 auto 50px;}
.entry-title {text-align: center; font-size: 30px; line-height: 1.2; font-weight: 500;}
.entry-column hr{border-bottom: none;}
.acms-grid, .acms-grid-r {margin: 0;}
.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;}
.acms-entry [class*=column-media].img-full {width: 100%; max-width: 100%;}
.acms-entry [class*=column-media].acms-col-sm-12,
.acms-entry [class*=column-media].acms-col-sm-10,
.acms-entry [class*=column-media].acms-col-sm-8,
.acms-entry [class*=column-media].acms-col-sm-6,
.acms-entry [class*=column-media].acms-col-sm-4 {width: 100%;}
.acms-entry [class*=column-media-auto],
.acms-entry [class*=column-media-left],
.acms-entry [class*=column-media-center],
.acms-entry [class*=column-media-right] {float: none;}
.acms-entry [class*=column-media-auto] > * {margin-right: auto;}
.acms-entry [class*=column-media-left] > * {margin-right: auto;}
.acms-entry [class*=column-media-center] > * {margin: auto;width: 100%;max-width: 100%;margin-bottom: 20px;}
.acms-entry [class*=column-media-right] > * {margin-left: auto;}
.acms-entry [class*=column-media-auto] > a,
.acms-entry [class*=column-media-left] > a,
.acms-entry [class*=column-media-center] > a,
.acms-entry [class*=column-media-right] > a {display: inline-block;}
.acms-entry [class*=column-media].img-full > * {max-width: 100%;}
.acms-entry [class*=column-media].img-full > img,
.acms-entry [class*=column-media].img-full > a > img {width: 100%;}
.acms-entry [class*=column-media].acms-col-sm-12 > * {width: 100%; max-width: 1200px;}
.acms-entry [class*=column-media].acms-col-sm-10 > * {width: 100%; max-width: 1000px;}
.acms-entry [class*=column-media].acms-col-sm-8 > * {width: 100%; max-width: 800px;}
.acms-entry [class*=column-media].acms-col-sm-6 > * {width: 100%; max-width: 600px;}
.acms-entry [class*=column-media].acms-col-sm-4 > * {width: 100%; max-width: 400px;}

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

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .acms-entry .entry-container {margin: 0; padding: 0 10px;}
    .entry {width: 100%; margin: 30px auto 25px;}
}

@media screen and (max-width: 896px) 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 > * {max-width: 1200px; margin-left: auto; margin-right: auto;}
@media screen and (max-width:1024px){
	.acms-grid > * {max-width: 960px;}
}
@media print {
	.acms-grid > * {max-width: 960px;}
}

/* yahBGカラー */
[class*=group-bg-] {max-width: 100%; padding: 100px 0;}
[class*=group-bg-] > * {max-width: 1200px; margin-left: auto; margin-right: auto;}
@media screen and (max-width:1024px){
	[class*=group-bg-] > * {max-width: 960px;}
}
@media print {
	[class*=group-bg-] > * {max-width: 960px;}
}
.group-bg-gray {background: #eee;}
.group-bg-gray > *{margin-bottom: 0 !important;}

/* カラム */
.l-2col-l {width: 590px; max-width: 590px; margin-left: calc((100% - 1200px) / 2); margin-right: 10px;}
.l-2col-r {width: 590px; max-width: 590px; margin-right: calc((100% - 1200px) / 2); margin-left: 10px;}

.l-3col-l {float: left; width: 384px; max-width: 384px; margin-left: calc((100% - 1200px) / 2);}
.l-3col-c {float: left; width: 384px; max-width: 384px; margin: 0 24px;}
.l-3col-r {float: left; width: 384px; max-width: 384px; margin-right: calc((100% - 1200px) / 2);}

@media screen and (max-width: 1280px) {
	/* カラム */
	.l-2col-l {width: calc(100vw * (590 / 1280)); margin-left: calc((100% - (100vw * (1200 / 1280))) / 2); margin-right: calc(100vw * (10 / 1280));}
	.l-2col-r {width: calc(100vw * (590 / 1280)); margin-right: calc((100% - (100vw * (1200 / 1280))) / 2); margin-left: calc(100vw * (10 / 1280));}

	.l-3col-l {float: left; width: calc(100vw * (384 / 1280)); max-width: 384px; margin-left: calc((100% - (100vw * (1200 / 1280))) / 2);}
	.l-3col-c {float: left; width: calc(100vw * (384 / 1280)); max-width: 384px; margin: 0 calc(100vw * (24 / 1280));}
	.l-3col-r {float: left; width: calc(100vw * (384 / 1280)); max-width: 384px; margin-right: calc((100% - (100vw * (1200 / 1280))) / 2);}
}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
	.acms-grid > * {max-width: 100%; margin-left: auto; margin-right: auto;}

	/* yahBGカラー */
	[class*=group-bg-] {max-width: 100%; padding: 50px 0;}
	[class*=group-bg-] > * {max-width: 100%;}
	.group-bg-gray {}

	/* カラム */
	.l-2col-l {width: 100%; max-width: 100%; margin-left: 0;}
	.l-2col-r {width: 100%; max-width: 100%; margin-right: 0;}

	.l-3col-l {float: none; width: 100%; max-width: 100%; margin-left: 0;}
	.l-3col-c {float: left; width: 100%; max-width: 100%; margin: 0;}
	.l-3col-r {float: left; width: 100%; max-width: 100%; margin-right: 0;}
}
@media print {
    .l-2col-l {width: 480px; margin-left: 10px; margin-right: 10px;}
    .l-2col-r {width: 480px; margin-right: 10px; margin-left: 10px;}

	.l-3col-l {float: left; width: 320px; max-width: 320px; margin-left: 10px;}
	.l-3col-c {float: left; width: 320px; max-width: 320px; margin: 0 10px;}
	.l-3col-r {float: left; width: 320px; max-width: 320px; margin-right: 10px;}
}

/* ---------------------------------------------------
	ダイレクト編集用調整
------------------------------------------------------ */
.js-edit_inplace-hovering {width: 100%!important; max-width: 100%;}
.acms-admin-tableadmin-edit th {width: 20%;}


/* ---------------------------------------------------
	汎用ユニット
------------------------------------------------------ */
/* 見出し大 */
.entry-column h2 {font-weight: 700; font-style: normal; font-size: 40px; line-height: 1.5; color: var(--charactercolor); margin: 0 auto 35px; padding: 0; border-left: none; letter-spacing: 0.1em;}

/* 見出し中 */
.entry-column h3 {font-weight: 700; font-style: normal; font-size: 32px; line-height: 1.4; color: var(--subthemecolor); margin: 0 auto 30px; padding: 0; background: none; letter-spacing: 0.1em;}

/* 見出し小 */
.entry-column h4 {font-weight: 700; font-style: normal; font-size: clamp(18px, 1.5vw, 24px); line-height: 1.4; color: var(--charactercolor); padding: 0; margin: 0 auto 20px;}
.entry-column h4::before {content: ""; display: inline-block; width: 20px; height: 1px; border-top: 1px solid var(--charactercolor); vertical-align: middle; margin-right: 10px;}

/* 小見出し */
.entry-column h5 {font-weight: 700; font-style: normal; font-size: 22px; line-height: 1.4; padding: 0; margin: 0 auto 20px;font-size: clamp(18px, 1.5vw, 22px);}

/* 本文 */
.entry-column p {font-size: clamp(16px, 1.4vw, 18px); line-height: 1.8; margin: 0 auto 50px; padding: 0;}
.entry-column p span.taL,
.entry-column p span.taC,
.entry-column p span.taR {display: block;}
.entry-column p a.txt-link{text-decoration: underline;}

/* リスト */
.entry-column ul, .entry-column ol {padding: 0; margin: 0 auto;}
.entry-column ul li, .entry-column ol li {padding: 0; margin: 0; font-size: clamp(14px, 1.5vw, 18px); 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: var(--charactercolor); font-family:var(--fontfamily),  "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", 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;}
.gmap-iframe{margin-bottom: 40px;}
.gmap-iframe iframe{max-width: 100%;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    h2.entry-title {font-size: 24px; margin: 0 auto 20px; padding: 0 10px;}
    .entry-column h2 {font-size: 24px; margin: 0 auto 20px; padding: 0 10px;}
    .entry-column h3 {font-size: 22px; margin: 0 auto 20px; padding: 0 10px;}
    .entry-column h4 {padding: 0 10px 0 10px; font-size: 20px; }
    .entry-column h4::before {left: 0; top: 50%; width: 15px;}
    .entry-column h5 {padding: 0 10px; font-size: 18px; margin: 0 auto 10px;}
    .entry-column p {padding: 0 10px; margin-bottom: 20px;}
    .entry-column p.taC {text-align: left;}

    .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: 896px) 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:var(--fontfamily), "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-weight: bold; background: var(--subthemecolor); margin-top: -20px;letter-spacing: 0;}
/*.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: 896px), (max-width: 896px) and (orientation:landscape) {
.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; 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;}

/*本文のテキストリンク*/
a.txt-link{padding: 0;}

/*本文のボタンリンク*/
a.btn-link{margin: 10px 0;}

.is_tablet .txt-link .row_col a {font-size: 18px;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
	.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;}
	.txt-link .row_col {margin-right: 0;}
}

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

/* ---------------------------------------------------
	ボタンリンク
------------------------------------------------------ */
.btnlink {justify-content: flex-start; margin-bottom: 60px; font-feature-settings: "palt";}
.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: 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: 30%; max-width: 30%; margin-right: 5%;}
.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;}

.btn-link,
.btnlink .row_col a {position: relative; display: inline-block; min-width: 0; width: 100%; max-width: 100%; padding: 25px 50px; border: 1px solid var(--charactercolor); color: var(--charactercolor); font-weight: bold; text-align: left; text-decoration: none; background-color: #FFF;}

.btn-link::after,
.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%;
background: var(--charactercolor);
mask:url(../images/common/ico-arrow-cr@2x.png) no-repeat center;
-webkit-mask:url(../images/common/ico-arrow-cr@2x.png) no-repeat center;
mask-size:100%;
-webkit-mask-size:100%;    
}

a[target="_blank"].btn-link::after,
.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%;
background: var(--charactercolor);
mask: url(../images/common/ico-blank@2x.png) no-repeat center;   
-webkit-mask: url(../images/common/ico-blank@2x.png) no-repeat center;
mask-size:100%;
-webkit-mask-size:100%;
}



.btn-link {width: auto; margin-right: 10px; line-height: 1.2;}
.btn-link:hover {text-decoration: none!important;}
.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 50px 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%;
background: var(--charactercolor);    
mask:url(../images/common/ico-arrow-bb@2x.png) no-repeat center;
-webkit-mask:url(../images/common/ico-arrow-bb@2x.png) no-repeat center;
mask-size:100%;
-webkit-mask-size:100%;
transition: transform .2s;
}

.btnlink .row_col a[href^="#"]:hover {opacity: 1;}
.btnlink .row_col a[href^="#"]:hover::after {transform: translateY(2px);}

.is_tablet .btn-link, .btnlink .row_col a {font-size: 18px;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .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;}
	.btn-link,
    .btnlink .row_col a {padding: 20px 50px;}
	.btn-link::after,
    .btnlink .row_col a::after {right: 30px;}
	a[target="_blank"].btn-link::after,
    .btnlink .row_col.blank a::after {right: 25px;}
	.btn-link {margin-right: 0; margin-top: 10px;}
}

@media screen and (max-width: 896px) and (orientation:landscape) {
    .btnlink{padding: 0 10px;}
	.btn-link,
    .btnlink .row_col a{padding: 25px;}
	.btn-link::after,
    .btnlink .row_col a::after{right: 10px;}
	a[target="_blank"].btn-link::after,
    .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; }
.column_unit > .box .content-wrap{display: flex;}
.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: 896px), (max-width: 896px) and (orientation:landscape) {
    .column_unit {width: calc(100% - 20px); margin: 0 auto 30px;}
    .column_unit > .box .content-wrap{display: block;}
    .column_unit > .box h2{padding: 0;}
    .column_unit > .box h3{padding: 0;}
    .column_unit > .box h4{padding: 0;}
    .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: 896px) and (orientation:landscape) {
}

/* ---------------------------------------------------
	画像＋テキスト（左右配置）
------------------------------------------------------ */
.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 p + .btn-link {margin-top: 40px;}
.btn-link.btnL{margin-left: 0; margin-right: auto;}
.btn-link.btnC{margin-left: auto; margin-right: 0;}
.btn-link.btnL{margin-left: auto; margin-right: auto;}
/*.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: 896px), (max-width: 896px) and (orientation:landscape) {
	.border-caution {padding: 20px; margin: 0 auto 30px; width: calc(100% - 20px);}
	.border-standard {padding: 20px;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 p + .btn-link {margin-top: 20px;}
/*    .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;}*/

    .btn-link.btnL,.btn-link.btnC,.btn-link.btnR{
        margin-right: auto; margin-left: auto;
    }

    /* .pic_txt .row_txt h2 { padding: 0; } */
    .pic_txt .row_txt h3 { padding: 0; }
    .pic_txt .row_txt h4 { padding: 0; }
    .pic_txt .row_txt h5 { padding: 0; }
}

@media screen and (max-width: 896px) 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;}
}

/* ---------------------------------------------------
	画像＋テキスト（画像に重ねて配置）
------------------------------------------------------ */
.pic-ontxt {margin-bottom: 40px; position: relative; display: flex; justify-content: center; align-items: center; flex-wrap: wrap;}
.pic-ontxt .img {position: relative; z-index: 100; order: 1;}
.pic-ontxt .txt {background: rgba(238,238,238,0.9); padding: 50px; position: relative; z-index: 200; order: 2;}
.pic-ontxt .txt p {margin-bottom: 0;}

.pic-ontxt.ontxt-top {}
.pic-ontxt.ontxt-top .img {width: 100%; order: 10;}
.pic-ontxt.ontxt-top .txt {width: calc(100% - 100px); margin: 0 auto -150px;}

.pic-ontxt.ontxt-bottom {}
.pic-ontxt.ontxt-bottom .img {width: 100%;}
.pic-ontxt.ontxt-bottom .txt {width: calc(100% - 100px); margin: -150px auto 0;}

.pic-ontxt.ontxt-left {flex-wrap: nowrap;}
.pic-ontxt.ontxt-left .img {width: 70%; margin-left: auto; order: 10;}
.pic-ontxt.ontxt-left .txt {width: 50%; margin: 50px -20% 50px 0;}

.pic-ontxt.ontxt-right {flex-wrap: nowrap;}
.pic-ontxt.ontxt-right .img {width: 70%; margin-right: auto;}
.pic-ontxt.ontxt-right .txt {width: 50%; margin: 50px 0 50px -20%;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .pic-ontxt {margin-bottom: 20px;}
	.pic-ontxt.ontxt-left,
	.pic-ontxt.ontxt-right {flex-wrap: wrap;}
    .pic-ontxt.ontxt-top .img,
    .pic-ontxt.ontxt-bottom .img,
    .pic-ontxt.ontxt-left .img,
    .pic-ontxt.ontxt-right .img {width: 100%; order: 1;}
    .pic-ontxt.ontxt-top .txt,
    .pic-ontxt.ontxt-bottom .txt,
    .pic-ontxt.ontxt-left .txt,
    .pic-ontxt.ontxt-right .txt {width: calc(100% - 20px); margin: -50px auto 0; padding: 20px; order: 2;}
}

/* ---------------------------------------------------
	画像＋テキスト（縦：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;}
.box_row2 .row_col  .col_txt a.btn-link{width: 100%;margin:3px 0 3px 0;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
  .box_row2 h2 {padding: 0;}
  .box_row2 h3 {padding: 0;}
  .box_row2 h4 {margin-bottom: 10px;padding: 0;}
  .box_row2 h5 {padding: 0;}
  .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;}
}

@media screen and (max-width: 896px) 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: 20px; text-align: center;}
.box_row3 .row_col .col_pic img {}
.box_row3 .row_col .col_txt p {margin: 0;}
.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;}
.box_row3 .row_col  .col_txt a.btn-link{width: 100%;margin:3px 0 3px 0;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .box_row3 {margin-bottom: 50px;}
    .box_row3 h4 {margin-bottom: 10px;}
    .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;}

    .entry-column .box_row2 h4{width: 100%;}
    .entry-column .box_row3 h4{width: calc(100% - 10px);}
    .entry-column .box_row4 h5{padding: 0 10px;}
}

@media screen and (max-width: 896px) 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 {margin-bottom: 20px;}
.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: 20px; text-align: center;}
.box_row4 .row_col .col_pic img {}

.box_row4 .row_col  .col_txt a.btn-link{padding: 0.7rem 3.8rem 0.7rem 2.4rem;width: 100%;margin:3px 0 3px 0;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .box_row4 {margin-bottom: 50px; justify-content: space-between;}
    .box_row4 h5 {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: 896px) and (orientation:landscape) {
    .box_row4 .row_col .col_txt h5{padding: 0;}
}

/* ---------------------------------------------------
	タイトル＋テキスト（左右配置）
------------------------------------------------------ */
.tit_and_txt_wrap{display: flex; align-items: flex-start; flex-wrap:wrap;}
.tit_and_txt_wrap .tit-wrap{width:50%;}
.tit_and_txt_wrap .text-wrap{width:47%;}
/* 70% */
.tit_and_txt_wrap .tit-wrap.w70{width:70%;}
.tit_and_txt_wrap .tit-wrap.w70 + .text-wrap{width:27%;}
/* 60% */
.tit_and_txt_wrap .tit-wrap.w60{width:60%;}
.tit_and_txt_wrap .tit-wrap.w60 + .text-wrap{width:37%;}
/* 50% */
.tit_and_txt_wrap .tit-wrap.w50{width:50%;}
.tit_and_txt_wrap .tit-wrap.w50 + .text-wrap{width:47%;}
/* 40% */
.tit_and_txt_wrap .tit-wrap.w40{width:40%;}
.tit_and_txt_wrap .tit-wrap.w40 + .text-wrap{width:57%;}
/* 30% */
.tit_and_txt_wrap .tit-wrap.w30{width:30%;}
.tit_and_txt_wrap .tit-wrap.w30 + .text-wrap{width:67%;}

/* 上付き */
.tit_and_txt_wrap.pos_top{align-items: flex-start;}
/* 中段 */
.tit_and_txt_wrap.pos_middle{align-items: center;}
/* 下付き */
.tit_and_txt_wrap.pos_under{align-items: flex-end;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .tit_and_txt_wrap .tit-wrap{width:100% !important;}
    .tit_and_txt_wrap .text-wrap{width:100% !important;}

    .tit_and_txt_wrap .text-wrap .btn-link{margin-left: 10px;margin-right: 10px;margin-bottom: 10px;}
}

/* ---------------------------------------------------
	Q&A
------------------------------------------------------ */
.faq-group {max-width: 1200px; margin: 0 auto 40px;}
.faq-group.ui-widget,.faq-group.ui-helper-reset {max-width: 1200px; margin: 0 auto 40px;font-family:var(--fontfamily), "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;}
.faq-group h2 {width: 100%; text-align: center; background: rgba(42,24,0,0.05); padding: 5px 0; cursor: pointer;border: none;}
.faq-group h2.ui-accordion-header {width: 100%;text-align: center;background: rgba(42,24,0,0.05);padding: 5px 0;cursor: pointer;border: none;font-size: 40px;margin: 0;display: block;font-family:var(--fontfamily), "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;}
.faq-group h2 span {display: none;}
.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.ui-state-active::after {-webkit-transform: rotate(180deg); transform: rotate(180deg);}
.faq-group-contents {display: none;}
.faq-group-contents .faq-content {border-bottom: 1px solid #2A1800; margin-bottom: 40px;}
.faq-group-contents.ui-widget-content {border: none;}
.faq-content {margin: 0 auto; border-bottom: 1px solid #2A1800; margin-bottom: 40px;}
.faq-content .faq-q { position: relative; padding-left: 40px; text-align: left; font-family:var(--fontfamily), "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; font-size: 22px; margin-bottom: 20px;}
.faq-content .faq-q::before { content: 'Q.'; margin-right: 10px; position: absolute; left: 0; font-weight: bold;}
.faq-content .faq-a { position: relative; padding-left: 40px;}
.faq-content .faq-a::before { content: 'A.'; margin-right: 10px; position: absolute; top: 5px; left: 0; font-size: 22px; font-weight: bold; line-height: 1;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
	.faq-group {max-width: 100%; margin: 0 auto 40px; padding: 0 10px;}
    .faq-content .faq-q::before {margin-right: 5px; margin-left: 5px;}
    .faq-content .faq-a::before {margin-right: 5px; margin-left: 5px;}
    .faq-group h2.ui-accordion-header {font-size: 24px;position: relative;padding:5px 45px 5px 10px;text-align:left;}
    .faq-group h2.ui-accordion-header::after {position: absolute;right:2%;top: 35%;margin: 0;}
}


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

.column-table table {width: 100%; border-spacing: 0; border-collapse: collapse; empty-cells: show; tablelayout: fixed; background: #FFF;}
.column-table table th, .column-table table td { padding: 20px; border: 1px solid #CCCCCC; vertical-align: middle; font-size: clamp(14px, 1.3vw, 16px);}
.column-table table th { width: 25%; background: var(--subthemecolor); text-align: left; font-weight: bold; border-bottom: 1px solid #FFF; color: #FFF;}

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

    .column-table table.js-tableunit-scroll-hint {tablelayout: auto;}
    .column-table table.acms-tablescrollable {tablelayout: auto;}
}

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


/* ---------------------------------------------------
	罫線
------------------------------------------------------ */
.entry-column .hr-line {margin: 0 auto; border-bottom: 1px solid #000; border-top: none;}

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

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

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .margin-s {margin-bottom: 10px;}
	.margin-m {margin-bottom: 20px;}
	.margin-l {margin-bottom: 30px;}
}


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

/* ---------------------------------------------------
	スタッフ紹介
------------------------------------------------------ */
.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: 896px), (max-width: 896px) and (orientation:landscape) {
    .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;}
}

/* ---------------------------------------------------
	流れ・手順用
------------------------------------------------------ */
.custom-flow {counter-reset: flow;}
.flow-box {position: relative; padding: 40px 10px;}
.flow-box:nth-child(2n) {background: rgba(42,24,0,0.05);}
.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: 896px), (max-width: 896px) and (orientation:landscape) {
.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%;}
}

/* ---------------------------------------------------
	画像テキスト載せ
------------------------------------------------------ */
.bgontxt {max-width: 100%; padding: 100px 0;}
.bgontxt .container {max-width: 1200px;}

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

/* ---------------------------------------------------
	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: 896px), (max-width: 896px) and (orientation:landscape) {
/*    .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: 250px;}

    .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: var(--charactercolor); display: inline-block; margin: 0 auto 30px; padding: 5px 30px;}
.custom-philosophy p {font-size: 1.555em;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .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: 896px), (max-width: 896px) and (orientation:landscape) {
    .custom-philosophy {margin-bottom: 30px;}
    .custom-philosophy h3 {margin: 0 auto 20px;}
}*/


/* ---------------------------------------------------
	お問い合わせユニット
------------------------------------------------------ */
.contact-banner{background: #CCC;}
.contact-banner.type1{padding:50px; display: flex; justify-content: flex-end; align-items: center;}
.contact-banner.type1 .text{margin-right: 30px; width: 37.9%;}
.contact-banner.type1 .text p{margin-bottom: 0;}
.contact-banner.type h4{margin-bottom: 20px; padding: 0; font-weight: 700;}
.contact-banner h4::before{content:none;}
.contact-banner .contact{display: flex; align-items: center; width: 576px;}
.contact-banner .tel{margin-right: 30px;}
.contact-banner .tel p,.contact-banner.type1 .tel a{font-size: 38px; line-height: .663; font-weight: 400; margin-bottom: 5px; text-decoration: none; color: var(--charactercolor); font-family: "Arial"; white-space: nowrap;}
.contact-banner .tel p small{font-size: 16px; font-weight: 500; line-height: 1.575;}
.contact-banner .mail{background:#999999; min-width:240px;}
.contact-banner .mail a{color:#FFF; display: block; text-align: center; font-size: 18px; font-weight: 700; letter-spacing: .05em; line-height: 2; padding: 22px 0;}
.contact-banner .mail a:hover{text-decoration: none;}
.contact-banner .mail a::before{content:""; display: inline-block; width: 26px; height: 20px; background:url(../images/common/mail_icon.png) no-repeat center/contain; margin-right: 15.4px;}


.contact-banner.type2{text-align: center; padding:50px;}
.contact-banner.type2 .contact{margin: auto;}
.contact-banner.type2 .text p{margin-bottom: 20px;}

@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .contact-banner.type1{flex-wrap:wrap; padding: 50px 0;}
    .contact-banner.type1 .text{width: 100%; margin-right: 0; margin-bottom: 20px;}
    .contact-banner .contact{flex-wrap:wrap; width: 100%;}
    .contact-banner.type2{padding: 50px 0;}
    .contact-banner .tel{width: 100%; text-align: center; margin-right: 0; margin-bottom: 20px;}
    .contact-banner .mail{width: 100%; margin: 0 10px;}
}


.benrishi-unit{width: 100%; display: flex; align-items: flex-start; justify-content: space-between; flex-wrap:wrap; background:#F2F2F2; padding: 50px; margin-bottom: 60px;}
.benrishi-unit .left{width: 300px;}
.benrishi-unit .left img{width: 100%; height: 360px; object-fit: cover; display: block; margin-bottom: 10px;}
.benrishi-unit .left .title{font-size: 16px; letter-spacing: 0; line-height: 1.6; font-weight: 400; text-align: center; margin-bottom: 10px;}
.benrishi-unit .left .name{font-size: 24px; font-weight: 700; letter-spacing: 0; line-height: 1.41666; text-align: center; margin-bottom: 5px;}
.benrishi-unit .left .en-name{font-size: 16px; letter-spacing: 0; line-height: 1.6; font-weight: 400; margin-bottom: 0; text-align: center;}
.benrishi-unit .right{width: 750px;}
.benrishi-unit .right > *:last-child{margin-bottom: 0;}
@media screen and (max-width:1240px) {
    .benrishi-unit{width: 120rem; margin: auto; padding: 5rem; margin-bottom: 6rem;}
    .benrishi-unit .left{width: 30rem;}
    .benrishi-unit .left img{height: 36rem; margin-bottom: 1rem;}
    .benrishi-unit .left .title{font-size: 1.6rem; margin-bottom: 1rem;}
    .benrishi-unit .left .name{font-size: 2.4rem; margin-bottom: .5rem;}
    .benrishi-unit .left .en-name{font-size: 1.6rem;}
    .benrishi-unit .right{width: 75rem;}
    .benrishi-unit .right > *:last-child{margin-bottom: 0;}
}
@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .benrishi-unit{width: calc(100% - 20px); flex-direction: column; padding: 2rem;}
    .benrishi-unit .left{width: 100%; margin-bottom: 2rem;}
    .benrishi-unit .right{width: 100%;}
    .entry-column .benrishi-unit .right > h2,.entry-column .benrishi-unit .right > h3,.entry-column .benrishi-unit .right > h4,.entry-column .benrishi-unit .right > h5,.entry-column .benrishi-unit .right > p{padding-left:0; padding-right: 0;}
}

/* ------------------------------
　　sdgs
------------------------------ */
.sdgs-unit-wrap{width: 100%; max-width: 1200px; display: flex; align-items: flex-start; justify-content: space-between; flex-wrap:wrap; margin: auto; margin-bottom: 60px;}
.sdgs-unit-wrap img{display: block; width: 260px; height: 260px; object-fit: cover; margin-right: 40px;}
.sdgs-unit-wrap .text{width: 900px;}
.sdgs-unit-wrap  > *:last-child{margin-bottom: 0;}
@media screen and (max-width:1240px) {
    .sdgs-unit-wrap{width: 120rem; margin: auto; margin-bottom: 6rem;}
    .sdgs-unit-wrap img{width: 26rem; height: 26rem; margin-right: 4rem;}
    .sdgs-unit-wrap .text{width: 90rem;}
}
@media screen and (max-width: 896px), (max-width: 896px) and (orientation:landscape) {
    .sdgs-unit-wrap{width: 100%;}
    .sdgs-unit-wrap img{margin-right: auto; margin: auto; margin-bottom: 20px;}
    .sdgs-unit-wrap .text{width:100%;}
}

/* ------------------------------
　　動的フォーム
------------------------------ */
.entry-column .contact-form li{padding-left: 0; background:transparent;}
/* .contact-form-label{display: flex; align-items: center; justify-content: space-between;} */
.textarea .contact-form-label{align-items: flex-start; padding-top: 20px;}

.layout-two-column{
    display: flex;
}

.layout-two-column[data-type="columns"] {
  display: flex;
  justify-content: center; /* これで中身が中央に寄ります */
}

/* 各カラム（箱）の幅を指定（合計600pxにする場合） */
.layout-two-column[data-type="columns"] > [data-type="column"] {
  width: 300px;            /* 1つ300px × 2 = 600px */
  flex: 0 0 600px;         /* 幅を固定する場合 */
}

/* 3カラムレイアウトの親要素 */
.layout-three-column[data-type="columns"] {
  display: flex;
  justify-content: center; /* これで3つのカラムを中央に寄せます */
  gap: 20px;               /* カラム間の余白 */
  max-width: 1200px;       /* 全体の最大幅 */
  margin: 0 auto 20px auto;
}

/* 各カラム（箱）の設定：合計600pxにする場合 */
.layout-three-column[data-type="columns"] > [data-type="column"] {
  flex: 0 0 calc((1200px - (20px * 2)) / 3); 
  min-width: 0; /* 中身の突き抜け防止 */
}

/* 画像ブロック全体の基本設定 */
.media-image-block {
  width: 100%; /* 親の幅いっぱいに広げて配置の余白を作る */
  display: flow-root;
  margin-bottom: 20px;
}

/* figure要素（画像の外枠）の制御 */
.media-image-block figure {
  margin: 0; /* デフォルトの余白をリセット */
}

/* 右寄せの設定 */
.media-image-block.align-right figure {
  margin-left: auto !important;
  margin-right: 0 !important;
}

/* 中央寄せの設定 */
.media-image-block.align-center figure {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* 左寄せの設定 */
.media-image-block.align-left figure {
  margin-left: 0 !important;
  margin-right: auto !important;
}

/* 画像自体のリサイズ設定 */
.media-image-block img {
  display: block;
  width: 100%;
  height: auto;
}

/* テーブルを包む外枠の設定 */
.tableWrapper.acms-tablescrollable {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto 20px auto;
  clear: both;
}

/* テーブルを包むラッパーの余白をゼロにする */
.column-block-editor .tableWrapper {
  margin-top: 0 !important;
  margin-bottom: 0 !important; /* ユニット間の隙間をなくす */
  padding: 0 !important;
}

/* テーブル本体の設定 */
.tableWrapper table {
  width: 100% !important;
  tablelayout: fixed !important; /* 幅を固定して突き抜けを防止 */
  border-collapse: collapse !important;
}

/* セルの枠線を設定 */
.tableWrapper td {
  border: 1px solid #ccc !important; /* 線の色や太さは適宜調整してください */
  padding: 15px !important;           /* セル内の余白を適度に持たせる */
  white-space: normal !important;  /* 改行禁止を解除 */
  word-wrap: break-word !important; /* 長い単語を折り返す */
  overflow-wrap: break-word !important;
  word-break: break-all !important; /* どんな文字でも枠の端で改行させる */
  vertical-align: top;             /* テキストが多い時は上揃えが見やすい */
}

/* a-blog cms のエディター特有のpタグ設定も修正 */
.tableWrapper td p {
  white-space: normal !important;
  margin: 0 !important;
  word-break: break-all !important;
}
/* 親要素のスクロールを強制解除 */
.tableWrapper.acms-tablescrollable {
  overflow: visible !important;   /* スクロールバーを消す */
  height: auto !important;        /* 高さを内容に合わせる */
  position: static !important;    /* ScrollHintの制御を無効化 */
}


/* スマホ対応：画面が狭いときは縦に並べて中央寄せ */
@media (max-width: 767px) {
  .layout-three-column[data-type="columns"] {
    flex-direction: column;
    align-items: center;
  }
  .layout-three-column[data-type="columns"] > [data-type="column"] {
    width: 100%;
    max-width: 400px; /* スマホで広がりすぎないサイズ */
    flex: none;
  }
}

@media screen and (max-width: 896px){
    .layout-two-column{
        display: block;
    }
}

/* スマホでは100%にする */
@media (max-width: 767px) {
  .layout-two-column[data-type="columns"] {
    flex-direction: column;
    align-items: center;
  }
  .layout-two-column[data-type="columns"] > [data-type="column"] {
    width: 100%;
    max-width: 600px; /* スマホでも広がりすぎないようにする場合 */
    flex: none;
  }
}

/* スマホ表示（767px以下）の設定 */
@media (max-width: 767px) {
  /* テーブルの機能を解除してブロック要素にする */
  .tableWrapper table,
  .tableWrapper tbody,
  .tableWrapper tr,
  .tableWrapper td {
    display: block !important;
    width: 100% !important;
  }

  /* セル（td）ごとの調整 */
  .tableWrapper td {
    border-bottom: none !important; /* 下線が重複しないように調整 */
    padding: 10px 15px !important;
    box-sizing: border-box;
  }

  /* ユニット同士の重なりを調整して、枠線が消えないようにする */
  .tableWrapper table {
    margin-bottom: 0 !important;
  }

  /* 最後のセルにだけ下線を付けて箱を閉じる */
  .tableWrapper tr:last-child td:last-child {
    border-bottom: 1px solid #ccc !important;
  }
}

/* まず：通常のグリッドは従来どおり（サイト全体） */
@media (min-width: 480px) {
  .acms-row::after { content:""; display:block; clear:both; }

  .acms-row > .acms-col-sm-4,
  .acms-row > .acms-col-sm-6,
  .acms-row > .acms-col-sm-8,
  .acms-row > .acms-col-sm-10 { float:left; box-sizing:border-box; }

  .acms-row > .acms-col-sm-4  { width:33.3333333333%; }
  .acms-row > .acms-col-sm-6  { width:50%; }
  .acms-row > .acms-col-sm-8  { width:66.6666666667%; }
  .acms-row > .acms-col-sm-10 { width:83.3333333333%; }
}

/* そして：縦並びにしたい「画像ユニットのサンプル」だけ例外扱い */
.unit-demo .acms-col-sm-4,
.unit-demo .acms-col-sm-6,
.unit-demo .acms-col-sm-8,
.unit-demo .acms-col-sm-10{
  float:none;
  width:auto;
}

.table{
    width: 100%;
    border-spacing: 0;
    border-collapse: collapse;
    empty-cells: show;
    tablelayout: fixed;
    background: #FFF;
}

.column-table table th{
  width: 25%;
  background: var(--subthemecolor);
  text-align: left;
  font-weight: bold;
  border-bottom: 1px solid #fff;
  color: #fff;
}

.column-table table th,
.column-table table td{
  padding: 20px;
  border: 1px solid #CCCCCC;
  vertical-align: middle;
  font-size: 18px;
}
.column-table table{
  border-collapse: collapse;
  border-spacing: 0;
}

.column-block-editor p{
  margin-bottom: 10px;
}

.media-image-block {
  margin-bottom: 75px;
}
.layout-two-column h3 p{
  margin-right: 20px;
}


/* ブロックエディター内の引用 */
.column-block-editor blockquote{
  margin: 1.2em 0;
  padding: 0.6em 1em;
  border-left: 1px solid #222222; /* ← 縦線 */
}

/* 中のpの余白を整える（任意） */
.column-block-editor blockquote p{
  margin: 0;
}

/* link button block */
.link-button-block.align-center{
  text-align: center;
}

.link-button-block-link{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  /* 形（画像っぽいサイズ感） */
  min-width: 220px;
  padding: 14px 42px;
  border-radius: 9999px;

  /* 見た目 */
  background: #4b4f5a;
  color: #fff;
  font-weight: 700;
  font-size: 20px;
  line-height: 1;

  text-decoration: none;
  border: 0;
  cursor: pointer;
  box-sizing: border-box;

  transition: opacity .2s ease, transform .2s ease, background-color .2s ease;
}

.link-button-block-link:hover{
  opacity: .92;
  transform: translateY(-1px);
}

.link-button-block-link:active{
  transform: translateY(0);
}

/* キーボード操作時の見やすさ */
.link-button-block-link:focus-visible{
  outline: 3px solid rgba(75,79,90,.35);
  outline-offset: 3px;
}

.link-button-block[data-type="linkButton"] a.link-button-block-link{
  color: #fff !important;
  margin-bottom: 40px;
}

/* テーブル全体の基本 */
.acms-table-scrollable table{
  width: 100%;
  border-collapse: collapse;
}
.acms-table-scrollable td,
.acms-table-scrollable th{
  border: 1px solid #ddd;
  padding: .6em .8em;
  vertical-align: top;
}

/* 見出しセル（th）を分かりやすく */
.acms-table-scrollable th{
  padding: .6em .8em;
  background: #00316D; /* 任意：見出しを見分けやすく */
  font-weight: 700;
  text-align: left;
  color: #fff;
}

.column-block-editor h2 + p{
  margin-bottom: 50px;
}

/* セル内を縦中央寄せ */
.acms-table-scrollable th,
.acms-table-scrollable td{
  vertical-align: middle;
}

/* セル内のpの余白を消す（これが効きます） */
.acms-table-scrollable th p,
.acms-table-scrollable td p{
  margin: 0;
}

@media screen and (max-width:896px){
  .column-table table th{
  width: 100%;
  background: var(--subthemecolor);
  text-align: left;
  font-weight: bold;
  border-bottom: 1px solid #fff;
  color: #fff;
}
}
