@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&family=Roboto:ital,wdth,wght@0,75..100,100..900;1,75..100,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;
	--font-family03: 'Roboto', '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: #fdf6dc;
	--color-font: #000000;
	--color-primary: #ff8705;
	--color-primary-shade: #9bc32b;
	--color-primary-tint: #3e940f;
	--color-secondary: #e43536;
	--color-secondary-tint: #ffe0e0;
	--color-table-border: #cccccc;
	--color-table-background: #ffffff;
	--color-white: #ffffff;
	--color-link: #f0f0f0;
	--color-gray: #989898;
	--color-gray-light: #808080;
	--color-yellow: #f7a630;
	--color-green: #a7ce70;
	--color-blue: #79bef2;
	--color-blue-dark: #168aff;
	--color-form: #f6f6f6;
	--shadow-green-light: #5d731f;
	--shadow-green-dark: #1f4909;

	/*------------------------------------------------------
  Header
  ------------------------------------------------------*/
	--header-background: #ffffff;
	--header-color-font: #000000;
	--header-color-primary: #ff8705;
	--header-color-primary-shade: #9bc32b;
	--header-color-primary-tint: #3e940f;
	/*------------------------------------------------------
  Footerh
  ------------------------------------------------------*/
	--footer-background: #ff8705;
	--footer-color-font: #ffffff;
	--footer-color-primary: #ffffff;
	/*------------------------------------------------------
  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)*/
	--px40s: clamp(10px, calc(40px + ((1vw - 19.2px) * 1.9417)), 40px);
	--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)*/
	--px24: min(calc(24px + (1vw - 19.2px) * 0.6472), 24px);
	/*24px-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)*/
	--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)*/
	--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:active,
a:hover {
	color: var(--color-primary);
}

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

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

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

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

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

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

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

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

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

.color-blue-dark {
	color: var(--color-blue-dark) !important;
	border-bottom: 2px solid #168aff;
}

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

.lh-25 {
	line-height: 2.5;
}

/*---------------------- Text Style -------------------*/
h1.title,
.post h1,
header#h1Header h1.title {
	font-size: var(--rem40w);
	font-weight: 700;
}

header#h1Header h1.title {
	color: var(--color-background);
	font-family: var(--font-family03);
}

.post h1 {
	font-family: var(--font-family03);
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.05em;
	text-align: center;
	color: var(--color-font);
	margin-bottom: var(--px40);
}

.post h1::after {
	display: none;
}

.post h1>span {
	display: block;
	font-family: var(--font-family04);
	font-weight: 400;
	line-height: 1.2;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--color-primary);
}

.post h2,
.cta-bg h2 {
	font-family: var(--font-family02);
	text-align: center;
	color: var(--color-font);
	padding-bottom: 0;
	position: relative;
	margin-bottom: var(--px40);
	font-weight: 700;
	line-height: 1.2;
}

.post h2::after,
.cta-bg h2:after {
	display: none;
}

.post h2.txt_l::after {
	margin-left: 0;
}

.post h2>span,
.cta-bg h2>span {
	display: block;
	font-family: var(--font-family03);
	line-height: 1.2;
	text-transform: uppercase;
	color: var(--color-primary);
	font-weight: 700;
	font-size: var(--rem30w);
}

.post h3 {
	border-left: 0;
	font-size: var(--rem36);
	font-family: var(--font-family02);
	font-weight: 700;
	text-align: left;
	color: var(--color-font);
	padding: 0;
	margin-bottom: var(--px30);
	position: relative;
	border-bottom: 0;
	font-weight: 700;
	font-size: 36px;
	line-height: 2.2;
	display: flex;
	align-items: center;
}

.post h3::before {
	content: '';
	display: block;
	width: 12px;
	height: 100%;
	min-height: 46px;
	margin-right: var(--px30);
	background-color: var(--color-primary);
	position: static;
}

.post h4 {
	color: var(--color-font);
	font-family: var(--font-family02);
	font-weight: 700;
	font-size: var(--rem24w);
	line-height: 1.4;
	text-align: left;
	letter-spacing: 0.05em;
	padding: 0 0 16px;
	max-width: fit-content;
	border-bottom: 1px solid;
	margin: 0 0 var(--px20);
}

.post h4::before {
	display: none;
}

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

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

.fs-20 {
	font-size: var(--rem20);
}

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

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

/*---------------------- Table Style -------------------*/
.post table {
	font-size: 100%;
	border: 0;
}

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

.post table th {
	background: var(--color-table-background);
	width: 28%;
	font-weight: 700;
	color: var(--color-font);
}

/*---------------------- Button Style -------------------*/
.linkBtn,
.post .linkBtn {
	color: var(--color-background);
	background: var(--color-font);
	border-radius: 0;
	padding: 20px 40px 20px 40px;
	max-width: 385px;
	font-family: var(--font-family04);
	font-weight: 400;
	font-size: var(--rem16);
	line-height: 1.75;
	border: 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	text-align: center;
}

.linkBtn:hover,
.post .linkBtn:hover {
	background: var(--color-primary);
	opacity: 0.7;
}

.link_btn {
	max-width: 240px;
	background: transparent;
	padding: 10px;
	border-bottom: 2px solid var(--color-font);
	color: var(--color-font);
	border-radius: 0;
	font-family: var(--font-family03);
	font-weight: 700;
	font-size: var(--rem20);
	text-transform: uppercase;
	text-align: left;
}

