@charset "utf-8";
/*
Theme Name:mrp-child
Template:mrp
Version: 1.0.0
*/
/*
DesignCode CSS: ver 0.01
*/
/*------------------------------------------------------
Theme Material
------------------------------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');

:root {
	/*------------------------------------------------------
  System - Font
  ------------------------------------------------------*/
	--body-font-family: 'Noto Sans JP', sans-serif;
	--font-family01: 'Noto Sans JP', sans-serif;
	--font-family02: 'Noto Sans JP', sans-serif;
	--body-font-size: min(calc(1.6rem + (1vw - 1.92rem) * 0.1294), 1.6rem);
	/*1.6rem-1.4rem (1920-375)*/
	--content-max-width: 1240px;
	--content-max-width-lg: 1240px;
	/*------------------------------------------------------
  Background - Color 
  ------------------------------------------------------*/
	--color-background: #ffffff;
	--color-font: #1b1b1b;
	--color-primary: #e00000;
	--color-primary-shade: #e00000;
	--color-primary-tint: #e00000;
	--color-secondary: #027db4;
	--color-secondary-tint: #f3f3f3;
	--color-table-border: #cccccc;
	--color-table-background: #e00000;
	--color-white: #ffffff;
	--color-black: #000000;
	--color-gray: #4d4d4d;
	/*------------------------------------------------------
  Header
  ------------------------------------------------------*/
	--header-background: #ffffff;
	--header-color-font: #1b1b1b;
	--header-color-primary: #e00000;
	--header-color-primary-shade: #f3f3f3;
	--header-color-primary-tint: #ffffff;
	/*------------------------------------------------------
  Footer
  ------------------------------------------------------*/
	--footer-background: #ffffff;
	--footer-color-font: #1b1b1b;
	--footer-color-primary: #e00000;
	/*------------------------------------------------------
  PX Variations
  ------------------------------------------------------*/
	--px240: min(calc(240px + (1vw - 19.2px) * 10.356), 240px);
	/*240px-80px (1920-375)*/
	--px220: min(calc(220px + (1vw - 19.2px) * 10.356), 220px);
	/*220px-80px (1920-375)*/
	--px210: min(calc(210px + (1vw - 19.2px) * 6.4725), 210px);
	/*210px-100px (1920-375)*/
	--px200: min(calc(200px + (1vw - 19.2px) * 6.4725), 200px);
	/*200px-100px (1920-375)*/
	--px190: min(calc(190px + (1vw - 19.2px) * 3.8835), 190px);
	/*190-120px (1920-375) */
	--px180: min(calc(180px + (1vw - 19.2px) * 3.8835), 180px);
	/*180-120px (1920-375) */
	--px170: min(calc(170px + (1vw - 19.2px) * 3.8835), 170px);
	/*170-120px (1920-375) */
	--px160w: min(calc(160px + (1vw - 19.2px) * 5.178), 160px);
	/*160px-80px (1920-375)*/
	--px160: min(calc(160px + (1vw - 19.2px) * 6.4725), 160px);
	/*160px-60px (1920-375)*/
	--px150: min(calc(150px + (1vw - 19.2px) * 3.2362), 150px);
	/*150-100px (1920-375) */
	--px145: min(calc(145px + (1vw - 19.2px) * 3.2362), 145px);
	/*145-100px (1920-375) */
	--px140: min(calc(140px + (1vw - 19.2px) * 6.4725), 140px);
	/*140px-40px (1920-375)*/
	--px130: min(calc(130px + (1vw - 19.2px) * 2.589), 130px);
	/*130px-80px (1920-375)*/
	--px120: min(calc(120px + (1vw - 19.2px) * 2.589), 120px);
	/*120px-80px (1920-375)*/
	--px100w: min(calc(100px + (1vw - 19.2px) * 3.2362), 100px);
	/*100px-50px (1920-375)*/
	--px100: min(calc(100px + (1vw - 19.2px) * 3.8835), 100px);
	/*100px-40px (1920-375)*/
	--px96: min(calc(96px + (1vw - 19.2px) * 3.1068), 96px);
	/*96px-48px (1920-375)*/
	--px90: min(calc(90px + (1vw - 19.2px) * 1.2945), 90px);
	/*90px-60px (1920-375)*/
	--px80w: min(calc(80px + (1vw - 19.2px) * 1.2945), 80px);
	/*80px-60px (1920-375)*/
	--px80: min(calc(80px + (1vw - 19.2px) * 2.589), 80px);
	/*80px-40px (1920-375)x*/
	--px80s: min(calc(80px + (1vw - 19.2px) * 3.8835), 80px);
	/*80px-20px (1920-375)x*/
	--px70: min(calc(70px + (1vw - 19.2px) * 1.9417), 70px);
	/*70px-20px (1920-375)x*/
	--px68: min(calc(68px + (1vw - 19.2px) * 1.9417), 68px);
	/*68px-20px (1920-375)x*/
	--px65: min(calc(65px + (1vw - 19.2px) * 1.9417), 65px);
	/*65px-20px (1920-375)x*/
	--px60w: min(calc(60px + (1vw - 19.2px) * 1.2945), 60px);
	/*60px-40px (1920-375)*/
	--px60: min(calc(60px + (1vw - 19.2px) * 1.9417), 60px);
	/*60px-30px (1920-375)*/
	--px50: min(calc(50px + (1vw - 19.2px) * 1.2945), 50px);
	/*50px-30px (1920-375) */
	--px40w: min(calc(40px + (1vw - 19.2px) * 0.6472), 40px);
	/*40px-30px (1920-375)*/
	--px40: min(calc(40px + (1vw - 19.2px) * 1.2945), 40px);
	/*40px-20px (1920-375)*/
	--px35: min(calc(35px + (1vw - 19.2px) * 1.2945), 35px);
	/*35px-20px (1920-375)*/
	--px30w: min(calc(30px + (1vw - 19.2px) * 0.6472), 30px);
	/*30px-20px (1920-375)*/
	--px30: min(calc(30px + (1vw - 19.2px) * 0.9709), 30px);
	/*30px-15px (1920-375)*/
	--px28: min(calc(28px + (1vw - 19.2px) * 0.9709), 28px);
	/*28px-15px (1920-375)*/
	--px24: min(calc(24px + (1vw - 19.2px) * 0.6472), 24px);
	/*24px-14px (1920-375)*/
	--px26: min(calc(26px + (1vw - 19.2px) * 0.6472), 26px);
	/*26px-14px (1920-375)*/
	--px20: min(calc(20px + (1vw - 19.2px) * 0.6472), 20px);
	/*20px-10px (1920-375)*/
	--px18: min(calc(18px + (1vw - 19.2px) * 0.2589), 18px);
	/*18px-14px (1920-375)*/
	--px16: min(calc(16px + (1vw - 19.2px) * 0.1294), 16px);
	/*16px-14px (1920-375)*/
	--px15: min(calc(15px + (1vw - 19.2px) * 0.1294), 15px);
	/*15px-14px (1920-375)*/
	--px14: min(calc(14px + (1vw - 19.2px) * 0.1294), 14px);
	/*14px-12px (1920-375)*/
	--px12: min(calc(12px + (1vw - 19.2px) * 0.0647), 12px);
	/*12px-11px (1920-375)*/
	/*------------------------------------------------------
  REM Variations
  ------------------------------------------------------*/
	--rem200: min(calc(20rem + (1vw - 1.92rem) * 6.472), 20rem);
	/*20rem-10rem (1920-375)*/
	--rem160: min(calc(16rem + (1vw - 1.92rem) * 6.472), 16rem);
	/*16rem-10rem (1920-375)*/
	--rem120: min(calc(12rem + (1vw - 1.92rem) * 3.8835), 12rem);
	/*12rem-6rem (1920-375)*/
	--rem96: min(calc(9.6rem + (1vw - 1.92rem) * 1.2945), 9.6rem);
	/*9.6rem-6rem (1920-375)*/
	--rem80w: min(calc(8rem + (1vw - 1.92rem) * 1.2945), 8rem);
	/*8rem-6rem (1920-375)*/
	--rem82: min(calc(8.2rem + (1vw - 1.92rem) * -0.271), 8.2rem);
	/* 8.2rem → 4rem (1920 → 375px) */
	--rem80: min(calc(8rem + (1vw - 1.92rem) * 2.589), 8rem);
	/*8rem-4rem (1920-375)x*/
	--rem72: min(calc(7.2rem + (1vw - 1.92rem) * 1.9417), 7.2rem);
	/*7.2rem-4.2rem (1920-375)*/
	--rem70: min(calc(7rem + (1vw - 1.92rem) * 1.8875), 7rem);
	/*7rem-4rem (1920-375)*/
	--rem64: min(calc(6.4rem + (1vw - 1.92rem) * 1.5534), 6.4rem);
	/*6.4rem-4rem (1920-375)*/
	--rem60: min(calc(6rem + (1vw - 1.92rem) * 1.5534), 6rem);
	/*6rem-3.6rem (1920-375)*/
	--rem56: min(calc(5.6rem + (1vw - 1.92rem) * 1.5534), 5.6rem);
	/*5.6rem-3.6rem (1920-375)*/
	--rem52: min(calc(5.2rem + (1vw - 1.92rem) * 1.5534), 5.2rem);
	/*5.2rem-3.6rem (1920-375)*/
	--rem50: min(calc(5rem + (1vw - 1.92rem) * 1.5534), 5rem);
	/*5rem-3.6rem (1920-375)*/
	--rem48w: min(calc(4.8rem + (1vw - 1.92rem) * 0.6472), 4.8rem);
	/*4.8rem-3.8rem*/
	--rem48: min(calc(4.8rem + (1vw - 1.92rem) * 1.5534), 4.8rem);
	/*4.8rem-2.4rem (1920-375)*/
	--rem46: min(calc(4.6rem + (1vw - 1.92rem) * 1.5534), 4.6rem);
	/*4.6rem-2.4rem (1920-375)*/
	--rem42w: min(calc(4.2rem + (1vw - 1.92rem) * 0.6472), 4.2rem);
	/*4.2rem-3.2rem (1920-375)*/
	--rem42: min(calc(4.2rem + (1vw - 1.92rem) * 1.165), 4.2rem);
	/*4.2rem-2.4rem (1920-375)*/
	--rem42s: min(calc(4.2rem + (1vw - 1.92rem) * 1.4887), 4.2rem);
	/*4.2rem-1.9rem (1920-375)*/
	--rem40w: min(calc(4rem + (1vw - 1.92rem) * 0.6472), 4rem);
	/*4rem-3rem (1920-375)*/
	--rem40: min(calc(4rem + (1vw - 1.92rem) * 1.2945), 4rem);
	/*4rem-2rem (1920-375)*/
	--rem36: min(calc(3.6rem + (1vw - 1.92rem) * 0.7767), 3.6rem);
	/*3.6rem-2.4rem (1920-375)*/
	--rem32: min(calc(3.2rem + (1vw - 1.92rem) * 0.3883), 3.2rem);
	/*3.2rem-2.4rem (1920-375)*/
	--rem30w: min(calc(3rem + (1vw - 1.92rem) * 0.3883), 3rem);
	/*3rem-2.4rem (1920-375)*/
	--rem30: min(calc(3rem + (1vw - 1.92rem) * 0.6472), 3rem);
	/*3rem-2rem (1920-375)*/
	--rem30s: min(calc(3rem + (1vw - 1.92rem) * 0.9709), 3rem);
	/*3rem-1.5rem (1920-375)*/
	--rem28: min(calc(2.8rem + (1vw - 1.92rem) * 0.6472), 2.8rem);
	/*2.8rem-1.8rem (1920-375)*/
	--rem27: min(calc(2.7rem + (1vw - 1.92rem) * 0.6472), 2.7rem);
	/*2.7rem-1.8rem (1920-375)*/
	--rem26: min(calc(2.6rem + (1vw - 1.92rem) * 0.6472), 2.6rem);
	/*2.6rem-1.8rem (1920-375)*/
	--rem24w: min(calc(2.4rem + (1vw - 1.92rem) * 0.3883), 2.4rem);
	/*2.4rem-1.8rem (1920-375)*/
	--rem24: min(calc(2.4rem + (1vw - 1.92rem) * 0.6472), 2.4rem);
	/*2.4rem-1.4rem (1920-375)*/
	--rem22w: min(calc(2.2rem + (1vw - 1.92rem) * 0.3883), 2.2rem);
	/*2.2rem-1.6rem (1920-375)*/
	--rem22: min(calc(2.2rem + (1vw - 1.92rem) * 0.6472), 2.2rem);
	/*2.2rem-1.4rem (1920-375)*/
	--rem20w: min(calc(2rem + (1vw - 1.92rem) * 0.2589), 2rem);
	/*2rem-1.6rem (1920-375)*/
	--rem20: min(calc(2rem + (1vw - 1.92rem) * 0.3883), 2rem);
	/*2rem-1.4rem (1920-375)*/
	--rem18: min(calc(1.8rem + (1vw - 1.92rem) * 0.2589), 1.8rem);
	/*1.8rem-1.4rem (1920-375)*/
	--rem16: min(calc(1.6rem + (1vw - 1.92rem) * 0.1294), 1.6rem);
	/*1.6rem-1.4rem (1920-375)*/
	--rem15: min(calc(1.5rem + (1vw - 1.92rem) * 0.1294), 1.5rem);
	/*1.5rem-1.4rem (1920-375)*/
	--rem14: min(calc(1.4rem + (1vw - 1.92rem) * 0.1294), 1.4rem);
	/*1.4rem-1.2rem (1920-375)*/
	--rem12: min(calc(1.2rem + (1vw - 1.92rem) * 0.0647), 1.2rem);
	/*1.2rem-1.1rem (1920-375)*/
}

