@charset "utf-8";
/*
Theme Name:mrp-child
Template:mrp
Version: 1.0.0
*/
/*
DesignCode CSS: ver 0.01
*/
/*------------------------------------------------------
Theme Material
------------------------------------------------------*/


/*------@import------*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&family=Sorts+Mill+Goudy:ital@0;1&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

:root {
  /*------â–¼åŸºæœ¬è¨­å®šâ–¼------*/
  --color-background: #fff;
  --color-background-body: #f5f5f5;
  --color-font: #333333;
  --color-primary: #ff8a1e;
  --color-primary-shade: #ff8a1e;
  --color-primary-tint: #244a73;
  --color-secondary: #244a73;
  --color-secondary-tint: #ff8a1e;
  --color-table-border: #ccc;
  --color-111: #111;
  --clr-bg-fff: #ffffffcc;
  --color-eyecatch-filter: #17727e;
  --body-font-size: min(calc(1.6rem + (1vw - 19.2px) * 0.1294), 1.6rem);
  /* 1.6-1.4rem (1920-375) */
  --body-font-family: "Noto Sans JP", sans-serif;
  --content-max-width: 1100px;
  /*------â–¼ãƒ˜ãƒƒãƒ€ãƒ¼è¨­å®šâ–¼------*/
  --header-background: #fff;
  --header-color-font: #444444;
  --header-color-primary: #244a73;
  /*------â–¼ãƒ•ãƒƒã‚¿ãƒ¼è¨­å®šâ–¼------*/
  --footer-background: #ff8a1e;
  --footer-color-font: #fff;
  --footer-color-primary: #fff;
  /*------â–¼ãƒ•ã‚©ãƒ³ãƒˆè¨­å®šâ–¼------*/
  --font-family01: "Noto Sans JP", sans-serif;
  --font-family02: "Oswald", "Noto Sans JP", sans-serif;
  --font-family-en: "Montserrat", "Noto Sans JP", serif;
	--font-family-en02: "Poppins", "Noto Sans JP", serif;
  /*------â–¼pxãƒãƒªã‚¨ãƒ¼ã‚·ãƒ§ãƒ³â–¼------*/
  --px240: min(calc(240px + (1vw - 19.2px) * 10.356), 240px);
  /*240px-80px (1920-375)*/
  --px200: min(calc(200px + (1vw - 19.2px) * 6.4725), 200px);
  /*200px-100px (1920-375)*/
  --px180: min(calc(180px + (1vw - 19.2px) * 3.8835), 180px);
  /*180-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) */
  --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-90px (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) * 3.8835), 90px);
  /*90px-30px (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*/
  --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-15px (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ãƒãƒªã‚¨ãƒ¼ã‚·ãƒ§ãƒ³â–¼------*/
  --rem120: min(calc(12rem + (1vw - 1.92rem) * 3.8835), 12rem);
  /*12rem-6rem (1920-375)*/
  --rem80w: min(calc(8rem + (1vw - 1.92rem) * 1.2945), 8rem);
  /*8rem-6rem (1920-375)*/
  --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.9417), 7rem);
  /*7rem-4.2rem (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.2rem (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)*/
  --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)*/
  --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)*/
  --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)*/
  --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)*/
  --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)*/
}
html {
	 scroll-behavior: smooth;
}
header#h1Header h1.title {
  color: var(--color-background);
  font-size: var(--rem40w);
  font-weight: bold;
  letter-spacing: 0;
}
#thumbImg::before,
header#h1Header::before {
  background: var(--color-eyecatch-filter);
  opacity: 0.2;
}

body:not(.home) {
  background: var(--color-background-body);
}
/* linkBtn */

.linkBtn,
.post .linkBtn,
a.linkBtn,
.post .subimitarea .linkBtn input[type="submit"] {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 288px;
  font-size: var(--rem16);
  color: var(--color-background);
  line-height: 1.8;
  text-align: center;
  background: var(--color-primary);
  font-weight: bold;
  letter-spacing: 0.1em;
  padding: var(--rem20) 30px var(--rem20) 20px;
  margin: var(--px40) auto 0;
  border: solid 2px transparent;
  border-radius: 0;
	z-index: 10;
  transition: all 0.3s;
}
.post .linkBtn::after,
.linkBtn::after,
a.linkBtn::after {
  border-color: var(--color-background);
}
.post .linkBtn:hover,
.linkBtn:hover,
a.linkBtn:hover,
.post .subimitarea .linkBtn input[type="submit"]:hover {
  color: var(--color-background);
  background: var(--color-secondary);
  border-color: var(--color-primary);
}
.post .linkBtn:hover::after,
.linkBtn:hover::after,
a.linkBtn:hover::after {
  border-color: var(--color-background);
}
.subimitarea > .linkBtn {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
}
.post .subimitarea .linkBtn input[type="submit"] {
  margin-top: 0;
}

.linkBtn:has(.arw-vector)::after {
  content: none;
}

.linkBtn:has(.arw-vector) .arw-vector {
  position: relative;

  margin-left: var(--rem16);
}
.linkBtn:has(.arw-vector) .arw-vector::after {
  content: url(/wp-content/uploads/btn-vector.png);
  display: inline-block;
  position: absolute;
  left: 0;
  top: -25%;
}

.linkBtn.bg-244A73 {
  background: var(--color-secondary);
}

.linkBtn.bg-244A73:hover {
  background: var(--color-primary);
  border-color: var(--color-secondary);
}

.linkBtn.long-btn {
  max-width: max-content;
  padding-right: 50px;
}
/* lower titles */
body:not(.home) .post h2 {
  font-size: var(--rem24w);
  color: var(--color-font);
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media print, screen and (min-width: 769px) {
	body:not(.home) .post h2  {
		font-size: calc(var(--rem24w) * 1.2);
	}
}
body:not(.home) .post h2::after {
  content: none;
}

body:not(.home) .post h2 > span {
  font-size: calc(var(--rem72) - 2px);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--color-primary);
  display: block;
}

body:not(.home) .post h3 {
  color: var(--color-secondary);
  font-size: var(--rem24w);
  border-bottom: 0;
  text-align: center;
  padding: 0;
}

body:not(.home) .post h3::after {
  content: "";
  display: block;
  height: 7px;
  width: var(--rem48w);
  background: var(--color-primary);
  margin: 0 auto;
  margin-top: 1rem;
}

body:not(.home) .post .flexbox h3 {
  color: var(--color-primary);
  font-weight: bold;
  border-bottom: 0;
  margin: 0;
  text-align: left;
  margin-bottom: var(--px40w);
}
body:not(.home) .post .flexbox h3::after {
  content: none;
}
/* lower pages */

.lh2 {
  line-height: 2;
}

.full-clr {
  margin-right: calc(((100vw - 100%) / 2) * -1);
  margin-left: calc(((100vw - 100%) / 2) * -1);
  padding: var(--px100) var(--px40);

  background: var(--color-background);
}

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

.content-wrap .flexbox .imgarea {
  display: flex;
  justify-content: center;
  align-items: center;
}
.content-wrap .flexbox .imgarea img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.content-wrap .flexbox .txtarea {
  padding: var(--px24);
}