.link_btn::after {
	font-size: 1.2rem;
	border-radius: 100%;
	width: 4rem;
	height: 4rem;
	background: var(--color-primary-shade);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color-background);
	padding-left: 3px;
	box-sizing: border-box;
}

.link_btn:hover {
	border-bottom-color: var(--color-primary-shade);
	color: var(--color-background);
}

.link_btn:hover::after {
	background: var(--color-white);
	color: var(--color-primary-shade);
}

/*------------------------------------------------------
  Header Style
  ------------------------------------------------------*/
nav#mainNav ul li a b {
	font-family: var(--font-family03);
	font-weight: 500;
	letter-spacing: 0.05em;
	display: flex;
	align-items: center;
}

nav#mainNav ul li ul.sub-menu li a {
	display: flex;
	flex-direction: row;
}

nav#mainNav ul li a b::before,
nav#mainNav ul li ul.sub-menu li a::before {
	display: block;
	content: '\f078';
	font-family: 'FontAwesome';
	font-size: clamp(12px, 12px + 2 * ((100vw - 1024px) / 896), 14px);
	font-weight: 700;
	line-height: 1;
	margin-right: 0.6rem;
}

/*------------------------------------------------------
  Footer Style
  ------------------------------------------------------*/
.footer__link {
	max-width: var(--content-max-width-lg);
	margin: 0 auto;
	text-align: center;
}

.footer__link .linkBtn {
	background: var(--color-primary-shade);
	box-shadow: 0px 6px 0px var(--shadow-green-light);
	border-radius: 10px;
	width: 287px;
	height: 82px;
	padding: 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: var(--rem20w);
	font-weight: 500;
	letter-spacing: 0;
}

.footer__link .linkBtn:hover {
	opacity: 0.75;
}

.footer__logo-text {
	font-weight: bold;
	font-size: var(--rem20w);
	line-height: 1.4;
	margin-bottom: 1rem;
}

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

#footer .footer__logo img {
	max-width: 438px;
	max-height: 276px;
	width: 100%;
}

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

#copyright {
	line-height: 1.2;
	margin-top: 1rem;
	background: transparent;
	font-weight: 400;
	width: 95%;
	max-width: var(--content-max-width-lg);
}

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

.footer__contact {
	display: flex;
}

#footer ul.info_footer {
	font-size: var(--rem16);
	line-height: 1.4;
	width: auto;
	text-align: left;
	margin: 0;
}

#footer .inner {
	padding-bottom: var(--px30);
	border-bottom: 1px solid var(--color-link);
	margin-bottom: var(--px30);
}

/*------------------------------------------------------
  Home Page Style
  ------------------------------------------------------*/
.home .post p {
	line-height: 2;
}

.home .post h1 {
	font-size: var(--rem20w);
}

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

.home .post h1>span {
	margin-top: 1rem;
	font-size: calc(var(--rem48w) + 2px);
}

.home .post h2 {
	font-size: calc(var(--rem48w) + 2px);
}

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

.home .post h2>span {
	font-size: var(--rem30w);
}

.home .post h3 {
	border: 0;
	padding: 0;
	text-align: center;
	font-size: var(--rem36);
}

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

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

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

#strengths {
	background: linear-gradient(180deg, #2d8ff5 35.15%, rgba(45, 143, 245, 0) 100%), url('/products/reliable-mr-kanamori/wp-content/uploads/strengths-bg.png') no-repeat center bottom;
	padding-bottom: 0;
}

#strengths {
	background-size: cover;
}

.strengths-icon {
	text-align: right;
}

.strengths-icon img {
	width: 22.45%;
	height: auto;
	margin-top: -31px;
	margin-right: max(calc(22.45% / -2), calc((100% - 100vw) / 2) + 10px);
}

#strengths h2,
#strengths h2 span {
	color: var(--color-white);
}

.list-icon__item .imgarea {
	display: flex;
	align-items: center;
	justify-content: center;
}

.list-icon__item:nth-child(1) .imgarea {
	background: #4db6d6;
}

.list-icon__item:nth-child(2) .imgarea {
	background: #fef6de;
}

.list-icon__item:nth-child(3) .imgarea {
	background: #ffffff;
}

.list-icon__item:nth-child(4) .imgarea {
	background: #3c6878;
}

.list-icon__strong {
	background-color: #ffef63;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.6;
}

.list-icon__item .textarea {
	padding: var(--px40);
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-white);
}

.list-icon__inner {
	width: 100%;
	max-width: 700px;
	margin: 0 auto;
}

.headding__01 {
	font-family: var(--font-family03);
	font-weight: 700;
	font-size: var(--rem50);
	line-height: 1;
	color: var(--color-primary);
}

.headding__01-sub {
	font-weight: 700;
	font-size: var(--rem30w);
	line-height: 1.4;
	color: var(--color-primary);
	margin-bottom: var(--px12);
}

.list-icon__item:not(:last-child) {
	margin-bottom: var(--px30);
}

#gas_water_heater {
	background-color: var(--color-secondary-tint);
}

#gas_water_heater h2,
#gas_water_heater h2 span {
	color: var(--color-secondary);
}

.headding__02 {
	max-width: fit-content;
	margin: 0 auto var(--px60);
	padding: 10px 20px;
	background: var(--color-secondary);
	font-size: var(--px40w);
	font-weight: 700;
	color: var(--color-white);
	line-height: 1.2;
}

.products {
	background-color: var(--color-white);
	border-radius: var(--px20) var(--px20) 0 0;
}