/*------------------------------------------------------
Global Style
------------------------------------------------------*/
html {
	scroll-behavior: smooth;
}

body p {
	line-height: 2;
}

a:hover {
	opacity: 0.8;
}

.clear-both {
	clear: both;
}

.imgarea img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.fw-medium {
	font-weight: 500 !important;
}

.fw-bold {
	font-weight: 700 !important;
}

.bg-primary-tint {
	background-color: var(--color-primary-tint);
}

.bg-gray {
	background-color: var(--color-table-background);
}

.color-white {
	color: var(--color-white) !important;
}

.color-primary {
	color: var(--color-primary) !important;
}

.color-secondary {
	color: var(--color-secondary) !important;
}

.lh-2 {
	line-height: 2;
}

.marker--yellow {
	background: linear-gradient(transparent 60%, #ffff66 60%);
	font-weight: 700;
}

.marker--primary {
	background: linear-gradient(transparent 60%, var(--color-primary-tint) 60%);
}

.fs-18 {
	font-size: var(--rem18) !important;
}

.fs-20 {
	font-size: var(--rem20w) !important;
}

.txtstyle01 {
	font-weight: 500;
	font-size: var(--rem24w);
	line-height: 1.8;
	margin-bottom: var(--px24);
}

.txtstyle02 {
	font-weight: 700;
	font-size: var(--rem16);
	line-height: 2;
	margin-bottom: var(--px40);
}

.txtstyle02 span {
	font-size: var(--rem20w);
	display: block;
}

.txtstyle03 {
	text-align: center;
	margin: var(--px20) 0;
	font-weight: bold;
}

.anchor_link::before {
	padding-top: var(--px80);
	margin-top: calc(var(--px80) * -1);
}

/*---------------------- Text Style -------------------*/
.post h2,
.cta-bg h2 {
	font-family: var(--font-family02);
	color: var(--color-font);
	letter-spacing: 0;
	position: relative;
	margin-bottom: var(--px60);
	text-transform: capitalize;
	text-align: center;
	font-weight: 700;
	line-height: 1.4;
}

.home .post h2,
.cta-bg h2 {
	font-size: var(--rem50);
}

.post h2 span,
.cta-bg h2 span {
	display: block;
	font-family: var(--font-family02);
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0;
	text-transform: capitalize;
	color: var(--color-gray);
}

.cta-bg h2,
.cta-bg h2 span {
	color: var(--color-white);
}

.home .post h2 span,
.cta-bg h2 span {
	font-size: var(--rem24w);
}

.home .post h2::after {
	display: none;
}

.post h3 {
	padding-left: 0;
	margin-bottom: var(--px40);
}

/*---------------------- Table Style -------------------*/
.post table {
	font-size: 100%;
	border: 0;
	border-collapse: separate;
	border-spacing: 0 2px;
}

.post table.tbl-spacing {
	border-collapse: separate;
	border-spacing: 0 2px;
}

.post table th,
.post table td {
	padding: var(--px20) var(--px20);
	letter-spacing: 0;
}

.post table th {
	width: 28%;
	font-weight: 700;
	border-width: 1px 0 1px 1px;
	vertical-align: top;
	background-color: var(--color-secondary);
	color: var(--color-white);
	border: 0;
}

/*---------------------- Button Style -------------------*/
.linkBtn,
.post .linkBtn {
	padding: 23px 40px 23px 20px;
	max-width: 300px;
	font-family: var(--font-family02);
	font-size: var(--rem16);
	border: 0;
	text-transform: uppercase;
	text-align: center;
	font-weight: 700;
	line-height: 1.4;
	border-radius: 0;
	letter-spacing: 0;
	background: var(--color-white);
	color: var(--color-font);
	box-shadow: inset 0 0 0 2px var(--color-table-border);
}

.linkBtn.linkBtn_secondary,
.post .linkBtn.linkBtn_secondary {
	background-color: var(--color-secondary);
	box-shadow: inset 0 0 0 2px var(--color-secondary);
	color: var(--color-white);
}

.linkBtn.linkBtn_primary,
.post .linkBtn.linkBtn_primary {
	background-color: var(--color-primary);
	box-shadow: inset 0 0 0 2px var(--color-primary);
	color: var(--color-white);
}

.linkBtn::after,
.post .linkBtn::after {
	/* content: '\f0a9'; */
	content: '\f105';
	font-size: 1.6rem;
	font-weight: 700;
	font-family: 'FontAwesome';
	transform: rotate(0) translateY(-50%);
	width: auto;
	height: auto;
	border: 0;
	margin: 0;
	right: 25px;
}

.linkBtn:hover,
.post .linkBtn:hover {
	background: var(--color-white);
	color: var(--color-primary);
	box-shadow: inset 0 0 0 2px var(--color-primary);
	opacity: 1;
}

.linkBtn.linkBtn_secondary:hover,
.post .linkBtn.linkBtn_secondary:hover {
	background-color: var(--color-white);
	box-shadow: inset 0 0 0 2px var(--color-secondary);
	color: var(--color-secondary);
}

.linkBtn.linkBtn_primary:hover,
.post .linkBtn.linkBtn_primary:hover {
	background-color: var(--color-white);
	box-shadow: inset 0 0 0 2px var(--color-primary);
	color: var(--color-primary);
}

/*------------------------------------------------------
  Footer Style
  ------------------------------------------------------*/
#footer .footer__logo a {
	display: inline-block;
	line-height: 1;
}

