<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@charset "UTF-8";
/**
  @fonts
--------------------------------------------------------
  setting/_font.scss
--------------------------------------------------------
■日本語フォント
- Zen Kaku Gothic New
https://fonts.google.com/specimen/Zen+Kaku+Gothic+New

- Yaku Han JP
https://yakuhanjp.qranoko.jp/

■英字フォント
- Poppins
https://fonts.google.com/specimen/Poppins
-------------------------------------------------------- */
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-style: normal;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

ul, ol {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  color: inherit;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

*, *::before, *::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

hr {
  display: block;
  height: 0;
  border: none;
  margin: 0;
  padding: 0;
  background: none;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

b, strong {
  font-weight: 700;
}

i, em {
  font-style: normal;
}

sup {
  font-size: 70%;
  vertical-align: top;
  position: relative;
}

:root {
  --scrollbar: 0;
  --vw: calc(100vw - var(--scrollbar));
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  height: 100%;
  letter-spacing: 0.1em;
  word-wrap: normal;
  overflow-wrap: anywhere;
  line-break: strict;
}

body {
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg.png") repeat;
  color: #484d4b;
  font-family: YakuHanJP, "Roboto", "Zen Kaku Gothic New", sans-serif;
  line-height: 1;
  opacity: 0;
}
body.is-loaded {
  -webkit-animation: fadein 0.3s ease-in 0.5s forwards;
          animation: fadein 0.3s ease-in 0.5s forwards;
}

@-webkit-keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
a {
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
    cursor: default;
  }
}

:root {
  --body-width: calc(100vw - var(--scrollbar));
  --fz-3: 0.625rem;
  --fz-2: 0.75rem;
  --fz-1: 0.875rem;
  --fz0: clamp(1rem, 1rem + 0vw, 1rem);
  --fz1: clamp(1.125rem, 1.0708rem + 0.2312vw, 1.25rem);
  --fz2: clamp(1.2656rem, 1.1369rem + 0.5491vw, 1.5625rem);
  --fz3: clamp(1.4238rem, 1.1944rem + 0.979vw, 1.9531rem);
  --fz4: clamp(1.6018rem, 1.2378rem + 1.553vw, 2.4414rem);
  --fz5: clamp(1.802rem, 1.2602rem + 2.3116vw, 3.0518rem);
  --fz6: clamp(2.0273rem, 1.2524rem + 3.3062vw, 3.8147rem);
  --fz7: clamp(2.2807rem, 1.2022rem + 4.6015vw, 4.7684rem);
}

/* =========================================================
 header
========================================================= */
.scroll-prevent {
  position: fixed;
  z-index: -1;
  width: 100%;
  height: 100%;
}

.l-header {
  position: fixed;
  gap: 30px;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  width: 100%;
  z-index: 99999;
}
@media screen and (max-width: 991px) {
  .l-header {
    gap: 10px;
    height: 80px;
    padding-inline: 5vw;
  }
}
@media screen and (max-width: 767px) {
  .l-header {
    height: 70px;
  }
}
@media screen and (min-width: 992px) {
  .l-header {
    height: 98px;
    padding-inline: 40px;
  }
}
@media screen and (min-width: 1200px) {
  .l-header {
    height: 118px;
  }
}
@media screen and (min-width: 1400px) {
  .l-header {
    padding-inline: 80px;
  }
}
.l-header.is-on:after {
  -webkit-transform: translateY(-105%);
          transform: translateY(-105%);
}
.l-header:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg.png") repeat;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.l-header a {
  display: block;
  color: #484d4b;
  text-decoration: none;
}
.l-header-logo {
  position: relative;
  margin-right: auto;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  z-index: 999999;
}
@media screen and (max-width: 991px) {
  .l-header-logo {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
@media screen and (min-width: 992px) {
  .l-header:has(.l-header-menu__input:checked) .l-header-logo {
    -webkit-transform: translateY(15px);
            transform: translateY(15px);
  }
}
.scroll-prevent .l-header-logo {
  opacity: 1;
  pointer-events: auto;
}
.l-header-logo a {
  aspect-ratio: 60/7;
}
.l-header.is-on:not(:has(.l-header-menu__input:checked)) .l-header-logo a {
  background: url("/koa-wp/wp-content/uploads/2025/03/logo-wht.svg") no-repeat center center;
  background-size: 100%;
}
.l-header-logo img {
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media screen and (max-width: 991px) {
  .l-header-logo img {
    height: 26px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-logo img {
    height: 22px;
  }
}
@media screen and (min-width: 992px) {
  .l-header-logo img {
    height: 30px;
  }
}
.l-header.is-on:not(:has(.l-header-menu__input:checked)) .l-header-logo img {
  opacity: 0;
}
@media screen and (max-width: 1199px) {
  .l-header-nav {
    display: none;
  }
}
.l-header-nav__list {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  z-index: 10;
}
@media screen and (min-width: 1200px) {
  .l-header-nav__list {
    gap: 30px;
  }
}
.l-header-nav__item {
  position: relative;
}
@media screen and (min-width: 1200px) {
  .l-header-nav__item {
    font-size: var(--fz0);
  }
}
.l-header-nav__item &gt; a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-block: 10px;
}
.l-header.is-on .l-header-nav__item &gt; a {
  color: #fff;
}
@media screen and (min-width: 1200px) {
  .l-header-nav__item &gt; a.is-current {
    color: #004f9e;
  }
  .l-header-nav__item &gt; a.is-current:after {
    bottom: 0;
    opacity: 1;
  }
}
@media (hover: hover) {
  .l-header-nav__item &gt; a:hover {
    color: #004f9e;
  }
  .l-header-nav__item &gt; a:hover:after {
    bottom: 0;
    opacity: 1;
  }
}
@media screen and (min-width: 1200px) {
  .l-header-nav__item &gt; a:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: -5px;
    height: 2px;
    width: 100%;
    background: #004f9e;
    opacity: 0;
    -webkit-transition: all 0.15s ease;
    transition: all 0.15s ease;
  }
  .l-header.is-on .l-header-nav__item &gt; a:after {
    background: #fff;
  }
}
.l-header-hamburger {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 80px;
  height: 54px;
  border-radius: 27px;
  background: #004f9e;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  cursor: pointer;
  z-index: 999999;
}
.l-header.is-on:not(:has(.l-header-menu__input:checked)) .l-header-hamburger {
  background: #fff;
}
@media screen and (max-width: 767px) {
  .l-header-hamburger {
    width: 70px;
    height: 44px;
    border-radius: 22px;
  }
}
@media screen and (min-width: 992px) {
  .l-header:has(.l-header-menu__input:checked) .l-header-hamburger {
    -webkit-transform: translateY(15px);
            transform: translateY(15px);
  }
}
@media (hover: hover) {
  .l-header-hamburger:hover {
    background: #00a560;
  }
  .l-header-hamburger:hover [class$=__line]:nth-of-type(3) {
    width: 100%;
  }
}
.l-header-hamburger__lines {
  position: relative;
  width: 20px;
  height: 13px;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.l-header-hamburger__line {
  display: block;
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fff;
  -webkit-transform-origin: center;
          transform-origin: center;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.l-header.is-on:not(:has(.l-header-menu__input:checked)) .l-header-hamburger__line {
  background: #004f9e;
}
.l-header-hamburger__line:nth-of-type(1) {
  top: 0;
}
.l-header:has(.l-header-menu__input:checked) .l-header-hamburger__line:nth-of-type(1) {
  top: 50%;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.l-header-hamburger__line:nth-of-type(2) {
  top: 50%;
}
.l-header:has(.l-header-menu__input:checked) .l-header-hamburger__line:nth-of-type(2) {
  opacity: 0;
}
.l-header-hamburger__line:nth-of-type(3) {
  bottom: 0;
  width: 50%;
}
.l-header:has(.l-header-menu__input:checked) .l-header-hamburger__line:nth-of-type(3) {
  top: 50%;
  bottom: auto;
  width: 100%;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.l-header-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100svh;
  pointer-events: none;
  z-index: 99999;
}
@media screen and (max-width: 991px) {
  .l-header-menu {
    padding-top: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu {
    padding-top: 70px;
  }
}
@media screen and (min-width: 992px) {
  .l-header-menu {
    padding-top: 98px;
    padding-inline: 15px;
    padding-bottom: 15px;
  }
}
@media screen and (min-width: 1200px) {
  .l-header-menu {
    padding-top: 118px;
  }
}
.l-header:has(.l-header-menu__input:checked) .l-header-menu {
  pointer-events: auto;
}
.l-header-menu__input {
  display: none;
}
.l-header-menu__main {
  position: relative;
  height: 100%;
  overflow-y: auto;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
  opacity: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
  z-index: 2;
}
@media screen and (max-width: 991px) {
  .l-header-menu__main {
    padding-inline: 5vw;
  }
}
@media screen and (min-width: 992px) {
  .l-header-menu__main {
    padding-top: 15px;
    padding-inline: 40px;
  }
}
@media screen and (min-width: 1400px) {
  .l-header-menu__main {
    padding-inline: 80px;
  }
}
.l-header:has(.l-header-menu__input:checked) .l-header-menu__main {
  opacity: 1;
  pointer-events: auto;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.l-header-menu__inner {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 991px) {
  .l-header-menu__inner {
    padding-bottom: 10vw;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__inner {
    gap: 30px;
  }
}
@media screen and (max-width: 575px) {
  .l-header-menu__inner {
    padding-bottom: 3rem;
  }
}
@media screen and (min-width: 768px) {
  .l-header-menu__inner {
    gap: 50px;
    padding-bottom: 40px;
  }
}
@media screen and (min-width: 1400px) {
  .l-header-menu__inner {
    padding-bottom: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__bnrs {
    gap: 15px;
  }
}
@media screen and (max-width: 575px) {
  .l-header-menu__bnrs {
    display: -ms-grid;
    display: grid;
  }
}
@media screen and (min-width: 576px) {
  .l-header-menu__bnrs {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
@media screen and (min-width: 768px) {
  .l-header-menu__bnrs {
    gap: 30px;
  }
}
.l-header-menu__bnrs li {
  max-width: 350px;
}
.l-header-menu__bnrs a {
  display: block;
}
.l-header-menu__nav {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 991px) {
  .l-header-menu__nav {
    -ms-grid-columns: auto 40px auto 40px auto;
    grid-template-columns: repeat(3, auto);
    gap: 40px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__nav {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 0;
    border-top: 1px solid #dbdad1;
  }
}
@media screen and (min-width: 992px) {
  .l-header-menu__nav {
    -ms-grid-columns: auto 60px auto 60px auto 60px auto;
    grid-template-columns: repeat(4, auto);
    gap: 60px;
  }
}
@media screen and (min-width: 1400px) {
  .l-header-menu__nav {
    gap: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__list {
    border-bottom: 1px solid #dbdad1;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__list:has(input:checked) dd {
    -ms-grid-rows: 1fr;
    grid-template-rows: 1fr;
    padding-bottom: 30px;
  }
}
@media screen and (max-width: 575px) {
  .l-header-menu__list:has(input:checked) dd {
    padding-bottom: 20px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__list dd {
    display: -ms-grid;
    display: grid;
    -ms-grid-rows: 0fr;
    grid-template-rows: 0fr;
    -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
    transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  }
}
.l-header-menu__items {
  display: -ms-grid;
  display: grid;
  gap: 1.3em;
}
@media screen and (max-width: 767px) {
  .l-header-menu__items {
    overflow: hidden;
  }
}
.l-header-menu__items ul {
  display: -ms-grid;
  display: grid;
  gap: 1em;
  margin-top: 1em;
}
.l-header-menu__items ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 5px;
  font-weight: 400;
  line-height: 1.3;
}
@media screen and (max-width: 1199px) {
  .l-header-menu__items ul li {
    font-size: 0.8125rem;
  }
}
@media screen and (min-width: 1200px) {
  .l-header-menu__items ul li {
    font-size: var(--fz-1);
  }
}
.l-header-menu__items ul li:before {
  content: "";
  display: block;
  width: 10px;
  height: 1px;
  margin-top: 0.6em;
  background: #004f9e;
}
.l-header-menu__item {
  font-weight: 500;
}
@media screen and (max-width: 1199px) {
  .l-header-menu__item {
    font-size: var(--fz-1);
  }
}
@media screen and (min-width: 768px) {
  .l-header-menu__item.--sp {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .l-header-menu__ttl {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__ttl:has(input:checked) label:after {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__ttl label {
    position: relative;
    display: block;
    padding-block: 30px;
  }
}
@media screen and (max-width: 575px) {
  .l-header-menu__ttl label {
    padding-block: 20px;
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__ttl label:before, .l-header-menu__ttl label:after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 13px;
    width: 13px;
    height: 1px;
    background: #484d4b;
    -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
    transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  }
}
@media screen and (max-width: 767px) {
  .l-header-menu__ttl label:after {
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }
}
.l-header-menu__ttl input {
  display: none;
}
@media screen and (max-width: 767px) {
  .l-header-menu__ttl a {
    pointer-events: none;
  }
}
.l-header-menu__ttl span {
  display: block;
  color: #004f9e;
}
.l-header-menu__ttl-en {
  font-family: "Poppins", sans-serif;
  font-size: var(--fz-3);
  font-weight: 500;
}
@media screen and (max-width: 575px) {
  .l-header-menu__ttl-en {
    margin-bottom: 5px;
  }
}
@media screen and (min-width: 576px) {
  .l-header-menu__ttl-en {
    margin-bottom: 8px;
  }
}
.l-header-menu__ttl-jp {
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .l-header-menu__ttl-jp {
    font-size: var(--fz1);
  }
}
@media screen and (min-width: 992px) {
  .l-header-menu__ttl-jp {
    font-size: var(--fz1);
  }
}
@media screen and (min-width: 1200px) {
  .l-header-menu__ttl-jp {
    font-size: var(--fz2);
  }
}
.l-header-menu__other {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 30px;
}
@media screen and (min-width: 768px) {
  .l-header-menu__other {
    padding-top: 30px;
    border-top: 1px solid #dbdad1;
  }
}
.l-header-menu__other li {
  font-size: var(--fz-1);
}
.l-header-menu__bg {
  position: fixed;
  background: #fff;
  opacity: 0;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
  z-index: 1;
}
@media screen and (max-width: 991px) {
  .l-header-menu__bg {
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
  }
}
@media screen and (min-width: 992px) {
  .l-header-menu__bg {
    top: 15px;
    left: 15px;
    width: calc(100% - 30px);
    height: calc(100vh - 30px);
    border-radius: 30px;
  }
}
.l-header:has(.l-header-menu__input:checked) .l-header-menu__bg {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
}
.l-header-menu__overlay {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.3);
  opacity: 0;
  pointer-events: none;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  z-index: 9;
}
.l-header:has(.l-header-menu__input:checked) .l-header-menu__overlay {
  opacity: 1;
  pointer-events: auto;
}

.l-footer {
  display: -ms-grid;
  display: grid;
  gap: 30px;
  padding-block: min(60px, 10vw);
}
@media screen and (max-width: 991px) {
  .l-footer {
    padding-inline: 5vw;
  }
}
@media screen and (max-width: 575px) {
  .l-footer {
        grid-template-areas: "info" "group" "copyright";
    text-align: center;
  }
}
@media screen and (min-width: 576px) {
  .l-footer {
        grid-template-areas: "info group" "copyright group";
  }
}
@media screen and (min-width: 992px) {
  .l-footer {
    gap: 50px;
    padding-inline: 40px;
  }
}
@media screen and (min-width: 1400px) {
  .l-footer {
    padding-inline: 80px;
  }
}
.l-footer-group {
  grid-area: group;
}
@media screen and (min-width: 576px) {
  .l-footer-group {
    margin-left: auto;
  }
}
.l-footer-group a {
  display: block;
}
.l-footer-group img {
  height: 30px;
}
@media screen and (max-width: 575px) {
  .l-footer-group img {
    height: 25px;
  }
}
.l-footer-info {
  grid-info: group;
  display: -ms-grid;
  display: grid;
  gap: 20px;
}
.l-footer-info p {
  font-size: var(--fz-2);
}
.l-footer-logo img {
  height: 20px;
}
.l-footer-copyright {
  grid-area: copyright;
  font-size: var(--fz-3);
  font-family: "Poppins", sans-serif;
  letter-spacing: 0.05em;
  line-height: 1;
}
@media screen and (max-width: 575px){
  .l-footer-group {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .l-footer-copyright {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
}
@media screen and (min-width: 576px){
  .l-footer-group {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
  }
  .l-footer-copyright {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
}
@media screen and (max-width: 575px) {
  .l-footer-copyright {
    text-align: center;
  }
}
.l-aside-contact {
  grid-area: contact;
}
@media screen and (max-width: 991px) {
  .l-aside-contact {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr var(--gap) 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--gap);
  }
}
@media screen and (max-width: 991px) {
  .l-aside-contact {
    margin-bottom: 80px;
  }
}
@media screen and (max-width: 767px) {
  .l-aside-contact {
    display: block;
    margin-bottom: 10vw;
  }
}
.l-aside-contact * {
  color: #fff;
  line-height: 1;
}
.l-aside-contact__ttl {
  display: -ms-grid;
  display: grid;
  gap: 20px;
  font-weight: 400;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 991px) {
  .l-aside-contact__ttl {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 767px) {
  .l-aside-contact__ttl {
    margin-bottom: 5vw;
  }
}
@media screen and (min-width: 992px) {
  .l-aside-contact__ttl {
    margin-bottom: 50px;
  }
}
.l-aside-contact__ttl--en {
  font-size: var(--fz-3);
  font-weight: 700;
}
.l-aside-contact__ttl--jp {
  font-size: var(--fz4);
}
.l-aside-contact__txt {
  font-size: var(--fz-1);
  text-align: justify;
  line-height: 1.6;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 767px) {
  .l-aside-contact__txt {
    margin-bottom: 5vw;
  }
}
@media screen and (max-width: 575px) {
  .l-aside-contact__txt {
    font-size: 0.812rem;
  }
}
@media screen and (min-width: 992px) {
  .l-aside-contact__txt {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 991px) {
  .l-aside-contact__main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
.l-aside-contact__tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 15px;
  margin-bottom: min(20px, 2.5vw);
  font-size: var(--fz4);
  font-weight: 300;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 1399px) {
  .l-aside-contact__tel {
    font-size: 3vw;
  }
}
@media screen and (max-width: 991px) {
  .l-aside-contact__tel {
    font-size: var(--fz4);
  }
}
.l-aside-contact__tel a {
  color: #fff;
  text-decoration: none;
}
.l-aside-contact__tel svg {
  width: 0.7em;
  aspect-ratio: 1/1;
}
.l-aside-contact__time {
  font-size: var(--fz-2);
}
.l-aside-link {
  position: relative;
  padding-block: min(80px, 10vw);
  background: #004f9e;
}
.l-aside-link svg {
  fill: #fff;
}
.l-aside-link__grid {
  position: absolute;
  top: 0;
  left: 0;
  display: -ms-grid;
  display: grid;
  gap: var(--gap);
  padding-inline: var(--body-space);
  width: var(--body-width);
  height: 100%;
  pointer-events: none;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .l-aside-link__grid {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 992px) {
  .l-aside-link__grid {
    -ms-grid-columns: (1fr)[3];
    grid-template-columns: repeat(3, 1fr);
  }
}
.l-aside-link__grid div {
  border-left: 1px solid rgba(255, 255, 255, 0.05);
  border-right: 1px solid rgba(255, 255, 255, 0.05);
}
@media screen and (max-width: 991px) {
  .l-aside-link__grid div:nth-of-type(1) {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .l-aside-link__grid div:nth-of-type(2) {
    display: none;
  }
}
.l-aside-link__inner {
  position: relative;
  padding-inline: var(--body-space);
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .l-aside-link__inner {
    display: -ms-grid;
    display: grid;
    grid-column-gap: var(--gap);
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    -ms-grid-columns: 1fr var(--gap) 1fr;
    grid-template-columns: repeat(2, 1fr);
        grid-template-areas: "contact contact" "link01 link02";
  }
  .l-aside-contact {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
}
@media screen and (min-width: 992px) {
  .l-aside-link__inner {
        grid-template-areas: "contact link01 link02";
    -ms-grid-columns: (1fr)[3];
    grid-template-columns: repeat(3, 1fr);
  }
  .l-aside-contact {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
}
.l-aside-link__list {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 768px) {
  .l-aside-link__list {
    gap: min(20px, 2vw);
  }
}
.l-aside-link__list:nth-of-type(1) {
  grid-area: link01;
}
.l-aside-link__list:nth-of-type(2) {
  grid-area: link02;
}
@media screen and (min-width: 768px){
  .l-aside-link__list:nth-of-type(1) {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .l-aside-link__list:nth-of-type(2) {
    -ms-grid-row: 2;
    -ms-grid-column: 3;
  }
}
@media screen and (min-width: 992px){
  .l-aside-link__list:nth-of-type(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .l-aside-link__list:nth-of-type(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
}
.l-aside-link__list:not(:last-child) {
  margin-bottom: min(20px, 2vw);
}
.l-aside-link__item {
  line-height: 1;
}
.l-aside-link__item a, .l-aside-link__item span {
  display: block;
  position: relative;
  padding-block: 5px;
  color: #fff;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .l-aside-link__item a, .l-aside-link__item span {
    padding-block: 10px;
  }
}
.l-aside-link__item a:before, .l-aside-link__item a:after, .l-aside-link__item span:before, .l-aside-link__item span:after {
  content: "";
  display: block;
}
.l-aside-link__item a {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.l-aside-link__item a:after {
  position: absolute;
  bottom: 0px;
  left: 0;
  width: 0;
  height: 1px;
  background: rgba(255, 255, 255, 0.3);
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  .l-aside-link__item a:hover:after {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .l-aside-link__item &gt; span {
    display: none;
  }
}
.l-aside-link__item ul {
  display: -ms-grid;
  display: grid;
  gap: 5px;
}
@media screen and (min-width: 768px) {
  .l-aside-link__item ul {
    margin-top: 10px;
  }
}
.l-aside-link__item ul li {
  position: relative;
  padding-left: 20px;
  font-size: 0.875rem;
}
.l-aside-link__item ul li:before {
  content: "";
  display: block;
  position: absolute;
  top: calc(0.5em + 4px);
  left: 0;
  width: 10px;
  height: 1px;
  background: rgba(255, 255, 255, 0.7);
}
.l-aside-link__item ul a {
  color: rgba(255, 255, 255, 0.7);
}
@media screen and (max-width: 767px) {
  .l-aside-link__item ul a {
    padding: 0;
    padding-block: 5px;
  }
}

.l-main {
  position: relative;
  padding-bottom: min(150px, 20vw);
  border-bottom: 1px solid #dbdad1;
}
.l-main:before, .l-main:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  height: min(150px, 20vw);
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg-footer.png") no-repeat left bottom;
  background-size: cover;
  aspect-ratio: 54/29;
}
.l-main:before {
  left: 0;
}
.l-main:after {
  right: 0;
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}
.l-main ::-moz-selection {
  background-color: #484d4b;
  color: #fff;
}
.l-main ::selection {
  background-color: #484d4b;
  color: #fff;
}
.l-main a {
  text-decoration: none;
}
.l-main a:not([class]) {
  color: #004f9e;
  text-decoration: underline;
}
@media (hover: hover) {
  .l-main a:not([class]):hover {
    color: #00a560;
    text-decoration: none;
  }
}

.c-btn {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 230px;
  height: 60px;
  margin-inline: auto;
  padding-left: 40px;
  padding-right: 30px;
  background: #004f9e;
  border-radius: 30px;
  color: #fff;
  font-weight: 500;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .c-btn {
    height: 70px;
    border-radius: 35px;
  }
}
@media screen and (max-width: 413px) {
  .c-btn {
    width: 100%;
    padding-inline: 25px;
  }
}
@media screen and (min-width: 414px) {
  .c-btn {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 15px;
  }
}
@media screen and (max-width: 413px) {
  .c-btn:has(.c-icon-badge) {
    height: 80px;
    border-radius: 40px;
  }
}
@media (hover: hover) {
  .c-btn:hover {
    background: #00a560;
  }
}
@media screen and (max-width: 575px) {
  .c-btn span {
    font-size: var(--fz-1);
  }
}
@media screen and (max-width: 413px) {
  .c-btn .c-icon {
    margin-left: auto;
  }
}
.c-btn .c-icon svg {
  fill: #fff;
}
@media screen and (max-width: 413px) {
  .c-btn .c-icon-badge {
    width: 60px;
    -webkit-transform: translate(-10px, 0);
            transform: translate(-10px, 0);
  }
  .c-btn .c-icon-badge:after {
    display: none;
  }
}
@media screen and (min-width: 414px) {
  .c-btn .c-icon-badge {
    position: absolute;
    top: 0;
    left: 0;
    width: 80px;
    -webkit-transform: translate(calc(-100% + 30px), -40%);
            transform: translate(calc(-100% + 30px), -40%);
  }
}
.c-btn--en {
  height: 60px;
}
.c-btn--en span {
  font-family: "Poppins", sans-serif;
  font-size: var(--fz-1);
}
.c-btn--sub {
  background: #00a560;
  border-color: #00a560;
  color: #00a560;
}
@media (hover: hover) and (pointer: fine) {
  .c-btn--sub:hover {
    color: #00a560;
  }
  .c-btn--sub:hover svg {
    fill: #00a560;
  }
}
.c-btn--sub:hover .c-icon-circle:after {
  background: #00a560;
}
.c-btn--sub .c-icon-circle svg {
  fill: #00a560;
}
.c-btn--wht {
  border-color: #004f9e;
  background: #fff;
  color: #004f9e;
}
.c-btn--wht .c-icon svg {
  fill: #004f9e;
}
@media screen and (min-width: 992px) {
  .c-btn--wht:hover {
    background: #004f9e;
    color: #fff;
  }
}
.c-btn--lg {
  width: 400px;
}
@media screen and (max-width: 575px) {
  .c-btn--lg {
    width: 100%;
  }
}
.c-btn--primary {
  position: relative;
  width: 100%;
  height: 120px;
  padding-left: min(40px, 5vw);
  padding-right: min(30px, 5vw);
  color: #fff;
  font-size: var(--fz1);
  text-decoration: none;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  line-height: 1;
}
.c-btn-wrap {
  margin-top: min(50px, 8vw);
}
.c-btn-wrap:has(.c-btn--primary) {
  margin-top: min(80px, 10vw);
}
.c-btn-lead {
  margin-bottom: 1em;
  line-height: 1.5em;
  text-align: center;
}
.c-btn-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 30px;
}
@media screen and (max-width: 575px) {
  .c-btn-list {
    display: -ms-grid;
    display: grid;
    gap: 15px;
  }
}
/**
  @forms
---------------------------------------------------------
  elements/_forms.scss
--------------------------------------------------------- */
.c-form {
  max-width: 700px;
  margin-inline: auto;
}
.c-form__info {
  display: block;
  width: 100%;
  margin: 0;
  margin-top: 5px;
  font-weight: 500;
  font-size: clamp(0.688rem, 0.631rem + 0.24vw, 0.813rem);
}
.c-form-block {
  display: -ms-grid;
  display: grid;
  gap: min(2.6vw,15px);
  margin-bottom: 0;
}
.c-form-block:not(:first-child) {
  margin-top: clamp(1.875rem, 1.307rem + 2.42vw, 3.125rem);
}
.c-form-block dt:not(:first-child) {
  margin-top: 1em;
  margin-bottom: 5px;
}
.c-form-block--privacy {
  text-align: center;
}
.c-form-block--privacy .horizontal-item {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto !important;
}
.c-form-block--privacy:has(.wpcf7-not-valid-tip) .horizontal-item label:after {
  border-color: #ad0306;
}
.c-form-block--privacy label {
  height: auto !important;
  padding: 0 !important;
  border: none !important;
}
.c-form-block--privacy label:before {
  top: 5px !important;
  left: 1px !important;
}
.c-form-block--privacy label:has(input:checked):before {
  opacity: 1;
}
.c-form-block--privacy p {
  text-align: center;
  margin-bottom: 0 !important;
}
.c-form__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.c-form__head span {
  display: block;
  font-weight: 500;
  line-height: 1;
}
.c-form__head small {
  font-weight: 400;
  font-size: 75%;
  margin-left: 0.5em;
}
.c-form__head-icon {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 4em;
  height: 2em;
  margin-right: 10px;
  padding-top: 1px;
  border-radius: 1em;
  color: #fff;
  font-size: clamp(0.625rem, 0.568rem + 0.24vw, 0.75rem);
  font-weight: 700;
  line-height: 1;
}
.c-form__head-icon--optional {
  background: #808080;
}
.c-form__head-icon--optional:before {
  content: "任意";
}
.c-form__head-icon--required {
  background: #ad0306;
}
.c-form__head-icon--required:before {
  content: "必須";
}
.c-form__cnt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-form__cnt .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
  line-height: 0;
}
.c-form__cnt p {
  width: 100%;
}
.c-form__cnt:has(.wpcf7-not-valid-tip) input[type=text], .c-form__cnt:has(.wpcf7-not-valid-tip) input[type=tel], .c-form__cnt:has(.wpcf7-not-valid-tip) input[type=email], .c-form__cnt:has(.wpcf7-not-valid-tip) input[type=number], .c-form__cnt:has(.wpcf7-not-valid-tip) textarea, .c-form__cnt:has(.wpcf7-not-valid-tip) .c-form__select, .c-form__cnt:has(.wpcf7-not-valid-tip) .horizontal-item label {
  border-color: #ad0306;
  background: rgba(173, 3, 6, 0.1);
}
.c-form__cnt:has(.wpcf7-not-valid-tip) .c-form__list {
  border-color: #ad0306;
}
.c-form__cnt:has(.zip) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.c-form__cnt:has(.zip) .wpcf7-form-control-wrap {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.c-form input[type=text], .c-form input[type=tel], .c-form input[type=email], .c-form input[type=number], .c-form select {
  height: clamp(3.125rem, 2.841rem + 1.21vw, 3.75rem);
}
.c-form input[type=text], .c-form input[type=tel], .c-form input[type=email], .c-form input[type=number], .c-form textarea, .c-form__select {
  -webkit-appearance: none;
  -webkit-transition: border 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: border 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  background: #fff;
  border: solid 1px #d9d9d9;
  border-radius: 6px;
}
.c-form input[type=text], .c-form input[type=tel], .c-form input[type=email], .c-form input[type=number], .c-form textarea {
  padding: 1em;
}
.c-form input[type=text], .c-form input[type=tel], .c-form input[type=email], .c-form input[type=number], .c-form textarea, .c-form select {
  cursor: pointer;
  width: 100%;
  color: #484d4b;
  font-family: YakuHanJP, "Roboto", "Zen Kaku Gothic New", sans-serif;
  font-size: 1rem;
  vertical-align: baseline;
}
.c-form input[type=text]:focus, .c-form input[type=tel]:focus, .c-form input[type=email]:focus, .c-form input[type=number]:focus, .c-form textarea:focus, .c-form select:focus {
  outline: none;
}
.c-form select {
  position: relative;
  cursor: pointer;
  border: none;
  background: none;
  z-index: 15;
  vertical-align: middle;
  -moz-appearance: button;
       appearance: button;
  -webkit-appearance: none;
}
.c-form select::-ms-expand {
  display: none;
}
.c-form textarea {
  height: clamp(100px, 25vw, 200px);
  padding: 1em;
}
.c-form input[type=radio], .c-form input[type=checkbox] {
  display: none;
}
.c-form input.short {
  width: 150px;
}
.c-form input.zip {
  width: 100px;
}
.c-form input.num {
  width: 80px;
}
.c-form-icon__hyphen {
  display: block;
  width: 10px;
  height: 1px;
  background: #d9d9d9;
  margin: 0 10px;
  line-height: 0;
}
.c-form span[data-name=pref] {
  position: relative;
  width: 100%;
  height: clamp(3.125rem, 2.841rem + 1.21vw, 3.75rem);
  border: 1px solid #d9d9d9;
  background: #fff;
  z-index: 10;
  border-radius: 6px;
}
.c-form span[data-name=pref]:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 1em;
  -webkit-transform: translateY(-50%) rotate(135deg);
          transform: translateY(-50%) rotate(135deg);
  margin: 0;
  width: 8px;
  height: 8px;
  border-top: 2px solid #d9d9d9;
  border-right: 2px solid #d9d9d9;
  z-index: 11;
}
.c-form span[data-name=pref]:has(.wpcf7-not-valid-tip) {
  border-color: #ad0306;
  background: rgba(173, 3, 6, 0.1);
}
.c-form span[data-name=pref]:has(.wpcf7-not-valid-tip):after {
  border-color: #ad0306;
}
.c-form span[data-name=pref] select {
  padding: 0 1em;
}

/* =========================================================
 error
========================================================= */
.wpcf7-form-control-wrap {
  position: relative;
}
.wpcf7-form-control-wrap .wpcf7-not-valid-tip {
  position: absolute;
  left: 0;
  bottom: 0;
  -webkit-transform: translateY(calc(100% + 10px));
          transform: translateY(calc(100% + 10px));
  white-space: nowrap;
}

/* =========================================================
 custom
========================================================= */
.c-form .wpcf7-not-valid-tip {
  color: #ad0306;
  font-size: var(--fz-2);
  font-weight: 700;
  line-height: 1;
}
.c-form .wpcf7-spinner {
  position: absolute;
  display: block;
  top: 0;
  left: 50%;
  margin: 0;
  margin-top: -10px;
  -webkit-transform: translate(-50%, -100%);
          transform: translate(-50%, -100%);
}
.c-form .wpcf7-response-output {
  padding: 1em !important;
  border-color: #ad0306 !important;
  background: rgba(173, 3, 6, 0.1);
  color: #ad0306;
  font-size: var(--fz-1);
  font-weight: 500;
  text-align: center;
}

/* =========================================================
 btn
========================================================= */
.c-form input.c-btn, .c-form button.c-btn {
  cursor: pointer;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 300px;
  margin-inline: 0;
  padding-inline: 0;
  border: none;
  font-size: 1rem;
  font-weight: 500;
  text-decoration: none;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media screen and (max-width: 413px) {
  .c-form input.c-btn, .c-form button.c-btn {
    width: 100%;
  }
}
@media (hover: hover) {
  .c-form input.c-btn:hover, .c-form button.c-btn:hover {
    background: #00a560;
  }
}
.c-form .c-btn-wrap {
  position: relative;
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 30px;
}
@media screen and (max-width: 575px) {
  .c-form .c-btn-wrap {
    gap: 20px;
  }
}
@media screen and (max-width: 413px) {
  .c-form .c-btn-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 15px;
  }
}

/* =========================================================
 message
========================================================= */
.c-form-message p {
  line-height: 2 !important;
}
.c-form-message th {
  white-space: nowrap;
}
.c-form-message--error, .c-form-message--conf {
  display: none;
  margin-top: 1.5em;
}
.c-form-thanks h2 {
  margin-bottom: 1.5em;
  font-size: var(--fz3);
  font-weight: 700;
}
.c-form-thanks p {
  line-height: 2 !important;
}
.c-form-thanks .c-btn {
  padding-inline: 20px;
}
@media (hover: hover) {
  .c-form-thanks .c-btn:hover svg {
    fill: #004f9e;
  }
}

/* =========================================================
 hide
========================================================= */
.js-form-hide {
  display: none;
}
.js-form-hide.is-show {
  display: block;
}

:root {
  --spacing: .25rem;
}

.c-grid {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 767px) {
  .c-grid + .c-grid {
    margin-top: 20px;
  }
}
@media screen and (min-width: 768px) {
  .c-grid + .c-grid {
    margin-top: 30px;
  }
}
@media screen and (min-width: 992px) {
  .c-grid + .c-grid {
    margin-top: 40px;
  }
}
@media screen and (max-width: 991px) {
  .c-grid-cols-2 {
    gap: 8vw;
  }
}
@media screen and (min-width: 992px) {
  .c-grid-cols-2 {
    -ms-grid-columns: 1fr 40px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }
}
@media screen and (min-width: 1200px) {
  .c-grid-cols-2 {
    gap: 60px;
  }
}
@media screen and (min-width: 1400px) {
  .c-grid-cols-2 {
    gap: 80px;
  }
}
@media screen and (min-width: 992px) {
  .c-grid-cols-2.img-s {
    -ms-grid-columns: 1fr 35%;
    grid-template-columns: 1fr 35%;
  }
}
@media screen and (min-width: 576px) {
  .c-grid-cols-3 {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 991px) {
  .c-grid-cols-3 {
    gap: 15px;
  }
}
@media screen and (min-width: 992px) {
  .c-grid-cols-3 {
    gap: 20px;
  }
}
@media screen and (min-width: 768px) {
  .c-grid-col-span-2 {
    -ms-grid-column-span: 2;
    grid-column: span 2/span 2;
  }
}
@media screen and (min-width: 768px) {
  .c-grid-col-span-3 {
    -ms-grid-column-span: 3;
    grid-column: span 3/span 3;
  }
}
.c-grid-gap_s {
  gap: min(50px, 6vw);
}
.c-grid figure {
  -ms-flex-item-align: start;
      -ms-grid-row-align: start;
      align-self: start;
}

i[class^=c-icon] {
  line-height: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
i[class^=c-icon] svg {
  aspect-ratio: 1/1;
  position: relative;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  z-index: 2;
}

.c-icon {
  line-height: 0;
}
.c-icon-arrow svg {
  width: 11px;
}
.c-icon-arrow--blu svg {
  fill: #004f9e;
}
.c-icon-arrow--wht svg {
  fill: #fff;
}
.c-icon-separate {
  display: inline-block;
  width: 1px;
  height: 1em;
  margin-inline: 0.5em;
  background: #484d4b;
  -webkit-transform: rotate(15deg);
          transform: rotate(15deg);
  vertical-align: middle;
}
.c-icon-map {
  height: 1.5em;
  aspect-ratio: 1/1;
}
.c-icon-map svg {
  fill: #004f9e;
}
.c-icon-dot svg {
  width: 20px;
}
.c-icon-circle {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 50px;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 575px) {
  .c-icon-circle {
    width: 30px;
  }
}
.c-icon-circle:after {
  display: block;
  content: "";
  position: absolute;
  inset: 0;
  background: #004f9e;
  border-radius: 100%;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transform-origin: center;
          transform-origin: center;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  z-index: 1;
}
@media (hover: hover) {
  a:hover .c-icon-circle:after {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.c-icon-circle--wht:after {
  border: none;
  background: #fff;
}
.c-icon-circle--gry:after {
  background: #bfbfbf;
}
.c-icon-circle svg {
  fill: #fff;
}
.c-icon-blank svg {
  width: 0.8em;
  aspect-ratio: 1/1;
}
a:not(:has(class)) .c-icon-blank {
  margin-inline: 5px;
  fill: #004f9e;
  vertical-align: text-top;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  a:not(:has(class)):hover .c-icon-blank {
    fill: #00a560;
  }
}
.c-icon-pdf svg {
  width: 26px;
  aspect-ratio: 1/1;
  fill: #004f9e;
}
.c-icon-badge {
  position: relative;
  width: 100px;
  background: #ffe500;
  aspect-ratio: 1/1;
  border-radius: 100%;
}
@media screen and (max-width: 413px) {
  .c-icon-badge {
    width: 60px;
  }
}
@media screen and (min-width: 414px) {
  .c-icon-badge {
    width: 80px;
  }
}
.c-icon-badge:after {
  position: absolute;
  right: -5px;
  bottom: 10%;
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 0px 10px 30px;
  border-color: transparent transparent transparent #ffe500;
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
}

@-webkit-keyframes icon-arrow {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  37% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
    opacity: 1;
  }
  38% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
    opacity: 0;
  }
  39% {
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    opacity: 0;
  }
  40% {
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}

@keyframes icon-arrow {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  37% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
    opacity: 1;
  }
  38% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
    opacity: 0;
  }
  39% {
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    opacity: 0;
  }
  40% {
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
.c-link-txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 15px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 30px;
  color: #484d4b;
  text-decoration: none;
}
@media screen and (max-width: 575px) {
  .c-link-txt {
    margin-top: 20px;
  }
}
.c-link-txt:has(.c-icon-map) {
  gap: 5px;
}
.c-link-txt &gt; span {
  overflow: hidden;
  position: relative;
  display: block;
  padding-block: 5px;
  line-height: 1.3;
}
.c-link-txt &gt; span:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #949a98;
  -webkit-transform-origin: right bottom;
          transform-origin: right bottom;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.c-link-txt p {
  margin: 0 !important;
}
@media screen and (hover: hover) and (pointer: fine) and (min-width: 992px) {
  .c-link-txt:hover span:after {
    -webkit-animation: underline 0.4s cubic-bezier(0.29, 0.65, 0.62, 1) forwards;
            animation: underline 0.4s cubic-bezier(0.29, 0.65, 0.62, 1) forwards;
  }
}
.c-link-txt .c-icon-circle {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  position: relative;
}
.c-link-txt__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 15px 30px;
  margin-top: 30px;
}
.c-link-txt__list--right {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.c-link-txt__list--center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.c-link-txt__list .c-link-txt {
  margin-top: 0;
}
.c-link-pdf {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 10px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-height: 60px;
  padding: 1em;
  border-radius: 10px;
  border: 1px solid #dbdad1;
  background: #fff;
}
@media screen and (max-width: 413px) {
  .c-link-pdf {
    min-height: 50px;
  }
}
@media (hover: hover) {
  .c-link-pdf:hover {
    border-color: #004f9e;
  }
}
.c-link-pdf i {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 30px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
}
.c-link-pdf i svg {
  width: 16px;
  aspect-ratio: 1/1;
  fill: #fff;
}
.c-link-pdf__list {
  display: -ms-grid;
  display: grid;
  gap: 15px;
}
@media screen and (max-width: 767px) {
  .c-link-pdf__list {
    gap: 10px;
  }
}
@media screen and (min-width: 768px) {
  .c-link-pdf__list {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  }
}
.c-link-pdf__list .c-link-pdf {
  width: 100%;
}

@-webkit-keyframes underline {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  37% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    opacity: 1;
  }
  38% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    opacity: 0;
  }
  39% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
    opacity: 0;
  }
  40% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}

@keyframes underline {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
  37% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    opacity: 1;
  }
  38% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
    opacity: 0;
  }
  39% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
    opacity: 0;
  }
  40% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
.c-list {
  display: -ms-grid;
  display: grid;
}
.c-list:has(&gt; li) {
  gap: 0.5em;
}
.c-list:not(:last-child) {
  margin-bottom: 1.6em;
}
.c-list &gt; li, .c-list &gt; dt {
  position: relative;
  padding-left: 15px;
  line-height: 1.6;
}
.c-list &gt; li:before, .c-list &gt; dt:before {
  position: absolute;
  display: block;
  content: "";
  top: 0.8em;
  left: 0;
  width: 6px;
  margin-top: -3px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
}
.c-list dt {
  margin-bottom: 5px;
}
.c-list dt:not(:first-child) {
  margin-top: 1rem;
}
.c-list dd {
  padding-left: 15px;
}
.c-list dd ul {
  display: -ms-grid;
  display: grid;
  gap: 5px;
}
.c-list-num {
  display: -ms-grid;
  display: grid;
  gap: 0.5em;
}
.c-list-num:not(:last-child) {
  margin-bottom: 1.6em;
}
.c-list-num &gt; li, .c-list-num &gt; dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 5px;
  counter-increment: calc-ex9;
  line-height: 1.6;
}
.c-list-num &gt; li:last-child, .c-list-num &gt; dt:last-child {
  margin-bottom: 0;
}
.c-list-num &gt; li:before, .c-list-num &gt; dt:before {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  content: counter(calc-ex9) ".";
  display: inline-block;
  width: 2em;
  text-indent: 0;
}
.c-list-num &gt; dt {
  margin-bottom: 5px;
  line-height: 1.3;
}
.c-list-num &gt; dd {
  padding-left: calc(2em + 5px);
}
.c-list-num &gt; dd:not(:last-child) {
  margin-bottom: 10px;
}
.c-list-num--parenthesis &gt; li:before, .c-list-num--parenthesis &gt; dt:before {
  content: "（" counter(calc-ex9) "）";
}

.c-map iframe {
  width: 100%;
  aspect-ratio: 16/9;
}

/*  c-modal
--------------------------------------------- */
.c-modal {
  pointer-events: none;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  z-index: 99999999;
}
.c-modal.is-open {
  pointer-events: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.c-modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
}
.c-modal-container {
  overflow: hidden;
  position: relative;
  width: 90vw;
  height: 90vh;
  padding-top: min(90px, 16vw);
  padding-inline: min(60px, 8vw);
  background: #fff;
  overflow-x: hidden;
  overflow-y: auto;
  z-index: 10;
}
@media screen and (min-width: 992px) {
  .c-modal-container {
    max-width: 800px;
  }
}
.c-modal-main {
  padding-bottom: min(90px, 16vw);
}
.c-modal-close {
  cursor: pointer;
  position: absolute;
  top: 5vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  width: 90vw;
  z-index: 20;
}
@media screen and (max-width: 991px) {
  .c-modal-close {
    left: 5vw;
  }
}
@media screen and (min-width: 992px) {
  .c-modal-close {
    max-width: 800px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.c-modal-close i {
  position: relative;
  width: 60px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #00a560;
  -webkit-transform: translate(50%, -50%);
          transform: translate(50%, -50%);
}
@media screen and (max-width: 767px) {
  .c-modal-close i {
    width: 50px;
    -webkit-transform: translate(3vw, -5vw);
            transform: translate(3vw, -5vw);
  }
}
.c-modal-close i:before, .c-modal-close i:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 50%;
  height: 2px;
  margin-top: -1px;
  margin-left: -25%;
  background: #fff;
}
.c-modal-close i:before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.c-modal-close i:after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

/* Modal Animation Style　(アニメーション不要の場合は削除)
--------------------------------------------- */
.c-modal[aria-hidden=false] {
  -webkit-animation: mmfadeIn 0.8s cubic-bezier(0, 0.7, 0.22, 1);
          animation: mmfadeIn 0.8s cubic-bezier(0, 0.7, 0.22, 1);
}
.c-modal[aria-hidden=true] {
  -webkit-animation: mmfadeOut 0.8s cubic-bezier(0, 0.7, 0.22, 1);
          animation: mmfadeOut 0.8s cubic-bezier(0, 0.7, 0.22, 1);
}
.c-modal__overlay, .c-modal__container {
  will-change: transform;
}

@-webkit-keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@-webkit-keyframes mmslideIn {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes mmslideIn {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes mmslideOut {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(15%);
            transform: translateX(15%);
  }
}
@keyframes mmslideOut {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(15%);
            transform: translateX(15%);
  }
}
.wp-pagenavi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 15px 8px;
  padding-top: clamp(2.5rem, 1.296rem + 4.94vw, 5rem);
}
@media screen and (max-width: 575px) {
  .wp-pagenavi {
    gap: 10px 5px;
  }
}
.wp-pagenavi * {
  font-size: 0.875rem;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  line-height: 0.8;
  text-decoration: none;
}
.wp-pagenavi span:not(.pages):not(.extend), .wp-pagenavi a:not(.nextpostslink):not(.previouspostslink) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 50px;
  aspect-ratio: 1/1;
  border-radius: 5px;
  border: none;
  background: #fff;
  color: #c8ccca;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
@media screen and (max-width: 575px) {
  .wp-pagenavi span:not(.pages):not(.extend), .wp-pagenavi a:not(.nextpostslink):not(.previouspostslink) {
    width: 40px;
  }
}
.wp-pagenavi a:not(.nextpostslink):not(.previouspostslink) {
  border-radius: 5px;
  border: 1px solid #dbdad1;
}
@media (hover: hover) and (pointer: fine) {
  .wp-pagenavi a:not(.nextpostslink):not(.previouspostslink):hover {
    border-color: #004f9e;
    color: #484d4b;
  }
}
.wp-pagenavi a.previouspostslink, .wp-pagenavi a.nextpostslink {
  position: relative;
  width: 40px;
  aspect-ratio: 1/1;
  font-size: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) and (pointer: fine) {
  .wp-pagenavi a.previouspostslink:hover:before, .wp-pagenavi a.nextpostslink:hover:before {
    border-color: #004f9e;
  }
}
.wp-pagenavi a.previouspostslink:before, .wp-pagenavi a.nextpostslink:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  margin-top: -4px;
  margin-left: -4px;
  border-top: 2px solid #484d4b;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
.wp-pagenavi a.previouspostslink:before {
  border-left: 2px solid #484d4b;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.wp-pagenavi a.nextpostslink:before {
  border-right: 2px solid #484d4b;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.wp-pagenavi .pages {
  display: block;
  width: 100%;
  height: auto;
  text-align: center;
  font-size: var(--fz-2);
}
.wp-pagenavi .previouspostslink, .wp-pagenavi .nextpostslink, .wp-pagenavi .first, .wp-pagenavi .last {
  font-size: 0.875rem;
  font-family: YakuHanJP, "Roboto", "Zen Kaku Gothic New", sans-serif;
}
@media screen and (max-width: 575px) {
  .wp-pagenavi .previouspostslink, .wp-pagenavi .nextpostslink, .wp-pagenavi .first, .wp-pagenavi .last {
    font-size: 0.75rem;
  }
}
.wp-pagenavi span.current {
  color: #fff !important;
  background: #004f9e !important;
}

.c-sentence {
  text-align: justify;
  line-height: 2;
  letter-spacing: 0.1em;
}
.c-sentence:not(:last-child) {
  margin-bottom: 1.5em;
}
.c-sentence-note {
  display: -ms-grid;
  display: grid;
  margin-top: 5px;
}
.c-sentence-note p, .c-sentence-note li, .c-sentence-note dt {
  margin-left: 1em;
  text-indent: -1em;
  font-size: var(--fz-2);
  line-height: 1.6;
}
.c-sentence-note p:not(:last-child) {
  margin-bottom: 5px !important;
}
.c-sentence-note dd {
  margin-left: 1em;
  font-size: var(--fz-2);
}
.c-sentence-lead {
  color: #004f9e;
  font-size: var(--fz2);
  font-weight: 500;
}
.c-sentence-lead:not(:last-child) {
  margin-bottom: 0.8em;
}
.c-sentence-emphasis {
  margin-bottom: 0.8em;
  font-size: var(--fz1);
  font-weight: 500;
}

ul.c-sentence-note {
  gap: 5px;
}

.c-table {
  width: 100%;
  border-collapse: collapse;
  border: none;
  border-top: 1px solid #dbdad1;
  border-left: 1px solid #dbdad1;
}
.c-table th, .c-table td {
  border: none;
  border-right: 1px solid #dbdad1;
  border-bottom: 1px solid #dbdad1;
  font-weight: 400;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .c-table th, .c-table td {
    padding: 1em;
  }
}
@media screen and (min-width: 768px) {
  .c-table th, .c-table td {
    padding-block: 1.5em;
    padding-inline: 1em;
  }
}
.c-table th {
  background: #f2f2f2;
}
.c-table th[scope=row] {
  white-space: nowrap;
}
.c-table td {
  background: rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 413px) {
  .c-table--resp th, .c-table--resp td {
    display: block;
    padding-inline: 1em;
  }
}
@media screen and (max-width: 413px) {
  .c-table--resp th {
    width: 100%;
    border-bottom: 1px dotted #dbdad1;
    background: #f3f5f6;
  }
}
.c-table-swipe th, .c-table-swipe td {
  white-space: nowrap;
}

div:has(&gt; .js-scrollable) {
  overflow: hidden;
}

.c-title-head {
  margin-bottom: 1em;
  color: #004f9e;
  font-size: var(--fz4);
  font-weight: 500;
  letter-spacing: 0.15em;
}
.c-title-head span {
  display: inline-block;
}
.c-title-1ry {
  margin-bottom: 1em;
  padding-bottom: 0.3em;
  border-bottom: 1px solid #004f9e;
  font-size: var(--fz3);
}
.c-title-2ry {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.7em;
  margin-bottom: 0.8em;
  font-size: var(--fz2);
  font-weight: 500;
  letter-spacing: 0.15em;
  line-height: 1.5;
}
@media screen and (max-width: 575px) {
  .c-title-2ry {
    font-size: var(--fz1);
  }
}
.c-title-2ry:before {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  content: "";
  display: block;
  width: 2px;
  background: #004f9e;
  -webkit-transform: translateY(-0.1em);
          transform: translateY(-0.1em);
}
.c-title-3ry {
  margin-top: 2em;
  margin-bottom: 0.8em;
  color: #004f9e;
  font-size: var(--fz1);
  font-weight: 700;
  line-height: 1.4;
}
h2 + .c-title-3ry, h3 + .c-title-3ry, h4 + .c-title-3ry {
  margin-top: 0;
}
.c-title-4ry {
  margin-bottom: 0.5em;
  font-weight: 700;
  font-size: var(--fz0);
}
h2 + .c-title-4ry, h3 + .c-title-4ry, h4 + .c-title-4ry {
  margin-top: 0;
}

a img {
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

.c-img-mt {
  margin-top: min(50px, 5vw) !important;
}
@media screen and (max-width: 991px) {
  .c-img-rd img {
    border-radius: 20px;
  }
}
@media screen and (max-width: 575px) {
  .c-img-rd img {
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .c-img-rd img {
    border-radius: 30px;
  }
}

[class^=c-img] figcaption {
  display: block;
  margin-top: 1em;
  padding-inline: 1em;
  font-size: var(--fz-1);
}

@media screen and (max-width: 991px) {
  .p-page {
    padding-top: 80px;
  }
}
@media screen and (max-width: 767px) {
  .p-page {
    padding-top: 70px;
  }
}
@media screen and (min-width: 992px) {
  .p-page {
    padding-top: 98px;
  }
}
@media screen and (min-width: 1200px) {
  .p-page {
    padding-top: 118px;
  }
}
.p-page-container {
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: min(40px, 5vw);
}
.p-page-container--full {
  max-width: none;
}
@media screen and (min-width: 992px) {
  .p-page-container--full {
    padding-inline: 60px;
  }
}
@media screen and (min-width: 1400px) {
  .p-page-container--full {
    padding-inline: 80px;
  }
}
.p-page-header {
  position: relative;
  margin-bottom: min(200px, 15vw);
}
@media screen and (min-width: 992px) {
  .p-page-header:not(.p-page-header--parent) {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 30px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
  }
}
.p-page-header:not(:has(.p-page-header__img)) {
  border-bottom: 1px solid #dbdad1;
}
@media screen and (min-width: 992px) {
  .p-page-header:not(:has(.p-page-header__img)) {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    padding-top: 30px;
    padding-bottom: min(60px, 6vw);
  }
}
@media screen and (min-width: 992px) {
  .p-page-header:before, .p-page-header:after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    aspect-ratio: 1/1;
    background-size: cover;
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
    -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-transition-delay: 0.8s;
            transition-delay: 0.8s;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    opacity: 0;
  }
  .is-loaded .p-page-header:before, .is-loaded .p-page-header:after {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
.p-page-header:before {
  left: 0;
  width: 10vw;
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf_btm01.png");
}
@media screen and (min-width: 1400px) {
  .p-page-header:before {
    width: 140px;
  }
}
.p-page-header:after {
  right: 10px;
  width: 10vw;
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf_btm02.png");
}
@media screen and (min-width: 1400px) {
  .p-page-header:after {
    width: 150px;
  }
}
.p-page-header__title {
  position: relative;
  font-weight: 500;
  line-height: 1;
}
@media screen and (max-width: 991px) {
  .p-page-header__title {
    padding-block: min(60px, 8vw);
    padding-inline: min(40px, 5vw);
  }
}
@media screen and (min-width: 992px) {
  .p-page-header__title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding-left: 60px;
  }
}
@media screen and (min-width: 1400px) {
  .p-page-header__title {
    padding-left: 80px;
  }
}
@media screen and (min-width: 992px) {
  header.p-page-header--parent .p-page-header__title {
    margin-top: min(40px, 5vw);
    margin-bottom: min(60px, 7vw);
  }
}
header:not(:has(.p-page-header__img)) .p-page-header__title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 992px) {
  .p-page-header__title:before, .p-page-header__title:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    aspect-ratio: 1/1;
    background-size: cover;
    -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    -webkit-transition-delay: 0.8s;
            transition-delay: 0.8s;
    -webkit-filter: blur(10px);
            filter: blur(10px);
    opacity: 0;
  }
  .is-loaded .p-page-header__title:before, .is-loaded .p-page-header__title:after {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
.p-page-header__title:before {
  width: 3vw;
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf01.png");
  -webkit-transform: translate(-100%, 150%);
          transform: translate(-100%, 150%);
}
@media screen and (min-width: 1400px) {
  .p-page-header__title:before {
    width: 50px;
  }
}
.p-page-header__title:after {
  width: 4vw;
  left: 55%;
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf02.png");
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
}
@media screen and (min-width: 1400px) {
  .p-page-header__title:after {
    width: 55px;
  }
}
header:not(:has(.p-page-header__img)) .p-page-header__title:after {
  left: auto;
  right: 0;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
}
.p-page-header__title-jp, .p-page-header__title-en {
  translate: 0 2rem;
  opacity: 0;
  -webkit-transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.is-loaded .p-page-header__title-jp, .is-loaded .p-page-header__title-en {
  translate: 0 0;
  opacity: 1;
}
.p-page-header__title-jp {
  font-size: var(--fz5);
  font-weight: 500;
  line-height: 1.3;
  -webkit-transition-delay: 1.4s;
          transition-delay: 1.4s;
}
@media screen and (max-width: 575px) {
  .p-page-header__title-jp {
    font-size: var(--fz4);
  }
}
.p-page-header__title-jp small {
  font-size: 70%;
}
.p-page-header__title-en {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  margin-bottom: 1.5em;
  color: #004f9e;
  font-size: var(--fz-1);
  font-weight: 700;
  font-family: "Poppins", sans-serif;
  text-transform: uppercase;
  line-height: 0.8em;
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
@media screen and (max-width: 767px) {
  .p-page-header__title-en {
    font-size: var(--fz-2);
  }
}
@media screen and (max-width: 575px) {
  .p-page-header__title-en {
    font-size: var(--fz-3);
    line-height: 1;
  }
}
.p-page-header__title-en i img {
  width: auto;
  height: 1.5em;
}
.p-page-header__img {
  position: relative;
}
@media screen and (max-width: 991px) {
  header:not(.p-page-header--parent) .p-page-header__img {
    margin-left: min(40px, 5vw);
    aspect-ratio: 2.5/1;
  }
}
@media screen and (min-width: 992px) {
  header:not(.p-page-header--parent) .p-page-header__img {
    aspect-ratio: 15/8;
  }
}
@media screen and (max-width: 991px) {
  header.p-page-header--parent .p-page-header__img {
    padding-left: min(40px, 5vw);
  }
}
@media screen and (min-width: 992px) {
  header.p-page-header--parent .p-page-header__img {
    padding-left: 60px;
  }
}
@media screen and (min-width: 1400px) {
  header.p-page-header--parent .p-page-header__img {
    padding-left: 80px;
  }
}
.p-page-header__img:after {
  content: "";
  display: block;
  position: absolute;
  aspect-ratio: 1/1;
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf03.png");
  background-size: cover;
  -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  opacity: 0;
}
.is-loaded .p-page-header__img:after {
  opacity: 1;
  -webkit-filter: blur(0);
          filter: blur(0);
}
@media screen and (max-width: 1399px) {
  .p-page-header__img:after {
    width: 8vw;
  }
}
@media screen and (max-width: 991px) {
  .p-page-header__img:after {
    top: 0;
    right: 5vw;
    width: 12vw;
    -webkit-transform: translateY(-80%);
            transform: translateY(-80%);
  }
}
@media screen and (min-width: 992px) {
  .p-page-header__img:after {
    bottom: 0;
    left: 0;
    -webkit-transform: translate(-90%, -50%);
            transform: translate(-90%, -50%);
  }
}
@media screen and (min-width: 1400px) {
  .p-page-header__img:after {
    width: 100px;
  }
}
.p-page-header__img div {
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .p-page-header__img div {
    border-radius: 20px 0 0 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-page-header__img div {
    border-radius: 30px 0 0 30px;
  }
}
.p-page-header__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  opacity: 0;
  -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
.is-loaded .p-page-header__img img {
  -webkit-transform: scale(1);
          transform: scale(1);
  opacity: 1;
}
@media screen and (max-width: 991px) {
  .p-page-breadcrumbs {
    display: none;
  }
}
@media screen and (min-width: 992px) {
  .p-page-breadcrumbs {
    position: absolute;
    left: 50%;
    bottom: 15px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 10px;
    width: 100%;
    margin: 0;
    font-size: var(--fz-2);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.p-page-breadcrumbs br {
  display: none;
}
.p-page-breadcrumbs span, .p-page-breadcrumbs a {
  line-height: 1;
}
.p-page-breadcrumbs span {
  display: block;
}
.p-page-breadcrumbs &gt; span:not(:last-child) {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.p-page-breadcrumbs &gt; span a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  color: #949a98;
  text-decoration: underline;
}
.p-page-breadcrumbs &gt; span a:after {
  content: "";
  display: block;
  font-size: 0;
  width: 1px;
  height: 12px;
  background: #dbdad1;
  -webkit-transform: rotate(15deg);
          transform: rotate(15deg);
}
.p-page-breadcrumbs &gt; span a:hover {
  text-decoration: none;
}
.p-page-body {
  position: relative;
  padding-bottom: min(150px, 20vw);
  line-height: 1.6;
}
.p-page-body p:not(:last-child):not([class]), .p-page-body ul:not(:last-child):not([class]), .p-page-body ol:not(:last-child):not([class]) {
  margin-bottom: 1.6em;
}
.p-page-section + .p-page-section {
  margin-top: min(200px, 20vw);
}
.p-page-section__hgroup {
  position: relative;
  display: -ms-grid;
  display: grid;
  gap: 15px;
  margin-bottom: min(40px, 5vw);
}
.p-page-section__ttl {
  font-size: var(--fz4);
  font-weight: 500;
  line-height: 1.4;
}
.p-page-section__label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  color: #004f9e;
  font-size: var(--fz-2);
  font-weight: 600;
  line-height: 0.7;
}
.p-page-section__label:before {
  content: "";
  display: block;
  width: 20px;
  height: 14px;
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/icon-hgroup.png") no-repeat center center;
  background-size: cover;
}
.p-page-section__lead {
  margin-bottom: min(30px, 5vw);
  font-size: var(--fz3);
  font-weight: 700;
  letter-spacing: 0.3em;
  line-height: 1.8;
}
@media screen and (max-width: 575px) {
  .p-page-section__lead {
    letter-spacing: 0.2em;
  }
}
.p-page-section__lead span, .p-page-section__lead small {
  letter-spacing: inherit;
}
.p-page-article {
  position: relative;
}
.p-page-article + .p-page-article {
  margin-top: min(80px, 10vw);
}
.p-page-article__block + .p-page-article__block {
  margin-top: min(60px, 8vw);
}
.p-page-article--short {
  max-width: 800px;
}
.p-page-summary {
  background: rgba(0, 79, 158, 0.1);
}
@media screen and (max-width: 991px) {
  .p-page-summary {
    padding: 40px;
    border-radius: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-page-summary {
    padding: 30px;
  }
}
@media screen and (max-width: 575px) {
  .p-page-summary {
    padding: 20px;
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-page-summary {
    padding: 50px;
    border-radius: 30px;
  }
}
@media screen and (min-width: 992px) {
  .p-page-summary--s {
    padding: 40px;
  }
}
.p-page-summary--s p {
  font-size: var(--fz-1);
}
.p-page-summary--grn {
  background: rgba(0, 165, 96, 0.1);
}
.p-page-summary--red {
  background: rgba(173, 3, 6, 0.1);
}
.p-page-navi {
  margin-top: min(150px, 20vw);
  padding-block: min(60px, 6vw);
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg-multiply.png") repeat;
}
.p-page-navi__ttl {
  margin-bottom: 0.8em;
  font-size: var(--fz3);
  font-weight: 500;
}
.p-page-navi__ttl-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  text-decoration: none;
}
.p-page-navi__ttl div {
  display: -ms-grid;
  display: grid;
  gap: 10px;
}
.p-page-navi__ttl span, .p-page-navi__ttl small {
  line-height: 1;
}
.p-page-navi__ttl small {
  color: #004f9e;
  font-size: var(--fz-2);
  font-weight: 500;
  font-family: "Poppins", sans-serif;
}
.p-page-navi__list {
  display: -ms-grid;
  display: grid;
  gap: 15px;
  text-decoration: none;
}
@media screen and (max-width: 575px) {
  .p-page-navi__list {
    gap: 10px;
  }
}
@media screen and (min-width: 576px) {
  .p-page-navi__list {
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  }
}
.p-page-navi__list li {
  line-height: 1;
}
.p-page-navi__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 10px;
  height: 70px;
  padding-inline: 20px;
  border-radius: 6px;
  background: #fff;
  font-weight: 500;
}
@media screen and (max-width: 575px) {
  .p-page-navi__link {
    height: 60px;
  }
}
.p-page-navi__link.is-current {
  pointer-events: none;
  background: #004f9e;
  color: #fff;
}
.p-page-navi__link.is-current .c-icon-circle {
  display: none;
}
@media (hover: hover) {
  .p-page-navi__link:hover {
    color: #004f9e;
  }
  .p-page-navi__link:hover .c-icon-circle {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  .p-page-navi__link:hover .c-icon-circle:after {
    background: #004f9e;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  .p-page-navi__link:hover .c-icon-circle svg {
    opacity: 1;
  }
}
.p-page-navi__link .c-icon-circle {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 34px;
}
@media (hover: hover) {
  .p-page-navi__link .c-icon-circle {
    -webkit-transform: scale(0.2);
            transform: scale(0.2);
  }
}
@media (hover: hover) {
  .p-page-navi__link .c-icon-circle svg {
    opacity: 0;
  }
}
@media screen and (max-width: 991px) {
  .p-page-anchor {
    display: none;
  }
}
@media screen and (min-width: 992px) {
  .p-page-anchor {
    position: sticky;
    top: 100px;
    left: 0;
    grid-column: auto !important;
    grid-area: anchor;
  }
}
.p-page-anchor__ttl {
  margin-bottom: 20px;
  color: #00a560;
  font-weight: 700;
  font-size: var(--fz-3);
  letter-spacing: 0.2em;
  line-height: 1;
}
.p-page-anchor__list {
  display: -ms-grid;
  display: grid;
  gap: 20px;
}
.p-page-anchor__item {
  line-height: 1;
}
.p-page-anchor__link {
  position: relative;
  padding-left: 20px;
  opacity: 0.5;
}
@media (hover: hover) {
  .p-page-anchor__link:hover, .p-page-anchor__link.is-current {
    opacity: 1;
  }
  .p-page-anchor__link:hover:before, .p-page-anchor__link.is-current:before {
    height: 100%;
  }
}
.p-page-anchor__link:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 0;
  background: #004f9e;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}

.p-top .p-page {
  padding-top: 0;
}
.p-top-kv {
  position: relative;
  margin-bottom: min(200px, 15vw);
}
.p-top-kv__copy {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  z-index: 10;
}
@media screen and (max-width: 991px) {
  .p-top-kv__copy {
    padding: 5vw;
  }
}
@media screen and (min-width: 992px) {
  .p-top-kv__copy {
    padding: 40px;
  }
}
@media screen and (min-width: 1400px) {
  .p-top-kv__copy {
    padding: 80px;
  }
}
@media screen and (max-width: 767px) {
  .p-top-kv__copy {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.p-top-kv__copy-txt {
  position: relative;
  color: #fff;
  font-size: var(--fz5);
  font-weight: 500;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .p-top-kv__copy-txt {
    text-align: center;
  }
}
@media screen and (max-width: 575px) {
  .p-top-kv__copy-txt {
    font-size: 7vw;
  }
}
.p-top-kv__copy-txt:before, .p-top-kv__copy-txt:after {
  content: "";
  display: block;
  position: absolute;
  aspect-ratio: 1/1;
  background-size: cover;
  -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
  opacity: 0;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  opacity: 0;
}
.is-loaded .p-top-kv__copy-txt:before, .is-loaded .p-top-kv__copy-txt:after {
  opacity: 1;
  -webkit-filter: blur(0);
          filter: blur(0);
}
.p-top-kv__copy-txt:before {
  top: 0;
  left: 50%;
  width: 36px;
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf01.png");
}
@media screen and (max-width: 767px) {
  .p-top-kv__copy-txt:before {
    -webkit-transform: translate(-10%, -100%);
            transform: translate(-10%, -100%);
  }
}
.p-top-kv__copy-txt:after {
  bottom: 0;
  width: 85px;
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf03.png");
}
@media screen and (max-width: 767px) {
  .p-top-kv__copy-txt:after {
    right: 0;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
}
@media screen and (min-width: 768px) {
  .p-top-kv__copy-txt:after {
    left: 0;
    -webkit-transform: translate(-30%, 90%);
            transform: translate(-30%, 90%);
  }
}
@media screen and (min-width: 1400px) {
  .p-top-kv__copy-txt:after {
    -webkit-transform: translate(-20%, 110%);
            transform: translate(-20%, 110%);
  }
}
.p-top-kv__copy-txt span {
  display: block;
  translate: 0 2rem;
  opacity: 0;
  -webkit-transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
.is-loaded .p-top-kv__copy-txt span {
  translate: 0 0;
  opacity: 1;
}
.p-top-kv__video {
  position: relative;
  width: 100%;
}
@media screen and (max-width: 1399px) {
  .p-top-kv__video {
    height: 90vh;
  }
}
@media screen and (min-width: 1400px) {
  .p-top-kv__video {
    height: 100vh;
  }
}
.p-top-kv__video video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-top-kv__play {
  cursor: pointer;
  position: absolute;
  width: 140px;
  aspect-ratio: 1/1;
  border: none;
  background: none;
  outline: none;
  z-index: 10;
}
@media screen and (max-width: 991px) {
  .p-top-kv__play {
    right: 5vw;
    bottom: 5vw;
  }
}
@media screen and (max-width: 575px) {
  .p-top-kv__play {
    width: 100px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-kv__play {
    right: 40px;
    bottom: 40px;
  }
}
@media screen and (min-width: 1400px) {
  .p-top-kv__play {
    right: 80px;
    bottom: 80px;
  }
}
@media (hover: hover) {
  .p-top-kv__play:hover:after {
    background: #00a560;
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
}
.p-top-kv__play:after {
  overflow: hidden;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 100%;
  background: #004f9e;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.p-top-kv__play i {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1/1;
  background: url("/koa-wp/wp-content/uploads/2025/03/top-play-base.png");
  background-size: 100%;
  z-index: 2;
}
.p-top-kv__play i img {
  -webkit-transform-origin: center center;
          transform-origin: center center;
  -webkit-animation: rotate 8s linear infinite;
          animation: rotate 8s linear infinite;
}
@media screen and (min-width: 992px) {
  .p-top-news {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 80px;
  }
}
.p-top-news__head {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 991px) {
  .p-top-news__head {
    margin-bottom: min(40px, 5vw);
  }
}
@media screen and (min-width: 992px) {
  .p-top-news__main {
    -webkit-box-flex: 2;
        -ms-flex-positive: 2;
            flex-grow: 2;
    max-width: 880px;
  }
}
@media screen and (max-width: 991px) {
  .p-top-news__cat {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-news__cat {
    display: -ms-grid;
    display: grid;
    gap: 18px;
  }
}
.p-top-news__cat input {
  display: none;
}
.p-top-news__cat-item:has(input:checked) {
  color: #004f9e;
}
.p-top-news__cat-item:has(input:checked) label {
  opacity: 1;
}
.p-top-news__cat-item:has(input:checked) label:before {
  opacity: 1;
}
.p-top-news__cat-item label {
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6px;
  font-size: var(--fz-1);
  font-weight: 500;
  opacity: 0.6;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  .p-top-news__cat-item label:hover {
    opacity: 1;
  }
}
.p-top-news__cat-item label:before {
  content: "";
  display: block;
  width: 6px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
  opacity: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.p-top-news .p-news-list {
  display: none;
  opacity: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.p-top-news:has(input[id=tab-all]:checked) .p-top-news__main-all {
  display: block;
  opacity: 1;
}
.p-top-news:has(input[id=tab-info]:checked) .p-top-news__main-info {
  display: block;
  opacity: 1;
}
.p-top-news:has(input[id=tab-area]:checked) .p-top-news__main-area {
  display: block;
  opacity: 1;
}
.p-top-news:has(input[id=tab-recruit]:checked) .p-top-news__main-recruit {
  display: block;
  opacity: 1;
}
.p-top-news:has(input[id=tab-sustainability]:checked) .p-top-news__main-sustainability {
  display: block;
  opacity: 1;
}
@media screen and (max-width: 991px) {
  .p-top-contents {
    display: -ms-grid;
    display: grid;
    gap: 8vw;
    padding-inline: min(40px, 5vw);
  }
}
@media screen and (max-width: 991px) {
  .p-top-contents__item {
    padding-block: 40px;
    padding-inline: 5vw;
    border-radius: 40px;
    -webkit-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);
            box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);
  }
}
@media screen and (max-width: 767px) {
  .p-top-contents__item {
    padding-block: 30px;
    border-radius: 30px;
  }
}
@media screen and (max-width: 575px) {
  .p-top-contents__item {
    border-radius: 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__item {
    position: sticky;
    left: 0;
    padding-top: 50px;
    padding-inline: 40px;
    padding-bottom: min(200px, 15vw);
    border-radius: 50px 50px 0 0;
  }
}
@media screen and (min-width: 1400px) {
  .p-top-contents__item {
    padding-right: 80px;
    padding-left: calc((100% - 1200px) / 2);
  }
}
.p-top-contents__item:nth-of-type(odd) {
  background: #fff;
}
.p-top-contents__item:nth-of-type(even) {
  background: #eff1f5;
}
@media screen and (min-width: 992px) {
  .p-top-contents__item:nth-of-type(1) {
    top: 100px;
  }
}
@media screen and (min-width: 1200px) {
  .p-top-contents__item:nth-of-type(1) {
    top: 120px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__item:nth-of-type(2) {
    top: 150px;
  }
}
@media screen and (min-width: 1200px) {
  .p-top-contents__item:nth-of-type(2) {
    top: 200px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__item:nth-of-type(3) {
    top: 200px;
  }
}
@media screen and (min-width: 1200px) {
  .p-top-contents__item:nth-of-type(3) {
    top: 280px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__item:nth-of-type(4) {
    top: 250px;
  }
}
@media screen and (min-width: 1200px) {
  .p-top-contents__item:nth-of-type(4) {
    top: 360px;
  }
}
@media screen and (max-width: 991px) {
  .p-top-contents__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 50px;
  }
}
@media screen and (max-width: 767px) {
  .p-top-contents__inner {
    gap: 40px;
  }
}
@media screen and (max-width: 575px) {
  .p-top-contents__inner {
    gap: 30px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__inner {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 50px 50%;
    grid-template-columns: 1fr 50%;
    gap: 50px;
  }
}
@media screen and (min-width: 1200px) {
  .p-top-contents__inner {
    -ms-grid-columns: 1fr 70px 40%;
    grid-template-columns: 1fr 40%;
    gap: 70px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__main {
    padding-top: 50px;
  }
}
@media screen and (min-width: 1400px) {
  .p-top-contents__main {
    padding-top: 80px;
  }
}
.p-top-contents__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  margin-bottom: 1em;
  font-size: var(--fz4);
  font-weight: 500;
  line-height: 1;
}
.p-top-contents__ttl:before {
  content: "";
  display: block;
  height: 1.1em;
  aspect-ratio: 3/5;
  background: url("/koa-wp/wp-content/uploads/2025/03/contents-ttl-icon.png") no-repeat top left;
  background-size: cover;
}
.p-top-contents__en {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 5px;
  color: #004f9e;
  font-weight: 700;
  font-family: "Poppins", sans-serif;
  line-height: 0.7;
}
@media screen and (max-width: 991px) {
  .p-top-contents__en {
    margin-bottom: 1.5em;
    font-size: var(--fz-2);
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__en {
    position: absolute;
    top: 30px;
    left: 30px;
    font-size: var(--fz-1);
  }
}
@media screen and (min-width: 1400px) {
  .p-top-contents__en {
    left: 40px;
  }
}
@media screen and (max-width: 991px) {
  .p-top-contents__en i {
    font-size: var(--fz0);
  }
}
@media screen and (min-width: 992px) {
  .p-top-contents__en i {
    font-size: var(--fz1);
  }
}
.p-top-contents .c-btn {
  margin-top: min(40px, 5vw);
}
@media screen and (max-width: 991px) {
  .p-top-contents .c-btn {
    margin-inline: auto;
  }
}
.p-top-contents__img {
  overflow: hidden;
  border-radius: min(30px, 4vw);
}
.p-top-recruit__ttl {
  margin-bottom: 0.5em;
  font-weight: 500;
  font-family: "Poppins", sans-serif;
  text-align: center;
  line-height: 0.7;
}
@media screen and (max-width: 1199px) {
  .p-top-recruit__ttl {
    font-size: 8.5vw;
  }
}
@media screen and (min-width: 1200px) {
  .p-top-recruit__ttl {
    font-size: 6.25rem;
  }
}
.p-top-recruit__ttl span {
  color: #004f9e;
}
.p-top-recruit__copy {
  margin-bottom: 1em;
  font-size: var(--fz5);
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-top-recruit__copy {
    font-size: var(--fz3);
  }
}
.p-top-recruit .c-btn {
  margin-inline: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 991px) {
  .p-top-recruit .p-recruit-splide {
    margin-top: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-top-recruit .p-recruit-splide {
    margin-top: 10vw;
  }
}
@media screen and (min-width: 992px) {
  .p-top-recruit .p-recruit-splide {
    margin-top: 50px;
  }
}

@-webkit-keyframes rotate {
  from {
    -webkit-transform: rotateZ(0deg);
            transform: rotateZ(0deg);
  }
  to {
    -webkit-transform: rotateZ(360deg);
            transform: rotateZ(360deg);
  }
}

@keyframes rotate {
  from {
    -webkit-transform: rotateZ(0deg);
            transform: rotateZ(0deg);
  }
  to {
    -webkit-transform: rotateZ(360deg);
            transform: rotateZ(360deg);
  }
}
.p-page-header--news {
  padding-block: min(80px, 6vw);
  border-bottom: 1px solid #dbdad1;
}
.p-page-header--news:before, .p-page-header--news:after {
  display: none;
}
.p-page-header--news .p-page-header__title:before, .p-page-header--news .p-page-header__title:after {
  display: none;
}

@media screen and (min-width: 992px) {
  .p-news-column {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 80px;
  }
}
.p-news-sort {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 991px) {
  .p-news-sort {
    margin-bottom: min(40px, 5vw);
  }
}
@media screen and (min-width: 992px) {
  .p-news-sort {
    position: sticky;
    top: 120px;
    left: 0;
  }
}
.p-news-sort__ttl {
  margin-bottom: 20px;
  color: #004f9e;
  font-weight: 500;
  font-size: var(--fz-3);
  font-family: "Poppins", sans-serif;
  line-height: 0.7;
}
@media screen and (min-width: 992px) {
  .p-news-archive {
    -webkit-box-flex: 2;
        -ms-flex-positive: 2;
            flex-grow: 2;
    max-width: 880px;
  }
}
.p-news-list:has(.p-news-list__item) {
  border-top: 1px solid #dbdad1;
}
.p-news-list__item {
  border-bottom: 1px solid #dbdad1;
}
.p-news-list__link {
  position: relative;
  display: block;
  position: relative;
  padding-block: min(30px, 6vw);
}
@media (hover: hover) {
  .p-news-list__link {
    padding-right: 40px;
  }
}
@media screen and (min-width: 576px) {
  .p-news-list__link:has(.p-news-list__thumb) {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 150px 30px 1fr;
    grid-template-columns: 150px 1fr;
        grid-template-areas: "thumb main";
    gap: 30px;
  }
}
.p-news-list__link p {
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .p-news-list__link p {
    font-size: var(--fz-1);
  }
}
.p-news-list__main {
  grid-area: main;
}
@media screen and (min-width: 576px){
  .p-news-list__main {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
}
.p-news-list__desc {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 15px;
  margin-bottom: 20px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-news-list__desc {
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 575px) {
  .p-news-list__desc {
    margin-bottom: 10px;
  }
}
.p-news-list__date {
  font-size: var(--fz-2);
  font-family: "Poppins", sans-serif;
}
.p-news-list__ttl span {
  background-image: -webkit-gradient(linear, left top, right top, from(#484d4b), to(#484d4b));
  background-image: linear-gradient(90deg, #484d4b, #484d4b);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 0 1px;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  a:hover .p-news-list__ttl span {
    background-size: 100% 1px;
  }
}
@media screen and (max-width: 575px) {
  .p-news-list__thumb {
    display: none;
  }
}
@media screen and (min-width: 576px) {
  .p-news-list__thumb {
    overflow: hidden;
    width: 100%;
    aspect-ratio: 4/3;
    border-radius: 10px;
  }
}
.p-news-list__thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  a:hover .p-news-list__thumb img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.p-news-list__icon {
  display: none;
}
@media (hover: hover) {
  .p-news-list__icon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: absolute;
    right: 0;
    top: 50%;
    width: 29px;
    margin-top: -15px;
    aspect-ratio: 1/1;
    border-radius: 100%;
    background: #004f9e;
    -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
    transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
    -webkit-transform: scale(0.3);
            transform: scale(0.3);
  }
}
@media (hover: hover) {
  .p-news-list__link:hover .p-news-list__icon {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@media (hover: hover) {
  .p-news-list__icon svg {
    width: 11px;
    aspect-ratio: 1/1;
    fill: #fff;
    -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
    transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
    -webkit-transform: scale(0);
            transform: scale(0);
  }
}
@media (hover: hover) {
  .p-news-list__link:hover .p-news-list__icon svg {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
.p-news-filter {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
@media screen and (max-width: 991px) {
  .p-news-filter__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 20px;
    white-space: nowrap;
  }
}
@media screen and (min-width: 992px) {
  .p-news-filter__list {
    display: -ms-grid;
    display: grid;
    gap: 18px;
  }
}
.p-news-filter__list input {
  display: none;
}
.p-news-filter__item:has(input:checked, .is-current) {
  color: #004f9e;
}
.p-news-filter__item:has(input:checked, .is-current) label, .p-news-filter__item:has(input:checked, .is-current) a {
  opacity: 1;
}
.p-news-filter__item:has(input:checked, .is-current) label:before, .p-news-filter__item:has(input:checked, .is-current) a:before {
  opacity: 1;
}
.p-news-filter__item label, .p-news-filter__item a {
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6px;
  color: #484d4b !important;
  font-size: var(--fz-1);
  font-weight: 500;
  text-decoration: none !important;
  opacity: 0.6;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  .p-news-filter__item label:hover, .p-news-filter__item a:hover {
    opacity: 1;
  }
}
.p-news-filter__item label:before, .p-news-filter__item a:before {
  content: "";
  display: block;
  width: 6px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
  opacity: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.p-news-cat {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 24px;
  border-radius: 13px;
  border: 1px solid #004f9e;
  padding-inline: 1em;
  background: #fff;
  font-size: 0.6875rem;
}
.p-news-cat--info {
  border-color: #adac48;
  color: #adac48;
}
.p-news-cat--area {
  border-color: #004f9e;
  color: #004f9e;
}
.p-news-cat--recruit {
  border-color: #843aaa;
  color: #843aaa;
}
.p-news-cat--sustainability {
  border-color: #00a560;
  color: #00a560;
}
.p-news-article {
  max-width: 800px;
  margin-inline: auto;
}
.p-news-article__header {
  margin-bottom: min(50px, 8vw);
  padding-block: min(50px, 8vw);
  border-bottom: 1px solid #dbdad1;
}
.p-news-article__ttl {
  font-size: var(--fz3);
  font-weight: 500;
}
.p-news-article__eyecatch {
  margin-bottom: min(40px, 6vw);
  text-align: center;
}
.p-news-article__eyecatch img {
  max-height: 600px;
}
.p-news-article__txt p {
  line-height: 2;
}
.p-news-article__txt p, .p-news-article__txt li {
  letter-spacing: 0.15em;
}
.p-news-article__txt ul {
  display: -ms-grid;
  display: grid;
}
.p-news-article__txt ul:has(li) {
  gap: 0.5em;
}
.p-news-article__txt ul:not(:last-child) {
  margin-bottom: 1.6em;
}
.p-news-article__txt ul li {
  position: relative;
  padding-left: 15px;
  line-height: 1.6;
}
.p-news-article__txt ul li:before {
  position: absolute;
  display: block;
  content: "";
  top: 0.8em;
  left: 0;
  width: 6px;
  margin-top: -3px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
}
.p-news-article__txt h2:not(:first-child), .p-news-article__txt h3:not(:first-child), .p-news-article__txt h4:not(:first-child) {
  margin-top: 3em;
}
.p-news-article__txt h2 + h2, .p-news-article__txt h2 + h3, .p-news-article__txt h2 + h4, .p-news-article__txt h3 + h2, .p-news-article__txt h3 + h3, .p-news-article__txt h3 + h4, .p-news-article__txt h4 + h2, .p-news-article__txt h4 + h3, .p-news-article__txt h4 + h4 {
  margin-top: 0 !important;
}
@media screen and (max-width: 991px) {
  .p-recruit-splide .splide__slide {
    width: 40%;
    border-radius: 20px;
  }
}
@media screen and (max-width: 575px) {
  .p-recruit-splide .splide__slide {
    width: 60%;
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-splide .splide__slide {
    width: 400px;
    border-radius: 30px;
  }
}
@media screen and (max-width: 991px) {
  .p-recruit-splide .splide__slide:nth-of-type(even) {
    margin-top: 30px;
  }
}
@media screen and (max-width: 575px) {
  .p-recruit-splide .splide__slide:nth-of-type(even) {
    margin-top: 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-splide .splide__slide:nth-of-type(even) {
    margin-top: 50px;
  }
}
.p-recruit-splide .splide__slide span {
  display: block;
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .p-recruit-splide .splide__slide span {
    border-radius: 20px;
  }
}
@media screen and (max-width: 575px) {
  .p-recruit-splide .splide__slide span {
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-splide .splide__slide span {
    border-radius: 30px;
  }
}
.p-recruit-header {
  position: relative;
  margin-bottom: min(200px, 15vw);
}
@media screen and (min-width: 992px) {
  .p-recruit-header {
    padding-top: 70px;
  }
}
.p-recruit-header:before, .p-recruit-header:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  aspect-ratio: 1/1;
  background-size: cover;
  -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 0.8s;
          transition-delay: 0.8s;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  opacity: 0;
}
.is-loaded .p-recruit-header:before, .is-loaded .p-recruit-header:after {
  opacity: 1;
  -webkit-filter: blur(0);
          filter: blur(0);
}
.p-recruit-header:before {
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf03.png");
  -webkit-transform: translateY(80%);
          transform: translateY(80%);
}
@media screen and (max-width: 1279px) {
  .p-recruit-header:before {
    width: 12vw;
  }
}
@media screen and (max-width: 991px) {
  .p-recruit-header:before {
    width: 12vw;
    right: 5vw;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-header:before {
    right: 40px;
  }
}
@media screen and (min-width: 1280px) {
  .p-recruit-header:before {
    right: calc((100% - 1200px) / 2);
    width: 100px;
  }
}
.p-recruit-header:after {
  background-image: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/page-header-leaf04.png");
  -webkit-transform: translateY(15%);
          transform: translateY(15%);
}
@media screen and (max-width: 1279px) {
  .p-recruit-header:after {
    width: 15vw;
  }
}
@media screen and (max-width: 991px) {
  .p-recruit-header:after {
    left: 5vw;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-header:after {
    left: 40px;
  }
}
@media screen and (min-width: 1280px) {
  .p-recruit-header:after {
    left: calc((100% - 1200px) / 2);
    width: 125px;
  }
}
.p-recruit-header [class$=__title] {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 991px) {
  .p-recruit-header [class$=__title] {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-header [class$=__title] {
    width: 600px;
    margin-inline: auto;
    margin-bottom: 60px;
    padding: 0;
  }
}
.p-recruit-header [class$=__title]:before {
  top: auto;
  bottom: 0;
  left: 0;
  -webkit-transform: translate(-100%, 40%);
          transform: translate(-100%, 40%);
}
.p-recruit-header [class$=__title]:after {
  top: 0;
  left: auto;
  right: 0;
  -webkit-transform: translate(100%, 0) !important;
          transform: translate(100%, 0) !important;
}
.p-recruit-header [class$=__title-jp] {
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 991px) {
  .p-recruit-header [class$=__title-en] {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.p-recruit-message {
  position: relative;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}
@media screen and (max-width: 991px) {
  .p-recruit-message {
    display: -ms-grid;
    display: grid;
    gap: 8vw;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-message {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-message__txt {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 50%;
    padding-left: 4vw;
  }
}
@media screen and (min-width: 1400px) {
  .p-recruit-message__txt {
    padding-top: 20px;
    padding-left: 80px;
  }
}
.p-recruit-message__ttl {
  margin-bottom: 10px;
  color: #004f9e;
  font-size: var(--fz-2);
  font-weight: 500;
  line-height: 0.7;
}
.p-recruit-message__copy {
  margin-bottom: 1em;
  font-size: var(--fz3);
  font-weight: 500;
  line-height: 2;
}
.p-recruit-message__sign {
  text-align: right;
  margin-top: 2em;
  margin-right: 1.5em;
  line-height: 1;
}
@media screen and (max-width: 575px) {
  .p-recruit-message__sign {
    display: -ms-grid;
    display: grid;
    gap: 8px;
  }
}
@media screen and (max-width: 575px) {
  .p-recruit-message__sign small {
    font-size: var(--fz-1);
  }
}
@media screen and (min-width: 576px) {
  .p-recruit-message__sign small {
    margin-right: 10px;
  }
}
.p-recruit-message__sign em {
  font-family: "Shippori Mincho", serif;
  font-size: var(--fz2);
}
@media screen and (min-width: 992px) {
  .p-recruit-message__img {
    position: sticky;
    top: 120px;
    left: 0;
    width: 50%;
  }
}
.p-recruit-message__img figure {
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .p-recruit-message__img figure {
    border-radius: 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-message__img figure {
    position: relative;
    top: 0;
    left: 100%;
    width: calc(var(--body-width) / 2);
    border-radius: 0 30px 30px 0;
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
.p-recruit-job__header {
  margin-bottom: min(60px, 6vw);
}
@media screen and (min-width: 992px) {
  .p-recruit-job__header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 50px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-job__header [class$=__hgroup] {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-job__header .c-sentence {
    max-width: 700px;
  }
}
.p-recruit-job__list {
  display: -ms-grid;
  display: grid;
  gap: min(80px, 10vw);
}
@media screen and (min-width: 768px) {
  .p-recruit-job__list {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  }
}
.p-recruit-job__list .c-link-txt {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
}
.p-recruit-job__list .c-link-txt p {
  display: -ms-grid;
  display: grid;
  gap: 10px;
  font-weight: 500;
  line-height: 1;
}
.p-recruit-job__list .c-link-txt p small {
  color: #004f9e;
  font-family: "Poppins", sans-serif;
  text-transform: uppercase;
  font-size: var(--fz-2);
  letter-spacing: 0.05em;
}
.p-recruit-job__list .c-link-txt p span {
  font-size: var(--fz3);
}
.p-recruit-job__list__img {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 3/2;
  border-radius: 10px;
  -webkit-transform: scale(1);
          transform: scale(1);
}
.p-recruit-job__list__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  a:hover .p-recruit-job__list__img img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.p-recruit-attempt {
  position: relative;
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg-multiply.png") repeat;
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt {
    padding-block: 10vw;
  }
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt__main {
    margin-bottom: 10vw;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__main {
    padding-block: 10vw;
  }
}
@media screen and (min-width: 1400px) {
  .p-recruit-attempt__main {
    padding-block: 200px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__main-inner {
    width: 50%;
  }
}
.p-recruit-attempt__slide {
  overflow: hidden;
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt__slide {
    gap: 15px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__slide {
    -ms-grid-columns: 1fr 20px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    position: absolute;
    top: 0;
    right: 30px;
    width: 40%;
    height: 100%;
  }
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt__slide-left, .p-recruit-attempt__slide-right {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 15px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__slide-left, .p-recruit-attempt__slide-right {
    display: -ms-grid;
    display: grid;
    gap: 20px;
  }
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt__slide-left ul {
    -webkit-animation-name: ltr;
            animation-name: ltr;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__slide-left ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-animation-name: ttb;
            animation-name: ttb;
  }
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt__slide-right ul {
    -webkit-animation-name: rtl;
            animation-name: rtl;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__slide-right ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-animation-name: btt;
            animation-name: btt;
  }
}
.p-recruit-attempt__slide ul {
  margin: 0 !important;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt__slide ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 15px;
    -webkit-animation-duration: 50s;
            animation-duration: 50s;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__slide ul {
    display: -ms-grid;
    display: grid;
    gap: 20px;
    -webkit-animation-duration: 30s;
            animation-duration: 30s;
  }
}
@media screen and (min-width: 1200px) {
  .p-recruit-attempt__slide ul {
    -webkit-animation-duration: 40s;
            animation-duration: 40s;
  }
}
.p-recruit-attempt__slide-item {
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .p-recruit-attempt__slide-item {
    width: 150px;
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-attempt__slide-item {
    border-radius: 20px;
  }
}
@media screen and (min-width: 1200px) {
  .p-recruit-attempt__slide-item {
    border-radius: 30px;
  }
}
.p-recruit-interview {
  overflow: hidden;
}
.p-recruit-interview__slide {
  position: relative;
  margin-top: min(50px, 6vw);
}
@media screen and (max-width: 575px) {
  .p-recruit-interview__slide {
    padding-top: 60px;
  }
}
@media screen and (min-width: 576px) {
  .p-recruit-interview__slide {
    padding-top: 80px;
  }
}
.p-recruit-interview__slide .splide__track {
  overflow: visible;
}
.p-recruit-interview__slide .splide__pagination {
  position: static;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 8px;
  padding: 0;
}
.p-recruit-interview__slide .splide__pagination__page {
  width: 25px;
  height: 6px;
  margin: 0;
  border-radius: 3px;
  background: #dbdad1;
  opacity: 1;
}
.p-recruit-interview__slide .splide__pagination__page.is-active {
  -webkit-transform: scale(1);
          transform: scale(1);
  background: #004f9e;
}
.p-recruit-interview__slide .splide__arrows {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px;
}
.p-recruit-interview__slide .splide__arrow {
  position: static;
  width: 60px;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #fff;
  border: 1px solid #004f9e;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media screen and (max-width: 575px) {
  .p-recruit-interview__slide .splide__arrow {
    width: 50px;
  }
}
.p-recruit-interview__slide .splide__arrow svg {
  fill: #004f9e;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  .p-recruit-interview__slide .splide__arrow:hover {
    background: #004f9e;
  }
  .p-recruit-interview__slide .splide__arrow:hover svg {
    fill: #fff;
  }
}
.p-recruit-interview__ctrl {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 30px;
  width: 100%;
}
@media screen and (max-width: 991px) {
  .p-recruit-interview__item {
    width: 50%;
  }
}
@media screen and (max-width: 767px) {
  .p-recruit-interview__item {
    width: 60%;
  }
}
@media screen and (max-width: 413px) {
  .p-recruit-interview__item {
    width: 80%;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-interview__item {
    width: 400px;
  }
}
.p-recruit-interview__item:nth-of-type(odd) [class$=__link] {
  margin-top: 50px;
}
.p-recruit-interview__link {
  display: block;
}
@media (hover: hover) {
  .p-recruit-interview__link:hover img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.p-recruit-interview__img {
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-recruit-interview__img {
    border-radius: 10px 10px 0 10px;
  }
}
@media screen and (min-width: 768px) {
  .p-recruit-interview__img {
    border-radius: 15px 15px 0 15px;
  }
}
.p-recruit-interview__meta {
  position: absolute;
  right: 0;
  bottom: 0;
  display: -ms-grid;
  display: grid;
  gap: 10px;
  min-width: 67.5%;
  padding: 30px 10px 10px 20px;
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg.png") repeat;
  border-radius: 15px 0 0 0;
}
.p-recruit-interview__meta * {
  line-height: 1;
  font-weight: 500;
}
.p-recruit-interview__join {
  position: absolute;
  top: 0;
  left: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 2.2em;
  padding-top: 2px;
  padding-inline: 1em;
  background: #004f9e;
  border-radius: 6px;
  color: #fff;
  font-size: var(--fz-2);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.p-recruit-interview__name span {
  font-size: var(--fz1);
}
.p-recruit-interview__name small {
  font-size: var(--fz-2);
}
.p-recruit-interview__post {
  font-size: var(--fz-2);
}
.p-recruit-interview__lead {
  margin-top: 1em;
  font-weight: 500;
  font-size: var(--fz2);
}
.p-recruit-entry {
  position: relative;
  padding-block: min(100px, 15vw);
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg-multiply.png") repeat;
}
.p-recruit-entry__ttl {
  position: absolute;
  top: 0;
  left: 50%;
  color: #004f9e;
  font-family: "Poppins", sans-serif;
  font-size: clamp(2.5658rem, 1.0941rem + 6.2792vw, 5.9605rem);
  font-weight: 500;
  line-height: 0.7;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.p-recruit-entry__lead {
  margin-bottom: 1em;
  font-size: var(--fz2);
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 575px) {
  .p-recruit-entry__lead {
    font-size: var(--fz1);
  }
}
.p-recruit-entry__list {
  display: -ms-grid;
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-recruit-entry__list {
    gap: 30px;
    max-width: 350px;
    margin-inline: auto;
  }
}
@media screen and (min-width: 768px) {
  .p-recruit-entry__list {
    -ms-grid-columns: 1fr 30px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
  }
}
@media screen and (min-width: 992px) {
  .p-recruit-entry__list {
    -ms-grid-columns: (1fr)[3];
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 1200px) {
  .p-recruit-entry__list {
    -ms-grid-columns: 350px 40px 350px 40px 350px;
    grid-template-columns: repeat(3, 350px);
    gap: 40px;
  }
}
.p-recruit-entry__link {
  display: block;
  text-align: center;
}
@media (hover: hover) {
  .p-recruit-entry__link:hover [class$=__logo] {
    border-color: #004f9e;
  }
}
.p-recruit-entry__logo {
  width: 100%;
  aspect-ratio: 7/4;
  padding: 50px;
  border: 1px solid #dbdad1;
  background: #fff;
  border-radius: 15px;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
.p-recruit-entry__logo img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-recruit-entry__txt {
  margin-top: 0.8em;
  font-size: var(--fz1);
  font-weight: 500;
  line-height: 1.3;
}
.p-recruit-entry + .p-page-navi {
  margin-top: 0;
  border-top: 1px solid #dbdad1;
}

@-webkit-keyframes ttb {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}

@keyframes ttb {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@-webkit-keyframes btt {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes btt {
  0% {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes ltr {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes ltr {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  100% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes rtl {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes rtl {
  0% {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
.p-interview-header {
  margin-bottom: min(150px, 10vw);
  padding-top: min(50px, 5vw);
}
.p-interview-header__lead {
  margin-bottom: 1em;
  font-size: var(--fz4);
  font-weight: 500;
  line-height: 1.8;
  translate: 0 2rem;
  opacity: 0;
  -webkit-transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
@media screen and (max-width: 575px) {
  .p-interview-header__lead {
    font-size: var(--fz3);
  }
}
.is-loaded .p-interview-header__lead {
  translate: 0 0;
  opacity: 1;
}
.p-interview-header__meta {
  display: -ms-grid;
  display: grid;
  gap: 20px;
  margin-bottom: min(50px, 5vw);
  translate: 0 2rem;
  opacity: 0;
  -webkit-transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 1.4s;
          transition-delay: 1.4s;
}
.is-loaded .p-interview-header__meta {
  translate: 0 0;
  opacity: 1;
}
.p-interview-header__join {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 2.2em;
  margin-bottom: 15px;
  padding-top: 2px;
  padding-inline: 1em;
  background: #004f9e;
  border-radius: 6px;
  color: #fff;
  font-size: var(--fz-2);
}
.p-interview-header__name {
  font-weight: 500;
  line-height: 1;
}
.p-interview-header__name span {
  font-size: var(--fz3);
  font-weight: 400;
}
@media screen and (max-width: 575px) {
  .p-interview-header__name span {
    font-size: var(--fz2);
  }
}
.p-interview-header__name small {
  font-size: var(--fz0);
}
@media screen and (max-width: 575px) {
  .p-interview-header__name small {
    font-size: var(--fz-1);
  }
}
.p-interview-header__post {
  line-height: 1;
}
@media screen and (max-width: 575px) {
  .p-interview-header__post {
    font-size: var(--fz-1);
  }
}
@media screen and (max-width: 767px) {
  .p-interview-header__img {
    position: relative;
    width: 100vw;
    left: 50%;
    margin-left: -50vw;
  }
}
@media screen and (min-width: 768px) {
  .p-interview-header__img {
    overflow: hidden;
    border-radius: 30px;
  }
}
.p-interview-header__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top center;
     object-position: top center;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  opacity: 0;
  -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
.is-loaded .p-interview-header__img img {
  -webkit-transform: scale(1);
          transform: scale(1);
  opacity: 1;
}
.p-interview-question__item {
  display: -ms-grid;
  display: grid;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: start;
}
@media screen and (max-width: 575px) {
  .p-interview-question__item {
    gap: 30px;
  }
}
@media screen and (min-width: 576px) {
  .p-interview-question__item {
    gap: 40px;
  }
}
@media screen and (min-width: 992px) {
  .p-interview-question__item {
    -ms-grid-columns: 1fr 50px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 50px;
  }
}
@media screen and (min-width: 1200px) {
  .p-interview-question__item {
    gap: 60px;
  }
}
@media screen and (min-width: 1400px) {
  .p-interview-question__item {
    gap: 80px;
  }
}
@media screen and (min-width: 768px) and (min-width: 992px) {
  .p-interview-question__item:nth-of-type(odd) div {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
@media screen and (min-width: 768px) and (min-width: 992px) {
  .p-interview-question__item:nth-of-type(odd) [class$=img] {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
.p-interview-question__item + .p-page-article {
  margin-top: min(100px, 15vw);
}
.p-interview-question__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px;
  margin-bottom: 0.6em;
  color: #004f9e;
  font-size: var(--fz2);
  font-weight: 500;
  line-height: 1.4;
}
.p-interview-question__ttl i {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-family: "Poppins", sans-serif;
}
.p-interview-question__img {
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-interview-question__img {
    border-radius: 15px;
  }
}
@media screen and (min-width: 768px) {
  .p-interview-question__img {
    border-radius: 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-interview-question__img {
    border-radius: 30px;
  }
}
@media screen and (min-width: 992px) {
  .p-interview-schedule {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: start;
    gap: 60px;
  }
}
@media screen and (min-width: 1200px) {
  .p-interview-schedule {
    gap: 80px;
    padding: 60px;
  }
}
@media screen and (min-width: 1400px) {
  .p-interview-schedule {
    gap: 100px;
    padding: 80px;
  }
}
.p-interview-schedule [class$=section__hgroup] {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.p-interview-schedule [class$=section__ttl] {
  font-size: var(--fz3);
  line-height: 1;
}
.p-interview-schedule__list {
  border-top: 1px solid #d0cec3;
}
@media screen and (min-width: 992px) {
  .p-interview-schedule__list {
    -webkit-box-flex: 2;
        -ms-flex-positive: 2;
            flex-grow: 2;
  }
}
.p-interview-schedule__item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 25px;
  border-bottom: 1px solid #d0cec3;
}
@media screen and (max-width: 767px) {
  .p-interview-schedule__item {
    padding-inline: 0;
  }
}
.p-interview-schedule__item:first-child:after, .p-interview-schedule__item:last-child:after {
  height: 50%;
}
.p-interview-schedule__item:first-child:after {
  top: 50%;
}
.p-interview-schedule__item:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 55px;
  width: 10px;
  height: 100%;
  margin-left: -5px;
  background: #e3e4e4;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-interview-schedule__item:after {
    left: 20px;
  }
}
.p-interview-schedule__icon {
  position: relative;
  width: 60px;
  aspect-ratio: 1/1;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .p-interview-schedule__icon {
    width: 40px;
  }
}
.p-interview-schedule__icon:before, .p-interview-schedule__icon:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  aspect-ratio: 1/1;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  border-radius: 100%;
}
.p-interview-schedule__icon:before {
  width: 30px;
  background: #004f9e;
}
.p-interview-schedule__icon:after {
  width: 10px;
  background: #fff;
}
.p-interview-schedule__time {
  width: 6em;
  margin-left: 20px;
  color: #004f9e;
  font-size: var(--fz1);
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .p-interview-schedule__time {
    width: 4em;
    margin-left: 10px;
  }
}
.p-interview-schedule__txt {
  font-weight: 500;
}
.p-interview-list {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 575px) {
  .p-interview-list {
    gap: 30px;
  }
}
@media screen and (min-width: 576px) {
  .p-interview-list {
    gap: 40px;
  }
}
@media screen and (min-width: 768px) {
  .p-interview-list {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1200px) {
  .p-interview-list {
    -ms-grid-columns: 1fr 50px 1fr 50px 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: 50px;
  }
}
.p-interview-list .p-recruit-interview__item {
  width: 100%;
}
.p-interview-list .p-recruit-interview__lead {
  font-size: var(--fz1);
}

.p-works-shift table {
  width: 100%;
}
.p-works-shift th, .p-works-shift td {
  white-space: nowrap;
  font-size: var(--fz-1);
  font-weight: 500;
  text-align: center;
}
.p-works-shift thead th {
  padding-inline: 5px;
  padding-bottom: 0.5em;
}
.p-works-shift thead th.sat {
  color: #004b84;
}
.p-works-shift thead th.sun {
  color: #ad0306;
}
.p-works-shift thead th small {
  display: block;
  font-size: var(--fz-3);
}
.p-works-shift tbody th {
  width: 3em;
  padding-right: 1em;
  text-align: left;
}
.p-works-shift td {
  padding: 1px;
  line-height: 1;
}
.p-works-shift td span {
  display: block;
  padding: 0.6em;
  border-radius: 4px;
  color: #fff;
}
@media screen and (min-width: 992px) {
  .p-works-shift td span {
    padding-block: 1em;
  }
}
.p-works-shift td .morning {
  background: #39C;
}
.p-works-shift td .day {
  background: #FA9C57;
}
.p-works-shift td .night {
  background: #676696;
}
.p-works-shift__merit {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 575px) {
  .p-works-shift__merit {
    gap: 20px;
  }
}
@media screen and (min-width: 576px) {
  .p-works-shift__merit {
    -ms-grid-columns: 1fr 30px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
  }
}
@media screen and (min-width: 768px) {
  .p-works-shift__merit {
    -ms-grid-columns: 1fr 40px 1fr 40px 1fr;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
  }
}
.p-works-shift__merit-item {
  display: -ms-grid;
  display: grid;
  gap: 20px;
  padding: min(40px, 8vw);
  border-radius: 30px;
  background: #fff;
  text-align: center;
}
.p-works-shift__merit-item h4 {
  color: #004f9e;
  font-size: var(--fz1);
  font-weight: 500;
}
.p-works-shift__merit-item i {
  width: 100%;
  max-width: 100px;
  margin-inline: auto;
}

.p-attempt-training th, .p-attempt-training td {
  vertical-align: middle;
  white-space: nowrap;
}
@media screen and (max-width: 575px) {
  .p-attempt-training th, .p-attempt-training td {
    font-size: var(--fz-1);
  }
}
.p-attempt-training thead th {
  text-align: center;
}

.p-vision-header--project {
  margin-bottom: min(80px, 8vw);
}
.p-vision-header__title {
  position: relative;
  font-weight: 500;
  line-height: 1;
  padding-block: min(50px, 8vw);
}
@media screen and (max-width: 991px) {
  .p-vision-header__title {
    padding-inline: min(40px, 5vw);
  }
}
@media screen and (min-width: 992px) {
  .p-vision-header__title {
    padding-left: 40px;
  }
}
@media screen and (min-width: 1400px) {
  .p-vision-header__title {
    padding-left: 80px;
  }
}
.p-vision-header__title-jp, .p-vision-header__title-en {
  translate: 0 2rem;
  opacity: 0;
  -webkit-transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.is-loaded .p-vision-header__title-jp, .is-loaded .p-vision-header__title-en {
  translate: 0 0;
  opacity: 1;
}
.p-vision-header__title-jp {
  font-size: var(--fz5);
  font-weight: 500;
  -webkit-transition-delay: 1.4s;
          transition-delay: 1.4s;
}
@media screen and (max-width: 575px) {
  .p-vision-header__title-jp {
    font-size: var(--fz4);
  }
}
.p-vision-header__title-en {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  margin-bottom: 1.5em;
  color: #004f9e;
  font-size: var(--fz-1);
  font-weight: 700;
  font-family: "Poppins", sans-serif;
  text-transform: uppercase;
  line-height: 0.8em;
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
@media screen and (max-width: 767px) {
  .p-vision-header__title-en {
    font-size: var(--fz-2);
  }
}
@media screen and (max-width: 575px) {
  .p-vision-header__title-en {
    font-size: var(--fz-3);
    line-height: 1;
  }
}
.p-vision-intro {
  overflow: hidden;
  background: url("/koa-wp/wp-content/uploads/2025/03/vision-intro-bg.png") no-repeat left bottom #2a659d;
  background-size: 100%;
  padding-bottom: 45vw;
}
.p-vision-intro__img {
  position: relative;
  margin-bottom: min(200px, 15vw);
}
@media screen and (max-width: 991px) {
  .p-vision-intro__img {
    padding-left: min(40px, 5vw);
  }
}
@media screen and (min-width: 992px) {
  .p-vision-intro__img {
    padding-left: 40px;
  }
}
@media screen and (min-width: 1400px) {
  .p-vision-intro__img {
    padding-left: 80px;
  }
}
.p-vision-intro__img:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
  background: url("/koa-wp/wp-content/themes/koa-kogyo/assets/images/bg.png") repeat;
}
.p-vision-intro__img span {
  display: block;
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .p-vision-intro__img span {
    border-radius: 20px 0 0 20px;
  }
}
@media screen and (max-width: 575px) {
  .p-vision-intro__img span {
    border-radius: 10px 0 0 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-vision-intro__img span {
    border-radius: 30px 0 0 30px;
  }
}
.p-vision-intro__img img {
  position: relative;
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  opacity: 0;
  -webkit-transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition: all 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
  z-index: 5;
}
.is-loaded .p-vision-intro__img img {
  -webkit-transform: scale(1);
          transform: scale(1);
  opacity: 1;
}
.p-vision-intro__main {
  padding-inline: min(40px, 5vw);
  text-align: center;
}
.p-vision-intro__main h2 {
  margin-bottom: 5em;
  color: #fff;
  font-size: var(--fz-1);
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  text-align: center;
  -webkit-transition-duration: 0.6s;
          transition-duration: 0.6s;
}
@media screen and (max-width: 575px) {
  .p-vision-intro__main h2 {
    margin-bottom: 3em;
    font-size: var(--fz-2);
  }
}
.p-vision-intro__main p {
  display: -ms-grid;
  display: grid;
  gap: 1.5em;
  color: #fff;
  font-size: var(--fz4);
  font-weight: 500;
  letter-spacing: 0.15em;
  line-height: 1;
}
@media screen and (max-width: 413px) {
  .p-vision-intro__main p {
    font-size: var(--fz3);
  }
}
.p-vision-intro__main span {
  text-align: center;
  -webkit-transition-duration: 0.6s;
          transition-duration: 0.6s;
}
.p-vision-mission .p-page-container {
  margin-bottom: min(150px, 10vw);
}
@media screen and (min-width: 992px) {
  .p-vision-mission .p-page-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 100px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
.p-vision-mission__ttl {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  color: #004f9e;
  font-size: var(--fz-1);
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}
@media screen and (max-width: 991px) {
  .p-vision-mission__ttl {
    margin-bottom: 1em;
  }
}
@media screen and (max-width: 413px) {
  .p-vision-mission__ttl {
    font-size: var(--fz-2);
  }
}
.p-vision-mission__list {
  display: -ms-grid;
  display: grid;
  gap: 1.5em;
  font-size: var(--fz1);
}
@media screen and (max-width: 767px) {
  .p-vision-mission__list br {
    display: none;
  }
}
@media screen and (max-width: 413px) {
  .p-vision-mission__list {
    font-size: var(--fz0);
  }
}
.p-vision-mission__item {
  position: relative;
  color: #fff;
  letter-spacing: 0.15em;
  line-height: 2;
  -webkit-transition-duration: 0.6s !important;
          transition-duration: 0.6s !important;
}
.p-vision-mission__img {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 3/1;
}
.p-vision-mission__img.is-inview img {
  clip-path: inset(0);
  opacity: 1;
}
.p-vision-mission__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center 60%;
     object-position: center 60%;
  clip-path: inset(0 20%);
  opacity: 0;
  -webkit-transition: all 0.6s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.6s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.p-vision-epilogue p {
  display: -ms-grid;
  display: grid;
  gap: 1.5em;
  font-size: var(--fz4);
  font-weight: 500;
  letter-spacing: 0.15em;
  line-height: 1;
}
@media screen and (max-width: 413px) {
  .p-vision-epilogue p {
    font-size: var(--fz3);
  }
}
.p-vision-epilogue p span {
  text-align: center;
  -webkit-transition-duration: 0.6s;
          transition-duration: 0.6s;
}
.p-vision-splide {
  margin-top: min(100px, 8vw);
}
.p-vision-splide .splide__slide {
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .p-vision-splide .splide__slide {
    width: 40%;
    border-radius: 20px;
  }
}
@media screen and (max-width: 575px) {
  .p-vision-splide .splide__slide {
    width: 60%;
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-vision-splide .splide__slide {
    width: 400px;
    border-radius: 30px;
  }
}
.p-vision-message {
  background: #fff;
  padding-block: min(100px, 10vw);
}
.p-vision-message__intro {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .p-vision-message__intro {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    gap: 30px;
  }
}
@media screen and (min-width: 768px) {
  .p-vision-message__intro {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 40px;
  }
}
@media screen and (min-width: 992px) {
  .p-vision-message__intro {
    gap: 60px;
  }
}
@media screen and (min-width: 1200px) {
  .p-vision-message__intro {
    gap: 80px;
  }
}
.p-vision-message__intro-txt {
  -webkit-box-flex: 2;
      -ms-flex-positive: 2;
          flex-grow: 2;
}
.p-vision-message__ttl {
  margin-bottom: 1em;
  color: #004f9e;
  font-size: var(--fz-2);
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}
.p-vision-message__lead {
  margin-bottom: 1em;
  font-size: var(--fz3);
  font-weight: 500;
  line-height: 2;
}
.p-vision-message__name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 6px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-vision-message__name {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
.p-vision-message__name small {
  font-size: var(--fz-1);
  font-weight: 500;
}
.p-vision-message__name span {
  font-size: var(--fz2);
  font-weight: 500;
  font-family: "Shippori Mincho", serif;
}
.p-vision-message__img {
  overflow: hidden;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 991px) {
  .p-vision-message__img {
    border-radius: 20px;
  }
}
@media screen and (max-width: 575px) {
  .p-vision-message__img {
    border-radius: 10px;
  }
}
@media screen and (min-width: 768px) {
  .p-vision-message__img {
    width: 45%;
  }
}
@media screen and (min-width: 992px) {
  .p-vision-message__img {
    border-radius: 30px;
  }
}
.p-vision-message__txt {
  margin-top: min(80px, 10vw);
}
.p-vision-message__txt p {
  letter-spacing: 0.15em;
  line-height: 2;
}
.p-vision-project__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #004f9e;
}
@media screen and (max-width: 991px) {
  .p-vision-project__inner {
    max-width: 800px;
    margin-inline: auto;
    border-radius: 20px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (max-width: 575px) {
  .p-vision-project__inner {
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-vision-project__inner {
    border-radius: 30px;
  }
}
@media screen and (max-width: 991px) {
  .p-vision-project__txt {
    padding-block: 10vw;
  }
}
@media screen and (min-width: 992px) {
  .p-vision-project__txt {
    -webkit-box-flex: 2;
        -ms-flex-positive: 2;
            flex-grow: 2;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.p-vision-project__txt &gt; div {
  position: relative;
}
.p-vision-project__badge {
  position: absolute;
  top: 0;
}
@media screen and (max-width: 575px) {
  .p-vision-project__badge {
    left: 50%;
    margin-left: -50px;
    -webkit-transform: translateY(-105%);
            transform: translateY(-105%);
  }
}
@media screen and (max-width: 413px) {
  .p-vision-project__badge {
    width: 80px;
    margin-left: -40px;
  }
}
@media screen and (min-width: 414px) {
  .p-vision-project__badge {
    width: 100px;
  }
}
@media screen and (min-width: 576px) {
  .p-vision-project__badge {
    -webkit-transform: translate(calc(-100% - 10px), -10%);
            transform: translate(calc(-100% - 10px), -10%);
    left: 0;
  }
}
@media screen and (max-width: 575px) {
  .p-vision-project__badge:after {
    display: none;
  }
}
.p-vision-project__label {
  margin-bottom: 1em;
  color: #fff;
  font-size: var(--fz-2);
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}
@media screen and (max-width: 991px) {
  .p-vision-project__label {
    text-align: center;
  }
}
.p-vision-project__ttl {
  color: #fff;
  font-size: var(--fz4);
  font-weight: 500;
}
@media screen and (max-width: 991px) {
  .p-vision-project__ttl {
    text-align: center;
  }
}
@media screen and (max-width: 991px) {
  .p-vision-project__img {
    height: 70vw;
    padding-inline: 20px;
  }
  .p-vision-project__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (max-width: 575px) {
  .p-vision-project__img {
    max-height: 300px;
    padding-inline: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-vision-project__img {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 45%;
    padding-right: 30px;
  }
}
.p-vision-project .c-btn {
  margin-top: 30px;
  border: 1px solid #fff;
}
@media screen and (max-width: 991px) {
  .p-vision-project .c-btn {
    margin-inline: auto;
  }
}
@media screen and (max-width: 413px) {
  .p-vision-project .c-btn {
    width: 80%;
  }
}
@media (hover: hover) {
  .p-vision-project .c-btn:hover {
    background: #004f9e;
    color: #fff;
  }
  .p-vision-project .c-btn:hover svg {
    fill: #fff;
  }
}
.p-vision-project__video {
  max-width: 800px;
  margin-inline: auto;
}
.p-vision-project__video iframe {
  width: 100%;
  aspect-ratio: 16/9;
}
.p-vision-end {
  overflow: hidden;
  background: url("/koa-wp/wp-content/uploads/2025/03/vision-project-bg.png") no-repeat left bottom #48b9e4;
  background-size: 100%;
  padding-top: min(150px, 15vw);
  padding-bottom: 30vw;
}
.p-vision-end__main {
  text-align: center;
}
.p-vision-end__main p {
  display: -ms-grid;
  display: grid;
  gap: 1.5em;
  color: #fff;
  font-size: var(--fz4);
  font-weight: 500;
  letter-spacing: 0.15em;
  line-height: 1;
}
@media screen and (max-width: 413px) {
  .p-vision-end__main p {
    font-size: var(--fz3);
  }
}
.p-vision-end__main span {
  text-align: center;
  -webkit-transition-duration: 0.6s;
          transition-duration: 0.6s;
}
.p-vision-figcaption {
  margin-top: 10px;
  text-align: right;
}
.p-vision-figcaption small {
  font-size: var(--fz-2);
}

@media screen and (min-width: 992px) {
  .p-company-philosophy {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 100px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
  }
}
@media screen and (min-width: 992px) {
  .p-company-philosophy .p-page-section__hgroup {
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}
@media screen and (min-width: 992px) {
  .p-company-philosophy__txt {
    -webkit-box-flex: 2;
        -ms-flex-positive: 2;
            flex-grow: 2;
  }
}
.p-company-list {
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: min(50px, 10vw);
}
.p-company-list .c-link-txt {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
}
.p-company-list .c-link-txt p {
  display: -ms-grid;
  display: grid;
  gap: 7px;
  font-weight: 500;
  line-height: 1;
}
.p-company-list .c-link-txt p small {
  color: #004f9e;
  font-family: "Poppins", sans-serif;
  text-transform: uppercase;
  font-size: var(--fz-2);
  letter-spacing: 0.05em;
}
.p-company-list .c-link-txt p span {
  font-size: var(--fz1);
}
.p-company-list__img {
  overflow: hidden;
  width: 100%;
  aspect-ratio: 3/2;
  border-radius: 10px;
  -webkit-transform: scale(1);
          transform: scale(1);
}
.p-company-list__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
@media (hover: hover) {
  a:hover .p-company-list__img img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.p-company-message {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 992px) {
  .p-company-message {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
.p-company-message__img {
  overflow: hidden;
  border-radius: 0 30px 30px 0;
}
@media screen and (max-width: 991px) {
  .p-company-message__img {
    margin-right: 5vw;
  }
}
@media screen and (min-width: 992px) {
  .p-company-message__img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
@media screen and (max-width: 991px) {
  .p-company-message__txt {
    padding: 5vw;
    padding-bottom: 0;
  }
}
@media screen and (min-width: 992px) {
  .p-company-message__txt {
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media screen and (min-width: 1200px) {
  .p-company-message__txt {
    padding-left: 50px;
  }
}
@media screen and (min-width: 1280px) {
  .p-company-message__txt {
    padding-right: calc((var(--body-width) - 1200px) / 2);
  }
}
@media screen and (min-width: 1400px) {
  .p-company-message__txt {
    padding-left: 80px;
  }
}
.p-company-message .c-sentence {
  line-height: 2.5;
  letter-spacing: 0.15em;
}
.p-company-message__sign {
  text-align: right;
  margin-top: 2em;
  line-height: 1;
}
@media screen and (max-width: 575px) {
  .p-company-message__sign {
    display: -ms-grid;
    display: grid;
    gap: 8px;
  }
}
@media screen and (max-width: 575px) {
  .p-company-message__sign small {
    font-size: var(--fz-1);
  }
}
@media screen and (min-width: 576px) {
  .p-company-message__sign small {
    margin-right: 10px;
  }
}
.p-company-message__sign em {
  font-family: "Shippori Mincho", serif;
  font-size: var(--fz2);
}

.p-outline-table {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .p-outline-table {
    border-top: 1px solid #dbdad1;
    border-left: 1px solid #dbdad1;
  }
}
@media screen and (min-width: 768px) {
  .p-outline-table tr:first-child th {
    border-top: 1px solid #004f9e;
  }
}
@media screen and (min-width: 768px) {
  .p-outline-table tr:first-child td {
    border-top: 1px solid #dbdad1;
  }
}
.p-outline-table th, .p-outline-table td {
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .p-outline-table th, .p-outline-table td {
    display: block;
    padding: 1em;
    border-bottom: 1px solid #dbdad1;
    border-right: 1px solid #dbdad1;
    font-size: var(--fz-1);
  }
}
@media screen and (min-width: 768px) {
  .p-outline-table th, .p-outline-table td {
    padding-block: 30px;
  }
}
.p-outline-table th {
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .p-outline-table th {
    background: rgba(0, 0, 0, 0.05);
  }
}
@media screen and (min-width: 768px) {
  .p-outline-table th {
    padding-right: 80px;
    border-bottom: 1px solid #004f9e;
  }
}
.p-outline-table td {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-outline-table td {
    padding-left: 50px;
    border-bottom: 1px solid #dbdad1;
  }
}
@media screen and (max-width: 575px) {
  .p-outline-table td .separate {
    display: none;
  }
}
@media screen and (min-width: 576px) {
  .p-outline-table td .separate {
    display: inline-block;
    width: 1px;
    height: 1em;
    margin-inline: 0.5em;
    background: #484d4b;
    -webkit-transform: rotate(15deg);
            transform: rotate(15deg);
    vertical-align: middle;
  }
}
.p-outline-table .c-link-txt {
  margin-top: 0;
}
.p-outline-office dt:not(:first-child) {
  border-top: 1px dotted #dbdad1;
}
@media screen and (max-width: 767px) {
  .p-outline-office dt:not(:first-child) {
    margin-top: 1em;
    padding-top: 1em;
  }
}
@media screen and (min-width: 768px) {
  .p-outline-office dt:not(:first-child) {
    margin-top: 1.5em;
    padding-top: 1.5em;
  }
}
.p-outline-office dd {
  margin-left: 0.5em;
}
.p-outline-officer {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 3em 1fr;
  grid-template-columns: auto 1fr;
  gap: 0.5em 3em;
}

.p-history-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 991px) {
  .p-history-item {
    gap: 30px;
  }
}
@media screen and (max-width: 767px) {
  .p-history-item {
    gap: 20px;
  }
}
.p-history-item__year {
  position: relative;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media screen and (max-width: 991px) {
  .p-history-item__year {
    font-size: var(--fz3);
  }
}
@media screen and (max-width: 767px) {
  .p-history-item__year {
    font-size: var(--fz2);
  }
}
@media screen and (max-width: 413px) {
  .p-history-item__year {
    font-size: var(--fz1);
  }
}
@media screen and (min-width: 992px) {
  .p-history-item__year {
    font-size: var(--fz4);
  }
}
.p-history-item__year:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 9px;
  width: 1px;
  height: 100%;
  background: #dbdad1;
  z-index: -1;
}
.p-history-item__year p {
  width: 4em;
  margin-top: 20px;
  color: #004f9e;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  line-height: 1;
}
.p-history-item__year p small {
  font-size: 60%;
  font-weight: 700;
}
.p-history-item__year i {
  position: relative;
  display: block;
  width: 20px;
  aspect-ratio: 1/1;
  margin-top: 20px;
  -webkit-transform: translateY(calc(0.5em - 10px));
          transform: translateY(calc(0.5em - 10px));
  border-radius: 100%;
  background: rgba(0, 79, 158, 0.2);
}
.p-history-item__year i:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 6px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.p-history-item__month {
  position: relative;
  -webkit-box-flex: 2;
      -ms-flex-positive: 2;
          flex-grow: 2;
  display: -ms-grid;
  display: grid;
  gap: 1em;
  margin-bottom: 40px;
  padding: 40px;
  background: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 991px) {
  .p-history-item__month {
    margin-bottom: 30px;
    padding: 30px;
  }
}
@media screen and (max-width: 767px) {
  .p-history-item__month {
    margin-bottom: 20px;
    padding: 20px;
  }
}
.p-history-item__month:after {
  content: "";
  display: block;
  position: absolute;
  top: 40px;
  left: -40px;
  width: 40px;
  height: 1px;
  background: #dbdad1;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .p-history-item__month:after {
    width: 30px;
    top: 32px;
    left: -20px;
  }
}
@media screen and (max-width: 767px) {
  .p-history-item__month dl {
    display: -ms-grid;
    display: grid;
  }
}
@media screen and (min-width: 768px) {
  .p-history-item__month dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 20px;
  }
}
.p-history-item__month dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 3.5em;
}
@media screen and (max-width: 767px) {
  .p-history-item__month dt {
    margin-bottom: 5px;
    font-size: var(--fz-1);
  }
}
.p-history-item__month dt span {
  font-size: var(--fz2);
}
@media screen and (max-width: 767px) {
  .p-history-item__month dt span {
    font-size: var(--fz1);
  }
}
.p-history-item__month ul {
  display: -ms-grid;
  display: grid;
  gap: 8px;
}
.p-history-item__month li {
  position: relative;
  padding-left: 15px;
}
@media screen and (max-width: 767px) {
  .p-history-item__month li {
    font-size: var(--fz-1);
  }
}
.p-history-item__month li:before {
  content: "";
  display: block;
  position: absolute;
  top: calc(0.7em - 3px);
  left: 0;
  width: 6px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
}

.p-access-office {
  display: -ms-grid;
  display: grid;
  gap: min(60px, 6vw);
}
@media screen and (min-width: 992px) {
  .p-access-office {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
.p-access-office__add h3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  margin-top: 1.5em;
  font-size: var(--fz1);
  font-weight: 500;
}
.p-access-office__add h3 svg {
  height: 1em;
  aspect-ratio: 1/1;
  fill: #004f9e;
}
@media screen and (min-width: 992px) {
  .p-access-office__map {
    -ms-grid-column-span: 2;
    grid-column: span 2/span 2;
  }
}
.p-access-office__map iframe {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .p-access-office__map iframe {
    aspect-ratio: 3/2;
  }
}
@media screen and (min-width: 768px) {
  .p-access-office__map iframe {
    aspect-ratio: 2/1;
  }
}
.p-access-service {
  display: -ms-grid;
  display: grid;
  gap: min(80px, 10vw);
}
@media screen and (min-width: 992px) {
  .p-access-service {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
.p-access-service__map {
  margin-top: min(40px, 5vw);
}
.p-access-service__map iframe {
  width: 100%;
  aspect-ratio: 3/2;
}

.p-logistics-system__cat {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 2em;
  margin-bottom: 10px;
  padding-inline: 1em;
  background: #004f9e;
  border-radius: 1em;
  color: #fff;
  font-size: var(--fz-2);
  line-height: 1;
}
.p-logistics-system__ttl {
  margin-bottom: 0.8em;
  color: #004f9e;
  font-size: var(--fz2);
  font-weight: 500;
  letter-spacing: 0.15em;
  line-height: 1.5;
}
@media screen and (max-width: 575px) {
  .p-logistics-system__ttl {
    font-size: var(--fz1);
  }
}
.p-logistics-system .c-img-rd {
  margin-bottom: 1.5em;
}

.p-data-list {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 1399px) {
  .p-data-list {
    gap: 30px;
    max-width: 800px;
    margin-inline: auto;
  }
}
@media screen and (min-width: 1400px) {
  .p-data-list {
    -ms-grid-columns: 1fr 40px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }
}
.p-data-item {
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: min(40px, 8vw);
  border-radius: 30px;
  background: #fff;
}
@media screen and (max-width: 413px) {
  .p-data-item {
    padding: 20px;
  }
}
.p-data-item__inner {
  -webkit-box-flex: 2;
      -ms-flex-positive: 2;
          flex-grow: 2;
  background: #f1f5f7;
}
@media screen and (min-width: 1400px) {
  .p-data-item__inner {
    width: 100%;
    aspect-ratio: 134/79;
  }
}
.p-data-item__ttl {
  margin-bottom: 1em;
  color: #004f9e;
  font-size: var(--fz1);
  font-weight: 500;
  line-height: 1;
}
.p-data-item__cap {
  margin-top: 1em;
  margin-bottom: 0.5em;
  font-weight: 500;
}
.p-data-item__cap:first-child {
  margin-top: 0;
}
.p-data-graph {
  position: relative;
}
.p-data-graph span {
  display: block;
}
.p-data-graph__bar, .p-data-graph__num {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
}
.is-inview .p-data-graph__bar, .is-inview .p-data-graph__num {
  opacity: 1;
}
.p-data-graph__bar {
  -webkit-transform: scaleY(0);
          transform: scaleY(0);
  -webkit-transform-origin: center bottom;
          transform-origin: center bottom;
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
}
.is-inview .p-data-graph__bar {
  -webkit-transform: scaleY(1);
          transform: scaleY(1);
}
.p-data-graph__num {
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition-delay: 1.3s;
          transition-delay: 1.3s;
}
.is-inview .p-data-graph__num {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.p-data-number {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 30px;
  padding-top: 40px;
}
@media screen and (max-width: 575px) {
  .p-data-number {
    padding: 20px !important;
  }
}
.p-data-number__txt {
  visibility: hidden;
  height: 0;
}
.p-data-number__small {
  -ms-flex-item-align: end;
      align-self: flex-end;
  padding-bottom: 5px;
  font-size: var(--fz4);
  font-family: YakuHanJP, "Roboto", "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
}
@media screen and (max-width: 413px) {
  .p-data-number__small {
    font-size: var(--fz3);
  }
}
.p-data-number__countup {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  overflow: hidden;
  height: 0.85em;
  color: #004f9e;
  font-size: 80px;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  line-height: 0.85;
  letter-spacing: 0;
}
@media screen and (max-width: 575px) {
  .p-data-item--area .p-data-number__countup {
    font-size: 60px;
  }
}
@media screen and (max-width: 413px) {
  .p-data-item--area .p-data-number__countup {
    font-size: 50px;
  }
}
.p-data-number__countup .char {
  position: absolute;
  top: 0;
  left: 0;
  display: -ms-grid;
  display: grid;
}
.p-data-item.is-inview .p-data-number__countup .char {
  -webkit-animation: countUp 1s cubic-bezier(0.55, -0.17, 0.74, 1.29) 0.3s forwards;
          animation: countUp 1s cubic-bezier(0.55, -0.17, 0.74, 1.29) 0.3s forwards;
}
.p-data-number__countup .char-wrap {
  position: relative;
  width: 52px;
}
@media screen and (max-width: 575px) {
  .p-data-item--area .p-data-number__countup .char-wrap {
    width: 38px;
  }
}
@media screen and (max-width: 413px) {
  .p-data-item--area .p-data-number__countup .char-wrap {
    width: 32px;
  }
}
.p-data-number__countup .char-wrap--dot {
  width: 20px;
}
@media screen and (max-width: 575px) {
  .p-data-item--area .p-data-number__countup .char-wrap--dot {
    width: 13px;
  }
}
@media screen and (max-width: 413px) {
  .p-data-item--area .p-data-number__countup .char-wrap--dot {
    width: 12px;
  }
}
.p-data-number__countup .char span {
  height: 1em;
  text-align: center;
}
.p-data-childcare {
  overflow: visible !important;
  padding: 30px;
}
@media screen and (max-width: 575px) {
  .p-data-childcare {
    padding: 20px;
  }
}
.p-data-childcare table {
  width: 100%;
}
.p-data-childcare th, .p-data-childcare td {
  white-space: nowrap;
  padding: 0.7em;
  font-size: var(--fz-2);
}
.p-data-childcare thead th {
  text-align: center;
  line-height: 1.3;
}
.p-data-childcare td {
  text-align: center;
}
.p-data-childcare .scroll-hint-icon {
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.p-data-info {
  margin-top: 1em;
  text-align: center;
  font-size: var(--fz-2);
}
@media screen and (max-width: 1399px) {
  .p-data-icon {
    width: 300px;
  }
}
@media screen and (max-width: 767px) {
  .p-data-icon {
    margin-top: 20px;
  }
}
@media screen and (max-width: 413px) {
  .p-data-icon {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .p-data-icon {
    margin-top: 30px;
  }
}
@media screen and (min-width: 1400px) {
  .p-data-icon {
    -webkit-box-flex: 2;
        -ms-flex-positive: 2;
            flex-grow: 2;
  }
}
@media screen and (min-width: 1400px) {
  .p-data-icon img {
    height: 100%;
  }
}
.p-data-chart {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-data-chart {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 20px;
  }
}
@media screen and (min-width: 768px) {
  .p-data-chart {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 50px;
    -ms-grid-columns: 1fr 50px 1fr;
    grid-template-columns: repeat(2, 1fr);
  }
}
.p-data-chart__wrap {
  padding: 30px;
}
@media screen and (max-width: 575px) {
  .p-data-chart__wrap {
    padding: 20px;
  }
}
.p-data-chart svg {
  position: relative;
  width: 250px;
  height: 250px;
  -webkit-transform: rotate(-90deg);
          transform: rotate(-90deg);
}
.p-data-chart circle {
  position: relative;
  fill: none;
  stroke-width: 30;
  stroke: #fff;
  stroke-dasharray: 690;
  stroke-dashoffset: 0;
  stroke-linecap: round;
}
.p-data-chart circle.line {
  stroke: #004f9e;
}
.p-data-chart circle.line.man {
  stroke-dasharray: 518 690;
  stroke-dashoffset: 517.5;
}
.is-inview .p-data-chart circle.line.man {
  -webkit-animation: circleMan 1s forwards 1s;
          animation: circleMan 1s forwards 1s;
}
.p-data-chart circle.line.woman {
  stroke-dasharray: 0 690;
  stroke-dashoffset: 0;
}
.is-inview .p-data-chart circle.line.woman {
  -webkit-animation: circleWoan 1s forwards 1s;
          animation: circleWoan 1s forwards 1s;
}
.p-data-chart__inner {
  position: relative;
}
.p-data-chart__inner .p-data-number__countup {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  height: 0.85em;
  font-family: "Roboto Condensed", sans-serif;
  font-size: 60px;
}
.p-data-chart__inner .p-data-number__countup .char-wrap {
  width: 30px;
}
.p-data-chart__inner .p-data-number__countup .char-wrap--dot {
  width: 16px;
}
.p-data-chart__inner .p-data-number__small {
  font-size: var(--fz2);
}

@-webkit-keyframes countUp {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  100% {
    -webkit-transform: translateY(calc(-100% + 1em));
            transform: translateY(calc(-100% + 1em));
  }
}

@keyframes countUp {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  100% {
    -webkit-transform: translateY(calc(-100% + 1em));
            transform: translateY(calc(-100% + 1em));
  }
}
@-webkit-keyframes circleMan {
  0% {
    stroke-dasharray: 518 690;
  }
  99.9%, to {
    stroke-dasharray: 690 690;
  }
}
@keyframes circleMan {
  0% {
    stroke-dasharray: 518 690;
  }
  99.9%, to {
    stroke-dasharray: 690 690;
  }
}
@-webkit-keyframes circleWoan {
  0% {
    stroke-dasharray: 0 690;
  }
  99.9%, to {
    stroke-dasharray: 690 690;
  }
}
@keyframes circleWoan {
  0% {
    stroke-dasharray: 0 690;
  }
  99.9%, to {
    stroke-dasharray: 690 690;
  }
}
.p-products-intro {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 1199px) {
  .p-products-intro {
    gap: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-products-intro {
    gap: 30px;
  }
}
@media screen and (min-width: 1200px) {
  .p-products-intro {
    -ms-grid-columns: 1fr 60px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 60px;
  }
}
.p-products-intro .c-title-head {
  margin-bottom: 0.8em;
  font-size: var(--fz5);
  line-height: 1;
}
.p-products-intro .c-sentence-lead {
  color: #484d4b;
  font-size: var(--fz3);
}
@media screen and (min-width: 768px) {
  .p-products-intro .c-sentence-lead span {
    display: inline-block;
  }
}
.p-products-list {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 1199px) {
  .p-products-list {
    gap: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-products-list {
    gap: 10vw;
  }
}
@media screen and (min-width: 768px) {
  .p-products-list {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  }
}
@media screen and (min-width: 1200px) {
  .p-products-list {
    gap: 50px;
  }
}
@media screen and (min-width: 1400px) {
  .p-products-list {
    gap: 60px;
  }
}
.p-products-list__link {
  display: block;
  height: 100%;
  border: 1px solid #dbdad1;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .p-products-list__link {
    padding: 30px;
    border-radius: 10px;
  }
}
@media screen and (max-width: 575px) {
  .p-products-list__link {
    gap: 15px;
  }
}
@media screen and (min-width: 768px) {
  .p-products-list__link {
    padding: 40px;
    border-radius: 20px;
  }
}
@media (hover: hover) {
  .p-products-list__link:hover {
    border-color: #004f9e;
  }
}
.p-products-list__img {
  overflow: hidden;
  border-radius: 10px;
}
.p-products-list__img img {
  -webkit-transform: scale(1);
          transform: scale(1);
}
@media (hover: hover) {
  a:hover .p-products-list__img img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.p-products-list__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 30px;
  margin-bottom: 20px;
  font-weight: 500;
}
.p-products-list__ttl div {
  display: -ms-grid;
  display: grid;
}
.p-products-list__ttl small {
  margin-bottom: 1em;
  color: #00a560;
  font-size: var(--fz-3);
  line-height: 0.8;
}
.p-products-list__ttl span {
  color: #004f9e;
  font-size: var(--fz2);
  line-height: 1.3;
}
.p-products-list__ttl .c-icon-circle {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 40px;
}
a:hover .p-products-list__ttl .c-icon-circle:after {
  background: #004f9e;
}
@media screen and (max-width: 767px) {
  .p-products-list p {
    font-size: var(--fz-1);
  }
}
.p-products-flow__item {
  position: relative;
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 767px) {
  .p-products-flow__item {
    gap: 20px;
  }
}
@media screen and (min-width: 768px) {
  .p-products-flow__item {
    -ms-grid-columns: 40% 30px 1fr;
    grid-template-columns: 40% 1fr;
    gap: 30px;
  }
}
@media screen and (min-width: 992px) {
  .p-products-flow__item {
    gap: 40px;
  }
}
@media screen and (min-width: 1200px) {
  .p-products-flow__item {
    gap: 60px;
  }
}
.p-products-flow__item:nth-of-type(odd) [class$=_num], .p-products-flow__item:nth-of-type(odd) [class$=_label] {
  background: #004f9e;
}
.p-products-flow__item:nth-of-type(odd):before {
  border-color: #00a560 transparent transparent transparent;
}
.p-products-flow__item:nth-of-type(even) [class$=_num], .p-products-flow__item:nth-of-type(even) [class$=_label] {
  background: #00a560;
}
.p-products-flow__item:nth-of-type(even):before {
  border-color: #004f9e transparent transparent transparent;
}
.p-products-flow__item + div[class$=_item] {
  border-top: 1px solid #dbdad1;
}
@media screen and (max-width: 767px) {
  .p-products-flow__item + div[class$=_item] {
    margin-top: 40px;
    padding-top: 40px;
  }
}
@media screen and (max-width: 575px) {
  .p-products-flow__item + div[class$=_item] {
    margin-top: 30px;
    padding-top: 30px;
  }
}
@media screen and (min-width: 768px) {
  .p-products-flow__item + div[class$=_item] {
    margin-top: 50px;
    padding-top: 50px;
  }
}
.p-products-flow__item + div[class$=_item]:before {
  content: "";
  display: block;
  position: absolute;
  top: -15px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 30px 30px 0px 30px;
}
@media screen and (max-width: 767px) {
  .p-products-flow__item + div[class$=_item]:before {
    left: 50%;
  }
}
@media screen and (max-width: 575px) {
  .p-products-flow__item + div[class$=_item]:before {
    top: -10px;
    border-width: 20px 20px 0px 20px;
  }
}
@media screen and (min-width: 768px) {
  .p-products-flow__item + div[class$=_item]:before {
    left: 20%;
  }
}
.p-products-flow__img {
  position: relative;
}
.p-products-flow__img img {
  border-radius: 100px 10px 10px 10px;
}
.p-products-flow__num {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 60px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  color: #fff;
  font-family: "Poppins", sans-serif;
  font-size: var(--fz2);
}
.p-products-flow__label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 6em;
  height: 1.8em;
  margin-bottom: 1em;
  padding-top: 2px;
  border-radius: 9em;
  color: #fff;
  font-weight: 500;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .p-products-flow__label {
    font-size: var(--fz-1);
  }
}
@media screen and (max-width: 575px) {
  .p-products-flow__label {
    font-size: -2px;
  }
}
.p-products-flow__ttl {
  margin-bottom: 0.8em;
  font-size: var(--fz2);
  font-weight: 500;
}
.p-products-table th {
  text-align: center;
}

@media screen and (min-width: 992px) {
  .p-document-iso .c-grid-cols-2 {
    -ms-grid-columns: 1fr 25%;
    grid-template-columns: 1fr 25%;
  }
}
.p-document-flow__video {
  max-width: 800px;
  margin-inline: auto;
}
.p-document-flow__video video, .p-document-flow__video iframe {
  width: 100%;
  aspect-ratio: 16/9;
}
.p-document-point__item {
  background: #fff;
}
@media screen and (max-width: 991px) {
  .p-document-point__item {
    padding: 40px;
    border-radius: 20px;
  }
}
@media screen and (max-width: 767px) {
  .p-document-point__item {
    padding: 30px;
  }
}
@media screen and (max-width: 575px) {
  .p-document-point__item {
    padding: 20px;
    border-radius: 10px;
  }
}
@media screen and (min-width: 992px) {
  .p-document-point__item {
    padding: 50px;
    border-radius: 30px;
  }
}
.p-document-point__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 15px;
  margin-bottom: 0.8em;
  font-size: var(--fz3);
  font-weight: 500;
}
.p-document-point__ttl &gt; span {
  padding-top: 5px;
  line-height: 1.3;
}
.p-document-point__num {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 3px;
  width: 60px;
  padding-top: 3px;
  aspect-ratio: 1/1;
  background: #00a560;
  border-radius: 30px 30px 0 30px;
  color: #fff;
  font-weight: 500;
  font-family: "Poppins", sans-serif;
  line-height: 1;
}
.p-document-point__num small {
  font-size: var(--fz-3);
  letter-spacing: 0.05em;
}
.p-document-point__num span {
  font-size: var(--fz2);
}
.p-document-point .c-sentence-lead {
  color: #00a560;
}
.p-document-zero {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
.p-document-zero__hgroup {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 15px;
  margin-inline: auto;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .p-document-zero__hgroup {
    margin-bottom: 20px;
  }
}
.p-document-zero__hgroup i {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 40px;
}
.p-document-zero__hgroup div {
  display: -ms-grid;
  display: grid;
  gap: 5px;
}
.p-document-zero__hgroup h3 {
  color: #00a560;
  font-size: var(--fz4);
  font-weight: 500;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .p-document-zero__hgroup h3 {
    font-size: var(--fz5);
  }
}
.p-document-zero__hgroup p {
  font-weight: 500;
}
@media screen and (max-width: 575px) {
  .p-document-zero__hgroup p {
    font-size: var(--fz-1);
  }
}
@media screen and (min-width: 768px) {
  .p-document-zero__hgroup p {
    font-size: var(--fz1);
  }
}
.p-document-zero__summary {
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
@media screen and (max-width: 575px) {
  .p-document-zero__summary {
    gap: 15px;
  }
}
@media screen and (min-width: 576px) {
  .p-document-zero__summary {
    gap: 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-document-zero__summary {
    gap: 30px;
  }
}
@media screen and (min-width: 1200px) {
  .p-document-zero__summary {
    gap: 40px;
  }
}
.p-document-zero__summary-item {
  overflow: hidden;
  border: 1px solid #00a560;
}
@media screen and (max-width: 575px) {
  .p-document-zero__summary-item {
    border-radius: 10px;
  }
}
@media screen and (min-width: 576px) {
  .p-document-zero__summary-item {
    border-radius: 20px;
  }
}
.p-document-zero__summary-ttl {
  padding: 1em 0.8em;
  background: #00a560;
  color: #fff;
  font-weight: 500;
  font-size: var(--fz1);
  text-align: center;
  line-height: 1;
}
.p-document-zero__summary-inner {
  height: 100%;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .p-document-zero__summary-inner {
    padding: 20px;
  }
}
@media screen and (min-width: 768px) {
  .p-document-zero__summary-inner {
    padding: 30px;
  }
}
.p-document-zero__summary p {
  font-size: var(--fz-1);
}

.p-sustainability-header {
  -ms-grid-columns: 1fr !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
  background: url("/koa-wp/wp-content/uploads/2025/03/sustainability-header-bg.jpg") no-repeat right bottom #b0bf26;
  background-size: 100% auto;
}
@media screen and (max-width: 1199px) {
  .p-sustainability-header {
    padding-top: 30px;
    padding-bottom: 10vw;
  }
}
@media screen and (max-width: 767px) {
  .p-sustainability-header {
    padding-top: 10px;
    padding-bottom: 12vw;
  }
}
@media screen and (max-width: 413px) {
  .p-sustainability-header {
    background-size: 130%;
    padding-bottom: 30vw;
  }
}
@media screen and (min-width: 992px) {
  .p-sustainability-header {
    padding-top: 60px;
    padding-bottom: 10vw;
  }
}
@media screen and (min-width: 1200px) {
  .p-sustainability-header {
    padding-top: 80px;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 1400px) {
  .p-sustainability-header {
    padding-top: 100px !important;
  }
}
.p-sustainability-header [class$=__title] {
  line-height: 1;
}
@media screen and (max-width: 991px) {
  .p-sustainability-header [class$=__title] {
    padding-bottom: 20px;
  }
}
@media screen and (min-width: 992px) {
  .p-sustainability-header [class$=__title] {
    padding-bottom: 30px;
  }
}
@media screen and (min-width: 1400px) {
  .p-sustainability-header [class$=__title] {
    padding-bottom: 40px;
  }
}
.p-sustainability-header [class*=__title] {
  color: #fff;
}
@media screen and (max-width: 991px) {
  .p-sustainability-header__txt {
    padding-inline: min(40px, 5vw);
  }
}
@media screen and (min-width: 992px) {
  .p-sustainability-header__txt {
    padding-left: 60px;
  }
}
@media screen and (min-width: 1400px) {
  .p-sustainability-header__txt {
    padding-left: 80px;
  }
}
.p-sustainability-header__txt p {
  color: #fff;
  font-size: var(--fz3);
  font-weight: 500;
  line-height: 2.2;
  letter-spacing: 0.15em;
}
@media screen and (max-width: 767px) {
  .p-sustainability-header__txt p {
    font-size: var(--fz2);
  }
}
.p-sustainability-list {
  display: -ms-grid;
  display: grid;
}
@media screen and (max-width: 1199px) {
  .p-sustainability-list {
    gap: 40px;
  }
}
@media screen and (max-width: 767px) {
  .p-sustainability-list {
    gap: 10vw;
  }
}
@media screen and (min-width: 768px) {
  .p-sustainability-list {
    grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  }
}
@media screen and (min-width: 1200px) {
  .p-sustainability-list {
    gap: 50px;
  }
}
@media screen and (min-width: 1400px) {
  .p-sustainability-list {
    gap: 60px;
  }
}
.p-sustainability-list__link {
  display: block;
  height: 100%;
  border: 1px solid #dbdad1;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .p-sustainability-list__link {
    padding: 30px;
    border-radius: 10px;
  }
}
@media screen and (max-width: 575px) {
  .p-sustainability-list__link {
    gap: 15px;
  }
}
@media screen and (min-width: 768px) {
  .p-sustainability-list__link {
    padding: 40px;
    border-radius: 20px;
  }
}
@media (hover: hover) {
  .p-sustainability-list__link:hover {
    border-color: #004f9e;
  }
}
.p-sustainability-list__img {
  overflow: hidden;
  border-radius: 10px;
}
.p-sustainability-list__img img {
  -webkit-transform: scale(1);
          transform: scale(1);
}
@media (hover: hover) {
  a:hover .p-sustainability-list__img img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.p-sustainability-list__ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 15px;
  margin-top: 30px;
  margin-bottom: 20px;
  font-weight: 500;
}
.p-sustainability-list__ttl div {
  display: -ms-grid;
  display: grid;
}
.p-sustainability-list__ttl small {
  margin-bottom: 1em;
  color: #00a560;
  font-size: var(--fz-3);
  line-height: 0.8;
}
.p-sustainability-list__ttl span {
  color: #004f9e;
  font-size: var(--fz2);
  line-height: 1.3;
}
.p-sustainability-list__ttl .c-icon-circle {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 40px;
}
a:hover .p-sustainability-list__ttl .c-icon-circle:after {
  background: #004f9e;
}
@media screen and (max-width: 767px) {
  .p-sustainability-list p {
    font-size: var(--fz-1);
  }
}
.p-sustainability-closed {
  overflow: hidden;
}
.p-sustainability-history dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 991px) {
  .p-sustainability-history dl {
    width: 40%;
  }
}
@media screen and (max-width: 575px) {
  .p-sustainability-history dl {
    width: 60%;
  }
}
@media screen and (min-width: 992px) {
  .p-sustainability-history dl {
    width: 25%;
  }
}
.p-sustainability-history dt, .p-sustainability-history dd {
  text-align: center;
}
.p-sustainability-history dt {
  position: relative;
  padding-bottom: 30px;
  border-bottom: 1px solid #dbdad1;
  font-size: var(--fz2);
  line-height: 1;
}
.p-sustainability-history dt:before, .p-sustainability-history dt:after {
  content: "";
  display: block;
  position: absolute;
}
.p-sustainability-history dt:before {
  bottom: -1px;
  right: -30px;
  width: 30px;
  height: 1px;
  background: #dbdad1;
}
.p-sustainability-history dt:after {
  left: calc(50% - 4px);
  bottom: -5px;
  width: 8px;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #004f9e;
}
.p-sustainability-history dt small {
  font-size: var(--fz0);
}
.p-sustainability-history dd {
  position: relative;
  -webkit-box-flex: 2;
      -ms-flex-positive: 2;
          flex-grow: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 40px;
  padding: 1.5em;
  background: #fff;
  border-radius: 10px;
}
@media screen and (max-width: 575px) {
  .p-sustainability-history dd {
    font-size: var(--fz-1);
  }
}
.p-sustainability-history dd:before {
  content: "";
  display: block;
  position: absolute;
  top: -40px;
  left: 50%;
  width: 1px;
  height: 40px;
  margin-left: -1px;
  border-left: 1px dotted #004f9e;
}
.p-sustainability-history__ctrl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 15px;
}
.p-sustainability-history .splide__track {
  overflow: visible;
}
.p-sustainability-history .splide__pagination {
  position: static;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 8px;
  padding: 0;
}
.p-sustainability-history .splide__pagination__page {
  width: 25px;
  height: 6px;
  margin: 0;
  border-radius: 3px;
  background: #dbdad1;
  opacity: 1;
}
.p-sustainability-history .splide__pagination__page.is-active {
  -webkit-transform: scale(1);
          transform: scale(1);
  background: #004f9e;
}
.p-sustainability-history .splide__arrows {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 15px;
}
.p-sustainability-history .splide__arrow {
  position: static;
  width: 40px;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 100%;
  background: #fff;
  border: 1px solid #dbdad1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
@media screen and (min-width: 992px) {
  .p-sustainability-zero .c-grid-cols-2 {
    -ms-grid-columns: 1fr 25%;
    grid-template-columns: 1fr 25%;
  }
}
@media screen and (min-width: 576px) {
  .p-sustainability-zero .c-grid-cols-2 img {
    max-width: 300px;
  }
}
.p-sustainability-zero ol {
  display: -ms-grid;
  display: grid;
  gap: 15px;
  counter-reset: listnum;
}
.p-sustainability-zero ol li {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 2.5em 1fr;
  grid-template-columns: 2.5em 1fr;
}
@media screen and (max-width: 575px) {
  .p-sustainability-zero ol li {
    font-size: var(--fz-1);
  }
}
.p-sustainability-zero ol li:before {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  counter-increment: listnum;
  content: "（" counter(listnum, upper-roman) "）";
}
.p-sustainability-zero ol li ol {
  -ms-grid-column-span: 2;
  grid-column: span 2/span 2;
  gap: 8px;
  margin-top: 8px;
  padding-left: 2.5em;
}
.p-sustainability-zero ol li ol li:before {
  content: "（" counter(listnum, lower-roman) "）";
}

.p-404 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: 60svh;
  text-align: center;
}
.p-404-ttl {
  margin-bottom: 1em;
  font-size: var(--fz3);
}
@media screen and (min-width: 576px) {
  .p-404-ttl br {
    display: none;
  }
}
@media screen and (max-width: 575px) {
  .p-404 p br {
    display: none;
  }
}

/**
  @align
---------------------------------------------------------
  utility/_align.scss
--------------------------------------------------------- */
.u-align-left {
  margin-right: auto;
  margin-left: inherit;
}
.u-align-right {
  margin-left: auto;
  margin-right: 0;
}
.u-align-center {
  margin-inline: auto;
}

/**
  @hide
---------------------------------------------------------
  utility/_hide.scss
--------------------------------------------------------- */
.u-d-none {
  display: none !important;
}

.u-d-inline {
  display: inline !important;
}

.u-d-inline-block {
  display: inline-block !important;
}

.u-d-block {
  display: block !important;
}

.u-d-flex {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
}

@media screen and (max-width: 413px) {
  .u-d-xs-none {
    display: none !important;
  }
  .u-d-xs-inline {
    display: inline !important;
  }
  .u-d-xs-inline-block {
    display: inline-block !important;
  }
  .u-d-xs-block {
    display: block !important;
  }
  .u-d-xs-flex {
    display: -ms-flexbox !important;
    display: -webkit-box !important;
    display: flex !important;
  }
}
@media screen and (max-width: 575px) {
  .u-d-sm-none {
    display: none !important;
  }
  .u-d-sm-inline {
    display: inline !important;
  }
  .u-d-sm-inline-block {
    display: inline-block !important;
  }
  .u-d-sm-block {
    display: block !important;
  }
  .u-d-sm-flex {
    display: -ms-flexbox !important;
    display: -webkit-box !important;
    display: flex !important;
  }
}
@media screen and (max-width: 767px) {
  .u-d-md-none {
    display: none !important;
  }
  .u-d-md-inline {
    display: inline !important;
  }
  .u-d-md-inline-block {
    display: inline-block !important;
  }
  .u-d-md-block {
    display: block !important;
  }
  .u-d-md-flex {
    display: -ms-flexbox !important;
    display: -webkit-box !important;
    display: flex !important;
  }
}
@media screen and (max-width: 991px) {
  .u-d-lg-none {
    display: none !important;
  }
  .u-d-lg-inline {
    display: inline !important;
  }
  .u-d-lg-inline-block {
    display: inline-block !important;
  }
  .u-d-lg-block {
    display: block !important;
  }
  .u-d-lg-flex {
    display: -ms-flexbox !important;
    display: -webkit-box !important;
    display: flex !important;
  }
}
@media screen and (max-width: 1199px) {
  .u-d-xl-none {
    display: none !important;
  }
  .u-d-xl-inline {
    display: inline !important;
  }
  .u-d-xl-inline-block {
    display: inline-block !important;
  }
  .u-d-xl-block {
    display: block !important;
  }
  .u-d-xl-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
}
@media screen and (max-width: 1399px) {
  .u-d-xxl-none {
    display: none !important;
  }
  .u-d-xxl-inline {
    display: inline !important;
  }
  .u-d-xlx-inline-block {
    display: inline-block !important;
  }
  .u-d-xxl-block {
    display: block !important;
  }
  .u-d-xxl-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
}
/**
  @spacing
---------------------------------------------------------
  utility/_spacing.scss
------------------------------------------------------ */
.u-mt0 {
  margin-top: 0px !important;
}

.u-mb0 {
  margin-bottom: 0px !important;
}

.u-mr0 {
  margin-right: 0px !important;
}

.u-ml0 {
  margin-left: 0px !important;
}

.u-pt0 {
  padding-top: 0px !important;
}

.u-pb0 {
  padding-bottom: 0px !important;
}

.u-pr0 {
  padding-right: 0px !important;
}

.u-pl0 {
  padding-left: 0px !important;
}

.u-mt5 {
  margin-top: 5px !important;
}

.u-mb5 {
  margin-bottom: 5px !important;
}

.u-mr5 {
  margin-right: 5px !important;
}

.u-ml5 {
  margin-left: 5px !important;
}

.u-pt5 {
  padding-top: 5px !important;
}

.u-pb5 {
  padding-bottom: 5px !important;
}

.u-pr5 {
  padding-right: 5px !important;
}

.u-pl5 {
  padding-left: 5px !important;
}

.u-mt10 {
  margin-top: 10px !important;
}

.u-mb10 {
  margin-bottom: 10px !important;
}

.u-mr10 {
  margin-right: 10px !important;
}

.u-ml10 {
  margin-left: 10px !important;
}

.u-pt10 {
  padding-top: 10px !important;
}

.u-pb10 {
  padding-bottom: 10px !important;
}

.u-pr10 {
  padding-right: 10px !important;
}

.u-pl10 {
  padding-left: 10px !important;
}

.u-mt15 {
  margin-top: 15px !important;
}

.u-mb15 {
  margin-bottom: 15px !important;
}

.u-mr15 {
  margin-right: 15px !important;
}

.u-ml15 {
  margin-left: 15px !important;
}

.u-pt15 {
  padding-top: 15px !important;
}

.u-pb15 {
  padding-bottom: 15px !important;
}

.u-pr15 {
  padding-right: 15px !important;
}

.u-pl15 {
  padding-left: 15px !important;
}

.u-mt20 {
  margin-top: 20px !important;
}

.u-mb20 {
  margin-bottom: 20px !important;
}

.u-mr20 {
  margin-right: 20px !important;
}

.u-ml20 {
  margin-left: 20px !important;
}

.u-pt20 {
  padding-top: 20px !important;
}

.u-pb20 {
  padding-bottom: 20px !important;
}

.u-pr20 {
  padding-right: 20px !important;
}

.u-pl20 {
  padding-left: 20px !important;
}

.u-mt25 {
  margin-top: 25px !important;
}

.u-mb25 {
  margin-bottom: 25px !important;
}

.u-mr25 {
  margin-right: 25px !important;
}

.u-ml25 {
  margin-left: 25px !important;
}

.u-pt25 {
  padding-top: 25px !important;
}

.u-pb25 {
  padding-bottom: 25px !important;
}

.u-pr25 {
  padding-right: 25px !important;
}

.u-pl25 {
  padding-left: 25px !important;
}

.u-mt30 {
  margin-top: 30px !important;
}

.u-mb30 {
  margin-bottom: 30px !important;
}

.u-mr30 {
  margin-right: 30px !important;
}

.u-ml30 {
  margin-left: 30px !important;
}

.u-pt30 {
  padding-top: 30px !important;
}

.u-pb30 {
  padding-bottom: 30px !important;
}

.u-pr30 {
  padding-right: 30px !important;
}

.u-pl30 {
  padding-left: 30px !important;
}

@media screen and (max-width: 575px) {
  .u-mt-sm-0 {
    margin-top: 0px !important;
  }
  .u-mb-sm-0 {
    margin-bottom: 0px !important;
  }
  .u-pt-sm-0 {
    padding-top: 0px !important;
  }
  .u-pb-sm-0 {
    padding-bottom: 0px !important;
  }
  .u-mt-sm-5 {
    margin-top: 5px !important;
  }
  .u-mb-sm-5 {
    margin-bottom: 5px !important;
  }
  .u-pt-sm-5 {
    padding-top: 5px !important;
  }
  .u-pb-sm-5 {
    padding-bottom: 5px !important;
  }
  .u-mt-sm-10 {
    margin-top: 10px !important;
  }
  .u-mb-sm-10 {
    margin-bottom: 10px !important;
  }
  .u-pt-sm-10 {
    padding-top: 10px !important;
  }
  .u-pb-sm-10 {
    padding-bottom: 10px !important;
  }
  .u-mt-sm-15 {
    margin-top: 15px !important;
  }
  .u-mb-sm-15 {
    margin-bottom: 15px !important;
  }
  .u-pt-sm-15 {
    padding-top: 15px !important;
  }
  .u-pb-sm-15 {
    padding-bottom: 15px !important;
  }
  .u-mt-sm-20 {
    margin-top: 20px !important;
  }
  .u-mb-sm-20 {
    margin-bottom: 20px !important;
  }
  .u-pt-sm-20 {
    padding-top: 20px !important;
  }
  .u-pb-sm-20 {
    padding-bottom: 20px !important;
  }
  .u-mt-sm-25 {
    margin-top: 25px !important;
  }
  .u-mb-sm-25 {
    margin-bottom: 25px !important;
  }
  .u-pt-sm-25 {
    padding-top: 25px !important;
  }
  .u-pb-sm-25 {
    padding-bottom: 25px !important;
  }
  .u-mt-sm-30 {
    margin-top: 30px !important;
  }
  .u-mb-sm-30 {
    margin-bottom: 30px !important;
  }
  .u-pt-sm-30 {
    padding-top: 30px !important;
  }
  .u-pb-sm-30 {
    padding-bottom: 30px !important;
  }
}
@media screen and (max-width: 767px) {
  .u-mt-md-0 {
    margin-top: 0px !important;
  }
  .u-mb-md-0 {
    margin-bottom: 0px !important;
  }
  .u-pt-md-0 {
    padding-top: 0px !important;
  }
  .u-pb-md-0 {
    padding-bottom: 0px !important;
  }
  .u-mt-md-5 {
    margin-top: 5px !important;
  }
  .u-mb-md-5 {
    margin-bottom: 5px !important;
  }
  .u-pt-md-5 {
    padding-top: 5px !important;
  }
  .u-pb-md-5 {
    padding-bottom: 5px !important;
  }
  .u-mt-md-10 {
    margin-top: 10px !important;
  }
  .u-mb-md-10 {
    margin-bottom: 10px !important;
  }
  .u-pt-md-10 {
    padding-top: 10px !important;
  }
  .u-pb-md-10 {
    padding-bottom: 10px !important;
  }
  .u-mt-md-15 {
    margin-top: 15px !important;
  }
  .u-mb-md-15 {
    margin-bottom: 15px !important;
  }
  .u-pt-md-15 {
    padding-top: 15px !important;
  }
  .u-pb-md-15 {
    padding-bottom: 15px !important;
  }
  .u-mt-md-20 {
    margin-top: 20px !important;
  }
  .u-mb-md-20 {
    margin-bottom: 20px !important;
  }
  .u-pt-md-20 {
    padding-top: 20px !important;
  }
  .u-pb-md-20 {
    padding-bottom: 20px !important;
  }
  .u-mt-md-25 {
    margin-top: 25px !important;
  }
  .u-mb-md-25 {
    margin-bottom: 25px !important;
  }
  .u-pt-md-25 {
    padding-top: 25px !important;
  }
  .u-pb-md-25 {
    padding-bottom: 25px !important;
  }
  .u-mt-md-30 {
    margin-top: 30px !important;
  }
  .u-mb-md-30 {
    margin-bottom: 30px !important;
  }
  .u-pt-md-30 {
    padding-top: 30px !important;
  }
  .u-pb-md-30 {
    padding-bottom: 30px !important;
  }
}
@media screen and (max-width: 991px) {
  .u-mt-lg-0 {
    margin-top: 0px !important;
  }
  .u-mb-lg-0 {
    margin-bottom: 0px !important;
  }
  .u-pt-lg-0 {
    padding-top: 0px !important;
  }
  .u-pb-lg-0 {
    padding-bottom: 0px !important;
  }
  .u-mt-lg-5 {
    margin-top: 5px !important;
  }
  .u-mb-lg-5 {
    margin-bottom: 5px !important;
  }
  .u-pt-lg-5 {
    padding-top: 5px !important;
  }
  .u-pb-lg-5 {
    padding-bottom: 5px !important;
  }
  .u-mt-lg-10 {
    margin-top: 10px !important;
  }
  .u-mb-lg-10 {
    margin-bottom: 10px !important;
  }
  .u-pt-lg-10 {
    padding-top: 10px !important;
  }
  .u-pb-lg-10 {
    padding-bottom: 10px !important;
  }
  .u-mt-lg-15 {
    margin-top: 15px !important;
  }
  .u-mb-lg-15 {
    margin-bottom: 15px !important;
  }
  .u-pt-lg-15 {
    padding-top: 15px !important;
  }
  .u-pb-lg-15 {
    padding-bottom: 15px !important;
  }
  .u-mt-lg-20 {
    margin-top: 20px !important;
  }
  .u-mb-lg-20 {
    margin-bottom: 20px !important;
  }
  .u-pt-lg-20 {
    padding-top: 20px !important;
  }
  .u-pb-lg-20 {
    padding-bottom: 20px !important;
  }
  .u-mt-lg-25 {
    margin-top: 25px !important;
  }
  .u-mb-lg-25 {
    margin-bottom: 25px !important;
  }
  .u-pt-lg-25 {
    padding-top: 25px !important;
  }
  .u-pb-lg-25 {
    padding-bottom: 25px !important;
  }
  .u-mt-lg-30 {
    margin-top: 30px !important;
  }
  .u-mb-lg-30 {
    margin-bottom: 30px !important;
  }
  .u-pt-lg-30 {
    padding-top: 30px !important;
  }
  .u-pb-lg-30 {
    padding-bottom: 30px !important;
  }
}
/**
  @text
---------------------------------------------------------
  utility/_text.scss
--------------------------------------------------------- */
.u-text-red {
  color: #ad0306;
}
.u-text-blu {
  color: #004f9e;
}
.u-text-gry {
  color: #999999;
}
.u-text-left {
  text-align: left !important;
}
.u-text-right {
  text-align: right !important;
}
.u-text-center {
  text-align: center !important;
}
.u-text-mid {
  font-weight: 500;
}
.u-text-bold {
  font-weight: 700;
}
.u-text-lg {
  font-size: var(--fz2);
}
.u-text-md {
  font-size: var(--fz1);
}
.u-text-small {
  font-size: var(--fz-1);
}
.u-text-xs {
  font-size: var(--fz-2);
}
.u-text-sep {
  display: inline-block;
}
.u-text-sup {
  font-size: 10px;
}
.u-text-marker {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(0%, #fdeea9));
  background: linear-gradient(transparent 50%, #fdeea9 0%);
}

/**
  @inview
---------------------------------------------------------
  javascript/_inview.scss
--------------------------------------------------------- */
[data-slideup] {
  translate: 0 2rem;
  opacity: 0;
  -webkit-transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
  transition: all 0.3s cubic-bezier(0.55, 0.085, 0.68, 0.53);
}
[data-slideup].is-inview {
  translate: 0 0;
  opacity: 1;
}</pre></body></html>