.products__headding {
	font-weight: 900;
	font-size: var(--rem32);
	line-height: 2.2;
	color: var(--color-white);
	background-color: var(--color-secondary);
	border-radius: var(--px20) var(--px20) 0 0;
	padding: 10px 10px;
}

.products__list {
	background-color: var(--color-white);
	padding: 0 var(--px40);
}

.products__item {
	padding: var(--px40) 0;
}

.products__item:not(:last-child) {
	border-bottom: 1px solid var(--color-table-border);
}

.products__item .imgarea {
	border: 1px solid var(--color-table-border);
	padding: var(--px20);
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 310/200;
}

.products__item .imgarea img {
	width: auto;
	height: auto;
}

.products__title {
	background-color: var(--color-link);
	padding: var(--px20) 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: calc(var(--rem18) - 1px);
	line-height: 1.4;
	min-height: var(--px100w);
}

#gas_water_heater .products__list .products__item:first-child .products__title {
	min-height: 112px;
}

.products__note {
	font-weight: 500;
}

.products__price {
	color: var(--color-secondary);
}

.products__value {
	font-family: var(--font-family03);
	font-weight: 700;
	font-size: var(--rem36);
	line-height: 1.4;
}

.products__unit {
	font-weight: 700;
	font-size: var(--rem22w);
	line-height: 1.4;
}

.products__des {
	font-weight: 500;
}

#gas_stove {
	background-color: #ffe5c9;
}

#gas_stove h2,
#gas_stove h2 span {
	color: var(--color-primary);
}

#gas_stove .headding__02 {
	background-color: var(--color-primary);
}

#gas_stove .products__headding {
	background-color: var(--color-primary);
}

#gas_stove .products__title {
	min-height: 47px;
	padding: var(--px12) var(--px16);
	font-size: var(--rem20w);
}

#gas_stove .products__price {
	color: var(--color-primary);
}

#service_area {
	background: url('/products/reliable-mr-kanamori/wp-content/uploads/service-area-bg.png') no-repeat center center / cover;
}

#service_area::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.65);
}

.headding__03 {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--px40);
	position: relative;
	max-width: fit-content;
	margin: 0 auto var(--px30);
	padding: 0 129px;
}

.headding__03 h2 {
	margin: 0;
	color: var(--color-white);
}

.headding__03 h2 span {
	color: var(--color-white);
}

.headding__03 .imgarea {
	position: absolute;
	right: 0;
}

#service_area .textarea {
	padding: var(--px40);
	display: flex;
	align-items: center;
	justify-content: center;
}

#service_area .txtinner {
	max-width: 405px;
	width: 100%;
	margin: 0 auto;
	color: var(--color-white);
}

.block-label:not(:last-child) {
	margin-bottom: var(--px40);
}

.block-label__title {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 6px 16px;
	line-height: 1.6;
	font-weight: 700;
	font-size: var(--rem30);
	margin-bottom: var(--px12);
	max-width: fit-content;
}

.block-label__text {
	font-weight: 500;
}

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

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

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

#flow h2,
#flow h2 span {
	color: var(--color-primary);
}

#flow .headding__03 {
	max-width: 100%;
	padding: 0 19%;
}

#flow .headding__03 .imgarea {
	right: auto;
	left: 0;
}

.txtstyle01 {
	line-height: 1.6;
	font-weight: 500;
	font-size: var(--rem20w);
}

.txtstyle01 span {
	color: var(--color-white);
	text-align: center;
	padding: 0 0.2em;
	background: linear-gradient(90deg, #ff8705 0%, #e43536 100%);
	line-height: 1.4;
	font-size: var(--rem28);
}

.col3_flow {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 60px;
	counter-reset: number;
}

.col3_flow li {
	position: relative;
}

.col3_flow li:not(:last-child)::after {
	content: '';
	width: 36px;
	height: 20px;
	background: linear-gradient(90deg, #ff8705 0%, #e43536 100%);
	clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
	display: block;
	position: absolute;
	top: calc(100% * 164 / 200 / 2.2);
	transform: translateY(-50%) rotate(90deg);
	right: -48px;
}

.col3_flow .img-area {
	background-color: var(--color-white);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: var(--px35) 5px 1px;
	border-radius: 1rem;
	margin-bottom: 1rem;
	position: relative;
	aspect-ratio: 200/146;
}

.col3_flow>li::before {
	display: flex;
	position: absolute;
	top: -34px;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--font-family03);
	font-size: var(--rem36);
	font-weight: 900;
	counter-increment: number;
	content: '0' counter(number);
	color: var(--color-white);
	background-color: var(--color-primary);
	border-radius: 100%;
	align-items: center;
	justify-content: center;
	width: 68px;
	height: 68px;
	z-index: 10;
}

.col3_flow .img-area img {
	max-height: 79px;
	width: auto;
	height: auto;
}

#works {
	background: white url('/products/reliable-mr-kanamori/wp-content/uploads/work-bg.png') no-repeat bottom center;
}

#works h2 {
	color: var(--color-primary);
}

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

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

.col2_flow {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--px140);
}

.col2_flow li {
	position: relative;
}

.col2_flow li:not(:last-child)::after {
	content: '';
	aspect-ratio: 54 / 98;
	width: calc(var(--px140) - var(--px40s) * 2);
	height: auto;
	clip-path: polygon(0 0, 0% 100%, 100% 50%);

	display: block;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right: calc(calc(var(--px40s) + calc(var(--px140) - var(--px40s) * 2)) * -1);
}

.col2_flow-secondary li::after {
	background: var(--color-secondary);
}