#footer ul li a {
	font-weight: 500;
	font-size: var(--rem14);
	line-height: 1.2;
	color: var(--footer-color-font);
}

#copyright {
	line-height: 1.2;
	background: transparent;
	font-weight: 300;
	color: var(--footer-color-font);
	padding: 0 1rem;
	margin-top: var(--px20);
}

#footer .footnav:not(:last-child) {
	margin-bottom: 0;
}

#footer .socialicon .fa-facebook:before,
#footer .socialicon .fa-twitter:before,
#footer .socialicon .fa-youtube:before,
#footer .socialicon .fa-instagram:before,
#footer .socialicon .fa-x-twitter:before,
#footer .socialicon .fa-line:before,
#footer .socialicon .fa-tiktok:before {
	color: var(--color-font);
}

#footer .footer__logo:not(:last-child) {
	max-width: 95%;
	margin: var(--px20) auto;
}

.socialicon {
	max-width: 95%;
	margin: 0 auto;
}

/*------------------------------------------------------
  Home Page Style
  ------------------------------------------------------*/
.home .post {
	font-family: var(--font-family02);
}

.home .post .linkBtn {
	max-width: 340px;
}

.home .wrapper_content {
	max-width: var(--content-max-width-lg);
}

.home .home-none {
	display: none;
}