/* body:not(.home) .post p {
  line-height: 1.7;
} */
/* structure */

/* col4 anchor */
.col4_anchor {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: var(--px20);
  row-gap: 2rem;
  flex-wrap: wrap;
}

.col4_anchor > li {
  width: calc(calc(100% - var(--px20) * 3) / 4);
  display: flex;
  align-items: center;
}

@media screen and (max-width: 1023px) {
  .col4_anchor > li {
    width: calc(calc(100% - var(--px20)) / 2);
  }
}
@media screen and (max-width: 640px) {
  .col4_anchor > li {
    width: 100%;
  }
}

/* col3 anchor */
.col3_anchor {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: var(--px20);
  row-gap: 2rem;
  flex-wrap: wrap;
}

.col3_anchor > li {
  width: calc(calc(100% - var(--px20) * 2) / 3);
  display: flex;
  align-items: center;
}

@media screen and (max-width: 1023px) {
  .col3_anchor > li {
    width: calc(calc(100% - var(--px20)) / 2);
  }
}
@media screen and (max-width: 640px) {
  .col3_anchor > li {
    width: 100%;
  }
}

/* col2 anchor */
.col2_anchor {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: var(--px20);
  row-gap: 2rem;
  flex-wrap: wrap;
}

.col2_anchor > li {
  width: calc(calc(100% - var(--px20) * 2) / 2);
  display: flex;
  align-items: center;
}

@media screen and (max-width: 1023px) {
  .col2_anchor > li {
    width: calc(calc(100% - var(--px20)) / 2);
  }
}
@media screen and (max-width: 640px) {
  .col2_anchor > li {
    width: 100%;
  }
}

.img-ttl {
  line-height: 2;
  font-weight: 400;
  margin-top: 1rem;
  text-align: center;
}

/* col3 imgs */
.col3_imgs {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  gap: 2%;
  row-gap: var(--px40w);

  flex-wrap: wrap;
}

.col3_imgs > li {
  width: calc(calc(100% - 2% * 2) / 3);
}
.col3_imgs > li > .imgarea {
  display: flex;
  justify-content: center;
  align-items: center;
}
.col3_imgs > li > .imgarea iframe {
	aspect-ratio: 352 / 262;
    width: 100%;
    height: auto;
}
@media screen and (max-width: 1023px) {
  .col3_imgs > li {
    width: calc(calc(100% - 2% * 2) / 2);
  }
}
@media screen and (max-width: 500px) {
  .col3_imgs > li {
    width: 49%;
  }
  .col3_imgs {
    justify-content: center;
  }
}

/* col2 img */

.col2_imgs {
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  gap: 2%;
  row-gap: var(--px40w);
  flex-wrap: wrap;
}
.page-tech .col2_imgs {
	justify-content: center;
}
.col2_imgs > li {
  width: calc(calc(100% - 2%) / 2);
}
/* .page-tech .content02 .col2_imgs > li {
	width: calc(calc(100% - 2%) / 2);
} */
/* .page-tech .content02 .col2_imgs > li {
	width:100%;
} */
.col2_imgs > li .imgarea {
  display: flex;
  justify-content: center;
}
.img-group {
  padding: var(--px18);
  background: var(--color-background);
}
.img-group_ttl {
  font-size: var(--rem20w);
  font-weight: bold;
  text-align: center;
  margin-bottom: 1rem;
}
.img-group_imgs {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 2%;
  row-gap: var(--px40w);

  flex-wrap: wrap;
}

.img-group_imgs > .img-group_img-contain {
  width: calc(calc(100% - 2%) / 2);
	display: flex
;
    flex-flow: column;
    justify-content: stretch;
}
.img-group_imgs > .img-group_img-contain .imgarea {
  display: flex;
  justify-content: center;
  align-items: center;
	position: relative;
	overflow: hidden;
	aspect-ratio: 246 / 184;
    height: -webkit-fill-available;
}
.img-group_imgs > .img-group_img-contain .imgarea img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.col2_imgs:has(.bg-none) {
  justify-content: center;
}
.img-group.bg-none {
  background: none;
}

.img-group.bg-none .img-group_imgs {
  gap: 5%;
  width: 100%;
}
.img-group.bg-none .img-group_imgs > .img-group_img-contain {
  width: calc(calc(100% - 5%) / 2);
}
.col2_imgs > li:has(.img-group.bg-none) {
  width: 100%;
  max-width: 800px;
}
@media screen and (max-width: 821px) {
  .col2_imgs > li {
    width: 100%;
  }
  .col2_imgs {
    justify-content: center;
  }
}
@media screen and (max-width: 500px) {
  .col2_imgs > li {
    width: 100%;
  }
  .col2_imgs {
    justify-content: center;
  }
}

/* anchor link */
.anchor_link::before {
  content: "";
  display: block;
  padding-top: 150px;
  margin-top: -150px;
}
.ml10 {
  margin-left: var(--px100);
  font-size: 1.2rem;
}
.clr-FF0000 {
  color: var(--clr-FF0000);
}
.simple-link {
  transition: all 0.3s ease;
}

.simple-link:hover {
  color: var(--color-primary);
}

/* ------------------------------------ */

.anchor_group .linkBtn {
  margin-top: 0;
}
body.home #contact-bottom {
  display: none;
}



.text-normal {
  font-size: var(--rem16);
  letter-spacing: 0;
  line-height: 2;
  /* color: var(--color-font); */
}

.text-normal-sub {
  line-height: 1.7;
}