.col2_flow-primary li::after {
	background: var(--color-primary);
}

.note-style {
	background-color: var(--color-gray);
	color: white;
	text-align: center;
	font-family: var(--font-family03);
	font-weight: 900;
	font-size: var(--px30w);
	line-height: 1.5;
	padding: 12px 10px;
	letter-spacing: 0.05em;
}

.note-style.note-style__secondary {
	background-color: var(--color-secondary);
}

.note-style.note-style__primary {
	background-color: var(--color-primary);
}

.block__work {
	padding: var(--px60) var(--px40);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 20px;
}

.block__work>div {
	max-width: 1080px;
	width: 100%;
}

.block__work.block__work-secondary {
	background-color: var(--color-secondary-tint);
	box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.16);
}

.block__work.block__work-primary {
	background-color: #ffe5c9;
	box-shadow: 8px 8px 0px rgba(0, 0, 0, 0.16);
}

/*---------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: 31.5%;
	margin-bottom: 2%;
}

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

.post .col3_list:after {
	content: '';
	display: block;
	width: 31.5%;
	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: 500px) {
	.post .col3_list>li {
		width: 100%;
	}

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

/*------------------------------------------------------
  Contact Pages Style
  ------------------------------------------------------*/
.post .wpcf7-form table th,
.post .wpcf7-form table td {
	border-color: var(--color-secondary-tint);
}

.post .wpcf7-form table tr:first-child th,
.post .wpcf7-form table tr:first-child td {
	border-top: 0;
}

.post .wpcf7-form table th {
	font-size: var(--rem20);
	font-weight: 500;
	padding-top: 40px;
}

.post .wpcf7-form table td {
	font-size: var(--rem20);
}

.image_auth_jp_description,
.wpcf7-form-control-wrap {
	font-size: var(--rem20);
	font-weight: 500;
}

input[type='text'],
input[type='tel'],
input[type='email'],
input[type='date'],
input[type='url'],
input[type='number'],
select,
textarea {
	margin-bottom: 0;
	height: 52px;
	line-height: 1;
}

.subimitarea .linkBtn {
	padding: 0;
	background: transparent;
}

input[type='submit'],
input[type='reset'],
input[type='button'] {
	background: var(--color-font);
	color: var(--color-background);
	font-weight: 500;
	font-size: var(--rem24w);
	font-family: var(--font-family02);
	letter-spacing: 0.06em;
}

.post .subimitarea .linkBtn input[type='submit'] {
	text-align: center;
	padding: 13px 40px 13px 40px;
	line-height: 1.75;
	color: var(--color-background);
	border-radius: 0;
	font-size: var(--rem24w);
}

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

.wpcf7-form .must {
	background: var(--color-primary);
	color: var(--color-background);
}

#cta {
	background: linear-gradient(90deg, #ff8705 0%, #e43536 100%);
}

#cta form {
	background-color: var(--color-white);
	border-radius: 20px;
	padding: var(--px80) var(--px40);
}

#cta .wpcf7-form table {
	margin-top: var(--px60);
}

#cta .wpcf7-form table tr {
	border-bottom: 1px solid var(--color-table-border);
	padding-bottom: var(--px40);
	margin-bottom: var(--px40);
	display: flex;
}

#cta .wpcf7-form table th,
#cta .wpcf7-form table td {
	padding: 0;
	border: 0;
}

#cta .wpcf7-form table td {
	width: 70%;
}

#cta .wpcf7-form table th {
	font-weight: 500;
	font-size: var(--rem18);
	line-height: 2;
	width: 30%;
}

#cta .wpcf7-form table td {
	width: 70%;
}

#cta .wpcf7-form .must {
	float: none;
	font-size: var(--rem12);
	font-weight: 700;
	line-height: 2;
	border-radius: 3px;
}

input[type='text'],
input[type='tel'],
input[type='email'],
input[type='date'],
input[type='url'],
input[type='number'],
select,
textarea {
	padding: var(--px20);
	border-radius: 5px;
	font-family: var(--font-family01);
	font-size: var(--body-font-size);
	background-color: var(--color-form);
	color: #000;
}

#cta input[type='radio' i] {
	display: none;
}

#cta .wpcf7-radio .wpcf7-list-item-label {
	position: relative;
	padding-left: 30px;
}

#cta .wpcf7-radio .wpcf7-list-item-label::before {
	position: absolute;
	left: 0;
	top: 5px;
	display: block;
	width: 20px;
	height: 20px;
	border: 1px solid var(--color-table-border);
	border-radius: 100%;
	box-sizing: border-box;
	background-color: var(--color-form);
}

#cta .wpcf7-radio .wpcf7-list-item-label::after {
	position: absolute;
	left: 4px;
	top: 9px;
	content: '';
	display: block;
	width: 12px;
	height: 12px;
	border-radius: 100%;
	box-sizing: border-box;
}

#cta .wpcf7-radio input:checked+.wpcf7-list-item-label::before {
	border-color: var(--color-primary);
	background-color: transparent;
}

#cta .wpcf7-radio input:checked+.wpcf7-list-item-label:after {
	background-color: var(--color-primary);
}

.custom-checkbox input {
	display: none;
}

.custom-checkbox .wpcf7-list-item-label {
	position: relative;
	padding-left: 30px;
	cursor: pointer;
}

.custom-checkbox .wpcf7-list-item-label::before {
	content: '';
	position: absolute;
	left: 0;
	top: 5px;
	width: 20px;
	height: 20px;
	border: 1px solid var(--color-table-border);
	border-radius: 3px;
	box-sizing: border-box;
	background-color: var(--color-form);
}