#company {
	background: url('/wp-content/uploads/bg-01.png') no-repeat center top / cover;
}

#company .wrapper_content {
	background-color: var(--color-background);
	padding: var(--px120) var(--px40);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 90%;
}

#service {
	background: linear-gradient(180deg, #ffffff 0%, #e5e5e5 100%);
}

.column_01_box {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}

.column_01_box+.column_01_box {
	margin-top: var(--px60);
}

.column_01_box .imgarea {
	width: 60.4166667%;
	position: relative;
	overflow: hidden;
	aspect-ratio: 1160/860;
}

.column_01_box .txtarea {
	width: 50%;
	margin: 0 0 0 -10.4166667%;
	z-index: 10;
	background-color: var(--color-background);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--px100) var(--px40);
}

.column_01_box.rev .txtarea {
	margin: 0 -10.4166667% 0 0;
}

.column_01_box .txtinner {
	max-width: 760px;
	width: 100%;
	margin: 0 auto;
}

.column_01_box h3 {
	font-weight: 700;
	font-size: var(--rem48w);
	line-height: 1.4;
	padding: 0;
	border: 0;
	margin: 0;
}

.block_title {
	display: flex;
	align-items: center;
	
}
.block_title:has(>img) {
	flex-direction: row-reverse;
}
.btn_block {
	display: flex;
	gap: var(--px30);
}

.btn_block li {
	width: calc(50% - calc(var(--px30) / 2));
	max-width: 340px;
}

#news {
	background: linear-gradient(180deg, #ffffff 0%, #f5f5f5 100%);
}

.postlist li {
	border-bottom: 1px solid var(--color-table-border);
}