.home-content_max {
  max-width: 1240px;
  width: 94%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

@media print, screen and (min-width: 450px) {
  .sm_center {
    text-align: center;
  }
}

/* -------- style h1 -------------- */
h1.title.main-ttl,
h1.title.top-loop,
h1.title.bottom-loop {
  font-family: var(--font-family01);
  font-size: var(--rem24w);
  color: var(--color-font);
  line-height: 1.4;
  letter-spacing: 0.11em;
}
h1.title.main-ttl span span,
h1.title.top-loop span span,
h1.title.bottom-loop span span {
  font-family: var(--font-family-en);
  color: var(--color-font);
  letter-spacing: 0.02em;
  line-height: 1.4;
  font-weight: 600;
  font-size: var(--rem70);
  display: block;
}
/* -------- end style h1 -------------- */

/* ----------- style table ----------- */
table.responsive {
	border: none;
    border-collapse: separate;
	border-spacing: 0 3px;
}
table.responsive tr th {
  color: var(--color-background);
  background: var(--color-primary-tint);
  font-weight: bold;
  padding: var(--px30) var(--px20);
  font-size: var(--rem16);
  border: 1px solid var(--color-primary-tint);
  vertical-align: middle;
}

table.responsive tr td {
  padding: var(--px30) var(--px20);
  line-height: 1.8;
  font-size: var(--rem16);
  border: 1px solid var(--color-primary-tint);
}

table.responsive.bg-primary th {
  background: var(--color-primary);
  border-color: var(--color-primary);
}
table.responsive.bg-primary td {
  border-color: var(--color-primary);
}

.recruit-img {
  max-width: 838px;
  margin: var(--px120) auto 0;
  width: 96%;
}
/* ----------- end style table ----------- */

/* ---------------- HEADER ----------------------- */

.spmenu #menu p {
    min-width: max-content;
}
@media print, screen and (min-width: 1024px) {
  nav#mainNav ul li.pc_none {
    display: none;
  }

  #header {
    height: 100px;
  }

  .sticky-header #header-layout {
    height: 100px;
  }
	#header .logo a {
		width: 50%;
	}
  nav#mainNav ul li a {
    font-size: var(--rem16);
    font-weight: bold;
    color: var(--header-color-font);
    line-height: 1.6;
  }

  nav#mainNav ul li a b {
    letter-spacing: 0.1em;
    font-weight: bold;
  }

  #header ul.header__contact li {
    display: flex;
    align-items: center;
  }

  #header a.head_btn {
    padding: 10px;
  }

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

  #header a.head_btn.tel_btn {
    height: 60px;
    width: 229px;
    background: none;
    /*border-left: 1px solid var(--header-color-font);*/
    color: var(--header-color-primary);
  }

  #header a.head_btn.tel_btn .tel_icon {
    font-size: var(--rem20);
    font-weight: bold;
    letter-spacing: 0;
  }

  #header a.head_btn.tel_btn .note {
    font-weight: bold;
    color: var(--header-color-font);
    font-size: var(--rem12);
  }

  #header a.head_btn.tel_btn .tel_icon::before {
    font-family: "FontAwesome";
    content: "\f095";
    font-size: var(--rem16);
    margin-top: 4px;
    color: var(--header-color-primary);
    margin-right: 8px;
  }

  #header a.head_btn.mail_btn {
    width: 200px;
    font-size: var(--rem16);
    font-weight: bold;
    letter-spacing: 0.1em;
  }

  #header a.head_btn.mail_btn span::before {
    content: "\f0e0";
    font-family: "FontAwesome";
    font-size: var(--rem20);
    margin-top: 4px;
    color: var(--color-background);
    margin-right: 8px;
  }
	

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

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

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

  #header a.head_btn.mail_btn:hover {
    color: var(--header-color-primary);
    background: var(--color-background);
  }
  #header a.head_btn.mail_btn:hover span::before {
    color: var(--header-color-primary);
  }
	body.mobile{
		margin-top:0;
	}
	body.mobile .spmenu #menu{
		display:none;
	}
	body.mobile #header .logo .mark{
		height:auto;
	}
}

@media print, screen and (max-width: 1800px) and (min-width: 1024px) {
  #header .logo img {
    max-width: 180px;
  }

  nav#mainNav ul li a {
    padding: var(--px20);
  }

  #header a.head_btn.mail_btn {
    width: 180px;
  }
}

@media print, screen and (max-width: 1300px) and (min-width: 1024px) {
  #header .logo img {
    max-width: 150px;
  }
nav#mainNav ul li a {
        padding: var(--px20) var(--px12);
        font-size: var(--rem16);
    }
  #header a.head_btn.tel_btn {
    width: 180px;
  }
  #header a.head_btn.tel_btn .note {
    font-size: 9px;
  }
  #header a.head_btn.mail_btn {
    width: 150px;
  }
}
@media print, screen and (max-width: 1200px) and (min-width: 1024px) {
	nav#mainNav ul li a {
        padding: var(--px20) 8px;
        font-size: var(--rem14);
    }
}
@media print, screen and (max-width: 1023px) {
  nav#mainNav ul li.current-menu-item a,
  nav#mainNav ul li a:hover {
    color: var(--header-background);
    background: var(--color-primary) !important;
  }
}
/* ---------------- END HEADER ----------------------- */

/* --------------- HOME ------------------ */
.home-content {
  background: var(--color-background-body);
}
/* home about */
.column02 {
  position: relative;
  padding: var(--px100) 0;
}
.column02.no-rev:before {
  content: "";
  background: url(/wp-content/uploads/top-1.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 60%;
  height: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 0;
}

.column02.no-rev:after {
  content: "";
  position: absolute;
  background: #0000004c;
  height: 100%;
  width: 60%;
  z-index: 0;
  left: 0;
  bottom: 0;
}
.column02_wrap {
  position: relative;
  margin: 0 auto;
  z-index: 1;
}
.column02 .txtarea {
  background: var(--color-background);
  padding: var(--px40);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
}

.column02 .imgarea {
  overflow: hidden;
  line-height: 0;
  margin: 0;
  position: relative;
}
.column02 .imgarea img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/*---------rev-----------*/

.column02.rev:before {
  content: "";
  background: url(/wp-content/uploads/top-5.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 60%;
  height: 100%;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 0;
}

.column02.rev:after {
  content: "";
  position: absolute;
  background: #0000004c;
  height: 100%;
  width: 60%;
  z-index: 0;
  right: 0;
  bottom: 0;
}

@media screen and (max-width: 768px) {
  .column02.rev .flexbox {
    flex-direction: row-reverse;
  }

  .column02 {
    padding: 0;
  }

  .column02 .imgarea {
    padding: var(--px100) 0;
  }

  .column02 .imgarea img {
    position: relative;
    z-index: 1;
  }

  .column02.no-rev .imgarea:before {
    content: "";
    background: url(/wp-content/uploads/top-1.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 70%;
    height: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 0;
  }

  .column02.no-rev .imgarea:after {
    content: "";
    background: #0000004c;
    width: 70%;
    height: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 0;
  }

  .column02.rev .imgarea:before {
    content: "";
    background: url(/wp-content/uploads/top-5.png);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 70%;
    height: 100%;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 0;
  }

  .column02.rev .imgarea:after {
    content: "";
    background: #0000004c;
    width: 70%;
    height: 100%;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 0;
  }
}
/* end home about */

/* home service */

#home-service {
  padding: var(--px120) 0 var(--px100);
  position: relative;
}

#home-service::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 60%;
  background: var(--color-primary-tint);
  left: 0;
  bottom: 0;
}
/*---------col03-----------*/
.num_list01 .num_listttl {
  text-align: center;
  font-weight: bold;
  font-size: var(--rem24w);
  padding: 0 0 10px;
  position: relative;
  line-height: 1.3;
  color: var(--color-font);
  letter-spacing: 0.1em;
}

.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%;
  background: var(--color-background);
  display: flex;
  flex-direction: column;
}
.post .col3_list::before {
  content: "";
  display: block;
  width: 32%;
  height: 0;
  order: 1;
}
.post .col3_list:after {
  content: "";
  display: block;
  width: 32%;
  height: 0;
}

.post .col3_list > li .txtarea {
  padding: var(--px20) var(--px24) var(--px40);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex-grow: 1;
}
@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: 767px) {
  .post .col3_list {
    gap: var(--px40);
  }

  #home-service::after {
    height: 65%;
  }
  .post .col3_list > li {
    width: 100%;
  }
  .post .col3_list > li:last-child {
    margin-bottom: 0;
  }

  .img-group {
    padding: var(--px18) 0;
  }
}
/* end home service */

/* home recruit */
#home-recruit {
  padding-bottom: var(--px120);
}
/* end home recruit */
/* --------------- END HOME ------------------ */

/* ------------- COMPANY ----------------- */
body.page-company {
  background: var(--color-background);
}
.company-message-flexbox {
  display: flex;
  gap: var(--px50);
}

