@charset "UTF-8";
/* resset.dev • v5.0.2 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%; /* Prevent adjustments of font size after orientation changes in iOS */
  word-break: normal;
  -moz-tab-size: 4;
  tab-size: 4;
}

*,
::before,
::after {
  background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  box-sizing: inherit;
}

::before,
::after {
  text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  padding: 0; /* Reset `padding` and `margin` of all elements */
  margin: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */
hr {
  overflow: visible; /* Show the overflow in Edge and IE */
  height: 0; /* Add the correct box sizing in Firefox */
  color: inherit; /* Correct border color in Firefox. */
}

details,
main {
  display: block; /* Render the `main` element consistently in IE. */
}

summary {
  display: list-item; /* Add the correct display in all browsers */
}

small {
  font-size: 80%; /* Set font-size to 80% in `small` elements */
}

[hidden] {
  display: none; /* Add the correct display in IE */
}

abbr[title] {
  border-bottom: none; /* Remove the bottom border in Chrome 57 */
  /* Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari */
  text-decoration: underline;
  text-decoration: underline dotted;
}

a {
  background-color: transparent; /* Remove the gray background on active links in IE 10 */
}

a:active,
a:hover {
  outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; /* Specify the font family of code elements */
}

pre {
  font-size: 1em; /* Correct the odd `em` font sizing in all browsers */
}

b,
strong {
  font-weight: bolder; /* Add the correct font weight in Chrome, Edge, and Safari */
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

table {
  border-color: inherit; /* Correct border color in all Chrome, Edge, and Safari. */
  text-indent: 0; /* Remove text indentation in Chrome, Edge, and Safari */
}

iframe {
  border-style: none;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto; /* Correct the cursor style of increment and decrement buttons in Chrome */
}

[type=search] {
  -webkit-appearance: textfield; /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px; /* Correct the outline style in Safari */
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none; /* Remove the inner padding in Chrome and Safari on macOS */
}

textarea {
  overflow: auto; /* Internet Explorer 11+ */
  resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  font: inherit; /* Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold; /* Restore the font weight unset by the previous rule */
}

button {
  overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

button,
select {
  text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Apply cursor pointer to button elements */
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button; /* Correct the inability to style clickable types in iOS */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline-width: 0;
}

/* Style select like a standard input */
select {
  -moz-appearance: none; /* Firefox 36+ */
  -webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
  display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor; /* Internet Explorer 11+ */
}

legend {
  border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
  display: table; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge and IE */
  white-space: normal; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge 18- and IE */
}

::-webkit-file-upload-button {
  /* Correct the inability to style clickable types in iOS and Safari */
  -webkit-appearance: button;
  color: inherit;
  font: inherit; /* Change font properties to `inherit` in Chrome and Safari */
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
  border-style: none; /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled=true] {
  cursor: default;
}

ul {
  list-style: none;
}

figure {
  margin: 0;
}

:root {
  --vw: 1vw;
}

@media only screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}
@media only screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
a {
  color: inherit;
  text-decoration: none;
  transition: 0.3s;
}

button {
  transition: 0.3s;
}

.column__wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

img,
svg {
  vertical-align: top;
  width: 100%;
}

@media screen and (-webkit-min-device-pixel-ratio: 0) {
  img {
    image-rendering: -webkit-optimize-contrast;
  }
}
@media only screen and (max-width: 767px) {
  img {
    image-rendering: auto;
  }
}

:root {
  font-size: 62.5%;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  :root {
    font-size: calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  :root {
    font-size: calc(2.6666666667 * var(--vw));
  }
}

html,
body {
  height: 100%;
}

body {
  color: #222;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  transition: 0.5s;
}
body.is-preload {
  opacity: 0;
}
body.is-preload * {
  transition: none !important;
}
body.is-open-menu {
  overflow: hidden;
}
body > .wrapper {
  min-height: 100%;
  height: auto;
}

.wrapper {
  position: relative;
}

.content {
  width: 100%;
  height: auto;
}

.bg--01 {
  background-color: #FFFFF8;
}
.bg--02 {
  background-color: #F5F2EA;
}

.sec {
  position: relative;
  padding: 80px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec {
    padding: calc(5.5555555556 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  .sec {
    padding: calc(17.0666666667 * var(--vw)) 0;
  }
}
.sec__in {
  max-width: 1440px;
  height: 100%;
  margin: 0 auto;
  padding: 0 170px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec__in {
    padding: 0 calc(11.8055555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec__in {
    width: 100%;
    padding: 0 calc(2.6666666667 * var(--vw));
  }
}
.sec .sec-ttl-01 {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #003988;
  font-family: "Al Nile", "Roboto", sans-serif;
  font-size: 5.8rem;
  line-height: 1.18;
  font-weight: 700;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-01 {
    font-size: 4.8rem;
  }
}
@media only screen and (min-width: 768px) {
  .sec .sec-ttl-01.is-left {
    align-items: flex-start;
  }
}
@media only screen and (min-width: 768px) {
  .sec .sec-ttl-01.is-right {
    align-items: flex-end;
  }
}
.sec .sec-ttl-01 .sub {
  position: relative;
  color: #222;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2rem;
  line-height: 1;
  font-weight: 700;
  -webkit-text-stroke: initial;
  width: auto;
  margin: -5px 0 0;
  padding: 0 0 0 20px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-01 .sub {
    margin: calc(-0.3472222222 * var(--vw)) 0 0;
    padding: 0 0 0 calc(1.3888888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-01 .sub {
    margin: calc(-1.3333333333 * var(--vw)) 0 0;
    padding: 0 0 0 calc(5.3333333333 * var(--vw));
  }
}
.sec .sec-ttl-01 .sub::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 0;
  background: #0DABC7;
  aspect-ratio: 1;
  border-radius: 50%;
  width: 10px;
  height: 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-01 .sub::before {
    top: calc(0.3472222222 * var(--vw));
    width: calc(0.6944444444 * var(--vw));
    height: calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-01 .sub::before {
    top: calc(1.3333333333 * var(--vw));
    width: calc(2.6666666667 * var(--vw));
    height: calc(2.6666666667 * var(--vw));
  }
}
.sec .sec-ttl-02 {
  display: block;
  font-size: 3.2rem;
  line-height: 1.4;
}
.sec .sec-ttl-02::before, .sec .sec-ttl-02::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.sec .sec-ttl-02::before {
  margin-top: calc((1 - 1.4) * 0.5em);
}
.sec .sec-ttl-02::after {
  margin-bottom: calc((1 - 1.4) * 0.5em);
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02 {
    font-size: 2.4rem;
    text-align: center;
    margin-bottom: calc(8.5333333333 * var(--vw));
  }
}
.sec .sec-ttl-02 > span {
  display: inline-block;
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02 > span {
    display: inline-block;
  }
}
.sec .sec-ttl-02 .main {
  position: relative;
  padding: 0 0 0 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-02 .main {
    padding: 0 0 0 calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02 .main {
    padding: 0 0 0 calc(7.4666666667 * var(--vw));
  }
}
.sec .sec-ttl-02 .main::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  background: #00BEC6;
  aspect-ratio: 1;
  border-radius: 50%;
  width: 0.5em;
  height: 0.5em;
  margin: auto 0;
}
.sec .sec-ttl-02 .sub {
  display: block;
  font-size: 1.8rem;
  line-height: 1.4;
  margin: 7px 0 0;
  padding: 0 0 0 26px;
}
.sec .sec-ttl-02 .sub::before, .sec .sec-ttl-02 .sub::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.sec .sec-ttl-02 .sub::before {
  margin-top: calc((1 - 1.4) * 0.5em);
}
.sec .sec-ttl-02 .sub::after {
  margin-bottom: calc((1 - 1.4) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-02 .sub {
    margin: calc(0.4861111111 * var(--vw)) 0 0;
    padding: 0 0 0 calc(1.8055555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02 .sub {
    margin: calc(1.8666666667 * var(--vw)) 0 0;
    padding: 0;
  }
}
.sec .sec-ttl-02--center {
  text-align: center;
  margin: 0 0 64px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-02--center {
    margin: 0 0 calc(4.4444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02--center {
    margin: 0 0 calc(8.5333333333 * var(--vw));
  }
}
.sec .sec-ttl-02--small {
  font-size: 2.4rem;
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02--small {
    font-size: 1.8rem;
  }
}
.sec .sec-ttl-02--small .main {
  padding: 0 0 0 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-02--small .main {
    padding: 0 0 0 calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02--small .main {
    padding: 0 0 0 calc(4.8 * var(--vw));
  }
}
.sec .sec-ttl-02--small .sub {
  padding: 0 0 0 14px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-02--small .sub {
    padding: 0 0 0 calc(0.9722222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02--small .sub {
    font-size: 1.3rem;
    padding: 0 0 0 calc(2.6666666667 * var(--vw));
  }
}
.sec .sec-ttl-02--xs {
  font-size: 2rem;
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02--xs {
    font-size: 1.8rem;
  }
}
.sec .sec-ttl-02--xs .main {
  padding: 0 0 0 22px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec .sec-ttl-02--xs .main {
    padding: 0 0 0 calc(1.5277777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec .sec-ttl-02--xs .main {
    padding: 0 0 0 calc(4.8 * var(--vw));
  }
}
.sec .sec-ttl-02--xs .main::before {
  width: 0.4em;
}

.btn-box {
  margin: 64px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .btn-box {
    margin: calc(4.4444444444 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  .btn-box {
    margin: calc(17.0666666667 * var(--vw)) auto 0;
  }
}

.btn-basic--01 {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  background: #07A5C1;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1;
  font-weight: 500;
  border-radius: 27px;
  aspect-ratio: 136/27;
  overflow: hidden;
  width: 272px;
  margin: 0 auto;
}
@media only screen and (max-width: 767px) {
  .btn-basic--01 {
    order-radius: calc(7.2 * var(--vw));
    width: calc(72.5333333333 * var(--vw));
  }
}
.btn-basic--01::before, .btn-basic--01::after {
  content: "";
}
.btn-basic--01::before {
  position: absolute;
  top: 0;
  left: 0;
  background: url(../img/common/bg_btn_basic_01.png) no-repeat 0 0/100% auto;
  mix-blend-mode: overlay;
  width: 100%;
  height: 100%;
}
.btn-basic--01::after {
  position: absolute;
  top: 0;
  right: 8px;
  bottom: 0;
  background: url(../img/common/ico_arrow_white_01.svg) no-repeat center center/8px auto, #003988;
  aspect-ratio: 1;
  border-radius: 50%;
  width: 38px;
  height: 38px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .btn-basic--01::after {
    right: calc(0.5555555556 * var(--vw));
    width: calc(2.6388888889 * var(--vw));
    height: calc(2.6388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .btn-basic--01::after {
    right: calc(2.1333333333 * var(--vw));
    width: calc(10.1333333333 * var(--vw));
    height: calc(10.1333333333 * var(--vw));
  }
}
@media (hover: none) {
  .btn-basic--01 {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .btn-basic--01:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .btn-basic--01:hover {
    opacity: 0.65;
  }
}

.js-link {
  cursor: pointer;
  transition: 0.3s;
}
@media (hover: none) {
  .js-link {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .js-link:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .js-link:hover {
    opacity: 0.65;
  }
}

.sec-contact {
  background: url(../img/common/bg_contact_01.jpg) no-repeat 0 0/cover;
  color: #fff;
  padding: 100px 0 85px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact {
    padding: calc(6.9444444444 * var(--vw)) 0 calc(5.9027777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact {
    background-image: url(../img/common/bg_contact_01_sp.jpg);
    padding: calc(17.3333333333 * var(--vw)) 0;
  }
}
.sec-contact .sec-ttl {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: transparent;
  font-family: "Al Nile", "Roboto", sans-serif;
  font-size: 7.2rem;
  line-height: 1.2;
  font-weight: 700;
  text-align: center;
  -webkit-text-stroke: 2px white;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .sec-ttl {
    -webkit-text-stroke: calc(0.1388888889 * var(--vw)) white;
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .sec-ttl {
    font-size: 6.4rem;
    -webkit-text-stroke: calc(0.5333333333 * var(--vw)) white;
  }
}
.sec-contact .sec-ttl .sub {
  position: relative;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2rem;
  line-height: 1;
  font-weight: 700;
  -webkit-text-stroke: initial;
  width: auto;
  margin: -5px 0 0;
  padding: 0 0 0 20px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .sec-ttl .sub {
    margin: calc(-0.3472222222 * var(--vw)) 0 0;
    padding: 0 0 0 calc(1.3888888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .sec-ttl .sub {
    margin: calc(-1.3333333333 * var(--vw)) 0 0;
    padding: 0 0 0 calc(5.3333333333 * var(--vw));
  }
}
.sec-contact .sec-ttl .sub::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 0;
  background: #fff;
  aspect-ratio: 1;
  border-radius: 50%;
  width: 10px;
  height: 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .sec-ttl .sub::before {
    top: calc(0.3472222222 * var(--vw));
    width: calc(0.6944444444 * var(--vw));
    height: calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .sec-ttl .sub::before {
    top: calc(1.3333333333 * var(--vw));
    width: calc(2.6666666667 * var(--vw));
    height: calc(2.6666666667 * var(--vw));
  }
}
.sec-contact .txt {
  font-size: 1.6rem;
  text-align: center;
  margin: 60px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .txt {
    margin: calc(4.1666666667 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .txt {
    margin: calc(19.2 * var(--vw)) auto 0;
  }
}
.sec-contact .btn-box {
  margin-top: 48px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .btn-box {
    margin-top: calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .btn-box {
    margin-top: calc(17.0666666667 * var(--vw));
  }
}
.sec-contact .btn-contact {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: 20px;
  background: #fff;
  color: #003988;
  font-size: 1.6rem;
  border-radius: 36px;
  aspect-ratio: 159/36;
  width: 318px;
  margin: 0 auto;
  padding: 0 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .btn-contact {
    gap: calc(1.3888888889 * var(--vw));
    border-radius: calc(2.5 * var(--vw));
    width: calc(22.0833333333 * var(--vw));
    padding: 0 calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .btn-contact {
    border-radius: calc(9.6 * var(--vw));
    width: calc(84.8 * var(--vw));
    padding: 0 calc(4.2666666667 * var(--vw));
  }
}
@media (hover: none) {
  .sec-contact .btn-contact {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .sec-contact .btn-contact:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .sec-contact .btn-contact:hover {
    opacity: 0.65;
  }
}
.sec-contact .btn-contact::before, .sec-contact .btn-contact::after {
  content: "";
}
.sec-contact .btn-contact::before {
  background: url(../img/common/ico_contact_blue_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 1;
  width: 38px;
  height: 38px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .btn-contact::before {
    width: calc(2.6388888889 * var(--vw));
    height: calc(2.6388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .btn-contact::before {
    width: calc(10.1333333333 * var(--vw));
    height: calc(10.1333333333 * var(--vw));
  }
}
.sec-contact .btn-contact::after {
  position: absolute;
  top: 0;
  right: 24px;
  bottom: 0;
  background: url(../img/common/ico_arrow_blue_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 8/14;
  width: 8px;
  height: 14px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sec-contact .btn-contact::after {
    right: calc(1.6666666667 * var(--vw));
    width: calc(0.5555555556 * var(--vw));
    height: calc(0.9722222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sec-contact .btn-contact::after {
    right: calc(6.4 * var(--vw));
    width: calc(2.1333333333 * var(--vw));
    height: calc(3.7333333333 * var(--vw));
  }
}

@keyframes light {
  0% {
    opacity: 1;
  }
  20% {
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  60% {
    opacity: 0;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes loop {
  0% {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes loop2 {
  0% {
    transform: translateX(0);
  }
  to {
    transform: translateX(-200%);
  }
}
@keyframes rotation {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes blink {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes pop {
  0% {
    transform: scale(0.9);
  }
  50% {
    transform: scale(1);
  }
  100% {
    transform: scale(0.9);
  }
}
.header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 99;
  height: 96px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .header {
    height: calc(6.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .header {
    height: calc(20.2666666667 * var(--vw));
  }
}
.header.is-light-color {
  color: #fff;
}
.header::before {
  content: "";
  position: absolute;
  top: -100%;
  left: 0;
  transition: 0.3s;
  background: #fff;
  opacity: 0;
  pointer-events: none;
  width: 100%;
  height: 100%;
}
@media only screen and (min-width: 768px) {
  .header.is-scroll {
    color: #222;
  }
}
.header.is-scroll::before {
  top: 0;
  opacity: 0.6;
}
.header__in {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0 48px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .header__in {
    padding: 0 calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .header__in {
    padding: 0 calc(2.6666666667 * var(--vw));
  }
}
.header__logo {
  width: 218px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .header__logo {
    width: calc(15.1388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .header__logo {
    width: calc(42.9333333333 * var(--vw));
  }
}
.header__logo > a {
  display: block;
  background: url(../img/common/logo_header_01.png) no-repeat 0 0/100% auto;
  aspect-ratio: 454/130;
  width: 227px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .header__logo > a {
    width: calc(15.7638888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .header__logo > a {
    width: calc(44.5333333333 * var(--vw));
  }
}
@media (hover: none) {
  .header__logo > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .header__logo > a:active {
    opacity: 0.6;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .header__logo > a:hover {
    opacity: 0.6;
  }
}
body.PAGE .header__logo > a, .header.is-scroll .header__logo > a {
  background-image: url(../img/common/logo_header_02.png);
}

@media only screen and (max-width: 767px) {
  .fixed-btn-contact {
    position: fixed;
    right: 0;
    bottom: calc(32 * var(--vw));
    z-index: 98;
    width: calc(16 * var(--vw));
    height: calc(15.4666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .fixed-btn-contact .btn-contact {
    display: flex;
    justify-content: center;
    align-items: center;
    background: linear-gradient(to right, #07a5c1, #29abaa);
    border-radius: calc(8 * var(--vw)) 0 0 calc(8 * var(--vw));
    width: 100%;
    height: 100%;
    margin: 0;
  }
  .fixed-btn-contact .btn-contact::before {
    content: "";
    background: url(../img/common/ico_contact_white_01.svg) no-repeat 0 0/100% auto;
    aspect-ratio: 1;
    width: calc(10.1333333333 * var(--vw));
    height: calc(10.1333333333 * var(--vw));
  }
}

@media only screen and (max-width: 767px) {
  .gnavi {
    position: fixed;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    overflow: auto;
    width: 100%;
    height: 100vh;
  }
}
@media only screen and (min-width: 768px) {
  .gnavi__overlay {
    display: contents;
  }
}
@media only screen and (max-width: 767px) {
  .gnavi__overlay {
    position: fixed;
    top: 0;
    left: 0;
    background: url(../img/common/bg_gnavi_overlay_01_sp.jpg) no-repeat 0 0/100% auto, #F5F2EA;
    width: 100%;
    height: 100%;
  }
}
@media only screen and (min-width: 768px) {
  .gnavi__in {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 48px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .gnavi__in {
    gap: calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .gnavi__in {
    position: absolute;
    top: 0;
    left: 0;
    pointer-events: none;
    box-sizing: content-box;
    width: 100%;
    height: auto;
    padding: calc(23.4666666667 * var(--vw)) 0;
  }
  .gnavi__in * {
    box-sizing: border-box;
  }
}
.gnavi-list {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  font-size: 1.6rem;
  line-height: 1.5;
  font-weight: 500;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .gnavi-list {
    gap: calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .gnavi-list {
    color: #003953;
    flex-direction: column;
    align-items: center;
    gap: calc(10.6666666667 * var(--vw));
    font-size: 2.4rem;
    pointer-events: auto;
  }
}
@media only screen and (max-width: 767px) {
  .gnavi-list__item {
    text-align: center;
    width: 100%;
  }
}
.gnavi-list__item > a {
  display: block;
}
@media (hover: none) {
  .gnavi-list__item > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .gnavi-list__item > a:active {
    text-decoration: underline;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .gnavi-list__item > a:hover {
    text-decoration: underline;
  }
}
.gnavi .btn-contact {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  gap: 23px;
  background: linear-gradient(to right, #07a5c1 0%, #46b195 52.1%, #399f41 100%);
  color: #fff;
  font-size: 1.8rem;
  border-radius: 30px;
  aspect-ratio: 104/29;
  width: 208px;
  padding: 0 12px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .gnavi .btn-contact {
    gap: calc(1.5972222222 * var(--vw));
    border-radius: calc(2.0833333333 * var(--vw));
    width: calc(14.4444444444 * var(--vw));
    padding: 0 calc(0.8333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .gnavi .btn-contact {
    gap: calc(6.1333333333 * var(--vw));
    border-radius: calc(8 * var(--vw));
    width: calc(55.4666666667 * var(--vw));
    margin: calc(30.9333333333 * var(--vw)) auto 0;
    padding: 0 calc(3.2 * var(--vw));
  }
}
@media (hover: none) {
  .gnavi .btn-contact {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .gnavi .btn-contact:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .gnavi .btn-contact:hover {
    opacity: 0.65;
  }
}
.gnavi .btn-contact::before, .gnavi .btn-contact::after {
  content: "";
}
.gnavi .btn-contact::before {
  background: url(../img/common/ico_contact_white_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 1;
  width: 38px;
  height: 38px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .gnavi .btn-contact::before {
    width: calc(2.6388888889 * var(--vw));
    height: calc(2.6388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .gnavi .btn-contact::before {
    width: calc(10.1333333333 * var(--vw));
    height: calc(10.1333333333 * var(--vw));
  }
}
.gnavi .btn-contact::after {
  position: absolute;
  top: 0;
  right: 17px;
  bottom: 0;
  background: url(../img/common/ico_arrow_white_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 1/2;
  width: 6px;
  height: 12px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .gnavi .btn-contact::after {
    right: calc(1.1805555556 * var(--vw));
    width: calc(0.4166666667 * var(--vw));
    height: calc(0.8333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .gnavi .btn-contact::after {
    right: calc(4.5333333333 * var(--vw));
    width: calc(1.6 * var(--vw));
    height: calc(3.2 * var(--vw));
  }
}

.hamburger {
  position: absolute;
  top: calc(2.6666666667 * var(--vw));
  right: calc(2.6666666667 * var(--vw));
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(to bottom, #07a5c1 0%, #46b195 52.1%, #399f41 100%);
  border-radius: 50%;
  aspect-ratio: 1;
  width: calc(14.9333333333 * var(--vw));
  height: calc(14.9333333333 * var(--vw));
}
.hamburger__in {
  position: relative;
  aspect-ratio: 24/25;
  width: calc(6.4 * var(--vw));
}
.hamburger__in > span {
  position: absolute;
  right: 0;
  left: 0;
  background: #fff;
  transition: 0.3s;
  aspect-ratio: 8/1;
  width: calc(6.4 * var(--vw));
  height: calc(0.8 * var(--vw));
  margin: 0 auto;
}
.hamburger__in > span:nth-of-type(1) {
  top: 0;
}
.hamburger__in > span:nth-of-type(2) {
  top: 50%;
  margin-top: calc(-0.4 * var(--vw));
}
.hamburger__in > span:nth-of-type(3) {
  bottom: 0;
}
.is-open-menu .hamburger__in > span:nth-of-type(1) {
  top: 50%;
  transform: rotate(405deg);
  margin-top: calc(-0.4 * var(--vw));
}
.is-open-menu .hamburger__in > span:nth-of-type(2) {
  opacity: 0;
  visibility: hidden;
}
.is-open-menu .hamburger__in > span:nth-of-type(3) {
  top: 50%;
  transform: rotate(135deg);
  margin-top: calc(-0.4 * var(--vw));
  bottom: unset;
}

@media only screen and (min-width: 768px) {
  .footer {
    position: relative;
  }
}
.footer__logo {
  width: 295px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__logo {
    width: calc(20.4861111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .footer__logo {
    width: 90%;
    margin: 0 auto;
  }
}
.footer__logo a {
  display: block;
}
@media (hover: none) {
  .footer__logo a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .footer__logo a:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .footer__logo a:hover {
    opacity: 0.65;
  }
}
.footer__top {
  background: #F5F2EA;
  padding: 24px 0 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__top {
    padding: calc(1.6666666667 * var(--vw)) 0 calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .footer__top {
    padding: calc(12.8 * var(--vw)) 0 calc(21.3333333333 * var(--vw));
  }
}
.footer__top .footer__in {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0 48px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__top .footer__in {
    padding: 0 calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .footer__top .footer__in {
    padding: 0 calc(11.2 * var(--vw));
  }
}
.footer__top .txt {
  color: #003953;
  line-height: 1;
}
.footer__top .txt--01 {
  font-size: 1.6rem;
  font-weight: 500;
  margin: 21px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__top .txt--01 {
    margin: calc(1.4583333333 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .footer__top .txt--01 {
    font-size: 1.8rem;
    margin: calc(14.4 * var(--vw)) 0 0;
  }
}
.footer__top .txt--02 {
  font-size: 1.4rem;
  margin: 16px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__top .txt--02 {
    margin: calc(1.1111111111 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .footer__top .txt--02 {
    font-size: 1.6rem;
    line-height: 1.5;
    margin: calc(4.2666666667 * var(--vw)) 0 0;
  }
  .footer__top .txt--02::before, .footer__top .txt--02::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  .footer__top .txt--02::before {
    margin-top: calc((1 - 1.5) * 0.5em);
  }
  .footer__top .txt--02::after {
    margin-bottom: calc((1 - 1.5) * 0.5em);
  }
}
.footer__top .fnavi {
  color: #003953;
  font-size: 1.6rem;
  line-height: 1;
  padding: 25px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__top .fnavi {
    padding: calc(1.7361111111 * var(--vw)) 0 0;
  }
}
.footer__top .fnavi-list {
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__top .fnavi-list {
    gap: calc(1.5277777778 * var(--vw));
  }
}
.footer__top .fnavi-list__item > a {
  display: block;
}
@media (hover: none) {
  .footer__top .fnavi-list__item > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .footer__top .fnavi-list__item > a:active {
    text-decoration: underline;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .footer__top .fnavi-list__item > a:hover {
    text-decoration: underline;
  }
}
.footer__bottom {
  background: #003988;
  color: #fff;
  height: 50px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__bottom {
    height: calc(3.4722222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .footer__bottom {
    position: relative;
    height: auto;
    padding: calc(9.6 * var(--vw)) 0 calc(3.2 * var(--vw));
  }
}
.footer__bottom .footer__in {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding: 0 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__bottom .footer__in {
    padding: 0 calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .footer__bottom .footer__in {
    flex-direction: column;
    gap: calc(10.6666666667 * var(--vw));
    padding: 0 calc(2.6666666667 * var(--vw));
  }
}
.footer__bottom .fnavi {
  font-size: 1.4rem;
  line-height: 1;
}
@media only screen and (max-width: 767px) {
  .footer__bottom .fnavi {
    font-size: 1.6rem;
  }
}
.footer__bottom .fnavi-list {
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .footer__bottom .fnavi-list {
    flex-direction: column;
    align-items: center;
    gap: calc(8 * var(--vw));
  }
}
@media only screen and (min-width: 768px) {
  .footer__bottom .fnavi-list__item:not(:first-of-type) {
    border-left: 1px solid #fff;
    margin-left: 24px;
    padding-left: 24px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .footer__bottom .fnavi-list__item:not(:first-of-type) {
    margin-left: calc(1.6666666667 * var(--vw));
    padding-left: calc(1.6666666667 * var(--vw));
  }
}
.footer__bottom .fnavi-list__item > a {
  display: block;
  padding: 1px 0;
}
@media (hover: none) {
  .footer__bottom .fnavi-list__item > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .footer__bottom .fnavi-list__item > a:active {
    text-decoration: underline;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .footer__bottom .fnavi-list__item > a:hover {
    text-decoration: underline;
  }
}
.footer__bottom .copyright {
  font-size: 1.2rem;
}

.pagetop {
  position: fixed;
  right: 48px;
  bottom: 34px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  filter: drop-shadow(3px 3px 6px rgba(0, 0, 0, 0.25));
  border-radius: 50%;
  aspect-ratio: 1;
  width: 80px;
  height: 80px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .pagetop {
    right: calc(3.3333333333 * var(--vw));
    bottom: calc(2.3611111111 * var(--vw));
    filter: drop-shadow(calc(0.2083333333 * var(--vw)) calc(0.2083333333 * var(--vw)) calc(0.4166666667 * var(--vw)) rgba(0, 0, 0, 0.25));
    width: calc(5.5555555556 * var(--vw));
    height: calc(5.5555555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .pagetop {
    bottom: calc(2.6666666667 * var(--vw));
    right: calc(2.6666666667 * var(--vw));
    filter: drop-shadow(calc(0.8 * var(--vw)) calc(0.8 * var(--vw)) calc(1.6 * var(--vw)) rgba(0, 0, 0, 0.25));
    width: calc(21.3333333333 * var(--vw));
    height: calc(21.3333333333 * var(--vw));
  }
}
.pagetop.is-bottom {
  position: absolute;
  bottom: unset;
}
@media only screen and (min-width: 768px) {
  .pagetop.is-bottom {
    top: -114px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .pagetop.is-bottom {
    top: calc(-5.5555555556 * var(--vw) - 2.3611111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .pagetop.is-bottom {
    top: calc(-21.3333333333 * var(--vw) / 2);
  }
}
.pagetop > img {
  aspect-ratio: 9/5;
  width: 15px;
  height: 8px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .pagetop > img {
    width: calc(1.0416666667 * var(--vw));
    height: calc(0.5555555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .pagetop > img {
    width: calc(4 * var(--vw));
    height: calc(2.1333333333 * var(--vw));
  }
}

#TOP .kv {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 810px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv {
    height: calc(56.25 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv {
    height: 100vh;
  }
}
#TOP .kv .img {
  width: 100%;
  height: 100%;
}
#TOP .kv .img img {
  object-fit: cover;
  object-position: center;
  width: 100%;
  height: 100%;
}
#TOP .kv__in {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#TOP .kv .txt-box {
  position: absolute;
  top: 232px;
  left: calc(7.3611111111 * var(--vw));
  color: #fff;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv .txt-box {
    top: calc(16.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv .txt-box {
    top: calc(33.3333333333 * var(--vw));
    left: calc(2.6666666667 * var(--vw));
  }
}
#TOP .kv .txt-box .catch {
  font-size: 6.4rem;
  line-height: 1.4;
}
#TOP .kv .txt-box .catch::before, #TOP .kv .txt-box .catch::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#TOP .kv .txt-box .catch::before {
  margin-top: calc((1 - 1.4) * 0.5em);
}
#TOP .kv .txt-box .catch::after {
  margin-bottom: calc((1 - 1.4) * 0.5em);
}
@media only screen and (max-width: 767px) {
  #TOP .kv .txt-box .catch {
    font-size: 4rem;
  }
}
#TOP .kv .txt-box .txt {
  font-size: 2.4rem;
  line-height: 2;
  font-weight: 700;
  margin-top: 2.2em;
}
#TOP .kv .txt-box .txt::before, #TOP .kv .txt-box .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#TOP .kv .txt-box .txt::before {
  margin-top: calc((1 - 2) * 0.5em);
}
#TOP .kv .txt-box .txt::after {
  margin-bottom: calc((1 - 2) * 0.5em);
}
@media only screen and (min-width: 768px) {
  #TOP .kv__bottom {
    display: contents;
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv__bottom {
    position: absolute;
    right: 0;
    bottom: calc(5.3333333333 * var(--vw));
    left: 0;
    display: flex;
    flex-direction: column-reverse;
    gap: calc(4 * var(--vw));
    width: calc(100% - 5.3333333333 * var(--vw));
    margin: 0 auto;
  }
}
#TOP .kv .news-box {
  position: absolute;
  bottom: 72px;
  left: calc(3.4722222222 * var(--vw));
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  background: #fff;
  font-size: 1.6rem;
  line-height: 1.5;
  border-radius: 50px;
  width: 582px;
  padding: 18px 40px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv .news-box {
    bottom: calc(5 * var(--vw));
    border-radius: calc(3.4722222222 * var(--vw));
    width: calc(40.4166666667 * var(--vw));
    padding: calc(1.25 * var(--vw)) calc(2.7777777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv .news-box {
    position: static;
    border-radius: calc(2.6666666667 * var(--vw));
    width: 100%;
    margin: 0 auto;
    padding: calc(4.2666666667 * var(--vw));
  }
}
#TOP .kv .news-box .category {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.4rem;
  line-height: 1;
  font-weight: 500;
  border-radius: 14px;
  margin: 0 0 0 10px;
  padding: 5px 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv .news-box .category {
    border-radius: calc(0.9722222222 * var(--vw));
    margin: 0 0 0 calc(0.6944444444 * var(--vw));
    padding: calc(0.3472222222 * var(--vw)) calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv .news-box .category {
    border-radius: calc(3.7333333333 * var(--vw));
    margin: 0 0 0 calc(2.6666666667 * var(--vw));
    padding: calc(1.3333333333 * var(--vw)) calc(2.6666666667 * var(--vw));
  }
}
#TOP .kv .news-box .txt {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0 0 0 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv .news-box .txt {
    margin: 0 0 0 calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv .news-box .txt {
    flex: 0 0 auto;
    width: 100%;
    margin: calc(2.1333333333 * var(--vw)) 0 0;
  }
}
@media (hover: none) {
  #TOP .kv .news-box a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  #TOP .kv .news-box a:active {
    text-decoration: underline;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  #TOP .kv .news-box a:hover {
    text-decoration: underline;
  }
}
#TOP .kv .recruit-box {
  position: absolute;
  right: calc(1.3888888889 * var(--vw));
  bottom: 48px;
  background: #F8DA21;
  color: #003988;
  border-radius: 50%;
  aspect-ratio: 1;
  width: 180px;
  height: 180px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv .recruit-box {
    bottom: calc(3.3333333333 * var(--vw));
    width: calc(12.5 * var(--vw));
    height: calc(12.5 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv .recruit-box {
    position: static;
    width: calc(35.4666666667 * var(--vw));
    height: calc(35.4666666667 * var(--vw));
  }
}
#TOP .kv .recruit-box > a {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
}
@media (hover: none) {
  #TOP .kv .recruit-box > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  #TOP .kv .recruit-box > a:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  #TOP .kv .recruit-box > a:hover {
    opacity: 0.65;
  }
}
#TOP .kv .recruit-box .ttl {
  font-size: 3.2rem;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  #TOP .kv .recruit-box .ttl {
    font-size: 2.3rem;
  }
}
#TOP .kv .recruit-box .txt {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 1.8rem;
  font-weight: 500;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv .recruit-box .txt {
    gap: calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv .recruit-box .txt {
    gap: calc(2.6666666667 * var(--vw));
    font-size: 1.3rem;
  }
}
#TOP .kv .recruit-box .txt img {
  aspect-ratio: 1;
  width: 24px;
  height: 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .kv .recruit-box .txt img {
    width: calc(1.6666666667 * var(--vw));
    height: calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .kv .recruit-box .txt img {
    width: calc(6.4 * var(--vw));
    height: calc(6.4 * var(--vw));
  }
}
#TOP .sec-about-us .about-us-box {
  width: 824px;
  margin: 0 0 0 auto;
  padding-top: 64px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-about-us .about-us-box {
    width: calc(57.2222222222 * var(--vw));
    padding-top: calc(4.4444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-about-us .about-us-box {
    width: 100%;
    padding: calc(12.8 * var(--vw)) calc(6.6666666667 * var(--vw)) 0;
  }
}
#TOP .sec-about-us .about-us-box .ttl {
  font-size: 3.2rem;
  line-height: 2;
  font-weight: 700;
}
#TOP .sec-about-us .about-us-box .ttl::before, #TOP .sec-about-us .about-us-box .ttl::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#TOP .sec-about-us .about-us-box .ttl::before {
  margin-top: calc((1 - 2) * 0.5em);
}
#TOP .sec-about-us .about-us-box .ttl::after {
  margin-bottom: calc((1 - 2) * 0.5em);
}
@media only screen and (max-width: 767px) {
  #TOP .sec-about-us .about-us-box .ttl {
    font-size: 2.4rem;
    line-height: 1.6;
  }
  #TOP .sec-about-us .about-us-box .ttl::before, #TOP .sec-about-us .about-us-box .ttl::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  #TOP .sec-about-us .about-us-box .ttl::before {
    margin-top: calc((1 - 1.6) * 0.5em);
  }
  #TOP .sec-about-us .about-us-box .ttl::after {
    margin-bottom: calc((1 - 1.6) * 0.5em);
  }
}
#TOP .sec-about-us .about-us-box .txt {
  font-size: 1.8rem;
  line-height: 1.9;
  padding-top: 48px;
}
#TOP .sec-about-us .about-us-box .txt::before, #TOP .sec-about-us .about-us-box .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#TOP .sec-about-us .about-us-box .txt::before {
  margin-top: calc((1 - 1.9) * 0.5em);
}
#TOP .sec-about-us .about-us-box .txt::after {
  margin-bottom: calc((1 - 1.9) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-about-us .about-us-box .txt {
    padding-top: calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-about-us .about-us-box .txt {
    font-size: 1.6rem;
    line-height: 2;
    padding-top: calc(12.8 * var(--vw));
  }
  #TOP .sec-about-us .about-us-box .txt::before, #TOP .sec-about-us .about-us-box .txt::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  #TOP .sec-about-us .about-us-box .txt::before {
    margin-top: calc((1 - 2) * 0.5em);
  }
  #TOP .sec-about-us .about-us-box .txt::after {
    margin-bottom: calc((1 - 2) * 0.5em);
  }
}
#TOP .sec-works .work-box {
  margin: 64px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-works .work-box {
    margin: calc(4.4444444444 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-works .work-box {
    margin: calc(12.8 * var(--vw)) auto 0;
  }
}
#TOP .sec-works .work-box .work-list {
  display: grid;
  grid-template-columns: repeat(2, 480px);
  gap: 56px 50px;
  padding: 0 45px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-works .work-box .work-list {
    grid-template-columns: repeat(2, calc(33.3333333333 * var(--vw)));
    gap: calc(3.8888888889 * var(--vw)) calc(3.4722222222 * var(--vw));
    padding: 0 calc(3.125 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-works .work-box .work-list {
    grid-template-columns: 1fr;
    gap: calc(10.6666666667 * var(--vw));
    padding: 0;
  }
}
#TOP .sec-works .work-box .work-list__item > a {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-works .work-box .work-list__item > a {
    border-radius: calc(1.1111111111 * var(--vw));
  }
}
@media (hover: none) {
  #TOP .sec-works .work-box .work-list__item > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  #TOP .sec-works .work-box .work-list__item > a:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  #TOP .sec-works .work-box .work-list__item > a:hover {
    opacity: 0.65;
  }
}
#TOP .sec-works .work-box .work-list .img {
  aspect-ratio: 480/308;
}
@media only screen and (max-width: 767px) {
  #TOP .sec-works .work-box .work-list .img {
    aspect-ratio: 355/228;
  }
}
#TOP .sec-works .work-box .work-list .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#TOP .sec-works .work-box .work-list .txt {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-size: 1.6rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: 100%;
  padding: 18px 83px 18px 15px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-works .work-box .work-list .txt {
    height: calc(4.0277777778 * var(--vw));
    padding: calc(1.25 * var(--vw)) calc(5.7638888889 * var(--vw)) calc(1.25 * var(--vw)) calc(1.0416666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-works .work-box .work-list .txt {
    height: calc(10.4 * var(--vw));
    padding: calc(2.6666666667 * var(--vw)) calc(15.4666666667 * var(--vw)) calc(2.6666666667 * var(--vw)) calc(2.6666666667 * var(--vw));
  }
}
#TOP .sec-works .work-box .work-list .txt::after {
  content: "";
  position: absolute;
  top: 0;
  right: 24px;
  bottom: 0;
  background: url(../img/common/ico_arrow_white_01.svg) no-repeat center/8px auto;
  border: 1px solid #fff;
  border-radius: 50%;
  aspect-ratio: 1;
  width: 38px;
  height: 38px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-works .work-box .work-list .txt::after {
    background-size: calc(0.5555555556 * var(--vw)) auto;
    right: calc(1.6666666667 * var(--vw));
    width: calc(2.6388888889 * var(--vw));
    height: calc(2.6388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-works .work-box .work-list .txt::after {
    background-size: calc(1.3333333333 * var(--vw)) auto;
    right: calc(4.2666666667 * var(--vw));
    width: calc(6.9333333333 * var(--vw));
    height: calc(6.9333333333 * var(--vw));
  }
}
#TOP .sec-business .sec__top {
  display: grid;
  grid-template-columns: 1fr 60.7272727273%;
}
@media only screen and (max-width: 767px) {
  #TOP .sec-business .sec__top {
    grid-template-columns: 1fr;
  }
}
#TOP .sec-business .sec__top .txt {
  font-size: 1.6rem;
  line-height: 2;
}
#TOP .sec-business .sec__top .txt::before, #TOP .sec-business .sec__top .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#TOP .sec-business .sec__top .txt::before {
  margin-top: calc((1 - 2) * 0.5em);
}
#TOP .sec-business .sec__top .txt::after {
  margin-bottom: calc((1 - 2) * 0.5em);
}
@media only screen and (max-width: 767px) {
  #TOP .sec-business .sec__top .txt {
    margin: calc(12.8 * var(--vw)) auto 0;
    padding: 0 calc(6.6666666667 * var(--vw));
  }
}
@media only screen and (min-width: 768px) {
  #TOP .sec-business .sec__top .btn-basic--01 {
    margin: 0 0 0 auto;
  }
}
#TOP .business-box {
  margin: 64px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .business-box {
    margin: calc(4.4444444444 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #TOP .business-box {
    margin: calc(16 * var(--vw)) 0 0;
  }
}
#TOP .business-box .business-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px;
  padding: 0 45px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .business-box .business-list {
    gap: calc(3.4722222222 * var(--vw));
    padding: 0 calc(3.125 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .business-box .business-list {
    grid-template-columns: 1fr;
    gap: calc(10.6666666667 * var(--vw));
    padding: 0;
  }
}
#TOP .business-box .business-list__item {
  background: #F5F2EA;
  border-radius: 16px;
  padding: 40px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .business-box .business-list__item {
    border-radius: calc(1.1111111111 * var(--vw));
    padding: calc(2.7777777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .business-box .business-list__item {
    border-radius: calc(4.2666666667 * var(--vw));
    padding: calc(4.2666666667 * var(--vw)) calc(3.2 * var(--vw));
  }
}
#TOP .business-box .business-list__item .img {
  overflow: hidden;
  border-radius: 16px;
  aspect-ratio: 450/319;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .business-box .business-list__item .img {
    border-radius: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .business-box .business-list__item .img {
    border-radius: calc(4.2666666667 * var(--vw));
    aspect-ratio: 330/234;
  }
}
#TOP .business-box .business-list__item .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#TOP .business-box .business-list__item .txt {
  font-size: 2rem;
  line-height: 1.45;
  font-weight: 700;
  padding: 24px 0 0;
}
#TOP .business-box .business-list__item .txt::before, #TOP .business-box .business-list__item .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#TOP .business-box .business-list__item .txt::before {
  margin-top: calc((1 - 1.45) * 0.5em);
}
#TOP .business-box .business-list__item .txt::after {
  margin-bottom: calc((1 - 1.45) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .business-box .business-list__item .txt {
    padding: calc(1.6666666667 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #TOP .business-box .business-list__item .txt {
    font-size: 1.6rem;
    line-height: 1.5;
    padding: calc(4.2666666667 * var(--vw)) 0 0;
  }
  #TOP .business-box .business-list__item .txt::before, #TOP .business-box .business-list__item .txt::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  #TOP .business-box .business-list__item .txt::before {
    margin-top: calc((1 - 1.5) * 0.5em);
  }
  #TOP .business-box .business-list__item .txt::after {
    margin-bottom: calc((1 - 1.5) * 0.5em);
  }
}
#TOP .sec-news .news-box {
  width: 960px;
  margin: 64px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-news .news-box {
    width: calc(66.6666666667 * var(--vw));
    margin: calc(4.4444444444 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-news .news-box {
    width: 100%;
    margin: calc(12.8 * var(--vw)) auto 0;
  }
}
#TOP .sec-news .news-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-news .news-list {
    gap: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-news .news-list {
    gap: calc(10.6666666667 * var(--vw));
  }
}
#TOP .sec-news .news-list__item {
  position: relative;
}
#TOP .sec-news .news-list__item > a {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  background: #fff;
  font-size: 1.6rem;
  line-height: 1.5;
  border-radius: 16px;
  padding: 32px 48px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-news .news-list__item > a {
    gap: calc(1.1111111111 * var(--vw));
    border-radius: calc(1.1111111111 * var(--vw));
    padding: calc(2.2222222222 * var(--vw)) calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-news .news-list__item > a {
    gap: calc(2.6666666667 * var(--vw));
    border-radius: calc(4.2666666667 * var(--vw));
    padding: calc(4.2666666667 * var(--vw));
  }
}
#TOP .sec-news .news-list__item > a::after {
  content: "";
  position: absolute;
  top: 0;
  right: 24px;
  bottom: 0;
  background: url(../img/common/ico_arrow_green_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 4/7;
  width: 12px;
  height: 21px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-news .news-list__item > a::after {
    right: calc(1.6666666667 * var(--vw));
    width: calc(0.8333333333 * var(--vw));
    height: calc(1.4583333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-news .news-list__item > a::after {
    display: none;
  }
}
@media (hover: none) {
  #TOP .sec-news .news-list__item > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  #TOP .sec-news .news-list__item > a:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  #TOP .sec-news .news-list__item > a:hover {
    opacity: 0.65;
  }
}
#TOP .sec-news .news-list .category {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.4rem;
  border-radius: 14px;
  padding: 0 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-news .news-list .category {
    border-radius: calc(0.9722222222 * var(--vw));
    padding: 0 calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-news .news-list .category {
    border-radius: calc(3.7333333333 * var(--vw));
    padding: 0 calc(2.6666666667 * var(--vw));
  }
}
#TOP .sec-recruit {
  position: relative;
}
@media only screen and (max-width: 767px) {
  #TOP .sec-recruit {
    padding-top: 0;
  }
}
#TOP .sec-recruit .img {
  position: absolute;
  top: 0;
  left: 0;
  width: 52.4305555556%;
  height: 100%;
}
@media only screen and (max-width: 767px) {
  #TOP .sec-recruit .img {
    position: static;
    aspect-ratio: 377/255;
    width: 100%;
    height: auto;
  }
}
#TOP .sec-recruit .img img {
  object-fit: cover;
  object-position: top;
  width: 100%;
  height: 100%;
}
#TOP .sec-recruit .sec__in {
  display: flex;
  justify-content: flex-end;
}
#TOP .sec-recruit .txt-box {
  margin-left: auto;
  padding: 0 100px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-recruit .txt-box {
    padding: 0 calc(6.9444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-recruit .txt-box {
    margin: 0 auto 0;
    padding: calc(17.0666666667 * var(--vw)) calc(4.8 * var(--vw)) 0;
  }
}
#TOP .sec-recruit .txt {
  font-size: 1.6rem;
  line-height: 1.75;
  margin: 64px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #TOP .sec-recruit .txt {
    margin: calc(4.4444444444 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  #TOP .sec-recruit .txt {
    margin: calc(12.8 * var(--vw)) auto 0;
  }
}

.PAGE .wrapper {
  position: relative;
  background: #FFFFF8;
  padding: 96px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .PAGE .wrapper {
    padding: calc(6.6666666667 * var(--vw)) 0 0;
  }
}
.PAGE .wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background: url(../img/common/orn_page_01.png) no-repeat 0 0/100% auto;
  aspect-ratio: 170/365;
  width: 170px;
  height: 365px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .PAGE .wrapper::before {
    width: calc(11.8055555556 * var(--vw));
    height: calc(25.3472222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .PAGE .wrapper::before {
    background-image: url(../img/common/orn_page_01_sp.png);
    aspect-ratio: 100/225;
    width: calc(26.6666666667 * var(--vw));
    height: calc(60 * var(--vw));
  }
}
.PAGE .sec:not(.sec-contact) {
  padding: 100px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .PAGE .sec:not(.sec-contact) {
    padding: calc(6.9444444444 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  .PAGE .sec:not(.sec-contact) {
    padding: calc(12.8 * var(--vw)) 0;
  }
}
.PAGE .page-header {
  height: 216px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .PAGE .page-header {
    height: calc(15 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .PAGE .page-header {
    height: calc(30.6666666667 * var(--vw));
  }
}
.PAGE .page-header .sec__in {
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 767px) {
  .PAGE .page-header .sec__in {
    align-items: flex-end;
  }
}
.PAGE .page-header .ttl {
  display: grid;
  gap: 29px;
  width: 100%;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .PAGE .page-header .ttl {
    gap: calc(2.0138888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .PAGE .page-header .ttl {
    gap: calc(3.7333333333 * var(--vw));
    text-align: center;
  }
}
.PAGE .page-header .ttl .jp {
  color: #222;
  font-size: 4.8rem;
  line-height: 1.3;
}
.PAGE .page-header .ttl .jp::before, .PAGE .page-header .ttl .jp::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.PAGE .page-header .ttl .jp::before {
  margin-top: calc((1 - 1.3) * 0.5em);
}
.PAGE .page-header .ttl .jp::after {
  margin-bottom: calc((1 - 1.3) * 0.5em);
}
@media only screen and (max-width: 767px) {
  .PAGE .page-header .ttl .jp {
    font-size: 3.2rem;
  }
}
.PAGE .page-header .ttl .en {
  font-family: "Al Nile", "Roboto", sans-serif;
  color: #003988;
  font-size: 3.2rem;
  line-height: 1.25;
}
.PAGE .page-header .ttl .en::before, .PAGE .page-header .ttl .en::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.PAGE .page-header .ttl .en::before {
  margin-top: calc((1 - 1.25) * 0.5em);
}
.PAGE .page-header .ttl .en::after {
  margin-bottom: calc((1 - 1.25) * 0.5em);
}
@media only screen and (max-width: 767px) {
  .PAGE .page-header .ttl .en {
    font-size: 2.4rem;
  }
}
.PAGE .table {
  border-top: 2px solid #C4C4C4;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .PAGE .table {
    border-top-width: calc(0.1388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .PAGE .table {
    border-top-width: calc(0.5333333333 * var(--vw));
  }
}
.PAGE .table .row {
  display: grid;
  grid-template-columns: 140px 1fr;
  border-bottom: 2px solid #C4C4C4;
  padding: 35px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .PAGE .table .row {
    grid-template-columns: calc(9.7222222222 * var(--vw)) 1fr;
    border-bottom-width: calc(0.1388888889 * var(--vw));
    padding: calc(2.4305555556 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  .PAGE .table .row {
    grid-template-columns: 1fr;
    border-bottom-width: calc(0.5333333333 * var(--vw));
    padding: calc(5.3333333333 * var(--vw)) 0;
  }
}
.PAGE .table .term, .PAGE .table .desc {
  font-size: 1.8rem;
  line-height: 1.1;
}
@media only screen and (max-width: 767px) {
  .PAGE .table .term, .PAGE .table .desc {
    font-size: 1.6rem;
    line-height: 1.75;
  }
}
.PAGE .table .term {
  font-weight: 500;
}
.PAGE .table .desc {
  font-weight: 400;
}
@media only screen and (max-width: 767px) {
  .PAGE .table .desc {
    margin: calc(2.6666666667 * var(--vw)) 0 0;
  }
}
.PAGE .js-accordion__content {
  display: none;
}
#COMPANY.TOP .sec__in .column__wrap {
  display: grid;
  grid-template-columns: 1fr 720px;
  align-items: flex-start;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #COMPANY.TOP .sec__in .column__wrap {
    grid-template-columns: 1fr calc(50 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec__in .column__wrap {
    grid-template-columns: 1fr;
  }
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec .box {
    width: calc(80 * var(--vw));
    margin: 0 auto;
  }
}
#COMPANY.TOP .sec-greeting .txt {
  font-size: 1.8rem;
  line-height: 2.2;
}
#COMPANY.TOP .sec-greeting .txt::before, #COMPANY.TOP .sec-greeting .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#COMPANY.TOP .sec-greeting .txt::before {
  margin-top: calc((1 - 2.2) * 0.5em);
}
#COMPANY.TOP .sec-greeting .txt::after {
  margin-bottom: calc((1 - 2.2) * 0.5em);
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec-greeting .txt {
    font-size: 1.6rem;
    line-height: 2;
  }
  #COMPANY.TOP .sec-greeting .txt::before, #COMPANY.TOP .sec-greeting .txt::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  #COMPANY.TOP .sec-greeting .txt::before {
    margin-top: calc((1 - 2) * 0.5em);
  }
  #COMPANY.TOP .sec-greeting .txt::after {
    margin-bottom: calc((1 - 2) * 0.5em);
  }
}
#COMPANY.TOP .sec-greeting .txt:not(:first-of-type) {
  margin-top: 0.55em;
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec-greeting .txt:not(:first-of-type) {
    margin-top: 0.5em;
  }
}
#COMPANY.TOP .sec-greeting .author {
  font-size: 1.8rem;
  line-height: 1.5;
  text-align: right;
  margin: 8px 0 0;
}
#COMPANY.TOP .sec-greeting .author::before, #COMPANY.TOP .sec-greeting .author::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#COMPANY.TOP .sec-greeting .author::before {
  margin-top: calc((1 - 1.5) * 0.5em);
}
#COMPANY.TOP .sec-greeting .author::after {
  margin-bottom: calc((1 - 1.5) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #COMPANY.TOP .sec-greeting .author {
    margin: calc(0.5555555556 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec-greeting .author {
    margin: calc(8.5333333333 * var(--vw)) 0 0;
  }
}
#COMPANY.TOP .sec-greeting .author .name {
  font-family: serif;
  font-size: 3.2rem;
  font-weight: 500;
}
#COMPANY.TOP .sec-greeting .author .position {
  font-weight: 500;
  margin: 0 1em 0 0;
}
#COMPANY.TOP .sec-policy .lead-txt {
  font-size: 3.2rem;
  line-height: 2;
  font-weight: 700;
}
#COMPANY.TOP .sec-policy .lead-txt::before, #COMPANY.TOP .sec-policy .lead-txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#COMPANY.TOP .sec-policy .lead-txt::before {
  margin-top: calc((1 - 2) * 0.5em);
}
#COMPANY.TOP .sec-policy .lead-txt::after {
  margin-bottom: calc((1 - 2) * 0.5em);
}
#COMPANY.TOP .sec-policy .txt {
  font-size: 1.8rem;
  line-height: 2.2;
  font-weight: 500;
  margin: 48px 0 0;
}
#COMPANY.TOP .sec-policy .txt::before, #COMPANY.TOP .sec-policy .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#COMPANY.TOP .sec-policy .txt::before {
  margin-top: calc((1 - 2.2) * 0.5em);
}
#COMPANY.TOP .sec-policy .txt::after {
  margin-bottom: calc((1 - 2.2) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #COMPANY.TOP .sec-policy .txt {
    margin: calc(3.3333333333 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec-policy .txt {
    font-size: 1.6rem;
    line-height: 2;
    white-space: nowrap;
    margin: calc(12.8 * var(--vw)) 0 0;
  }
  #COMPANY.TOP .sec-policy .txt::before, #COMPANY.TOP .sec-policy .txt::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
  }
  #COMPANY.TOP .sec-policy .txt::before {
    margin-top: calc((1 - 2) * 0.5em);
  }
  #COMPANY.TOP .sec-policy .txt::after {
    margin-bottom: calc((1 - 2) * 0.5em);
  }
}
#COMPANY.TOP .sec-outline .table .term,
#COMPANY.TOP .sec-outline .table .desc {
  line-height: 1.78;
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec-access .box {
    width: 100%;
  }
}
#COMPANY.TOP .sec-access .map {
  position: relative;
  aspect-ratio: 720/413;
}
#COMPANY.TOP .sec-access .map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#COMPANY.TOP .sec-access .table {
  border-top: none;
}
@media only screen and (max-width: 767px) {
  #COMPANY.TOP .sec-access .table {
    width: calc(80 * var(--vw));
    margin: 0 auto;
  }
}

#BUSINESS.TOP .sec-lead .lead-txt {
  font-size: 1.6rem;
  line-height: 1.75;
  width: 840px;
  margin: 0 auto;
}
#BUSINESS.TOP .sec-lead .lead-txt::before, #BUSINESS.TOP .sec-lead .lead-txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#BUSINESS.TOP .sec-lead .lead-txt::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#BUSINESS.TOP .sec-lead .lead-txt::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-lead .lead-txt {
    width: calc(80 * var(--vw));
    margin: 0 auto;
  }
}
#BUSINESS.TOP .sec-residential-land-development .column__wrap {
  display: grid;
  grid-template-columns: 1fr 347px;
  gap: 48px;
  width: 840px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-residential-land-development .column__wrap {
    grid-template-columns: 1fr calc(24.0972222222 * var(--vw));
    gap: calc(3.3333333333 * var(--vw));
    width: calc(58.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-residential-land-development .column__wrap {
    grid-template-columns: 1fr;
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-residential-land-development .txt-box {
    width: calc(80 * var(--vw));
    margin: 0 auto;
  }
}
#BUSINESS.TOP .sec-residential-land-development .txt-box .txt {
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: -0.01em;
}
#BUSINESS.TOP .sec-residential-land-development .txt-box .txt::before, #BUSINESS.TOP .sec-residential-land-development .txt-box .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#BUSINESS.TOP .sec-residential-land-development .txt-box .txt::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#BUSINESS.TOP .sec-residential-land-development .txt-box .txt::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
#BUSINESS.TOP .sec-residential-land-development .img-box .img {
  overflow: hidden;
  border-radius: 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-residential-land-development .img-box .img {
    border-radius: calc(1.1111111111 * var(--vw));
  }
}
#BUSINESS.TOP .sec-business .business-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 80px;
  width: 840px;
  margin: 100px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-business .business-list {
    gap: calc(5.5555555556 * var(--vw));
    width: calc(58.3333333333 * var(--vw));
    margin: calc(6.9444444444 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-business .business-list {
    width: 100%;
    margin: calc(13.3333333333 * var(--vw)) auto 0;
  }
}
#BUSINESS.TOP .sec-business .business-list__item {
  display: grid;
  grid-template-columns: 347px 1fr;
  gap: 48px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-business .business-list__item {
    grid-template-columns: calc(24.0972222222 * var(--vw)) 1fr;
    gap: calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-business .business-list__item {
    grid-template-columns: 1fr;
    gap: calc(12.8 * var(--vw));
  }
}
@media only screen and (min-width: 768px) {
  #BUSINESS.TOP .sec-business .business-list__item:nth-of-type(even) {
    grid-template-columns: 1fr 347px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-business .business-list__item:nth-of-type(even) {
    grid-template-columns: 1fr calc(24.0972222222 * var(--vw));
  }
}
@media only screen and (min-width: 768px) {
  #BUSINESS.TOP .sec-business .business-list__item:nth-of-type(even) .txt-box {
    order: 1;
  }
}
@media only screen and (min-width: 768px) {
  #BUSINESS.TOP .sec-business .business-list__item:nth-of-type(even) .img-box {
    order: 2;
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-business .business-list .img-box {
    order: 2;
  }
}
#BUSINESS.TOP .sec-business .business-list .img-box .img {
  overflow: hidden;
  border-radius: 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-business .business-list .img-box .img {
    border-radius: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-business .business-list .txt-box {
    order: 1;
    margin: 0 auto;
  }
}
#BUSINESS.TOP .sec-business .business-list .txt-box .txt {
  font-size: 1.6rem;
  line-height: 1.75;
  margin: 24px 0 0;
}
#BUSINESS.TOP .sec-business .business-list .txt-box .txt::before, #BUSINESS.TOP .sec-business .business-list .txt-box .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#BUSINESS.TOP .sec-business .business-list .txt-box .txt::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#BUSINESS.TOP .sec-business .business-list .txt-box .txt::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-business .business-list .txt-box .txt {
    margin: calc(1.6666666667 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-business .business-list .txt-box .txt {
    width: calc(80 * var(--vw));
    margin: calc(6.4 * var(--vw)) auto 0;
  }
}
#BUSINESS.TOP .sec-business .business-list .category-list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 10px;
  margin: 24px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-business .business-list .category-list {
    gap: calc(1.1111111111 * var(--vw)) calc(0.6944444444 * var(--vw));
    margin: calc(1.6666666667 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-business .business-list .category-list {
    justify-content: center;
    gap: calc(4.2666666667 * var(--vw)) calc(2.6666666667 * var(--vw));
    margin: calc(4.8 * var(--vw)) 0 0;
  }
}
#BUSINESS.TOP .sec-business .business-list .category-list__item {
  background: #fff;
  color: #0EABC7;
  font-size: 1.6rem;
  line-height: 1;
  font-weight: 700;
  border: 1px solid #0EABC7;
  border-radius: 28px;
  padding: 9px 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #BUSINESS.TOP .sec-business .business-list .category-list__item {
    border-radius: calc(1.9444444444 * var(--vw));
    padding: calc(0.625 * var(--vw)) calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #BUSINESS.TOP .sec-business .business-list .category-list__item {
    font-size: 1.2rem;
    border-radius: calc(5.6 * var(--vw));
    padding: calc(1.8666666667 * var(--vw)) calc(3.2 * var(--vw));
  }
}

#NEWS .sec-category {
  padding: 48px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS .sec-category {
    padding: calc(3.3333333333 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  #NEWS .sec-category {
    padding: calc(21.3333333333 * var(--vw)) 0 calc(10.6666666667 * var(--vw));
  }
}
#NEWS .sec-category + .sec {
  padding-top: 0;
}
#NEWS .sec-category .category-list {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS .sec-category .category-list {
    gap: calc(2.7777777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS .sec-category .category-list {
    gap: calc(6.4 * var(--vw));
  }
}
#NEWS .sec-category .btn-category {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.8rem;
  font-weight: 700;
  border: 1px solid #01BEC6;
  border-radius: 28px;
  min-width: 100px;
  height: 46px;
  padding: 0 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS .sec-category .btn-category {
    border-radius: calc(1.9444444444 * var(--vw));
    min-width: calc(6.9444444444 * var(--vw));
    height: calc(3.1944444444 * var(--vw));
    padding: 0 calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS .sec-category .btn-category {
    font-size: 1.4rem;
    border-radius: calc(7.4666666667 * var(--vw));
    min-width: calc(13.8666666667 * var(--vw));
    height: calc(7.4666666667 * var(--vw));
    padding: 0 calc(2.9333333333 * var(--vw));
  }
}
@media (hover: none) {
  #NEWS .sec-category .btn-category {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  #NEWS .sec-category .btn-category:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  #NEWS .sec-category .btn-category:hover {
    opacity: 0.65;
  }
}
#NEWS .sec-news {
  padding: 0 0 120px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS .sec-news {
    padding: 0 0 calc(8.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS .sec-news {
    padding: 0 0 calc(17.0666666667 * var(--vw));
  }
}
#NEWS.ARCHIVES .news-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 80px 53px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list {
    gap: calc(5.5555555556 * var(--vw)) calc(3.6805555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list {
    grid-template-columns: 1fr;
    gap: calc(17.0666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list__item {
    width: calc(88 * var(--vw));
    margin: 0 auto;
  }
}
#NEWS.ARCHIVES .news-list__item > a {
  background: #F5F2EA;
  display: block;
  border-radius: 16px;
  height: 100%;
  padding: 32px 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list__item > a {
    border-radius: calc(1.1111111111 * var(--vw));
    padding: calc(2.2222222222 * var(--vw)) calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list__item > a {
    border-radius: calc(4.2666666667 * var(--vw));
    padding: calc(8.5333333333 * var(--vw)) calc(4.2666666667 * var(--vw));
  }
}
#NEWS.ARCHIVES .news-list__item .img {
  aspect-ratio: 298/160;
  width: 298px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list__item .img {
    width: calc(20.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list__item .img {
    width: calc(79.4666666667 * var(--vw));
  }
}
#NEWS.ARCHIVES .news-list__item .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#NEWS.ARCHIVES .news-list .news__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 15px;
  margin: 32px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list .news__header {
    gap: calc(1.0416666667 * var(--vw));
    margin: calc(2.2222222222 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list .news__header {
    gap: calc(4 * var(--vw));
    margin: calc(8.5333333333 * var(--vw)) 0 0;
  }
}
#NEWS.ARCHIVES .news-list .news__header .date {
  font-size: 1.6rem;
}
#NEWS.ARCHIVES .news-list .news__header .category {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.4rem;
  border-radius: 14px;
  min-width: 80px;
  height: 28px;
  padding: 0 12px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list .news__header .category {
    border-radius: calc(0.9722222222 * var(--vw));
    min-width: calc(5.5555555556 * var(--vw));
    height: calc(1.9444444444 * var(--vw));
    padding: 0 calc(0.8333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list .news__header .category {
    border-radius: calc(3.7333333333 * var(--vw));
    min-width: calc(21.3333333333 * var(--vw));
    height: calc(7.4666666667 * var(--vw));
    padding: 0 calc(3.2 * var(--vw));
  }
}
#NEWS.ARCHIVES .news-list .news__content {
  margin: 24px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list .news__content {
    margin: calc(1.6666666667 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list .news__content {
    margin: calc(6.4 * var(--vw)) 0 0;
  }
}
#NEWS.ARCHIVES .news-list .news__content .ttl {
  font-size: 1.6rem;
  line-height: 1.75;
  height: 3.5em;
}
#NEWS.ARCHIVES .news-list .news__content .ttl::before, #NEWS.ARCHIVES .news-list .news__content .ttl::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#NEWS.ARCHIVES .news-list .news__content .ttl::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#NEWS.ARCHIVES .news-list .news__content .ttl::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
#NEWS.ARCHIVES .news-list .news__content .link {
  position: relative;
  color: #0DABC7;
  text-align: right;
  margin: 20px 0 0;
  padding: 0 52px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list .news__content .link {
    margin: calc(1.3888888889 * var(--vw)) 0 0;
    padding: 0 calc(3.6111111111 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list .news__content .link {
    margin: calc(5.3333333333 * var(--vw)) 0 0;
    padding: 0 calc(13.8666666667 * var(--vw)) 0 0;
  }
}
#NEWS.ARCHIVES .news-list .news__content .link::after {
  content: "";
  position: absolute;
  top: 0;
  right: 10px;
  bottom: 0;
  background: url(../img/common/ico_arrow_green_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 9/16;
  width: 9px;
  height: 16px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #NEWS.ARCHIVES .news-list .news__content .link::after {
    right: calc(0.6944444444 * var(--vw));
    width: calc(0.625 * var(--vw));
    height: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #NEWS.ARCHIVES .news-list .news__content .link::after {
    right: calc(2.6666666667 * var(--vw));
    width: calc(2.4 * var(--vw));
    height: calc(4.2666666667 * var(--vw));
  }
}
#NEWS.ARCHIVES .news-list .news__content .link > span {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.75;
}
#NEWS.ARCHIVES .news-list .news__content .link > span::before, #NEWS.ARCHIVES .news-list .news__content .link > span::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#NEWS.ARCHIVES .news-list .news__content .link > span::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#NEWS.ARCHIVES .news-list .news__content .link > span::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}

#WORKS .sec-works {
  padding: 48px 0 120px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS .sec-works {
    padding: calc(3.3333333333 * var(--vw)) 0 calc(8.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS .sec-works {
    padding: calc(12.8 * var(--vw)) 0 calc(17.0666666667 * var(--vw));
  }
}
#WORKS.ARCHIVES .sec-kv {
  padding: 0 0 132px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .sec-kv {
    padding: 0 0 calc(9.1666666667 * var(--vw));
  }
}
#WORKS.ARCHIVES .sec-kv .sec__in {
  position: relative;
}
#WORKS.ARCHIVES .sec-kv .swiper-slide {
  aspect-ratio: 1100/498;
  width: 100%;
}
#WORKS.ARCHIVES .sec-kv .swiper-slide > a {
  display: block;
  width: 100%;
  height: 100%;
}
#WORKS.ARCHIVES .sec-kv .swiper-slide img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#WORKS.ARCHIVES .sec-kv .swiper-button-prev, #WORKS.ARCHIVES .sec-kv .swiper-button-next {
  background: #FFFFFF;
  border-radius: 50%;
  filter: drop-shadow(2px 3px 6px rgba(0, 0, 0, 0.25));
  aspect-ratio: 1;
  width: 48px;
  height: 48px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-prev, #WORKS.ARCHIVES .sec-kv .swiper-button-next {
    filter: drop-shadow(calc(0.1388888889 * var(--vw)) calc(0.2083333333 * var(--vw)) calc(0.4166666667 * var(--vw)) rgba(0, 0, 0, 0.25));
    width: calc(3.3333333333 * var(--vw));
    height: calc(3.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-prev, #WORKS.ARCHIVES .sec-kv .swiper-button-next {
    filter: drop-shadow(calc(0.5333333333 * var(--vw)) calc(0.8 * var(--vw)) calc(1.6 * var(--vw)) rgba(0, 0, 0, 0.25));
    width: calc(12.8 * var(--vw));
    height: calc(12.8 * var(--vw));
  }
}
#WORKS.ARCHIVES .sec-kv .swiper-button-prev::before, #WORKS.ARCHIVES .sec-kv .swiper-button-next::before {
  content: "";
  background: url(../img/common/ico_arrow_blue_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 10/18;
  width: 10px;
  height: 18px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-prev::before, #WORKS.ARCHIVES .sec-kv .swiper-button-next::before {
    width: calc(0.6944444444 * var(--vw));
    height: calc(1.25 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-prev::before, #WORKS.ARCHIVES .sec-kv .swiper-button-next::before {
    width: calc(2.6666666667 * var(--vw));
    height: calc(4.8 * var(--vw));
  }
}
#WORKS.ARCHIVES .sec-kv .swiper-button-prev::after, #WORKS.ARCHIVES .sec-kv .swiper-button-next::after {
  display: none;
}
#WORKS.ARCHIVES .sec-kv .swiper-button-prev {
  left: 82px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-prev {
    left: calc(5.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-prev {
    left: 0;
  }
}
#WORKS.ARCHIVES .sec-kv .swiper-button-prev::before {
  transform: rotate(180deg);
}
#WORKS.ARCHIVES .sec-kv .swiper-button-next {
  right: 82px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-next {
    right: calc(5.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .sec-kv .swiper-button-next {
    right: 0;
  }
}
#WORKS.ARCHIVES .sec-kv .swiper-pagination {
  top: unset;
  bottom: -60px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .sec-kv .swiper-pagination {
    bottom: calc(-4.1666666667 * var(--vw));
  }
}
#WORKS.ARCHIVES .sec-kv .swiper-pagination-bullet {
  background: #C4C4C4;
  opacity: 1;
  border-radius: 50%;
  aspect-ratio: 1;
  width: 16px;
  height: 16px;
  margin: 0 12px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .sec-kv .swiper-pagination-bullet {
    width: calc(1.1111111111 * var(--vw));
    height: calc(1.1111111111 * var(--vw));
    margin: 0 calc(0.8333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .sec-kv .swiper-pagination-bullet {
    width: calc(4.2666666667 * var(--vw));
    height: calc(4.2666666667 * var(--vw));
    margin: 0 calc(3.2 * var(--vw));
  }
}
#WORKS.ARCHIVES .sec-kv .swiper-pagination-bullet-active {
  background: #003988;
}
#WORKS.ARCHIVES .sec-works {
  background: #F5F2EA;
}
#WORKS.ARCHIVES .archive-dropdown {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .archive-dropdown {
    justify-content: center;
  }
}
#WORKS.ARCHIVES .archive-dropdown .container {
  position: relative;
  background: #fff;
  border: 2px solid #07A5C1;
  border-radius: 27px;
  min-width: 272px;
  height: 54px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .archive-dropdown .container {
    border-width: calc(0.1388888889 * var(--vw));
    border-radius: calc(1.875 * var(--vw));
    min-width: calc(18.8888888889 * var(--vw));
    height: calc(3.75 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .archive-dropdown .container {
    border-width: calc(0.5333333333 * var(--vw));
    border-radius: calc(7.2 * var(--vw));
    min-width: calc(72.5333333333 * var(--vw));
    height: calc(14.4 * var(--vw));
  }
}
#WORKS.ARCHIVES .archive-dropdown .container::after {
  content: "";
  position: absolute;
  top: 0;
  right: 30px;
  bottom: 0;
  transform: rotate(90deg);
  background: url(../img/common/ico_arrow_green_01.svg) no-repeat 0 0/100% auto;
  pointer-events: none;
  aspect-ratio: 5/9;
  width: 10px;
  height: 18px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .archive-dropdown .container::after {
    right: calc(2.0833333333 * var(--vw));
    width: calc(0.6944444444 * var(--vw));
    height: calc(1.25 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .archive-dropdown .container::after {
    right: calc(8 * var(--vw));
    width: calc(2.6666666667 * var(--vw));
    height: calc(4.8 * var(--vw));
  }
}
#WORKS.ARCHIVES .archive-dropdown select {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  color: #07A5C1;
  font-size: 1.8rem;
  width: 100%;
  height: 100%;
  padding: 0 25px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .archive-dropdown select {
    padding: 0 calc(1.7361111111 * var(--vw));
  }
}
#WORKS.ARCHIVES .works-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 80px 53px;
  padding: 48px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list {
    gap: calc(5.5555555556 * var(--vw)) calc(3.6805555556 * var(--vw));
    padding: calc(3.3333333333 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list {
    grid-template-columns: 1fr;
    gap: calc(17.0666666667 * var(--vw));
    padding: calc(12.8 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list__item {
    width: calc(88 * var(--vw));
    margin: 0 auto;
  }
}
#WORKS.ARCHIVES .works-list__item > a {
  background: #fff;
  display: block;
  border-radius: 16px;
  padding: 32px 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list__item > a {
    border-radius: calc(1.1111111111 * var(--vw));
    padding: calc(2.2222222222 * var(--vw)) calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list__item > a {
    border-radius: calc(4.2666666667 * var(--vw));
    padding: calc(8.5333333333 * var(--vw)) calc(4.2666666667 * var(--vw));
  }
}
#WORKS.ARCHIVES .works-list__item .img {
  aspect-ratio: 298/160;
  width: 298px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list__item .img {
    width: calc(20.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list__item .img {
    width: calc(79.4666666667 * var(--vw));
  }
}
#WORKS.ARCHIVES .works-list__item .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
#WORKS.ARCHIVES .works-list .works__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 15px;
  margin: 32px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list .works__header {
    gap: calc(1.0416666667 * var(--vw));
    margin: calc(2.2222222222 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list .works__header {
    gap: calc(4 * var(--vw));
    margin: calc(8.5333333333 * var(--vw)) 0 0;
  }
}
#WORKS.ARCHIVES .works-list .works__header .date {
  font-size: 1.6rem;
}
#WORKS.ARCHIVES .works-list .works__header .category {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.4rem;
  border-radius: 14px;
  min-width: 80px;
  height: 28px;
  padding: 0 12px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list .works__header .category {
    border-radius: calc(0.9722222222 * var(--vw));
    min-width: calc(5.5555555556 * var(--vw));
    height: calc(1.9444444444 * var(--vw));
    padding: 0 calc(0.8333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list .works__header .category {
    border-radius: calc(3.7333333333 * var(--vw));
    min-width: calc(21.3333333333 * var(--vw));
    height: calc(7.4666666667 * var(--vw));
    padding: 0 calc(3.2 * var(--vw));
  }
}
#WORKS.ARCHIVES .works-list .works__content {
  margin: 24px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list .works__content {
    margin: calc(1.6666666667 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list .works__content {
    margin: calc(6.4 * var(--vw)) 0 0;
  }
}
#WORKS.ARCHIVES .works-list .works__content .ttl {
  font-size: 1.6rem;
  line-height: 1.75;
  height: 3.5em;
}
#WORKS.ARCHIVES .works-list .works__content .ttl::before, #WORKS.ARCHIVES .works-list .works__content .ttl::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#WORKS.ARCHIVES .works-list .works__content .ttl::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#WORKS.ARCHIVES .works-list .works__content .ttl::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
#WORKS.ARCHIVES .works-list .works__content .link {
  position: relative;
  color: #0DABC7;
  text-align: right;
  margin: 20px 0 0;
  padding: 0 52px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list .works__content .link {
    margin: calc(1.3888888889 * var(--vw)) 0 0;
    padding: 0 calc(3.6111111111 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list .works__content .link {
    margin: calc(5.3333333333 * var(--vw)) 0 0;
    padding: 0 calc(13.8666666667 * var(--vw)) 0 0;
  }
}
#WORKS.ARCHIVES .works-list .works__content .link::after {
  content: "";
  position: absolute;
  top: 0;
  right: 10px;
  bottom: 0;
  background: url(../img/common/ico_arrow_green_01.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 9/16;
  width: 9px;
  height: 16px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.ARCHIVES .works-list .works__content .link::after {
    right: calc(0.6944444444 * var(--vw));
    width: calc(0.625 * var(--vw));
    height: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.ARCHIVES .works-list .works__content .link::after {
    right: calc(2.6666666667 * var(--vw));
    width: calc(2.4 * var(--vw));
    height: calc(4.2666666667 * var(--vw));
  }
}
#WORKS.ARCHIVES .works-list .works__content .link > span {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.75;
}
#WORKS.ARCHIVES .works-list .works__content .link > span::before, #WORKS.ARCHIVES .works-list .works__content .link > span::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#WORKS.ARCHIVES .works-list .works__content .link > span::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#WORKS.ARCHIVES .works-list .works__content .link > span::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
#WORKS.ARCHIVES .pagination .page-numbers .current {
  background: linear-gradient(to bottom, #46bec6 0%, #003988 100%);
}
#WORKS.ARCHIVES .pagination .page-numbers.prev, #WORKS.ARCHIVES .pagination .page-numbers.next {
  background: #01BEC6;
  border-color: #01BEC6;
}
#WORKS.SINGLE .article {
  width: 840px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.SINGLE .article {
    width: calc(58.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.SINGLE .article {
    width: 100%;
  }
}
#WORKS.SINGLE .article .kv {
  overflow: hidden;
  border-radius: 16px;
  aspect-ratio: 840/539;
  margin: 0 0 70px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #WORKS.SINGLE .article .kv {
    border-radius: calc(1.1111111111 * var(--vw));
    margin: 0 0 calc(4.8611111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #WORKS.SINGLE .article .kv {
    border-radius: calc(4.2666666667 * var(--vw));
    aspect-ratio: 355/450;
    margin: 0 0 calc(21.3333333333 * var(--vw));
  }
}
#WORKS.SINGLE .article .kv img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
@media only screen and (min-width: 768px) {
  #WORKS.SINGLE .article__header {
    border-top: unset;
    padding-top: 0;
  }
}

.ARCHIVES .pagination {
  margin: 90px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .ARCHIVES .pagination {
    margin: calc(6.25 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  .ARCHIVES .pagination {
    margin: calc(18.6666666667 * var(--vw)) auto 0;
  }
}
.ARCHIVES .pagination .page-numbers {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .ARCHIVES .pagination .page-numbers {
    gap: calc(4.2666666667 * var(--vw)) calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .ARCHIVES .pagination .page-numbers {
    gap: calc(4.2666666667 * var(--vw));
  }
}
.ARCHIVES .pagination .page-numbers > li > * {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  color: #00BEC6;
  font-size: 2.3rem;
  font-weight: 700;
  aspect-ratio: 1;
  border: 2px solid #01BEC6;
  border-radius: 50%;
  width: 56px;
  height: 56px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .ARCHIVES .pagination .page-numbers > li > * {
    border-width: calc(0.1388888889 * var(--vw));
    width: calc(3.8888888889 * var(--vw));
    height: calc(3.8888888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .ARCHIVES .pagination .page-numbers > li > * {
    font-size: 2.4rem;
    width: calc(12.8 * var(--vw));
    height: calc(12.8 * var(--vw));
  }
}
.ARCHIVES .pagination .page-numbers > li > *.current {
  background: #0DABC7;
  color: #fff;
  border-color: #0DABC7;
}
.ARCHIVES .pagination .page-numbers > li > *.prev, .ARCHIVES .pagination .page-numbers > li > *.next {
  background: #808080;
  border-color: #808080;
}
.ARCHIVES .pagination .page-numbers > li > *.prev::before, .ARCHIVES .pagination .page-numbers > li > *.next::before {
  content: "";
  position: relative;
  background: url(../img/common/ico_arrow_white_02.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 9/16;
  width: 9px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .ARCHIVES .pagination .page-numbers > li > *.prev::before, .ARCHIVES .pagination .page-numbers > li > *.next::before {
    width: calc(0.625 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .ARCHIVES .pagination .page-numbers > li > *.prev::before, .ARCHIVES .pagination .page-numbers > li > *.next::before {
    width: calc(2.4 * var(--vw));
  }
}
.ARCHIVES .pagination .page-numbers > li > *.prev::before {
  transform: rotate(180deg);
}

.SINGLE .article__header {
  border-top: 2px solid #C4C4C4;
  border-bottom: 2px solid #C4C4C4;
  margin: 0 0 64px;
  padding: 40px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__header {
    border-top-width: calc(0.1388888889 * var(--vw));
    border-bottom-width: calc(0.1388888889 * var(--vw));
    margin: 0 0 calc(4.4444444444 * var(--vw));
    padding: calc(2.7777777778 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__header {
    margin: 0 0 calc(12.8 * var(--vw));
    padding: calc(4.2666666667 * var(--vw)) 0;
  }
}
.SINGLE .article__header .row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 64px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__header .row {
    gap: calc(4.4444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__header .row {
    gap: calc(8.5333333333 * var(--vw));
  }
}
.SINGLE .article__header .date {
  font-size: 2.4rem;
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__header .date {
    font-size: 1.8rem;
  }
}
.SINGLE .article__header .category {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.8rem;
  border-radius: 14px;
  height: 34px;
  padding: 0 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__header .category {
    border-radius: calc(0.9722222222 * var(--vw));
    height: calc(2.3611111111 * var(--vw));
    padding: 0 calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__header .category {
    font-size: 1.6rem;
    border-radius: calc(4.2666666667 * var(--vw));
    height: calc(8.5333333333 * var(--vw));
  }
}
.SINGLE .article__header .ttl {
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.5;
  margin: 36px 0 0;
}
.SINGLE .article__header .ttl::before, .SINGLE .article__header .ttl::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.SINGLE .article__header .ttl::before {
  margin-top: calc((1 - 1.5) * 0.5em);
}
.SINGLE .article__header .ttl::after {
  margin-bottom: calc((1 - 1.5) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__header .ttl {
    margin: calc(2.5 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__header .ttl {
    font-size: 2rem;
    margin: calc(4.8 * var(--vw)) 0 0;
  }
}
.SINGLE .article__header .img {
  aspect-ratio: 730/400;
  width: 100%;
}
.SINGLE .article__header .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.SINGLE .article__content {
  font-size: 1.6rem;
  line-height: 1.75;
}
.SINGLE .article__content > * + * {
  margin-top: 64px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__content > * + * {
    margin-top: calc(4.4444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__content > * + * {
    margin-top: calc(12.8 * var(--vw));
  }
}
.SINGLE .article__content .wp-block-image img {
  width: 100%;
  height: auto;
}
.SINGLE .article__content .wp-block-image + * {
  margin-top: 80px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__content .wp-block-image + * {
    margin-top: calc(5.5555555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__content .wp-block-image + * {
    margin-top: calc(12.8 * var(--vw));
  }
}
.SINGLE .article__content .wp-block-columns {
  gap: 64px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__content .wp-block-columns {
    gap: calc(4.4444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__content .wp-block-columns {
    flex-direction: column;
    gap: calc(17.0666666667 * var(--vw));
  }
}
.SINGLE .article__content .wp-block-columns + * {
  margin-top: 80px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article__content .wp-block-columns + * {
    margin-top: calc(5.5555555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article__content .wp-block-columns + * {
    margin-top: calc(12.8 * var(--vw));
  }
}
.SINGLE .article .btn-box {
  margin-top: 120px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .SINGLE .article .btn-box {
    margin-top: calc(8.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .SINGLE .article .btn-box {
    margin-top: calc(21.3333333333 * var(--vw));
  }
}

.sidebar__wrap {
  display: grid;
  grid-template-columns: 716px 303px;
  justify-content: space-between;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sidebar__wrap {
    grid-template-columns: calc(49.7222222222 * var(--vw)) calc(21.0416666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sidebar__wrap {
    grid-template-columns: 1fr;
    gap: calc(32 * var(--vw));
  }
}

.sidebar--news .news-list {
  display: grid;
  gap: 40px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sidebar--news .news-list {
    gap: calc(2.7777777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sidebar--news .news-list {
    gap: calc(10.6666666667 * var(--vw));
  }
}
.sidebar--news .news-list__item > a {
  display: block;
  background: #F5F2EA;
  border-radius: 16px;
  height: 100%;
  padding: 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sidebar--news .news-list__item > a {
    border-radius: calc(1.1111111111 * var(--vw));
    padding: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sidebar--news .news-list__item > a {
    border-radius: calc(4.2666666667 * var(--vw));
    width: calc(80.8 * var(--vw));
    margin: 0 auto;
    padding: calc(4.2666666667 * var(--vw));
  }
}
.sidebar--news .news-list__item .container {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sidebar--news .news-list__item .container {
    grid-template-columns: calc(5.5555555556 * var(--vw)) 1fr;
    gap: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .sidebar--news .news-list__item .container {
    grid-template-columns: calc(21.3333333333 * var(--vw)) 1fr;
    gap: calc(4.2666666667 * var(--vw));
  }
}
.sidebar--news .news-list__item .img {
  aspect-ratio: 1;
}
.sidebar--news .news-list__item .img img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.sidebar--news .news-list__item .date {
  font-size: 1.4rem;
}
.sidebar--news .news-list__item .ttl {
  font-size: 1.4rem;
  line-height: 1.5;
  margin: 16px 0 0;
}
.sidebar--news .news-list__item .ttl::before, .sidebar--news .news-list__item .ttl::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.sidebar--news .news-list__item .ttl::before {
  margin-top: calc((1 - 1.5) * 0.5em);
}
.sidebar--news .news-list__item .ttl::after {
  margin-bottom: calc((1 - 1.5) * 0.5em);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .sidebar--news .news-list__item .ttl {
    margin: calc(1.1111111111 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .sidebar--news .news-list__item .ttl {
    margin: calc(4.2666666667 * var(--vw)) 0 0;
  }
}

.FORM .lead-txt {
  font-size: 1.6rem;
  line-height: 1.75;
  width: 840px;
  margin: 0 auto;
}
.FORM .lead-txt::before, .FORM .lead-txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
.FORM .lead-txt::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
.FORM .lead-txt::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
@media only screen and (max-width: 767px) {
  .FORM .lead-txt {
    width: calc(80 * var(--vw));
    margin: 0 auto;
  }
}
.FORM .form-box {
  border-top: 1px solid #c4c4c4;
  width: 840px;
  margin: 64px auto 0;
  padding: 32px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .form-box {
    width: getvPc(840);
    margin: calc(4.4444444444 * var(--vw)) auto 0;
    padding: calc(2.2222222222 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .FORM .form-box {
    width: 100%;
    margin: calc(12.8 * var(--vw)) auto 0;
  }
}
.FORM .form-box fieldset, .FORM .form-box legend {
  display: contents;
}
.FORM .form-box .row {
  display: grid;
  grid-template-columns: 220px 1fr;
  border-bottom: 1px solid #C4C4C4;
  margin: 0 0 32px;
  padding: 0 0 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .form-box .row {
    grid-template-columns: calc(15.2777777778 * var(--vw)) 1fr;
    margin: 0 0 calc(2.2222222222 * var(--vw));
    padding: 0 0 calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .form-box .row {
    grid-template-columns: 1fr;
    margin: 0 0 calc(6.4 * var(--vw));
    padding: 0 0 calc(6.4 * var(--vw));
  }
}
.FORM .form-box .ttl {
  position: relative;
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .FORM .form-box .ttl {
    padding: calc(1em + 1px) 0;
  }
}
.FORM .form-box .ttl.is-required::after {
  content: "必須";
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.4rem;
  border-radius: 14px;
  margin: 0 0 0 16px;
  padding: 0 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .form-box .ttl.is-required::after {
    border-radius: calc(0.9722222222 * var(--vw));
    margin: 0 0 0 calc(1.1111111111 * var(--vw));
    padding: 0 calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .form-box .ttl.is-required::after {
    border-radius: calc(3.7333333333 * var(--vw));
    margin: 0 0 0 calc(4.2666666667 * var(--vw));
    padding: 0 calc(2.6666666667 * var(--vw));
  }
}
.FORM .form-box .desc {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .FORM .form-box .desc {
    padding: 0 0 0 1em;
  }
}
@media only screen and (max-width: 767px) {
  .FORM .form-box .desc {
    padding: calc(6.4 * var(--vw)) 0 0;
  }
}
.FORM [data-name=agree-privacy-policy] {
  display: block;
  text-align: center;
  margin: 64px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM [data-name=agree-privacy-policy] {
    margin: calc(4.4444444444 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  .FORM [data-name=agree-privacy-policy] {
    margin: calc(12.8 * var(--vw)) auto 0;
  }
}
.FORM [data-name=agree-privacy-policy] > span {
  position: relative;
}
.FORM [data-name=agree-privacy-policy] .wpcf7-list-item {
  margin: 0;
}
.FORM [data-name=agree-privacy-policy] input[type=checkbox] {
  visibility: hidden;
  position: absolute;
  top: 0;
  left: 0;
}
.FORM [data-name=agree-privacy-policy] input[type=checkbox] + span {
  position: relative;
  font-size: 1.6rem;
  padding: 0 0 0 44px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM [data-name=agree-privacy-policy] input[type=checkbox] + span {
    padding: 0 0 0 calc(3.0555555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM [data-name=agree-privacy-policy] input[type=checkbox] + span {
    padding: 0 0 0 calc(11.7333333333 * var(--vw));
  }
}
.FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::before, .FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::after {
  content: "";
  position: absolute;
}
.FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::before {
  top: 0;
  left: 0;
  background: #fff;
  border: 1px solid #707070;
  aspect-ratio: 1;
  width: 24px;
  height: 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::before {
    width: calc(1.6666666667 * var(--vw));
    height: calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::before {
    width: calc(6.4 * var(--vw));
    height: calc(6.4 * var(--vw));
  }
}
.FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::after {
  top: 5px;
  left: 0;
  transform: rotate(-45deg);
  transform-origin: top;
  opacity: 0;
  border-bottom: 3px solid #0DABC7;
  border-left: 3px solid #0DABC7;
  aspect-ratio: 4/3;
  width: 16px;
  height: 12px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::after {
    top: calc(0.3472222222 * var(--vw));
    border-bottom-width: calc(0.2083333333 * var(--vw));
    border-left-width: calc(0.2083333333 * var(--vw));
    width: calc(1.1111111111 * var(--vw));
    height: calc(0.8333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM [data-name=agree-privacy-policy] input[type=checkbox] + span::after {
    top: calc(1.3333333333 * var(--vw));
    border-bottom-width: calc(0.8 * var(--vw));
    border-left-width: calc(0.8 * var(--vw));
    width: calc(4.2666666667 * var(--vw));
    height: calc(3.2 * var(--vw));
  }
}
.FORM [data-name=agree-privacy-policy] input[type=checkbox]:checked + span::after {
  opacity: 1;
}
.FORM .input-txt,
.FORM .txtarea,
.FORM .select {
  background: #fff;
  font-size: 1.8rem;
  border: 1px solid #C4C4C4;
  border-radius: 8px;
  width: 100%;
  padding: 18px 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .input-txt,
  .FORM .txtarea,
  .FORM .select {
    border-radius: calc(0.5555555556 * var(--vw));
    padding: calc(1.25 * var(--vw)) calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .input-txt,
  .FORM .txtarea,
  .FORM .select {
    border-radius: calc(2.1333333333 * var(--vw));
    padding: calc(4.2666666667 * var(--vw));
  }
}
.FORM .input-txt::placeholder,
.FORM .txtarea::placeholder,
.FORM .select::placeholder {
  color: #9F9F9F;
}
.FORM .txtarea {
  height: 171px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .txtarea {
    height: calc(11.875 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .txtarea {
    height: calc(45.6 * var(--vw));
  }
}
.FORM .input-radio {
  display: block;
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .FORM .input-radio {
    padding: calc(1em + 1px) 0;
  }
}
.FORM .input-radio .wpcf7-list-item {
  margin: 0 72px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .input-radio .wpcf7-list-item {
    margin: 0 calc(5 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .FORM .input-radio .wpcf7-list-item {
    display: block;
    margin: 0 0 0 calc(8.5333333333 * var(--vw));
  }
  .FORM .input-radio .wpcf7-list-item:not(:first-of-type) {
    margin-top: calc(6.4 * var(--vw));
  }
}
.FORM .input-radio .wpcf7-list-item label {
  position: relative;
}
.FORM .input-radio .wpcf7-list-item input[type=radio] {
  position: absolute;
  visibility: hidden;
  opacity: 0;
}
.FORM .input-radio .wpcf7-list-item input[type=radio] + span {
  position: relative;
  padding: 0 0 0 56px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .input-radio .wpcf7-list-item input[type=radio] + span {
    padding: 0 0 0 calc(3.8888888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .input-radio .wpcf7-list-item input[type=radio] + span {
    padding: 0 0 0 calc(14.9333333333 * var(--vw));
  }
}
.FORM .input-radio .wpcf7-list-item input[type=radio] + span::before, .FORM .input-radio .wpcf7-list-item input[type=radio] + span::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  aspect-ratio: 1;
  border-radius: 50%;
  width: 28px;
  height: 28px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .input-radio .wpcf7-list-item input[type=radio] + span::before, .FORM .input-radio .wpcf7-list-item input[type=radio] + span::after {
    width: calc(1.9444444444 * var(--vw));
    height: calc(1.9444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .input-radio .wpcf7-list-item input[type=radio] + span::before, .FORM .input-radio .wpcf7-list-item input[type=radio] + span::after {
    width: calc(7.4666666667 * var(--vw));
    height: calc(7.4666666667 * var(--vw));
  }
}
.FORM .input-radio .wpcf7-list-item input[type=radio] + span::before {
  border: 1px solid #C4C4C4;
}
.FORM .input-radio .wpcf7-list-item input[type=radio] + span::after {
  background: #0DABC7;
  transform: scale(0.5);
  opacity: 0;
}
.FORM .input-radio .wpcf7-list-item input[type=radio]:checked + span::after {
  opacity: 1;
}
.FORM .btn-submit {
  background: linear-gradient(to right, #46bec6 0%, #399f41 100%);
}
.FORM .btn-submit:disabled {
  opacity: 0.6;
}
.FORM .wpcf7-response-output {
  font-size: 1.8rem;
}
.FORM #wpcf7cpcnf {
  font-size: 1.8rem;
}
.FORM #wpcf7cpcnf .wpcf7cp-btns {
  text-align: center;
}
.FORM #wpcf7cpcnf table {
  border-top: 1px solid #c4c4c4;
  width: 840px;
  margin: 64px auto 0;
  padding: 32px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM #wpcf7cpcnf table {
    width: getvPc(840);
    margin: calc(4.4444444444 * var(--vw)) auto 0;
    padding: calc(2.2222222222 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  .FORM #wpcf7cpcnf table {
    width: 100%;
    margin: calc(12.8 * var(--vw)) auto 0;
    padding: calc(8.5333333333 * var(--vw)) 0 0;
  }
}
.FORM #wpcf7cpcnf table tr {
  display: grid;
  grid-template-columns: 220px 1fr;
  border-bottom: 1px solid #C4C4C4;
  margin: 0 0 32px;
  padding: 0 0 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM #wpcf7cpcnf table tr {
    grid-template-columns: calc(15.2777777778 * var(--vw)) 1fr;
    margin: 0 0 calc(2.2222222222 * var(--vw));
    padding: 0 0 calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM #wpcf7cpcnf table tr {
    grid-template-columns: 1fr;
    margin: 0 0 calc(6.4 * var(--vw));
    padding: 0 0 calc(6.4 * var(--vw));
  }
}
.FORM #wpcf7cpcnf table th {
  position: relative;
  font-size: 1.8rem;
  font-weight: normal;
}
@media only screen and (max-width: 767px) {
  .FORM #wpcf7cpcnf table th {
    text-align: left;
  }
}
.FORM #wpcf7cpcnf table th.is-required::after {
  content: "必須";
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background: #0DABC7;
  color: #fff;
  font-size: 1.4rem;
  border-radius: 14px;
  margin: 0 0 0 16px;
  padding: 0 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM #wpcf7cpcnf table th.is-required::after {
    border-radius: calc(0.9722222222 * var(--vw));
    margin: 0 0 0 calc(1.1111111111 * var(--vw));
    padding: 0 calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM #wpcf7cpcnf table th.is-required::after {
    border-radius: calc(3.7333333333 * var(--vw));
    margin: 0 0 0 calc(4.2666666667 * var(--vw));
    padding: 0 calc(2.6666666667 * var(--vw));
  }
}
.FORM #wpcf7cpcnf table td {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .FORM #wpcf7cpcnf table td {
    padding: 0 0 0 1em;
  }
}
@media only screen and (max-width: 767px) {
  .FORM #wpcf7cpcnf table td {
    padding: calc(6.4 * var(--vw)) 0 0;
  }
}
.FORM .wpcf7cp-cfm-edit-btn,
.FORM .wpcf7cp-cfm-submit-btn {
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  background: #07A5C1;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1;
  font-weight: 500;
  border-radius: 27px;
  aspect-ratio: 136/27;
  overflow: hidden;
  width: 272px;
}
@media only screen and (min-width: 768px) {
  .FORM .wpcf7cp-cfm-edit-btn,
  .FORM .wpcf7cp-cfm-submit-btn {
    margin-bottom: 0;
  }
}
@media only screen and (max-width: 767px) {
  .FORM .wpcf7cp-cfm-edit-btn,
  .FORM .wpcf7cp-cfm-submit-btn {
    margin-right: 0;
  }
}
@media only screen and (max-width: 767px) {
  .FORM .wpcf7cp-cfm-edit-btn,
  .FORM .wpcf7cp-cfm-submit-btn {
    order-radius: calc(7.2 * var(--vw));
    width: calc(72.5333333333 * var(--vw));
  }
}
.FORM .wpcf7cp-cfm-edit-btn::before, .FORM .wpcf7cp-cfm-edit-btn::after,
.FORM .wpcf7cp-cfm-submit-btn::before,
.FORM .wpcf7cp-cfm-submit-btn::after {
  content: "";
}
.FORM .wpcf7cp-cfm-edit-btn::before,
.FORM .wpcf7cp-cfm-submit-btn::before {
  position: absolute;
  top: 0;
  left: 0;
  background: url(../img/common/bg_btn_basic_01.png) no-repeat 0 0/100% auto;
  mix-blend-mode: overlay;
  width: 100%;
  height: 100%;
}
.FORM .wpcf7cp-cfm-edit-btn::after,
.FORM .wpcf7cp-cfm-submit-btn::after {
  position: absolute;
  top: 0;
  right: 8px;
  bottom: 0;
  background: url(../img/common/ico_arrow_white_01.svg) no-repeat center center/8px auto, #003988;
  aspect-ratio: 1;
  border-radius: 50%;
  width: 38px;
  height: 38px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .wpcf7cp-cfm-edit-btn::after,
  .FORM .wpcf7cp-cfm-submit-btn::after {
    right: calc(0.5555555556 * var(--vw));
    width: calc(2.6388888889 * var(--vw));
    height: calc(2.6388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .wpcf7cp-cfm-edit-btn::after,
  .FORM .wpcf7cp-cfm-submit-btn::after {
    right: calc(2.1333333333 * var(--vw));
    width: calc(10.1333333333 * var(--vw));
    height: calc(10.1333333333 * var(--vw));
  }
}
@media (hover: none) {
  .FORM .wpcf7cp-cfm-edit-btn,
  .FORM .wpcf7cp-cfm-submit-btn {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  .FORM .wpcf7cp-cfm-edit-btn:active,
  .FORM .wpcf7cp-cfm-submit-btn:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  .FORM .wpcf7cp-cfm-edit-btn:hover,
  .FORM .wpcf7cp-cfm-submit-btn:hover {
    opacity: 0.65;
  }
}
.FORM .wpcf7cp-cfm-edit-btn::after {
  right: unset;
  left: 8px;
  transform: rotate(180deg);
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  .FORM .wpcf7cp-cfm-edit-btn::after {
    left: calc(0.5555555556 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  .FORM .wpcf7cp-cfm-edit-btn::after {
    left: calc(2.1333333333 * var(--vw));
  }
}
.FORM .wpcf7cp-cfm-submit-btn {
  background: linear-gradient(to right, #46bec6 0%, #399f41 100%);
}
.FORM .valid-box:has(.wpcf7-not-valid-tip) .error-message {
  display: block;
}
.FORM .valid-box .wpcf7-not-valid-tip {
  display: none;
}
.FORM .valid-box .error-message {
  display: none;
  color: #dc3232;
  font-size: 1em;
  font-weight: normal;
}

@media only screen and (max-width: 767px) {
  #ERROR404 .page-header {
    padding: calc(53.3333333333 * var(--vw)) 0 0;
  }
}
#ERROR404 .page-header .sec__in {
  align-items: flex-end;
}
#ERROR404 .page-header .ttl {
  gap: 50px;
  text-align: center;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #ERROR404 .page-header .ttl {
    gap: calc(3.4722222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #ERROR404 .page-header .ttl {
    gap: calc(10.6666666667 * var(--vw));
  }
}
#ERROR404 .page-header .ttl .jp {
  font-size: 4rem;
}
@media only screen and (max-width: 767px) {
  #ERROR404 .page-header .ttl .jp {
    font-size: 3.2rem;
  }
}
#ERROR404 .page-header .ttl .en {
  font-family: "Noto Sans JP", sans-serif;
}
@media only screen and (max-width: 767px) {
  #ERROR404 .sec {
    padding: calc(21.3333333333 * var(--vw)) 0;
  }
}
#ERROR404 .sec .txt {
  font-size: 1.6rem;
  line-height: 1.75;
  text-align: center;
}
#ERROR404 .sec .txt::before, #ERROR404 .sec .txt::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
}
#ERROR404 .sec .txt::before {
  margin-top: calc((1 - 1.75) * 0.5em);
}
#ERROR404 .sec .txt::after {
  margin-bottom: calc((1 - 1.75) * 0.5em);
}
@media only screen and (max-width: 767px) {
  #ERROR404 .sec .txt {
    text-align: left;
    width: calc(80 * var(--vw));
    margin: 0 auto;
  }
}
#ERROR404 .sec .btn-box {
  margin: 120px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #ERROR404 .sec .btn-box {
    margin: calc(8.3333333333 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  #ERROR404 .sec .btn-box {
    margin: calc(21.3333333333 * var(--vw)) auto 0;
  }
}

#SITEMAP .box {
  width: 840px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #SITEMAP .box {
    width: calc(58.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #SITEMAP .box {
    width: 100%;
  }
}
#SITEMAP .page-list {
  display: grid;
  border-top: 2px solid #C4C4C4;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #SITEMAP .page-list {
    border-top-width: calc(0.1388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #SITEMAP .page-list {
    border-top-width: calc(0.5333333333 * var(--vw));
  }
}
#SITEMAP .page-list--in {
  border-top: none;
}
#SITEMAP .page-list--in .page-list__item {
  border-bottom: none;
  padding: 0 0 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #SITEMAP .page-list--in .page-list__item {
    padding: 0 0 calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #SITEMAP .page-list--in .page-list__item {
    padding: 0 0 calc(6.4 * var(--vw));
  }
}
#SITEMAP .page-list--in .page-list__item > a {
  padding: 0 0 0 36px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #SITEMAP .page-list--in .page-list__item > a {
    padding: 0 0 0 calc(2.5 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #SITEMAP .page-list--in .page-list__item > a {
    padding: 0 0 0 calc(9.6 * var(--vw));
  }
}
#SITEMAP .page-list__item {
  font-size: 1.8rem;
  font-weight: 500;
  border-bottom: 2px solid #C4C4C4;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #SITEMAP .page-list__item {
    border-bottom-width: calc(0.1388888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #SITEMAP .page-list__item {
    border-bottom-width: calc(0.5333333333 * var(--vw));
  }
}
#SITEMAP .page-list__item > a {
  display: inline-block;
  padding: 24px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #SITEMAP .page-list__item > a {
    padding: calc(1.6666666667 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  #SITEMAP .page-list__item > a {
    padding: calc(6.4 * var(--vw)) 0;
  }
}
@media (hover: none) {
  #SITEMAP .page-list__item > a {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  #SITEMAP .page-list__item > a:active {
    text-decoration: underline;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  #SITEMAP .page-list__item > a:hover {
    text-decoration: underline;
  }
}
#SITEMAP .page-list__item > a > span {
  position: relative;
  display: block;
  background: url(../img/common/ico_arrow_green_01.svg) no-repeat 0 center/8px auto;
  padding: 0 0 0 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #SITEMAP .page-list__item > a > span {
    background-size: calc(0.5555555556 * var(--vw)) auto;
    padding: 0 0 0 calc(1.6666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #SITEMAP .page-list__item > a > span {
    background-size: calc(2.1333333333 * var(--vw)) auto;
    padding: 0 0 0 calc(6.4 * var(--vw));
  }
}

#PRIVACY-POLICY .box {
  width: 840px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #PRIVACY-POLICY .box {
    width: calc(58.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #PRIVACY-POLICY .box {
    width: 100%;
  }
}
#PRIVACY-POLICY .lead-txt {
  font-size: 2rem;
}
#PRIVACY-POLICY .num-list {
  display: grid;
  gap: 32px;
  counter-reset: num;
  list-style-type: none;
  margin: 32px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #PRIVACY-POLICY .num-list {
    gap: calc(2.2222222222 * var(--vw));
    margin: calc(2.2222222222 * var(--vw)) 0 0;
  }
}
#PRIVACY-POLICY .num-list__item {
  position: relative;
  font-size: 1.6rem;
  line-height: 2;
  counter-increment: num;
  padding: 0 0 0 29px;
}
#PRIVACY-POLICY .num-list__item::before {
  content: counter(num) ".";
  position: absolute;
  top: 0;
  left: 0;
}

#RECRUIT .sec-kv {
  padding: 0;
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-kv {
    padding: calc(21.3333333333 * var(--vw)) 0 0;
  }
}
#RECRUIT .sec-kv .sec__in {
  display: grid;
  grid-auto-flow: row;
  grid-auto-columns: 1fr;
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-kv .sec__in {
    padding: 0;
  }
}
#RECRUIT .sec-kv .img,
#RECRUIT .sec-kv .container {
  grid-area: 1/-1;
}
#RECRUIT .sec-kv .container {
  display: grid;
  grid-template-rows: 1fr 56px;
  padding: 50px 54px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-kv .container {
    grid-template-rows: 1fr calc(3.8888888889 * var(--vw));
    padding: calc(3.4722222222 * var(--vw)) calc(3.75 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-kv .container {
    grid-template-rows: 1fr calc(12.8 * var(--vw));
    padding: calc(4.8 * var(--vw)) calc(7.7333333333 * var(--vw));
  }
}
#RECRUIT .sec-kv .catch {
  color: #fff;
  font-size: 3.2rem;
  line-height: 1.25;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-kv .catch {
    font-size: 2rem;
    line-height: 1.6;
    text-shadow: calc(0.5333333333 * var(--vw)) calc(0.5333333333 * var(--vw)) calc(1.0666666667 * var(--vw)) rgba(0, 0, 0, 0.5);
    padding: calc(38.4 * var(--vw)) 0 0;
  }
}
#RECRUIT .sec-kv .btn-entry {
  position: relative;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  background: #fff;
  font-size: 2rem;
  font-weight: 500;
  border-radius: 28px;
  filter: drop-shadow(3px 3px 6px rgba(0, 0, 0, 0.35));
  aspect-ratio: 328/56;
  width: 328px;
  padding: 0 50px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-kv .btn-entry {
    border-radius: calc(1.9444444444 * var(--vw));
    filter: drop-shadow(calc(0.2083333333 * var(--vw)) calc(0.2083333333 * var(--vw)) calc(0.4166666667 * var(--vw)) rgba(0, 0, 0, 0.35));
    width: calc(22.7777777778 * var(--vw));
    padding: 0 calc(3.4722222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-kv .btn-entry {
    font-size: 1.7rem;
    border-radius: calc(6.4 * var(--vw));
    filter: drop-shadow(calc(0.8 * var(--vw)) calc(0.8 * var(--vw)) calc(1.6 * var(--vw)) rgba(0, 0, 0, 0.35));
    aspect-ratio: 260/48;
    width: calc(69.3333333333 * var(--vw));
    padding: 0 calc(7.4666666667 * var(--vw));
  }
}
@media (hover: none) {
  #RECRUIT .sec-kv .btn-entry {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  #RECRUIT .sec-kv .btn-entry:active {
    opacity: 0.65;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active), (-moz-touch-enabled: 0), (hover: hover) {
  #RECRUIT .sec-kv .btn-entry:hover {
    opacity: 0.65;
  }
}
#RECRUIT .sec-kv .btn-entry::after {
  content: "";
  position: absolute;
  top: 0;
  right: 16px;
  bottom: 0;
  background: url(../img/common/ico_arrow_white_01.svg) no-repeat center/7px auto, #003988;
  aspect-ratio: 1;
  border-radius: 50%;
  transform: rotate(90deg);
  width: 34px;
  height: 34px;
  margin: auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-kv .btn-entry::after {
    right: calc(1.1111111111 * var(--vw));
    background-size: calc(0.4861111111 * var(--vw)) auto;
    width: calc(2.3611111111 * var(--vw));
    height: calc(2.3611111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-kv .btn-entry::after {
    right: calc(2.1333333333 * var(--vw));
    background-size: calc(1.8666666667 * var(--vw)) auto;
    width: calc(9.0666666667 * var(--vw));
    height: calc(9.0666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what {
    padding: calc(17.0666666667 * var(--vw)) 0;
  }
}
#RECRUIT .sec-what .what-box {
  width: 840px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .what-box {
    width: calc(58.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .what-box {
    width: 100%;
  }
}
#RECRUIT .sec-what .what-box .lead-txt {
  font-size: 1.8rem;
  line-height: 1.75;
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .what-box .lead-txt {
    font-size: 1.6rem;
    padding: 0 calc(5.3333333333 * var(--vw));
  }
}
#RECRUIT .sec-what .flow-list {
  counter-reset: flowNum;
  display: grid;
  grid-template-columns: repeat(3, 272px);
  justify-content: space-between;
  gap: 64px 0;
  margin: 64px auto 84px;
  padding: 0 45px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .flow-list {
    grid-template-columns: repeat(3, calc(18.8888888889 * var(--vw)));
    gap: calc(4.4444444444 * var(--vw)) 0;
    margin: calc(4.4444444444 * var(--vw)) auto calc(5.8333333333 * var(--vw));
    padding: 0 calc(3.125 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list {
    grid-template-columns: 1fr;
    gap: calc(17.0666666667 * var(--vw)) 0;
    margin: calc(12.8 * var(--vw)) auto calc(21.3333333333 * var(--vw));
    padding: 0;
  }
}
#RECRUIT .sec-what .flow-list__item {
  position: relative;
  counter-increment: flowNum;
  position: relative;
  padding: 10px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .flow-list__item {
    padding: calc(0.6944444444 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list__item {
    display: grid;
    grid-template-columns: calc(29.8666666667 * var(--vw)) 1fr;
    gap: calc(8.5333333333 * var(--vw));
    padding: calc(2.1333333333 * var(--vw)) 0 0 calc(2.6666666667 * var(--vw));
  }
}
#RECRUIT .sec-what .flow-list__item::before {
  content: counter(flowNum);
  position: absolute;
  top: 0;
  left: 65px;
  background: #07A5C1;
  color: #fff;
  display: flex;
  justify-content: center;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  aspect-ratio: 1;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  padding: 8px 0 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .flow-list__item::before {
    left: calc(4.5138888889 * var(--vw));
    width: calc(3.0555555556 * var(--vw));
    height: calc(3.0555555556 * var(--vw));
    padding: calc(0.5555555556 * var(--vw)) 0 0;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list__item::before {
    left: calc(0 * var(--vw));
    font-size: 2.1rem;
    width: calc(10.1333333333 * var(--vw));
    height: calc(10.1333333333 * var(--vw));
    padding: calc(2.1333333333 * var(--vw)) 0 0;
  }
}
#RECRUIT .sec-what .flow-list__item::after {
  content: "";
  position: absolute;
  top: 86px;
  left: 312px;
  background: url(../img/common/ico_arrow_green_02.svg) no-repeat 0 0/100% auto;
  aspect-ratio: 16/29;
  width: 16px;
  height: 29px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .flow-list__item::after {
    top: calc(5.9722222222 * var(--vw));
    left: calc(21.6666666667 * var(--vw));
    width: calc(1.1111111111 * var(--vw));
    height: calc(2.0138888889 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list__item::after {
    top: unset;
    right: 0;
    bottom: 0;
    left: 0;
    transform: rotate(90deg);
    transform-origin: left bottom;
    width: calc(4.2666666667 * var(--vw));
    height: calc(7.7333333333 * var(--vw));
    margin: 0 auto;
  }
}
@media only screen and (min-width: 768px) {
  #RECRUIT .sec-what .flow-list__item.no-icon::after {
    display: none;
  }
}
@media only screen and (min-width: 768px) {
  #RECRUIT .sec-what .flow-list__item.no-icon--sp::after {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list__item.no-icon--sp::after {
    display: none;
  }
}
#RECRUIT .sec-what .flow-list .img {
  border-radius: 50%;
  aspect-ratio: 1;
  overflow: hidden;
  width: 130px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .flow-list .img {
    width: calc(9.0277777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list .img {
    width: calc(29.8666666667 * var(--vw));
  }
}
#RECRUIT .sec-what .flow-list .ttl {
  margin: 15px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .flow-list .ttl {
    margin: calc(1.0416666667 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list .ttl {
    margin: 0 0 calc(2.6666666667 * var(--vw));
    text-align: left;
  }
}
#RECRUIT .sec-what .flow-list .ttl .main {
  padding: 0 0 0 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-what .flow-list .ttl .main {
    padding: 0 0 0 calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list .ttl .main {
    padding: 0 0 0 calc(4.2666666667 * var(--vw));
  }
}
#RECRUIT .sec-what .flow-list .txt {
  font-size: 1.6rem;
  line-height: 1.75;
  text-align: center;
}
#RECRUIT .sec-what .flow-list .txt--left {
  text-align: left;
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-what .flow-list .txt {
    font-size: 1.4rem;
    text-align: left;
  }
}
#RECRUIT .sec-read .row + .row {
  margin-top: 100px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-read .row + .row {
    margin-top: calc(6.9444444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-read .row + .row {
    margin-top: calc(17.0666666667 * var(--vw));
  }
}
#RECRUIT .sec-read .read-box {
  display: grid;
  grid-template-columns: 247px 1fr;
  gap: 72px;
  width: 832px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-read .read-box {
    grid-template-columns: calc(17.1527777778 * var(--vw)) 1fr;
    gap: calc(5 * var(--vw));
    width: calc(57.7777777778 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-read .read-box {
    grid-template-columns: 1fr;
    gap: calc(12.8 * var(--vw));
    width: 100%;
    margin: calc(12.8 * var(--vw)) auto 0;
  }
}
#RECRUIT .sec-read .read-box .img {
  border-radius: 16px;
  overflow: hidden;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-read .read-box .img {
    border-radius: calc(1.1111111111 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-read .read-box .img {
    border-radius: calc(4.2666666667 * var(--vw));
    width: calc(65.8666666667 * var(--vw));
    margin: 0 auto;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-read .read-box .txt-box {
    padding: 0 calc(5.3333333333 * var(--vw));
  }
}
#RECRUIT .sec-read .read-box .txt-box .txt {
  font-size: 1.6rem;
  line-height: 1.75;
}
#RECRUIT .sec-read .read-box .txt-box .txt + .txt {
  margin-top: 1.75em;
}
@media only screen and (min-width: 768px) {
  #RECRUIT .sec-read .read-box--reverse {
    grid-template-columns: 1fr 247px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-read .read-box--reverse {
    grid-template-columns: 1fr calc(17.1527777778 * var(--vw));
  }
}
@media only screen and (min-width: 768px) {
  #RECRUIT .sec-read .read-box--reverse .txt-box {
    order: 1;
  }
}
@media only screen and (min-width: 768px) {
  #RECRUIT .sec-read .read-box--reverse .img {
    order: 2;
  }
}
#RECRUIT .sec-work-environment .work-environment-box {
  font-size: 1.6rem;
  line-height: 1.75;
  width: 840px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-work-environment .work-environment-box {
    width: calc(58.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-work-environment .work-environment-box {
    width: 100%;
    margin: calc(12.8 * var(--vw)) auto 0;
    padding: 0 calc(5.3333333333 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-work-environment .work-environment-box {
    width: 100%;
  }
}
#RECRUIT .sec-work-environment .num-list {
  counter-reset: num;
  display: grid;
  gap: 48px;
  margin: 48px auto 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-work-environment .num-list {
    gap: calc(3.3333333333 * var(--vw));
    margin: calc(3.3333333333 * var(--vw)) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-work-environment .num-list {
    gap: calc(8.5333333333 * var(--vw));
    margin: calc(12.8 * var(--vw)) auto 0;
  }
}
#RECRUIT .sec-work-environment .num-list__item {
  position: relative;
  counter-increment: num;
  padding: 0 0 0 32px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-work-environment .num-list__item {
    padding: 0 0 0 calc(2.2222222222 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-work-environment .num-list__item {
    padding: 0;
  }
}
#RECRUIT .sec-work-environment .num-list__item::before {
  content: counter(num);
  position: absolute;
  top: 0;
  left: 0;
  color: #07A5C1;
  font-size: 2rem;
  line-height: 1;
  font-weight: 700;
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-work-environment .num-list__item .sec-ttl-02 {
    text-align: left;
    margin: 0 0 calc(4.8 * var(--vw));
    padding: 0 0 0 calc(6.4 * var(--vw));
  }
}
#RECRUIT .sec-work-environment .num-list__item .txt {
  margin-top: 24px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-work-environment .num-list__item .txt {
    margin-top: calc(1.6666666667 * var(--vw));
  }
}
#RECRUIT .sec-work-environment .dot-list {
  margin-top: 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-work-environment .dot-list {
    margin-top: calc(0.6944444444 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-work-environment .dot-list {
    margin-top: calc(5.3333333333 * var(--vw));
  }
}
#RECRUIT .sec-work-environment .dot-list__item {
  position: relative;
  padding: 0 0 0 1em;
}
#RECRUIT .sec-work-environment .dot-list__item::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
#RECRUIT .sec-job-description .accordion {
  display: grid;
  grid-template-rows: auto 1fr;
}
#RECRUIT .sec-job-description .accordion__header {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 3.2rem;
  font-weight: 700;
  border-radius: 16px 16px 0 0;
  height: 72px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-job-description .accordion__header {
    border-radius: calc(1.1111111111 * var(--vw)) calc(1.1111111111 * var(--vw)) 0 0;
    height: calc(5 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-job-description .accordion__header {
    border-radius: calc(4.2666666667 * var(--vw)) calc(4.2666666667 * var(--vw)) 0 0;
    height: calc(12.8 * var(--vw));
  }
}
#RECRUIT .sec-job-description .accordion__header--type-01 {
  background: #01BEC6;
}
#RECRUIT .sec-job-description .accordion__header--type-02 {
  background: #009F41;
}
#RECRUIT .sec-job-description .accordion__content {
  background: #fff;
  border-radius: 16px;
  padding: 64px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-job-description .accordion__content {
    border-radius: calc(1.1111111111 * var(--vw));
    padding: calc(4.4444444444 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-job-description .accordion__content {
    border-radius: calc(4.2666666667 * var(--vw));
    padding: calc(12.8 * var(--vw)) 0;
  }
}
#RECRUIT .sec-job-description .accordion__content .table {
  width: 810px;
  margin: 0 auto;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-job-description .accordion__content .table {
    width: calc(56.25 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-job-description .accordion__content .table {
    width: calc(80 * var(--vw));
  }
}
#RECRUIT .sec-job-description .accordion__content .table .row {
  grid-template-columns: 210px 1fr;
  padding: 20px 0;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-job-description .accordion__content .table .row {
    grid-template-columns: calc(14.5833333333 * var(--vw)) 1fr;
    padding: calc(1.3888888889 * var(--vw)) 0;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-job-description .accordion__content .table .row {
    grid-template-columns: 1fr;
    padding: calc(5.3333333333 * var(--vw)) 0;
  }
}
#RECRUIT .sec-job-description .accordion__content .table .term, #RECRUIT .sec-job-description .accordion__content .table .desc {
  line-height: 1.6;
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-job-description .accordion__content .table .term, #RECRUIT .sec-job-description .accordion__content .table .desc {
    line-height: 1.5;
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-entry {
    padding: calc(26.6666666667 * var(--vw)) 0;
  }
}
#RECRUIT .sec-entry .btn-entry {
  background-color: #01BEC6;
  font-size: 2.4rem;
  border-radius: 36px;
  aspect-ratio: 420/72;
  width: 420px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-entry .btn-entry {
    border-radius: calc(2.5 * var(--vw));
    width: calc(29.1666666667 * var(--vw));
  }
}
@media only screen and (max-width: 767px) {
  #RECRUIT .sec-entry .btn-entry {
    width: 100%;
  }
}
#RECRUIT .sec-entry .btn-entry::after {
  right: 16px;
}
@media only screen and (min-width: 768px) and (max-width: 1440px) {
  #RECRUIT .sec-entry .btn-entry::after {
    right: calc(1.1111111111 * var(--vw));
  }
}

/*# sourceMappingURL=style.css.map */