.custom-checkbox .wpcf7-list-item-label::after {
	content: '';
	position: absolute;
	left: 6px;
	top: 8px;
	width: 6px;
	height: 10px;
	border: solid transparent;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
	opacity: 0;
}

.custom-checkbox input:checked+.wpcf7-list-item-label::before {
	border-color: var(--color-primary);
	background-color: transparent;
}

.custom-checkbox input:checked+.wpcf7-list-item-label::after {
	border-color: var(--color-primary);
	opacity: 1;
}

/*---------------------- CTA Style --------------------*/
.cta-bg {
	position: relative;
	padding: var(--px120) 0;
	background: url('/products/reliable-mr-kanamori/wp-content/uploads/cta.png') no-repeat top center / cover;
}

.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-background);
	border: 0;
}

.cta01_inner {
	width: 100%;
	margin: 0 auto;
	display: flex;
	background: var(--color-white);
	color: var(--color-font);
}

.cta__left {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-background);
	padding: var(--px12);
}

.cta__right {
	padding: var(--px60) var(--px20);
	display: flex;
	align-items: center;
	justify-content: center;
}

.cta__right-inner {
	width: 100%;
	max-width: 740px;
	margin: 0 auto;
}

.cta-bg h2 {
	font-size: var(--rem50);
	color: var(--color-primary);
	margin-bottom: var(--px20);
}

.cta-bg h2::after {
	display: none;
}

.cta-bg h2>span {
	display: none;
}

.cta_des {
	font-weight: 700;
	font-size: 18px;
	line-height: 1.6;
	text-align: center;
	position: relative;
	padding: 0 40px;
	max-width: fit-content;
	margin: 0 auto var(--px30);
}

.cta_des::before,
.cta_des::after {
	content: '';
	position: absolute;
	top: 50%;
	display: inline-block;
	width: 4.4rem;
	height: 0.2rem;
	background-color: var(--color-font);
}

.cta_des::before {
	left: 0;
	-moz-transform: rotate(60deg);
	-webkit-transform: rotate(60deg);
	-ms-transform: rotate(60deg);
	transform: rotate(60deg);
}

.cta_des::after {
	right: 0;
	-moz-transform: rotate(-60deg);
	-webkit-transform: rotate(-60deg);
	-ms-transform: rotate(-60deg);
	transform: rotate(-60deg);
}

.cta01 .ctabtnlist {
	justify-content: center;
	gap: var(--px20);
}

.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: 600px;
	margin: 0 auto;
	padding: 22px 10px;
	text-align: center;
	box-sizing: border-box;
	border-radius: 0;
	transition: all ease 0.15s;
	border-radius: 10px;
	color: var(--color-white);
}

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

.cta01 .btnttl {
	display: block;
	font-weight: 700;
	font-size: var(--rem20w);
	line-height: 24px;
	text-align: center;
	letter-spacing: 0.05em;
}

.cta01 .infotxt {
	font-size: var(--rem15);
	line-height: 1.2;
	font-family: var(--font-family01);
	font-weight: 500;
}

.cta01 a.item.telbtn {
	background: var(--color-primary-shade);
	box-shadow: 0px 6px 0px var(--shadow-green-light);
}

.cta01 .telnum {
	margin: 1rem 0 0.5rem;
	font-family: var(--font-family03);
	font-weight: 700;
	font-size: var(--rem30w);
	line-height: 1;
	display: flex;
	align-items: center;
}

.cta01 a.mailarea {
	background: var(--color-primary-tint);
	box-shadow: 0px 6px 0px var(--shadow-green-dark);
}

.cta01 .mailarea .btnttl {
	display: flex;
	align-items: center;
	font-size: var(--rem24w);
	line-height: 1.2;
	margin-bottom: 0.5rem;
}

.cta01 .mailarea .infotxt {
	font-size: var(--rem18);
	font-weight: 700;
	letter-spacing: 0.05em;
}