.postlist li:first-child {
	border-top: 1px solid var(--color-table-border);
}

.postlist .post_text {
	padding: 25px 0;
	color: var(--color-gray);
}

.post .time,
.postlist .time,
.post2b .time,
.post4b .time {
	background-color: var(--color-primary-tint);
	padding: 1.5px 1rem;
	display: block;
	font-size: var(--rem12);
	line-height: 2;
	font-family: var(--font-family02);
}

.post .time a,
.post2b .time a,
.post4b .time a,
.postlist .time a {
	font-weight: 400;
	font-size: var(--rem12);
	line-height: 2;
	text-transform: uppercase;
	color: var(--color-white);
}

.postlist .ttls,
.postlist .date {
	font-size: var(--rem16);
	color: var(--color-font);
	font-family: var(--body-font-family);
}

.postlist .date {
	margin-right: 10px;
}

.postlist .ttls {
	margin-left: 10px;
}

.post2b li .post2b_contents,
.post4b li .post4b_contents {
	opacity: 1;
	font-size: var(--rem14);
	line-height: 1.8;
}

.post_link,
.post2b_link,
.post4b_link {
	font-size: var(--rem12);
	color: var(--color-font);
}

.post_link a,
.post2b_link a,
.post4b_link a {
	color: var(--color-font);
}

/*------------------------------------------------------
  Inner Pages Style
  ------------------------------------------------------*/
header#h1Header::before {
	background-color: var(--color-white);
	opacity: 0;
}

header#h1Header h1.title {
	color: var(--color-white);
	font-weight: 700;
	font-size: var(--rem40w);
	text-transform: uppercase;
}

/*---------col03-----------*/
.post .col3_list {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	flex-wrap: wrap;
}

.post .col3_list>li {
	width: 32%;
	margin-bottom: 2%;
}

.post .col3_list::before {
	content: '';
	display: block;
	width: 32%;
	height: 0;
	order: 1;
}

.post .col3_list:after {
	content: '';
	display: block;
	width: 32%;
	height: 0;
}

@media print,
screen and (max-width: 768px) {
	.post .col3_list>li {
		width: 49%;
	}

	.post .col3_list::before,
	.post .col3_list:after {
		content: none;
	}
}

@media print,
screen and (max-width: 414px) {
	.post .col3_list>li {
		width: 100%;
	}

	.post .col3_list>li:last-child {
		margin-bottom: 0;
	}
}

/*---------col4-----------*/
.post .col4_list {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	flex-wrap: wrap;
}

.post .col4_list>li {
	width: 24%;
	margin-bottom: 1.5%;
}

.post .col4_list::before {
	content: '';
	display: block;
	width: 24%;
	height: 0;
	order: 1;
}

.post .col4_list:after {
	content: '';
	display: block;
	width: 24%;
	height: 0;
}

@media print,
screen and (max-width: 1240px) {

	.post .col4_list>li,
	.post .col4_list::before,
	.post .col4_list:after {
		width: 32%;
		margin-bottom: 2%;
	}
}

@media print,
screen and (max-width: 768px) {
	.post .col4_list>li {
		width: 49%;
	}

	.post .col4_list::before,
	.post .col4_list:after {
		content: none;
	}
}

@media print,
screen and (max-width: 414px) {
	.post .col4_list>li {
		width: 100%;
	}

	.post .col4_list>li:last-child {
		margin-bottom: 0;
	}
}

/*--flow02--------------------------------------------*/

.flowlist02 {
	padding-left: 5rem;
	position: relative;
}

.flowlist02::before {
	content: '';
	width: 15px;
	height: 100%;
	background: var(--color-secondary-tint);
	margin-left: -8px;
	display: block;
	position: absolute;
	top: 0;
	left: 5rem;
}

.flowlist02>li {
	position: relative;
}

.flowlist02>li:not(:last-child) {
	margin-bottom: 8vh;
}

.flowlist02>li .icon {
	font-size: var(--rem20w);
	width: 5rem;
	height: 5rem;
	color: #fff;
	font-weight: bold;
	background: var(--color-primary-shade);
	padding: 0.2rem;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: -2.5rem;
	z-index: 100;
	border-radius: 50vh;
}

.flowlist02>li .icon::after {
	content: none;
}

.flowlist02>li dl {
	padding-left: 7rem;
	position: relative;
	padding-top: 0.7rem;
}

.flowlist02>li dl::before {
	content: none;
}

.flowlist02>li dl::after {
	content: '';
	display: block;
	position: absolute;
	top: 20px;
}

.flowlist02>li dl::after {
	width: 50px;
	border-bottom: 1px dashed #999;
	position: absolute;
	left: 5px;
	top: 2.3rem;
}

.flowlist02>li dd {
	/* padding-bottom: 10px;
  border-bottom: dotted 2px; */
}

.flowlist02>li dl dt {
	margin-bottom: 0.5rem;
	font-weight: 7s00;
	font-size: var(--rem20w);
	border-bottom: 1px solid var(--color-table-border);
}

@media (max-width: 768px) {
	.flowlist02 {
		padding-left: 2rem;
	}

	.flowlist02>li .icon {
		left: -3.5rem;
	}

	.flowlist02::before {
		left: 1rem;
	}

	.flowlist02>li dl {
		padding-left: 4.5rem;
	}

	.flowlist02>li dl::after {
		width: 30px;
	}

	.flowlist02>li dl dt {
		font-size: 1.4rem;
	}
}

/*------------------------------------------------------
  Contact Pages Style
  ------------------------------------------------------*/
input[type='text'],
input[type='tel'],
input[type='email'],
input[type='date'],
input[type='url'],
input[type='number'],
select,
textarea {
	min-height: 40px;
	border-radius: 5px;
}