.company-message-flexbox .imgarea {
  width: 30%;
  text-align: center;
}

.company-message-flexbox .txtarea {
  width: 70%;
}

@media print, screen and (max-width: 1023px) {
  .company-message-flexbox {
    flex-wrap: wrap;
  }

  .company-message-flexbox .imgarea {
    width: 100%;
  }
	
  .company-message-flexbox .imgarea img {
    aspect-ratio: 360 / 462;
  }
  .company-message-flexbox .txtarea {
    width: 100%;
  }
}
/* ------------- END COMPANY ----------------- */

/* ------------ RECRUIT ------------ */
body.page-recruit {
  background: var(--color-background);
}

.recruit-mark span {
  font-size: var(--rem30);
  font-weight: bold;
  color: var(--color-primary-tint);
  letter-spacing: 0.1em;
  padding: 0 8px;
  background: linear-gradient(transparent 60%, #ff8a1eb2 60%);
}

.recruit-en {
  font-size: calc(var(--rem28) - 1px);
  color: var(--color-primary);
  text-align: center;
  line-height: 1.8;
  letter-spacing: 0.3em;
  margin: var(--px20) 0 var(--px100);
}

.recruit-box {
  display: flex;
  align-items: center;
  gap: var(--px30);
}

.recruit-box .imgarea {
  width: 27%;
}

.recruit-box .imgarea > p {
  font-size: var(--rem20w);
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 2.5;
  margin-top: var(--px24);
}

.recruit-box .txtarea {
  width: 70%;
}

.recruit-box .txtarea p {
  font-size: var(--rem16);
  line-height: 2.5;
}

.post ul.list_number {
  counter-reset: number;
}

.post ul.list_number li {
  position: relative;
  padding-left: 35px;
  margin-bottom: 4px;
}

.post ul.list_number li::before {
  content: counter(number, decimal-leading-zero);
  counter-increment: number;
  position: absolute;
  left: 0;
  top: 50%;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateY(-50%);
  border: 1px solid var(--color-font);
  border-radius: 50%;
}

@media print, screen and (max-width: 767px) {
  .recruit-box {
    flex-wrap: wrap;
	  gap: 3rem;
  }

  .recruit-box .imgarea {
    width: 100%;
    text-align: center;
  }

  .recruit-box .txtarea {
    width: 100%;
  }
}
/* ------------ END RECRUIT ------------ */

/* --------- QUALITY ------------------ */
.quality-contact {
  background: url(/wp-content/uploads/quality-9.png);
  max-width: 1056px;
  padding: var(--px40);
  margin: 10px auto var(--px120);
}

.quality-contact-inner {
  background: var(--clr-bg-fff);
  max-width: 834px;
  margin: 0 auto;
  padding: var(--px50) var(--px100) var(--px30);
}

.quality-contact-inner .text-14 {
  font-size: 1.4rem;
  line-height: 1.8;
}

@media print, screen and (max-width: 767px) {
  .quality-contact-inner {
    padding: var(--px50) var(--px40) var(--px30);
  }

  .linkBtn.long-btn {
    padding-left: 10px;
    font-size: 1.2rem;
  }
}

@media print, screen and (max-width: 420px) {
  .linkBtn.long-btn {
    padding-right: 40px;
    padding-left: 10px;
    font-size: 1.2rem;
  }
}

/* --------- END QUALITY ------------------ */

/* ------------ BUSINESS -------------- */
.col2_list {
  display: flex;
  gap: var(--px50);
}

.col2_list-item {
  width: 50%;
  padding: var(--px40) var(--px50);
}

.col2_list-item.item-01 {
  background: url(/wp-content/uploads/business-25.png) no-repeat center/cover;
  inset: 0;
}
.col2_list-item.item-02 {
  background: url(/wp-content/uploads/business-26.png) no-repeat center/cover;
  inset: 0;
}

.col2_list-item .txtarea {
  background: var(--clr-bg-fff);
  padding: var(--px50);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

@media print, screen and (max-width: 1400px) {
  .col2_list-item .txtarea {
    padding: var(--px50) var(--px40);
  }

  .col2_list-item {
    padding: var(--px40) var(--px30);
  }
}
@media print, screen and (max-width: 1023px) {
  .col2_list {
    flex-wrap: wrap;
  }

  .col2_list-item {
    width: 100%;
  }
}

@media print, screen and (max-width: 420px) {
	.col2_list-item .txtarea {
		padding: var(--px40) var(--px20);
	}
	
	.col2_list-item {
        padding: var(--px40) var(--px20);
    }
}
/* ------------ END BUSINESS -------------- */

/* ----------- CONTACT --------------- */
/*-----------------------------
cta01_col2_max1240
------------------------------*/
.cta01 {
  background: url(/wp-content/uploads/cta-bg.png) no-repeat center/cover;
  inset: 0;
  position: relative;
  z-index: 0;
  padding: var(--px200) var(--px80) var(--px150);
}
.cta01 .cta01_wrap {
  max-width: 1240px;
  width: 100%;
  margin: 0 auto;
  background: none;
  padding: var(--px120) var(--px40);
}
.cta01 .ctabtnlist {
  gap: var(--px20);
  justify-content: space-between;
  max-width: 960px;
  margin: var(--px50) auto 0 auto;
}
.cta01 .ctabtnlist li {
  width: 50%;
  margin: 0;
  padding: 0;
  line-height: 1;
  display: flex;
}
.cta01 a.item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: var(--px30) 0;
  text-align: center;
  box-sizing: border-box;
  color: var(--color-background);
  border-radius: 0;
  transition: all ease 0.15s;
  border-radius: 50vh;
}
.cta01 a.item:hover {
  opacity: 0.8;
}
@media print, screen and (max-width: 768px) {
  .cta01 .ctabtnlist li,
  .cta01 .ctabtnlist a.item {
    width: 100%;
  }
  .cta01 .ctabtnlist li + li {
    margin-top: 1rem;
  }
}

/*ボタン共通パーツ*/

.cta01 .btnttl {
  display: block;
  font-weight: bold;
  margin-bottom: 1rem;
}
.cta01 .infotxt {
  font-size: var(--rem16);
  font-weight: bold;
}

.cta01 .mailbtn .infotxt {
  font-size: var(--rem18);
}

/*電話ボタン*/

.cta01 .telnum {
  font-size: var(--rem36);
  margin-bottom: 1rem;
  line-height: 1.2;
}
.cta01 .telbtn .btnttl {
  font-size: var(--rem20);
}
.cta01 a.telbtn {
  background: var(--color-secondary);
  color: var(--color-background);
}

/*メールボタン*/

.cta01 .mailbtn .btnttl {
  font-size: var(--rem24);
}
.cta01 a.mailbtn {
  background: var(--color-primary-tint);
  color: var(--color-background);
}

/*ボタンアイコン*/

.cta01 .mailbtn .btnttl::before,
.cta01 .telnum::before {
  content: "";
  display: inline-block;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  margin-right: 1rem;
}
.cta01 .mailbtn .btnttl::before {
  content: "\f0e0";
}
.cta01 .telnum::before {
  content: "\f3cd";
}

@media print, screen and (max-width: 767px) {
  .cta01 {
    padding: var(--px80) var(--px30);
  }
}
/* ----------- END CONTACT --------------- */

/* ----------------- NEWS --------------------- */
/* top news */
#front_top_content {
  padding: var(--px100) 0;
  background: var(--color-background);
}