.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: '\f3cd';
	content: '\f095';
	font-size: var(--rem20w);
	margin-right: 1rem;
}

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

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

	/*------------------------------------------------------
  Header Style
  ------------------------------------------------------*/
	#header {
		height: 100px;
	}

	#header .logo {
		padding: 5px 5px 5px clamp(0px, 0px + 0 * ((100vw - 1024px) / 896), 0px);
		display: flex;
		flex-direction: column;
	}

	#header .logo a img {
		max-width: clamp(160px, calc(0.2284 * 100vw - 73.84px), 255px);
		max-height: 60px;
	}

	#header .logo .header_logo-by {
		padding-top: 0;
		text-align: right;
		/*     margin-top: -1rem; */
		padding-bottom: 1rem;
	}

	#header .logo .header_logo-by img {
		max-width: 141px;
		max-height: 25px;
	}

	nav#mainNav ul li a {
		padding-left: clamp(5px, 5px + 9 * ((100vw - 1024px) / 896), 14px);
		padding-right: clamp(5px, 5px + 9 * ((100vw - 1024px) / 896), 14px);
		font-size: clamp(12px, 12px + 4 * ((100vw - 1024px) / 896), 16px);
	}

	nav#mainNav ul li a span {
		font-size: var(--rem12);
	}

	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-background);
	}

	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-color-primary);
		color: var(--header-background);
	}

	#header ul.header__contact {
		margin-left: clamp(5px, 5px + 21 * ((100vw - 1024px) / 896), 26px);
		margin-right: clamp(5px, 5px + 5 * ((100vw - 1024px) / 896), 10px);
		gap: 1rem;
	}

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

	#header a.head_btn {
		padding-left: 5px;
		padding-right: 5px;
		font-weight: 700;
		background: var(--header-color-primary);
		color: var(--header-background);
		width: clamp(190px, 190px + 73 * ((100vw - 1024px) / 896), 253px);
		max-height: 80px;
		border-radius: 50vh;
	}

	.sticky-header #header a.head_btn {
		max-height: 60px;
	}

	#header a.head_btn:hover {
		opacity: 0.75;
	}

	#header a.head_btn.tel_btn {
		position: relative;
		background: var(--color-primary-shade);
		box-shadow: 0px 5px 0px var(--shadow-green-light);
	}

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

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

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

	.tel_rec .note,
	.tel_rec .note b {
		font-weight: 500;
		font-size: var(--rem12);
	}

	#header a.head_btn.mail_btn {
		background: var(--color-primary-tint);
		box-shadow: 0px 5px 0px var(--shadow-green-dark);
	}

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

	#header a.head_btn.mail_btn span.mail_text {
		font-weight: 900;
		font-size: clamp(14px, 14px + 3 * ((100vw - 1024px) / 896), 17px);
		display: flex;
		align-items: center;
		letter-spacing: 0.05em;
		padding-left: 20px;
		position: relative;
		margin-bottom: 0.5rem;
	}

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

	#header a.head_btn.mail_btn span.mail_text::after {
		margin-right: 1rem;
		display: block;
		font-family: 'FontAwesome';
		font-weight: 700;
		font-size: clamp(12px, 12px + 2 * ((100vw - 1024px) / 896), 14px);
		line-height: 1;
		content: '\f078';
		position: absolute;
		left: 0;
	}

	.mail_sub {
		font-weight: 700;
		font-size: var(--rem14);
		line-height: 134.64%;
		text-align: center;
		letter-spacing: 0.05em;
	}

	#footer {
		padding: var(--px50) 0 var(--px40);
	}

	#footer .inner {
		display: flex;
		justify-content: space-between;
		align-items: center;
		text-align: left;
		margin-bottom: var(--px60);
		margin-top: calc(var(--px90) * -1);
	}

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

	.socialicon {
		margin-top: 1rem;
	}

	.pc_none {
		display: none !important;
	}
}

@media print,
screen and (min-width: 1440px) {
	#header .logo {
		flex-direction: row;
	}

	#header .logo a img {
		max-width: clamp(255px, calc(0.5542 * 100vw - 543.75px), 521px);
		max-height: 85px;
	}

	#header .logo .header_logo-by {
		padding-top: clamp(40px, calc(40px + (50 - 40) * ((100vw - 1440px) / (1920 - 1440))), 50px);
		margin-top: -1rem;
	}
}

@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);
	}

	.pc_none {
		display: inherit;
	}
}

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

	.cta01_inner,
	#cta .wpcf7-form table tr {
		display: block;
	}

	.column02 .txtarea,
	.column02 .rev .txtarea {
		padding: 0;
		margin-bottom: 0;
	}

	.cta__left,
	.list-icon__item .imgarea {
		margin-bottom: 0;
	}

	.cta__left img {
		max-height: 148px;
	}

	.list-icon__item .imgarea {
		padding: 1rem;
	}

	.list-icon__item .imgarea img {
		width: auto;
		height: auto;
		max-height: 120px;
	}

	.strengths-icon img {
		width: 37%;
	}

	.sp_center {
		text-align: center;
	}

	.cta01 .ctabtnlist li {
		width: 100%;
		height: 100px;
	}

	.cta01 .ctabtnlist li+li {
		margin-top: 1rem;
	}
}

@media print,
screen and (max-width: 640px) {
	.post table.responsive tr:first-child th {
		border-top: 1px solid var(--color-table-border);
	}

	.post table.responsive th {
		border-bottom: 0;
	}

	.post table.responsive tr:not(:first-child) th {
		border-top: 0;
	}

	.post table.responsive tr:last-child td:last-child {
		border-bottom: 1px solid var(--color-table-border);
	}
}

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

.content-inner {
	position: relative;
	z-index: 2;
	max-width: 1240px;
	width: 90%;
	margin: 0 auto;
}

#content-add01 {
	position: relative;
	padding: var(--px120) 0;
}

.col4flex {
	display: flex;
	justify-content: center;
	gap: var(--px70);
	flex-wrap: wrap;
	max-width: 1010px;
}

.post .col4flex {
	margin: 0 auto;
}

.col4flex>li {
	position: relative;
	width: calc((100% - var(--px70) * 3) / 4);
}

.col4flex>li .img-wrap {
	aspect-ratio: 200 / 250;
	overflow: hidden;
	position: relative;
	background: var(--color-white);
	display: flex;
	justify-content: center;
	align-items: flex-end;
}

.col4flex>li .img-wrap .imgarea {
	position: relative;
	width: 95%;
	max-width: 150px;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: flex-end;
}

.col4flex>li .img-wrap .imgarea img {
	object-fit: contain;
	object-position: bottom;
}

.col4flex .col-ttl {
	line-height: 1.4;
	color: var(--color-primary);
	font-weight: bold;
	font-size: calc(var(--rem20w) + 2px);
	text-align: center;
	padding: 0.7em 0 0.5em;
	letter-spacing: 0.05em;
}

.col4flex .col-info {
	font-size: clamp(1.4rem, calc(1.5rem + ((1vw - 19.2px) * 0.0647)), 1.5rem);
	line-height: 1.6;
}