input[type='text'],
input[type='tel'],
input[type='email'],
input[type='date'],
input[type='url'],
input[type='number'],
select,
textarea {
	margin-bottom: 0;
	line-height: 1;
	font-family: var(--font-family02);
}

.subimitarea .linkBtn,
.subimitarea .linkBtn:hover {
	padding: 0;
	background: transparent;
	box-shadow: none;
}

input[type='submit'],
input[type='reset'],
input[type='button'] {
	padding: 23px 40px 23px 20px;
	max-width: 300px;
	font-family: var(--font-family02);
	font-size: var(--rem16);
	border: 0;
	text-transform: uppercase;
	text-align: center;
	font-weight: 700;
	line-height: 1.4;
	border-radius: 0;
	letter-spacing: 0;
	background: var(--color-white);
	color: var(--color-font);
	box-shadow: inset 0 0 0 2px var(--color-table-border);
}

.post .subimitarea .linkBtn input[type='submit'] {
	padding: 23px 40px 23px 20px;
	max-width: 300px;
	font-family: var(--font-family02);
	font-size: var(--rem16);
	border: 0;
	text-transform: uppercase;
	text-align: center;
	font-weight: 700;
	line-height: 1.4;
	border-radius: 0;
	letter-spacing: 0;
	background: var(--color-white);
	color: var(--color-font);
	box-shadow: inset 0 0 0 2px var(--color-table-border);
}

.post .subimitarea .linkBtn:hover input[type='submit'] {
	background: var(--color-white);
	color: var(--color-primary);
	box-shadow: inset 0 0 0 2px var(--color-primary);
	opacity: 1;
}

.wpcf7-form input[type='submit']:disabled:hover {
	cursor: not-allowed;
}

.wpcf7-form .must {
	background: var(--header-color-primary);
	color: var(--color-white);
	font-size: 100%;
	font-weight: 500;
}

.wrapper-acceptance {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}

.wrapper-acceptance>span {
	width: auto;
}

.wpcf7-form .must_fn {
	float: none;
}

/*---------------------- CTA Style --------------------*/
.cta-bg {
	position: relative;
	padding: var(--px120) 0 0;
	clear: both;
	color: var(--color-white);
}

.cta-bg::before,
.cta-bg::after {
	display: block;
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 84%;
	z-index: -1;
}

.cta-bg::before {
	background: url('/wp-content/uploads/cta.png') no-repeat center center / cover;
}

.cta-bg::after {
	background-color: var(--color-black);
	opacity: 0.4;
}

.cta01 .cta01_wrap {
	max-width: var(--content-max-width-lg);
	width: 94%;
	margin: 0 auto;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--color-primary);
	border: 0;
	background-color: transparent;
	border-radius: 0;
	padding: 0;
}

.cta01_inner {
	width: 94%;
	margin: 0 auto;
	max-width: 1000px;
}

.cta_des {
	text-align: center;
	color: var(--color-font);
	margin-bottom: var(--px60);
	font-family: var(--font-family02);
	font-weight: 400;
	font-size: var(--rem16);
	letter-spacing: 0;
}

.cta01 .ctabtnlist {
	justify-content: center;
	gap: 0;
}

.cta01 .ctabtnlist li {
	width: 50%;
	margin: 0;
	padding: 0;
	line-height: 1;
	display: flex;
}

.cta01 a.item,
.cta01 .mailarea {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 100%;
	margin: 0 auto;
	padding: 36px 10px;
	text-align: center;
	box-sizing: border-box;
	color: var(--color-background);
	transition: all ease 0.15s;
	background: var(--color-primary);
	box-shadow: inset 0 0 0 1px var(--color-primary);
	border-radius: 0;
}

.cta01 a.item:hover,
.cta01 .mailarea:hover {
	opacity: 0.8;
}

.cta01 .btnttl {
	display: block;
	font-size: var(--rem20w);
	line-height: 1.2;
	font-weight: 700;
	font-family: var(--font-family02);
}

.cta01 .infotxt {
	font-size: var(--rem16);
	line-height: 1.2;
	font-family: var(--font-family02);
	font-weight: 700;
}

.cta01 a.item.telbtn {
	background: var(--color-secondary-tint);
	color: var(--color-primary);
}


.cta01 a.item.telbtn2 {
	background-color: var(--color-secondary);
	color: var(--color-white);
	box-shadow: inset 0 0 0 1px var(--color-secondary);
}


.cta01 .telnum {
	margin: 0 0 1rem;
	font-family: var(--font-family02);
	font-size: var(--rem36);
	line-height: 1.2;
	font-weight: 700;
	display: flex;
	align-items: center;
	color: var(--color-font);
}

.cta01 a.item.telbtn .telnum {
	color: inherit;
}

.telnum.white {
	color: var(--color-white);
}

.cta01 a.mailarea {
	background: var(--color-primary);
	color: var(--color-white);
}

.cta01 .mailarea .btnttl {
	display: flex;
	align-items: center;
	font-size: var(--rem20w);
	line-height: 1.2;
	font-weight: 700;
	font-family: var(--font-family02);
	margin-bottom: 0;
}

.cta01 .mailarea .infotxt {
	font-size: var(--rem16);
	font-weight: 700;
}

.mailbtn {
	border-radius: 0;
	color: var(--color-white);
	font-family: var(--font-family02);
	font-weight: 700;
	font-size: var(--rem24w);
	letter-spacing: 0;
	line-height: 1.2;
}