.post ul.post4b {
  margin-bottom: var(--px60);
}

.post4b li {
  border: 1px solid var(--color-111) !important;
  padding: var(--px14) var(--px14) var(--px20);
}

.post4b_text {
  padding: var(--px20) 0;
}

.post4b_link {
  right: var(--px14);
  color: var(--color-font);
  font-size: var(--rem12);
  bottom: 20px;
}

.post4b_link a {
  color: var(--color-font);
}
.post4b img {
  max-width: 100%;
}
.post4b h2 a {
  font-size: var(--rem18);
  color: var(--color-font);
}

.post4b li .post4b_contents {
  color: var(--color-font);
  opacity: 1;
  font-size: var(--rem14);
  line-height: 1.8;
  margin: var(--px20) 0;
}

.post4b .time {
  line-height: 1.8;
}
/* end top news */

/* bottom news */
#front_bottom_content {
  background: var(--color-background);
}
.postlist li {
  border-bottom: 1px solid var(--color-table-border);
}

.postlist .post_text {
  padding: var(--px30) 10px;
}

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

.post li.clearfix:last-child {
  border-bottom: 1px solid var(--color-table-border);
}

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

.postlist .date {
  font-size: var(--rem16);
  color: #000;
  line-height: 2;
}

.postlist .ttls {
  color: #111;
  font-size: var(--rem16);
  line-height: 2;
}
/* end bottom  news */
/* ----------------- END NEWS --------------------- */

/* ----------------- FOOTER --------------- */
#footer {
  padding: var(--px50) 0 var(--px40);
}
.footer-flex {
  display: flex;
  align-items: center;
  max-width: 1600px;
  margin: 0 auto;
  border-bottom: 1px solid var(--color-background);
  padding-bottom: 20px;
  width: 94%;
  margin-bottom: var(--px60);
}

#footer .footer__logo img {
  padding: var(--px30) var(--px16);
  background: var(--color-background);
  max-height: 100px;
}

#footer .footnav ul > li {
  margin-bottom: 0;
}

#footer .footer__logo:not(:last-child) {
  width: 50%;
  text-align: left;
  margin-bottom: 0;
}

#footer .inner {
  width: 50%;
}
#footer .inner ul {
  justify-content: flex-end;
}

@media print, screen and (max-width: 767px) {
  .footer-flex {
    flex-wrap: wrap;
    gap: var(--px50);
  }

  #footer .footer__logo:not(:last-child) {
    width: 100%;
    text-align: center;
  }

  #footer .inner {
    width: 100%;
  }

  #footer .inner ul {
    justify-content: center;
  }
}

@media print, screen and (max-width: 420px) {
	.cta01 .cta01_wrap {
		padding: var(--px120) 0;
	}
}
/* ----------------- END FOOTER --------------- */

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

#home-about .home-content_max, #home-recruit .home-content_max{
	max-width: none;
	width: 100%;
}

.column02 .txtarea {
	padding: clamp(40px, calc(120px + ((1vw - 19.2px) * 5.178)), 120px);
}
.column02:before {

filter: blur(12px);

}
.post table.responsive {
	border-collapse: collapse;
}
.post table.responsive th, 
.post table.responsive td {
	border: 1px solid var(--color-background-body);
}
.company-message-flexbox {
	align-items: center;
}
.company-message-flexbox .imgarea {
	display: flex;
	align-items: center;
	justify-content: center;
}
body:not(.home) .post h2 {
	margin-top: 0;
}
@media print, screen and (min-width: 1024px) {
	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(--color-background);
	}
   nav#mainNav ul li li a:hover, nav#mainNav ul li li.current-menu-item a {
        color: var(--header-color-font);
        background: var(--color-background);
    }
}

.recruit-box .imgarea > p {
	font-size: var(--rem16);
	font-weight: 400;
	letter-spacing: .05em;
	margin-top: 1em;
	min-width: max-content;
}
.content-wrap .flexbox {
	align-items: stretch;
}

.content-wrap .flexbox .imgarea img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.content-wrap .flexbox .txtarea {
	padding: var(--px40w) var(--px24);
	display: flex;
	flex-direction: column;
	justify-content: center;
	
}
.quality-contact {
	margin-top: var(--px60);
}
.cta01 .cta01_wrap {
	padding: var(--px120) var(--px40) var(--px80);
}


@-webkit-keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translate3d(-30px, 0, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}
@keyframes fadeInLeft {
  from {
    opacity: 0;
    transform: translate3d(-30px, 0, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft;
}

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

@-webkit-keyframes fadeInUp2 {
  0% {
    opacity: 0.6;
    transform: translate3d(0, 6%, 0);
  }

  100% {
    opacity: 1;
    transform: none;
  }
}

@keyframes fadeInUp2 {
  0% {
    opacity: 0.6;
    transform: translate3d(0, 6%, 0);
  }

  100% {
    opacity: 1;
    transform: none;
  }
}

.fadeInUp2 {
  -webkit-animation-name: fadeInUp2;
  animation-name: fadeInUp2;
}

#mainImg {
　　　　width: 100%;
　　　　height: 100%;
　　　　position: relative;
}
#mainImg::before {
　　　　content: "";
　　　　display: block;
　　　　position: absolute;
　　　　top: 0;
　　　　bottom: 0;
　　　　left: 0;
　　　　background-color: #111;
　　　　width: 70%;
}

div#n2-ss-2 .n2-font-9dc5eef258c8cb5967f601ecd15ba84d-paragraph {
	font-family: var(--font-family-en02);
	font-weight: bold !important;
	margin-left: calc(var(--px30) + 3px);
}
div#n2-ss-2 .n2-style-072bb6e1a9e624c8e623998ad5df8fc5-heading,
div#n2-ss-2 .n2-style-d43829a2f2aa0ac969a4b47f429f427c-heading{
	background: linear-gradient(90deg, #FF8D1E 2.34%, #FFAD1E 98.02%) !important;
-webkit-background-clip: text !important;
-webkit-text-fill-color: transparent;
background-clip: text !important;
text-fill-color: transparent;
	position: relative;
	
}
div#n2-ss-2 .n2-style-d43829a2f2aa0ac969a4b47f429f427c-heading::before {
	content: "";
	display: block;
	position: absolute;
	inset: 0;
	background: #fff;
	opacity: .9;
	z-index: -1;
}
@media (orientation: landscape) and (max-width: 900px), (orientation: portrait) and (max-width: 700px) {
    div#n2-ss-2 .n-uc-BCV7e2jae65j {
        --margin-top: 40px;
        --margin-bottom: 40px;
        max-width: 700px !important;
        --ssfont-scale: 0.3;
    }
	div#n2-ss-2 .n2-style-072bb6e1a9e624c8e623998ad5df8fc5-heading {
		max-width: 600px;
	}
}