@media print,
screen and (max-width: 1023px) {
	.col4flex>li {
		width: calc((100% - var(--px70) * 2) / 3);
	}
}

@media print,
screen and (max-width: 767px) {
	.col4flex>li {
		width: calc((100% - var(--px70) * 1) / 2);
	}
}

#faq {
	position: relative;
	padding: var(--px120) 0 var(--px180);
	background: url(/products/reliable-mr-kanamori/wp-content/uploads/top-add-8.png) no-repeat center / cover;
}

.fs24 {
	font-size: var(--rem24);
}

.lh16 {
	line-height: 1.6 !important;
}

/*--FAQ-------------------------------------------*/
.qa_list {
	cursor: pointer;
}

.qa_list .qa_list_inner dt {
	position: relative;
	font-weight: normal;
	margin: 1rem 0 0 0;
	display: flex;
	align-items: stretch;
	padding: 0rem 1rem 0rem 0rem;
	background: #ffffff;
	border: 1px solid #cccccc;
}

.qa_list .qa_list_inner dd .ans_flex {
	position: relative;
	font-weight: normal;
	margin: 0;
	display: flex;
	align-items: stretch;
	padding: 0;
	background: #ffffff;
}

.qa_list .qa_list_inner .a_ico {
	color: #ffffff;
	background: var(--color-primary);
	line-height: 1;
	padding: 1rem 1rem 1rem 1rem;
	font-size: 2.2rem;
	border-right: 1px solid #cccccc;
	width: 100%;
	text-align: center;
	max-width: 90px;
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--body-font-family);
}

.qa_list .qa_list_inner .q_ico {
	background: #f2f2f2;
	line-height: 1;
	padding: 1rem 1rem 1rem 1rem;
	font-size: 2.2rem;
	font-weight: bold;
	width: 100%;
	text-align: center;
	max-width: 90px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--body-font-family);
	border-right: 1px solid #cccccc;
}

.qa_list .qa_list_inner .q_desc,
.qa_list .qa_list_inner .a_desc {
	padding: 1.5rem 1.5rem 1.5rem 2rem;
	line-height: 1.7;
}

.qa_list .qa_list_inner .a_desc {
	line-height: 1.8;
	width: 100%;
}

.qa_list .qa_list_inner dt:after {
	content: '';
	position: absolute;
	top: 46%;
	right: 3rem;
	width: 12px;
	height: 12px;
	border-right: 1px solid #494949;
	border-bottom: 1px solid #494949;
	-webkit-transform: rotate(45deg) translateY(-50%);
	transform: rotate(45deg) translateY(-50%);
}

.qa_list .qa_list_inner .active:after {
	top: 43%;
	right: 2rem;
	-webkit-transform: rotate(-135deg) translateY(-50%);
	transform: rotate(-135deg) translateY(-50%);
}

.qa_list .qa_list_inner dd {
	display: none;
	position: relative;
	padding: 0;
	margin: 0 0 1rem 0;
	border: 1px solid #cccccc;
	border-top: 0;
}

@media only screen and (max-width: 959px) {
	.qa_list .qa_list_inner {
		margin-bottom: 8rem;
	}
}

@media only screen and (max-width: 768px) {

	.qa_list .qa_list_inner .q_desc,
	.qa_list .qa_list_inner .a_desc {
		padding: 0.5rem 1rem 0.5rem 1rem;
	}

	.qa_list .qa_list_inner dt {
		padding: 0rem 1rem 0rem 0rem;
	}

	.qa_list .qa_list_inner .a_ico,
	.qa_list .qa_list_inner .q_ico {
		max-width: 50px;
		padding: 1.2rem 1rem;
	}

	.qa_list .qa_list_inner dt:after {
		right: 1.5rem;
		width: 6px;
		height: 6px;
	}

	.qa_list .qa_list_inner .active:after {
		right: 1rem;
	}
}

@media only screen and (max-width: 559px) {
	.qa_list .qa_list_inner dd {
		font-size: 1.4rem;
	}

	.qa_list .qa_list_inner {
		margin-bottom: 6rem;
	}

	.qa_list .qa_list_inner dt {
		font-size: 1.4rem;
	}
}

.faq-wrap {
	background: var(--color-background);
	padding: var(--px80) 0;
	overflow: hidden;
	border-radius: 10px;
}

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

.qa_list .faq-wrap dt,
.qa_list .faq-wrap dd {
	max-width: 900px;
	width: 95%;
	margin: 0 auto;
	background: transparent;
	border: 0;
}

.qa_list.style02 .qa_list_inner .a_ico {
	opacity: 0;
	background: transparent;
	max-width: 2em;
	font-size: var(--rem36);
}

.qa_list.style02 .qa_list_inner .q_ico {
	background: transparent;
	max-width: 2em;
	font-size: var(--rem36);
}

.qa_list.style02 .qa_list_inner dd .ans_flex {
	background: transparent;
}

.qa_list.style02 .qa_list_inner .q_ico {
	border: 0;
}

.qa_list.style02 .qa_list_inner .q_desc,
.qa_list.style02 .qa_list_inner .a_desc {
	padding: 1.5rem 0;
}

.qa_list.style02 .qa_list_inner .q_desc {
	font-size: var(--rem24);
	color: var(--color-primary);
	font-weight: bold;
	display: flex;
	align-items: center;
	width: 100%;
	border-bottom: 1px solid #bfbfbf;
}