.mailbtn::before {
	content: '\f0e0';
	margin-right: 1rem;
	display: inline-block;
	font-family: 'FontAwesome';
	font-weight: 900;
	margin-right: 1rem;
	font-size: var(--rem28);
}

.cta01 .mailarea .btnttl::before,
.cta01 .telnum::before {
	content: '';
	display: inline-block;
	font-family: 'FontAwesome';
	font-weight: 900;
	margin-right: 1rem;
	font-size: var(--rem20);
}

.cta01 .telnum::before {
	content: '\f095';
	font-size: var(--rem32);
	margin-right: 1rem;
	color: var(--color-primary);
}

.cta01 .telnum.white::before {
	content: '\f095';
	font-size: var(--rem32);
	margin-right: 1rem;
	color: var(--color-white);
}

.cta01 .mailarea .btnttl::before {
	content: '\f0e0';
	font-size: var(--rem24w);
	margin-right: 1rem;
	display: none;
}

.cta01 a.linearea.item {
	background-color: var(--color-secondary);
	color: var(--color-primary);
}

.cta01 a.linearea.item .linebtn {
	font-weight: 700;
	font-size: var(--rem20w);
	line-height: 1.2;
}

.cta01 a.linearea.item .linebtn::before {
	content: '\f073';
	display: inline-block;
	font-family: 'FontAwesome';
	font-weight: 900;
	margin-right: 1rem;
	font-size: var(--rem24w);
}

/*------------------------------------------------------
  Responsive Style
  ------------------------------------------------------*/
@media print,
screen and (min-width: 1024px) {

	/*------------------------------------------------------
  Header Style
  ------------------------------------------------------*/
	.top_bar {
		background-color: var(--color-primary);
		color: var(--color-white);
		font-weight: 600;
		font-size: var(--rem14);
		line-height: 1.4;
		padding: 10px clamp(10px, 10px + 10 * ((100vw - 1024px) / 896), 20px);
	}

	#header {
		height: 100px;
		font-family: var(--font-family02);
	}

	.sticky-header #header>.inner {
		background-color: var(--header-background);
	}

	#header .logo {
		padding: 10px clamp(10px, 10px + 10 * ((100vw - 1024px) / 896), 20px);
	}

	#header .logo img {
		max-width: clamp(240px, 240px + 336 * ((100vw - 1024px) / 896), 576px);
		max-height: 80px;
	}

	nav#mainNav ul li a {
		padding-left: clamp(10px, 10px + 20 * ((100vw - 1024px) / 896), 30px);
		padding-right: clamp(10px, 10px + 20 * ((100vw - 1024px) / 896), 30px);
		font-size: clamp(14px, 14px + 2 * ((100vw - 1024px) / 896), 16px);
		text-align: center;
		font-family: var(--font-family02);
		font-weight: 700;
		line-height: 1.6;
		letter-spacing: 0;
		color: var(--header-color-font);
	}

	nav#mainNav ul li a b {
		font-family: var(--font-family02);
		font-size: clamp(14px, 14px + 2 * ((100vw - 1024px) / 896), 16px);
		font-weight: 700;
		line-height: 1.6;
		letter-spacing: 0;
	}

	nav#mainNav ul li a span {
		font-family: var(--font-family02);
		font-size: var(--rem12);
		font-weight: 400;
		line-height: 1.6;
		letter-spacing: 0;
	}

	nav#mainNav ul li a:active,
	nav#mainNav ul li a:hover,
	nav#mainNav ul li.current-menu-ancestor a,
	nav#mainNav ul li.current-menu-item a,
	nav#mainNav ul li.current-menu-parent a {
		background: var(--header-background);
		color: var(--header-color-primary);
	}

	nav#mainNav ul li.current-menu-item a b,
	nav#mainNav ul li a:hover b,
	nav#mainNav ul li a:active b,
	nav#mainNav ul li.current-menu-parent a b {
		color: var(--header-color-primary);
	}

	nav#mainNav ul li a:active span,
	nav#mainNav ul li a:hover span,
	nav#mainNav ul li.current-menu-item a span,
	nav#mainNav ul li.current-menu-parent a span {
		color: var(--header-color-primary);
	}

	nav#mainNav ul li ul.sub-menu li a:hover,
	nav#mainNav ul li li a:hover,
	nav#mainNav ul li li.current-menu-item a,
	nav#mainNav ul li li.current-menu-item li a:hover,
	nav#mainNav ul li.current-menu-item li a:hover,
	nav#mainNav ul li.current-menu-ancestor li.current-menu-item a,
	nav#mainNav ul li.current-menu-ancestor li a:hover {
		background: var(--header-background);
		color: var(--header-color-primary);
	}

	#header ul.header__contact {
		margin-left: clamp(10px, 10px + 20 * ((100vw - 1024px) / 896), 30px);
		margin-right: 0;
	}

	.header__contact>li {
		display: flex;
		align-items: center;
	}

	#header a.head_btn {
		padding-left: clamp(5px, 5px + 0 * ((100vw - 1024px) / 896), 5px);
		padding-right: clamp(5px, 5px + 0 * ((100vw - 1024px) / 896), 5px);
		font-weight: 700;
		background: var(--header-color-primary);
		color: var(--header-color-font);
		text-align: center;
		border-radius: 0;
	}

	#header a.head_btn:hover {
		background: var(--header-color-primary);
		color: var(--header-background);
	}

	#header a.head_btn.tel_btn {
		color: var(--header-color-font);
		width: clamp(193px, 193px + 47 * ((100vw - 1024px) / 896), 240px);
		position: relative;
		text-align: center;
		background: var(--color-secondary-tint);
		color: var(--color-primary);
	}

	#header a.head_btn.tel_btn.tel_btn_2 {
		background-color: var(--color-secondary);
		color: var(--color-white);
	}

	.tel_title {
		font-size: clamp(10px, 10px + 2 * ((100vw - 1024px) / 896), 12px);
		font-weight: 700;
	}

	.tel_title_2 {
		font-size: clamp(12px, 12px + 2 * ((100vw - 1024px) / 896), 16px);
		font-weight: 700;
	}

	#header a.head_btn.tel_btn::before {
		display: none;
	}

	#header a.head_btn.tel_btn:hover {
		background: var(--color-secondary-tint);
		color: var(--color-primary);
		opacity: 0.8;
	}

	#header a.head_btn.tel_btn.tel_btn_2:hover {
		background-color: var(--color-secondary);
		color: var(--color-white);
		opacity: 0.8;
	}

	#header a.head_btn.tel_btn .tel_num {
		font-size: clamp(16px, 16px + 8 * ((100vw - 1024px) / 896), 24px);
		font-family: var(--font-family02);
		display: flex;
		align-items: center;
		font-weight: 700;
		line-height: 1;
		margin: 0.5rem 0;
	}

	#header a.head_btn.tel_btn .tel_num::before {
		content: '\f095';
		display: block;
		font-family: 'FontAwesome';
		font-size: clamp(14px, 14px + 4 * ((100vw - 1024px) / 896), 18px);
		font-weight: 700;
		line-height: 1;
		margin-right: 1rem;
	}

	.tel_rec,
	.tel_rec .note,
	.tel_rec .note b {
		font-weight: 400;
		font-size: clamp(10px, 10px + 2 * ((100vw - 1024px) / 896), 12px);
		font-family: var(--font-family02);
	}

	#header a.head_btn.mail_btn {
		line-height: 1.2;
		font-size: var(--rem14);
		font-family: var(--font-family02);
		width: clamp(120px, 120px + 70 * ((100vw - 1024px) / 896), 190px);
		font-weight: 700;
		text-transform: uppercase;
		color: var(--color-white);
		border-radius: 0;
		border: 0;
		background: var(--header-color-primary);
	}

	#header a.head_btn.mail_btn:hover {
		background: var(--header-color-primary);
		color: var(--color-white);
		opacity: 0.8;
	}

	#header a.head_btn.mail_btn::before {
		font-size: var(--rem20);
		margin-bottom: 1rem;
		display: none;
	}

	#header a.head_btn.mail_btn span {
		font-size: var(--rem14);
		display: flex;
		align-items: center;
		font-family: var(--font-family02);
		font-weight: 700;
		line-height: 1.2;
		text-transform: uppercase;
		letter-spacing: 0.03em;
	}

	#header a.head_btn.mail_btn span::before {
		margin-right: 1rem;
		display: block;
		font-family: 'FontAwesome';
		font-weight: 700;
		font-size: clamp(14px, 14px + 6 * ((100vw - 1024px) / 896), 20px);
		line-height: 1;
		content: '\f0e0';
	}

	#footer {
		padding: var(--px80) 0 var(--px60);
	}

	#footer .footer__logo:not(:last-child) {
		margin-top: 0;
		margin-bottom: var(--px20);
	}

	#footer .footer__logo img {
		max-width: 576px;
		max-height: 80px;
	}

	.pc_none {
		display: none !important;
	}
}