@media only screen and (max-width: 1023px) {
    nav#mainNav ul li li a:hover, nav#mainNav ul li li.current-menu-item a, nav#mainNav ul li.current-menu-item li a:hover,nav#mainNav ul li li.current-menu-item:last-child a, nav#mainNav ul li li:last-child a:hover, nav#mainNav ul li.current-menu-item li:last-child a:hover {
       
        color: var(--color-background);
        
    }
}
.post4b .time a {
	display: inline-block;
}

@media print, screen and (min-width: 1024px) {
    #header .logo {
        display: block;
        line-height: 1;
        padding: min(calc(10px +(1vw - 19.2px)* 0.5580), 10px) min(calc(20px +(1vw - 19.2px)* 1.1161), 20px);
        display: flex
;
        flex-wrap: wrap;
        font-size: clamp(12px, calc(1.6rem + ((1vw - 19.2px) * 0.4464)), 16px);
        font-weight: bold;
        color: var(--header-color-font);
        align-items: center;
        height: auto;
        gap: clamp(10px, calc(2.4rem + ((1vw - 19.2px) * 1.5625)), 24px);
        row-gap: 1rem;
        justify-content: center;
        /* text-align: center; */
    }
	.home #header .logo, #header .logo  {
		color: var(--header-color-font);
		text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
	}
	#header .logo img {
		width: 100%;
		height: auto;
		min-width: 120px;
	}
	    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(--color-primary);
    }
}
.fv_txt {
	-webkit-text-stroke: 2px var(--color-secondary);
text-stroke:  2px var(--color-secondary);

paint-order: stroke fill;
}
.fv_txt .fv_txt-blue {
	color: var(--color-secondary) !important;
	-webkit-text-stroke: 2px var(--color-background);
text-stroke:  2px var(--color-background);

paint-order: stroke fill;
}

@media print, screen and (min-width: 1024px) {
/* 	.sticky-header #header-layout *,.sticky-header #header-layout a.head_btn.tel_btn .tel_icon::before{
        color: #444;
    }
	#header a.head_btn.mail_btn > span {
		color: #fff;
	}
	#header a.head_btn.mail_btn:hover > span {
		color: var(--header-color-primary);
	}
	 */

    body.home #header, #header {
        background: none;
		position: relative;
		z-index: 999;
    }
	html:not(.mobile) body.home #mainImg,html:not(.mobile) #mainImg, html:not(.mobile) body.home #breadcrumnb,
    html:not(.mobile) #breadcrumnb {
    margin-top: -100px;
}
	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: transparent;
	}
/* 	.home nav#mainNav ul li a ,
    nav#mainNav ul li a{
		color: var(--header-background);
	} */
	nav#mainNav ul li ul.sub-menu li a {
		color: var(--header-color-font);
	}
	nav#mainNav ul li.current-menu-item ul.sub-menu li a {
		color: inherit;
	}
	nav#mainNav ul li ul.sub-menu li.current-menu-item a{
		color: var(--color-primary);
	}
	.home #header a.head_btn.tel_btn,.home #header a.head_btn.tel_btn .tel_icon::before,.home #header a.head_btn.tel_btn .note,
	 #header a.head_btn.tel_btn, #header a.head_btn.tel_btn .tel_icon::before, #header a.head_btn.tel_btn .note  {
		color: var(--header-color-font);
	}
	.sticky-header #header-layout a.head_btn.tel_btn .tel_icon::before,
	 .sticky-header #header-layout a.head_btn.tel_btn .note  {
        color: #444;
    }
	 #header-layout a.head_btn.tel_btn:hover *,
	 #header-layout a.head_btn.tel_btn:hover .tel_icon::before,
	  #header-layout a.head_btn.tel_btn:hover .note {
        
        color: var(--header-background);
    }
	#header a.head_btn.tel_btn .tel_icon {
		display: flex;
		align-items: center;
	}
/* 	#header a.head_btn.tel_btn {
		border-color: var(--header-background);
	} */
	.sticky-header #header > .inner{
        background: #e7edf4ba !important;
	}
	#thumbImg, header#h1Header {
		margin-top: -100px;
	}
}

/* .post .col3_list > li .imgarea {
	-webkit-border-top-left-radius: var(--px30);
-webkit-border-top-right-radius: var(--px30);
-moz-border-radius-topleft: var(--px30);
-moz-border-radius-topright: var(--px30);
border-top-left-radius: var(--px30);
border-top-right-radius: var(--px30);
	overflow: hidden;
}

.post .col3_list > li .txtarea {
	-webkit-border-bottom-right-radius: var(--px30);
-webkit-border-bottom-left-radius: var(--px30);
-moz-border-radius-bottomright: var(--px30);
-moz-border-radius-bottomleft: var(--px30);
border-bottom-right-radius: var(--px30);
border-bottom-left-radius: var(--px30);
	overflow: hidden;
} */

.post .col3_list > li {
	border-radius: var(--px30);
	overflow: hidden;
}
.post .col3_list > li .imgarea {
	overflow: hidden;
}
.post .col3_list > li .imgarea img {
	transition: .3s all ease;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.post .col3_list > li .imgarea:hover img{
	transform: scale(1.5);
}
#front_top_content {
	display: none;
}
#footer .footer__logo img {
	background: transparent;
	padding:0;
	max-width: 260px;
}

.btns-wrap {
	display: flex;
	gap: var(--px30);
	flex-wrap: wrap;
	flex-shrink: 0;
	margin-top: var(--px40);
}

.btns-wrap .linkBtn {
	margin: 0;
}
#home-service::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 40%;
    background: url(/wp-content/uploads/top-1-2.png) no-repeat center / cover;
    left: 0;
    top: 0;
	opacity: .5;
}
#home-service .home-content_max {
	max-width: 1600px;
}
#content-double {
	position: relative;
	z-index:0;
	padding: var(--px200) 0;
}
#content-double:before {
	content:"";
	display: block;
	position: absolute;
	inset: 0;
	background: url(/wp-content/uploads/top-2-1.png) no-repeat center / cover;
	opacity: .2;
	
}

.column02.no-rev:after,.column02.rev:after,
.column02.no-rev:before,.column02.rev:before{
	content: none;
}

#content-double .column02 .txtarea {
	background: transparent;
}
#content-double .column02 {
	padding: var(--px100) 0 0;
}
#home-recruit {
	padding-bottom: 0;
}

.cta01 .cta01_wrap h1 {
  text-align: center;
	color: var(--color-background);
}

.cta01 .cta01_wrap h1 > span span {
	color: var(--color-background);
}
#front_bottom_content {
	position: relative;
	z-index:0;
	
}

#front_bottom_content::before {
	content:"";
	display: block;
	position: absolute;
	inset: 0;
	background: url(/wp-content/uploads/post-bg.png) no-repeat center / cover;
	opacity: .2;
}
#footer .footnav ul > li::after {
content: none;
}
#footer .footnav ul > li::before {
	content: "\f054";
	display: inline-block;
	width: auto;
	height: auto;
	font-family: "FontAwesome";
	background: none;
	
}
#footer .footnav ul > li {
	padding: 0 var(--px30) 0 1em;
}
#footer .footnav ul > li:last-child {
	padding-right:0;
}