.qa_list.style02 .qa_list_inner .a_desc {
	font-size: var(--rem20);
	line-height: 1.4;
}

.linkanchor {
	color: #006aff !important;
	border-bottom: 2px solid #168aff;
}

.anchor_link::before {
	content: '';
	display: block;
	padding-top: 150px;
	margin-top: -150px;
}

#cta .main-ttl {
	color: var(--color-white);
	line-height: 1.1;
	letter-spacing: 0;
}

#cta .main-ttl>.en-ttl {
	font-size: 2.4em;
	min-width: fit-content;
	position: relative;
	z-index: 0;
	margin-bottom: calc(calc(var(--rem48w) + 2px) / -1.2);
	line-height: 1;
	font-weight: 400;
	color: var(--color-white);
	opacity: 0.2;
	letter-spacing: 0;
}

.linkBtn,
.post .linkBtn {
	border-radius: 100px;
	box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.45);
	background: var(--color-primary);
}

.wpcf7-form .must {
	line-height: 2;
	padding: 0.4em 0.6em;
}

.col3_flow .img-area {
	aspect-ratio: 200 / 164;
	font-size: var(--rem36);
	padding-top: calc(1.9em / 2);
	overflow: hidden;
}

.col3_flow .img-area img {
	max-height: 100%;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}

.post .col3_flow {
	margin-top: var(--px100);
}

.col3_flow .img-area>div {
	display: flex;
	justify-content: center;
	padding-bottom: 10px;
	align-items: center;
	aspect-ratio: 120 / 108;
	overflow: hidden;
	position: relative;
	width: 63%;
}

@media print,
screen and (max-width: 640px) {
	#cta .main-ttl>.en-ttl {
		font-size: 1.8em;
		margin-bottom: calc(calc(var(--rem48w) + 2px) / -1.2);
	}
}

#flow .headding__03 .imgarea {
	width: 19%;
	max-width: 227px;
}

#service_area .headding__03 {
	padding: 0 11%;
}

#service_area .headding__03 .imgarea {
	width: 25%;
	max-width: 129px;
}

#cta .wpcf7-form table th {
	padding-right: var(--px70);
	width: calc(var(--px70) + 13em);
}

#cta .wpcf7-form table td {
	width: calc(100% - calc(var(--px70) + 13em));
}

#cta form>* {
	width: 100%;
	max-width: 1080px;
	margin-left: auto;
	margin-right: auto;
}

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

	#footer .footer__logo,
	#footer .footnav:not(:last-child) {
		margin-top: var(--px40);
	}

	.col3_flow {
		grid-template-columns: 1fr;
		gap: 100px;
	}

	.col3_flow li:not(:last-child)::after {
		top: calc(100% + 15px);
		left: 50%;
		transform: translateX(-50%) rotate(180deg);
	}

	.post .col3_flow {
		display: block;
		width: 80%;
		margin: 0 auto;
	}

	.col3_flow .img-area>div {
		width: auto;
		aspect-ratio: unset;
	}

	.col3_flow .img-area {
		aspect-ratio: unset;
		padding: 0;
		width: auto;
		margin: 0;
	}

	#flow .headding__03 {
		flex-direction: column-reverse;
		padding: 0;
	}

	#flow .headding__03 .imgarea {
		position: static;
		width: auto;
		max-width: 140px;
	}

	.col3_flow .img-area img {
		width: auto;
		height: auto;
	}

	.col3_flow li {
		display: flex;
		align-items: center;
		gap: 30px;
		background-color: var(--color-white);
		border-radius: 1rem;
		padding: 20px;
		padding-left: 50px;
		margin-bottom: 50px;
	}

	.col3_flow li .txtstyle01 {
		font-weight: 700;
		font-size: var(--rem20w);
		line-height: 1.4;
		letter-spacing: 0.05em;
	}

	.col3_flow>li::before {
		width: 49px;
		height: 49px;
		font-weight: 900;
		font-size: 22px;
		left: -2.5%;
		top: -24px;
		transform: translateX(0);
	}

	.header_logo-by {
		display: none;
	}

	#service_area .headding__03 .imgarea {
		width: 32%;
	}

	.home .post #service_area h2 {
		font-size: 24px;
	}

	.home .post #service_area h2>span {
		font-size: 30px;
	}
}

@media print,
screen and (max-width: 768px) {
	.col3_flow .img-area {
		aspect-ratio: none;
	}

	.col3_flow .img-area img {
		width: auto;
		height: auto;
		max-height: 35px;
	}

	#footer .footer__logo img {
		max-width: 300px;
	}
}

/* @media print, screen and (max-width: 480px) {
  body.mobile {
    margin-top: 80px;
  }
  body.mobile #header .logo {
    justify-content: space-between;
  }
  body.mobile #header .logo .mark {
    max-width: fit-content;
    flex-direction: column;
    height: 80px;
  }
  .header_logo-by {
    width: 90%;
    text-align: right;
  }
} */

.sp-br {
	display: none;
}

@media (max-width: 768px) {
	.sp-br {
		display: inline;
	}
}

@media (max-width: 768px) {
	.home .post h2 {
		font-size: 24px;
	}
}

@media print,
screen and (max-width: 768px) {
	.img-area {
		width: 200px;
		margin: 0 auto;
	}
}

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

.phone-mobile {
	background-color: var(--color-primary-shade);
}

.mail-mobile .icon,
.mail-mobile .menu_name,
.phone-mobile .icon,
.phone-mobile .menu_name {
	color: var(--color-white) !important;
}