@media print,
screen and (max-width: 1023px) {
	#header .logo .mark a {
		display: block;
		line-height: 1;
	}

	nav#mainNav ul li.current-menu-item a,
	nav#mainNav ul li a:hover {
		background-color: var(--color-primary) !important;
		color: var(--color-white);
	}

	.column_01_box.rev {
		flex-direction: row;
	}

	.column_01_box .imgarea,
	.column_01_box .txtarea {
		width: 90%;
	}

	.column_01_box .txtarea,
	.column_01_box.rev .txtarea {
		margin: calc(-60px + (1vw - 10.23px) * -3.858) 0 0 auto;
	}

	.pc_none {
		display: inherit;
	}
	.cta01 .ctabtnlist li {
		width: 100%;
	}

	.cta01 .ctabtnlist li+li {
		margin-top: 0;
	}
	.cta01 .ctabtnlist {
		display: block;
	}
}

@media print,
screen and (max-width: 768px) {
	#company .wrapper_content {
		padding: var(--px80) var(--px40);
	}

	.block_title {
		flex-direction: column;
	}

	.btn_block {
		flex-direction: column;
		align-items: center;
	}

	.btn_block li {
		width: 100%;
	}

	.sp_center {
		text-align: center;
	}

	
}

@media print,
screen and (max-width: 640px) {
	.calendar_inner {
		flex-direction: column;
		align-items: center;
	}

	.post table.responsive.tbl-transparent th {
		border: 0;
		padding-right: 0;
		padding-bottom: 0;
	}

	.post table.responsive.tbl-transparent td {
		border-width: 0 0 1px 0;
		padding-left: 0;
		padding-right: 0;
	}

	.post table.responsive.tbl-transparent tr:last-child td:last-child {
		border-bottom: 1px solid var(--color-table-border);
	}
	
	#service > div.column_01_box.rev > div.txtarea > div > div.block_title.mb4 {
    flex-direction: column;
}
	
}

.tel_title_2 {
	font-size: var(--rem16);
	margin-bottom: 1rem;
	line-height: 1.4;
}

.cta01_inner {
	max-width: 1240px;
	width: 100%;
}

.cta01 a.item, .cta01 .mailarea {
	padding: var(--px30) 5px;
	min-height: 110px;
}