.column02.no-rev .imgarea img {
	object-position: right;
}

.column02.no-rev .imgarea:after, .column02.no-rev .imgarea:before, .column02.rev .imgarea:after, .column02.rev .imgarea:before {
	display: none;
}

.recruit-box .imgarea {
	 position: relative;
}

.recruit-box .imgarea > p {
	position: absolute;
	left: 50%;
	transform: translatex(-50%);
}
@media print, screen and (max-width: 1023px) {
    body.mobile #header .logo img {
      
        max-width: 170px;

    }
	body.mobile #header .logo .logo_txt {
		font-weight: bold;
		color: (--header-color-font);
		margin-left: .5em;
	}
}
@media print, screen and (max-width: 768px) {
	.btns-wrap {
		justify-content: center;
	}
	.column02 .imgarea {
		padding: 0;
	}
	.recruit-box .imgarea {
		margin-bottom: 2em;
	}
}

/* structure */

body.page-structure #wrapper,
body.page-quality #wrapper,
body.page-business #wrapper {
    position: relative;
    z-index: 0;
    max-width: none;
    width: 100%;
}

.page-structure #wrapper::before,
.page-quality #wrapper::before,
.page-business #wrapper::before {
    content: "";
    display: block;
    position: absolute;
    inset: 0;
    background: url(/wp-content/uploads/structure-bg-2.png) no-repeat center / cover;
    opacity: .2;
}
.page-quality #wrapper::before {
    background: url(/wp-content/uploads/quality-bg.jpg) no-repeat center / cover;
}
.page-business #wrapper::before {
    background: url(/wp-content/uploads/business-bg.jpg) no-repeat center / cover;
}
body.page-structure #wrapper #content.wide,
body.page-business #wrapper #content.wide,
body.page-quality #wrapper #content.wide {
    width: 90%;
    max-width: var(--content-max-width);
    position: relative;
    z-index: 1;
    padding-bottom: 0;
}
body.page-business #wrapper #content.wide,
body.page-quality #wrapper #content.wide {
    padding-bottom: var(--px180);
}
body:not(.home) .flexbox .imgarea {
    border-radius: var(--px30);
    overflow: hidden;
}

body:not(.home) .flexbox .txtarea {
    background: transparent;
}

body:not(.home) .flexbox {
    background: transparent;
}

/*--幅フル100%--------------------------------------------*/

.widearea {
	margin-right: calc(((100vw - 100%) / 2) * -1);
	margin-left: calc(((100vw - 100%) / 2) * -1);
}

.widearea .content-wrap {
	width: 90%;
    margin: 0 auto;
    max-width: var(--content-max-width);
}

.col3_link-img {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: var(--px30);
    row-gap: 20px;
    color: var(--color-background);
    flex-wrap: wrap;
}
.col3_link-img > li {
    width: calc(calc(100% - var(--px30) * 2) / 3);
}
.link-wrap {
    color: var(--color-background);
    position: relative;
    z-index: 0;
    display: block;
}
.link-ttl {
    position: absolute;
    bottom: 2em;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
	min-width: max-content;
}
.link-ttl .arw-vector {
    display: flex;
    align-items: center;
}
.link-wrap .link-img {
    display: block;
    position: relative;
    overflow: hidden;
    aspect-ratio: 373 / 280;
    width: 100%;
    border-radius: var(--px30);
}

.link-wrap .link-img img {
    transition: .3s all ease;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.link-wrap:hover .link-img img {
    transform: scale(1.5);
    opacity: 1;
}
.link-wrap:hover .link-ttl {
    color: var(--color-background);
}

.tech-name {
    text-align: center;
    margin-top: 1em;
    position: relative;
    z-index: 2;
}

.page-structure .content06 {
    position: relative;
    z-index: 0;
    padding-bottom: var(--px80);
}

.page-structure .content06:before {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 32%;
    bottom: 0;
    left: 0;
    background: var(--color-secondary);
}
@media print, screen and (max-width: 750px) {
	.col3_link-img > li {
    width: 100%;
}
	.page-structure .content06:before {
		height:75%;
	}
}
.link-zoom {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
}
.link-zoom img {
    transition: all .3s ease;
}
.link-zoom:hover img {
    transform: scale(1.5);
    opacity: 1;
}

header#h1Header h1.title {
    text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

body:not(.home) .post h2 > span {
    text-transform: uppercase;
    font-size: var(--rem56);
}

/* tech */

body.page-tech #wrapper #content.wide {
    padding-top: 0;
}

.page-tech .content01 {
    padding-top: var(--px100w);

}

.youtubeArea {
    max-width: 650px;
}
.page-tech .content01,
.page-tech .content02,
.page-tech .content03 {
    position: relative;
    z-index: 1;
}
.page-tech .content02,
.page-tech .content03 {
    padding: var(--px120) 0;
}
.page-tech .content01::before,
.page-tech .content02::before,
.page-tech .content03::before {
    content: "";
    display: block;
    position: absolute;
    inset: 0;
    opacity: .3;
    z-index: 1;
}

.page-tech .content01::before {
    opacity: .2;
    background: url(/wp-content/uploads/tech-4.png) no-repeat center / cover;
}

.page-tech .content02::before {
   
    background: url(/wp-content/uploads/tech-5.png) no-repeat center / cover;
}
.page-tech .content03::before {
   
    background: url(/wp-content/uploads/tech-6.png) no-repeat center / cover;
}

.page-tech .content01 .content-wrap,
.page-tech .content02 .content-wrap,
.page-tech .content03 .content-wrap {
    position: relative;
    z-index: 2;
}

#cat-post h1.title.cat-loop {
	font-family: var(--font-family-en);
	font-size: var(--rem70);
	color: var(--color-font);
}

.category-achievement #cat-post h1.title.cat-loop:after {
	content:"写真で見る業務実績";
	display: block;
	font-weight: 500;
	font-size: var(--rem24w);
	font-family: var(--font-family01);
}
.page-structure .content03 {
	padding-top: var(--px240);
}


@media print, screen and (min-width: 769px) {
	body:not(.home) .flexbox .btns-wrap .linkBtn {
	max-width: 220px;
	padding-left: .2em;
}
}

.link-wrap .link-img {
    -webkit-box-reflect:below 1px linear-gradient(0deg, #ffffff4d, transparent 25%);
}

.col3_imgs > li > .imgarea:has(.link-zoom) {
	position: relative;
	
}
.col3_imgs > li > .imgarea:has(.link-zoom) .img-txt {
	position: absolute;
	letter-spacing: .1em;
	font-weight: bold;
	line-height: 1.3;
	left: 50%;
	bottom: .5em;
	color: var(--color-background);
	min-width: max-content;
	transform: translatex(-50%);
}
@media screen and (max-width: 500px) {
    .col3_imgs > li:has(.img-txt) {
        width: 100%;
    }
}
body.page-tech #wrapper #content.wide {
	padding-bottom:0;
}
.page-tech .content03 {
	padding-bottom: var(--px200);
}
#home-service::before {
	height: 65%;
}
#home-service::after {
	height: 35%;
	background: var(--color-background);
}
#home-service .link-wrap .link-img {
/* 	-webkit-box-reflect: unset; */
}

#home-service .link-ttl {
	font-size: 16px;
	letter-spacing: .1em;
	font-weight: bold;
}

#home-service .tech-name {
	font-size: var(--rem30);
	font-weight: bold;
	letter-spacing: .1em;
	color: var(--color-secondary);
	display: none;
}

#home-service h1.main-ttl, #home-service h1.main-ttl > span span {
	color: var(--color-background);
	-webkit-text-stroke: 2px var(--color-secondary);
text-stroke:  2px var(--color-secondary);

paint-order: stroke fill;
}
#home-service h1.main-ttl > span span {
	-webkit-text-stroke: 3px var(--color-secondary);
text-stroke:  3px var(--color-secondary);
}
.flexbox .txtarea .main-ttl.txt_l {
	text-align: left;
}

@media print, screen and (min-width: 769px) {
	.pc_none {
		display: none !important;
	}
}
@media print, screen and (max-width: 768px) {
	.flexbox .txtarea .txtinner {
		width: 100%;
	}
	#content-double {
		padding-top: 0;
	}
}


@media print, screen and (max-width: 1023px) {
    .mobile #header {
       
        background: #ffffffbf;
    }
}

table.responsive.bg-primary th {
	background: transparent;
	color: var(--color-font);
}
.post table.responsive th, .post table.responsive td {
	background: transparent;
	color: var(--color-font);
	border-color: #d9d9d9;
	border-left: 0;
	border-right: 0;
}

span:has(.google_link):not(.flexbox) {
	display: block;
	
}
span.flexbox:has(.google_link) {
	gap: 10%;
	
}
a.google_link {
	display: inline-block;
	position: relative;
	z-index: 10;
	color: var(--color-secondary);
}

a.google_link:after {
	content: "\f08e";
	display: inline-block;
	font-family: "FontAwesome";
	margin-left: .5em;
}
.linkBtn{
	border-radius: var(--px50) !important;
}

.cta01 .infotxt {
	display:none;
}


#home-service .link-name {
	font-size: var(--rem30);
	font-weight: bold;
	letter-spacing: .1em;
	color: var(--color-background);
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
	position: absolute;
	top:70%;
	left: 50%;
	z-index: 1;
	transform: translate(-50%, -50%);
}

.col3_link-img > li {
	position: relative;
}
.col3_link-img > li .tech-name{
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
	font-weight: bold;
	font-size: clamp(14px, calc(2.4rem + ((1vw - 19.2px) * 0.8681)), 24px);
	position: absolute;
	margin-top:0;
	display: block;
	min-width: max-content;
	top:50%;
	left: 50%;
	z-index: 1;
	transform: translate(-50%, -50%);
}

.col3_link-img > li a:hover {
	color: var(--color-background);
}
@media print, screen and (max-width: 750px) {
	.col3_link-img > li .tech-name {
		font-size: 2rem;
	}
	#home-service .link-wrap .link-img {
	-webkit-box-reflect: unset;
}
}
@media print, screen and (min-width: 1024px) {
#header ul.header__contact li:hover{
background: var(--header-color-primary);	
}
	    #header a.head_btn.mail_btn {
background: none;	
    }
    }
.link-wrap .link-img {
    border: 3px solid #fff;
}
.col3_link-img > li .tech-name {
    text-shadow: 1px 1px 2px black, 0 0 1em blue, 0 0 0.2em blue;
}

@media print, screen and (min-width: 1024px) {
    #header a.head_btn.mail_btn {
        background: #244a73;
    }
}
.page-id-406 .img-group{
	background:none;
}
/* 20250324 */

#home-service .link-ttl {
	display: none;
}

.link-name > span {
	display: block; 
	font-size: var(--rem16);
	text-align:center;
}
#home-service .link-name {
	line-height: 1.2;
	top: 75%;
	padding: .5em 1em;
	background: #4472C466;
	border-radius: 50vh;
	min-width: max-content;
	text-align: center;
}

@media print, screen and (min-width: 769px) {
	#home-about .text-normal, #home-recruit .text-normal{
		font-size: calc(var(--rem16) * 1.2);
	}
	body:not(.home) .flexbox .txtarea .txtinner p, .company-message-flexbox .txtarea p{
		font-size: calc(var(--rem16) * 1.2);
		line-height: 1.5;
	}
	.recruit-box .txtarea p {
    font-size: calc(var(--rem16) * 1.2);
    line-height: 2.5;
}
}

@media print, screen and (min-width: 769px) {
    .company-message-flexbox .txtarea p.Messagettl {
        font-size: 140%;
        padding-bottom: 20px;
    }
}

@media print, screen and (min-width: 1024px) {
nav#mainNav ul li a {
        text-shadow: 1px 1px 2px #0000005e, 0 0 1em #00000073, 0 0 0.2em #00000066;
        color: white;
    }
	    #header ul.header__contact {
        background: #ffffff8a;
    }

    nav#mainNav ul li ul.sub-menu li a {
        text-shadow: none;
    }
    .home #header .logo, #header .logo {
        color: #ffffff;
        text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    }
    .sticky-header #header > .inner {
        background: #e7edf4ba !important;
    }

}

@media only screen and (max-width: 1023px) {
    nav#mainNav ul li a {
        background-color: rgb(36 74 115);
        color: #fff;
    }
    nav#mainNav ul.sub-menu a,nav#mainNav ul li li:last-child a {
        background-color: rgb(36 74 115);
        color: #fff;
    }
	
}
#home-service .link-name {
    background: none;
}
#home-service .link-name{
    text-shadow: 1px 1px 2px black, 0 0 1em blue, 0 0 0.2em blue;
}
@media only screen and (max-width: 768px) {
body:not(.home) .post h2.white {
    color: #ffffff;
}
	
}
.link-ttl {
    text-shadow: 1px 1px 2px black, 0 0 1em blue, 0 0 0.2em blue;
}
img.shadow {
filter: drop-shadow(3px 3px 3px blue);
}
p.Messagettl {
    font-weight: bolder;
    margin-bottom: 10px;
}
@media print, screen and (min-width: 1024px) {
	nav#mainNav ul li#menu-item-574 > a:hover b {
		color: #fff !important;
	}
	
}
@media only screen and (max-width: 1023px) {
    nav#mainNav ul li#menu-item-574 > a {
        background-color: #fff !important;
        color: #000 !important;
    }
}

@media print, screen and (min-width: 1024px) {
    nav#mainNav ul li a {
        text-shadow: 1px 1px 2px #0000008f, 0 0 1em #000000ad, 0 0 0.5em #00000099;
    }
	    .home #header .logo, #header .logo {
        text-shadow: 1px 1px 2px #0000008f, 0 0 1em #000000ad, 0 0 0.5em #00000099;
    }
}

/*----20250421----*/
.sns_icons ul {
    display: flex;
    gap: 10px;
    a {
        transition: all 0.3s;
        i::before {
            font-size: 3rem;
        }
        &:hover {
            opacity: .6;
        }
    }
}

.wp-image-719 {
	width: 32px;
}

h1:has(.wp-image-719){
    display: flex
;
    align-items: center;
    justify-content: center;
    gap: 10px;
}