@charset "UTF-8";
/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Prevent adjustments of font size after orientation changes in IE and iOS.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 * 2. Add the correct display in IE.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  /* 1 */
  display: block;
}

/**
 * Add the correct display in IE 9-.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Add the correct display in IE 10-.
 * 1. Add the correct display in IE.
 */
template,
[hidden] {
  display: none;
}

/* Links
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */
}

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0;
}

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
  -moz-text-decoration: underline dotted;
  text-decoration: underline dotted;
  /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10-.
 */
img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */
}

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */
}

/* Forms
   ========================================================================== */
/**
 * 1. Change font properties to `inherit` in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
select,
textarea {
  font: inherit;
  /* 1 */
  margin: 0;
  /* 2 */
}

/**
 * Restore the font weight unset by the previous rule.
 */
optgroup {
  font-weight: bold;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on OS X.
 */
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */
}

/* clearfix (micro) */
.clearfix:before,
.clearfix:after {
  content: " ";
  display: table;
}

.clearfix:after {
  clear: both;
}

/* For IE 6/7 only */
.clearfix {
  *zoom: 1;
}

div,
p {
  word-break: break-all;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video,
nav,
picture {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
}

html {
  font-size: 62.5%;
}

@media screen and (max-width: 768px) {
  html {
    font-size: 2.66666667vw;
  }
}

@media (min-width: 769px) and (max-width: 1366px) {
  html {
    font-size: 0.7585vw;
  }
}

body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-style: normal;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.5;
  color: #333333;
  word-break: normal;
  line-break: strict;
  font-weight: 500;
  letter-spacing: 0;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 1.2rem;
  }
  body.open {
    overflow-y: hidden;
  }
}

a {
  color: inherit;
  text-decoration: none;
  -webkit-transition-duration: 0.3s;
  transition-duration: 0.3s;
}

a:hover {
  text-decoration: none;
}

@media screen and (min-width: 769px) {
  a:hover {
    opacity: 0.75;
  }
}

a:focus {
  outline: none;
  text-decoration: none;
}

ul,
ol {
  margin: 0;
  padding: 0;
}

ul li,
ol li {
  list-style: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  margin: 0;
}

figure {
  margin: 0;
  padding: 0;
  line-height: 0;
}

figure img {
  max-width: 100%;
  height: auto;
}

input[type="submit"] {
  border: none;
  -webkit-transition-duration: 0.2s;
  transition-duration: 0.2s;
}

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

dl,
dt,
dd {
  margin: 0;
  padding: 0;
}

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  word-break: break-word;
}

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

p + p {
  margin: 1em 0 0 0;
}

ul,
ol,
li {
  list-style: none;
}

.align-center {
  text-align: center !important;
}

.align-right {
  text-align: right !important;
}

.fit {
  font-family: "object-fit: cover;";
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.container {
  max-width: 129.6rem;
  padding: 0 1.5rem;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .container {
    padding: 0 2rem;
  }
}

@media screen and (min-width: 769px) {
  .show_sp {
    display: none !important;
  }
  .show_pc {
    display: inherit;
  }
  a[href^="tel"] {
    pointer-events: none;
    text-decoration: none;
    opacity: 1 !important;
    cursor: default !important;
  }
}

@media screen and (max-width: 768px) {
  body p {
    word-break: normal;
    line-break: strict;
  }
  .show_sp {
    display: inherit;
  }
  .show_pc {
    display: none !important;
  }
}

.mode-txt {
  writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: vertical-rl;
}

.js-view-img {
  opacity: 0;
  -webkit-transition: all 2s ease;
  transition: all 2s ease;
}

.js-view-img.is-act {
  opacity: 1;
}

.js-inview {
  opacity: 0;
  -webkit-transform: translate(0, 20px);
  transform: translate(0, 20px);
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

.js-inview.is-act {
  opacity: 1;
  -webkit-transform: translate(0, 0);
  transform: translate(0, 0);
}

.hover-img {
  overflow: hidden;
}

.hover-img img {
  -webkit-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
}

.hover:hover .hover-img img {
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}

.page-main {
  margin-top: 9rem;
}

@media screen and (max-width: 768px) {
  .page-main {
    margin-top: 6rem;
  }
}

@media screen and (min-width: 769px) {
  .accodion-ctn {
    display: block !important;
  }
}

@media screen and (max-width: 768px) {
  .accodion-ctn {
    display: none;
  }
}

.sc-lbl {
  display: inline-block;
}

.sc-lbl img {
  max-width: unset;
  width: auto;
  height: 2.3rem;
}

@media screen and (max-width: 768px) {
  .sc-lbl img {
    height: 1.6rem;
  }
}

.sc-lbl._lg img {
  height: 4.8rem;
}

@media screen and (max-width: 768px) {
  .sc-lbl._lg img {
    height: 3.4rem;
  }
}

.sc-cta {
  padding: 10rem 0 8.4rem;
  background-color: #D5EEF0;
}

@media screen and (max-width: 768px) {
  .sc-cta {
    padding: 6rem 0 4rem;
  }
}

.sc-cta .cta-wrap {
  border: 0.1rem solid #333;
  position: relative;
}

@media screen and (min-width: 769px) {
  .sc-cta .cta-wrap {
    padding: 4rem 8rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap {
    padding: 5.4rem 2rem 3rem;
  }
}

.sc-cta .cta-wrap .sc-lbl {
  position: absolute;
  left: 6rem;
  top: -2.5rem;
  background-color: #D5EEF0;
  padding: 0 2.2rem;
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .sc-lbl {
    padding: 0 1rem;
    top: -2rem;
    left: 1rem;
  }
}

.sc-cta .cta-wrap .cta-wrap_head {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-left: 1rem;
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_head {
    padding: 0;
    text-align: center;
  }
}

.sc-cta .cta-wrap .cta-wrap_head .sc-cta_ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: 1.55;
  margin-bottom: 3rem;
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_head .sc-cta_ttl {
    font-size: 2.4rem;
    line-height: 1.4;
    margin-bottom: 2rem;
  }
}

.sc-cta .cta-wrap .cta-wrap_head .sc-cta_txt {
  font-size: 1.8rem;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_head .sc-cta_txt {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

@media screen and (min-width: 769px) {
  .sc-cta .cta-wrap .cta-wrap_btn {
    width: 64.4rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    border-right: 1px solid transparent;
    -o-border-image: repeating-linear-gradient(to bottom, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
    border-image: repeating-linear-gradient(to bottom, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
  }
}

.sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm {
  text-align: center;
}

@media screen and (min-width: 769px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm {
    width: 50%;
    padding: 0.3rem 3.5rem 2rem;
  }
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm:first-child {
    border-left: 1px solid transparent;
    border-right: 1px solid transparent;
    -o-border-image: repeating-linear-gradient(to bottom, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
    border-image: repeating-linear-gradient(to bottom, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
  }
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm {
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 1px solid transparent;
    -o-border-image: repeating-linear-gradient(to right, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
    border-image: repeating-linear-gradient(to right, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
  }
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm:last-of-type {
    border: none;
    padding-top: 0;
  }
}

.sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .cta-wrap_btn_itm_tooltip {
  display: inline-block;
  margin-bottom: 1.6rem;
  max-width: 15.3rem;
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .cta-wrap_btn_itm_tooltip {
    max-width: 12.7rem;
    margin-bottom: 0;
  }
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .cta-wrap_btn_itm_ctn {
    display: none;
  }
}

.sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .cta-wrap_btn_itm_icon {
  max-width: 9.3rem;
  margin: 0 auto 2rem;
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .cta-wrap_btn_itm_icon {
    width: 6.9rem;
    margin: 0;
  }
}

.sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .cta-wrap_btn_itm_sub {
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 2.5rem;
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .cta-wrap_btn_itm_sub {
    font-size: 2rem;
    margin: 0;
  }
}

@media screen and (min-width: 769px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .c-btn {
    margin: 0 auto;
  }
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .c-btn .c-btn_inner {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    padding: 0 4rem 0 2.5rem;
  }
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .c-btn .ico {
    right: 2rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .c-btn {
    margin-top: 1.8rem;
  }
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .c-btn._green {
    color: #fff;
  }
  .sc-cta .cta-wrap .cta-wrap_btn .cta-wrap_btn_itm .c-btn._green .ico svg path {
    fill: #fff;
  }
}

/** tags **/
._tag {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
  padding: 0.8rem 1.7rem;
  border: 0.1rem solid #333;
  border-radius: 8rem;
}

@media screen and (max-width: 768px) {
  ._tag {
    font-size: 1rem;
    padding: 0.6rem 0.9rem;
  }
}

._tag:hover {
  color: #63AFB4;
  border-color: #63AFB4;
}

.c-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0.5rem;
}

@media screen and (max-width: 768px) {
  .c-area {
    gap: 0.2rem;
  }
}

._cat:hover {
  color: #63AFB4;
  border-color: #63AFB4;
}

/** column post **/
.column-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 5rem 3rem;
}

@media screen and (max-width: 768px) {
  .column-list {
    gap: 4rem 1.5rem;
  }
}

.column-itm {
  width: calc(33.3333% - 2rem);
}

.column-itm:nth-child(1) {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.column-itm:nth-child(2) {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.column-itm:nth-child(3) {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

@media screen and (max-width: 768px) {
  .column-itm {
    width: calc(100%/2 - 0.8rem);
  }
}

.column-itm .column-itm_thumb {
  margin-bottom: 2rem;
  height: 46rem;
  overflow: hidden;
}

.column-itm .column-itm_thumb img {
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (max-width: 768px) {
  .column-itm .column-itm_thumb {
    margin-bottom: 1.8rem;
    height: 18.5rem;
  }
}

.column-itm .column-itm_date {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 1.3rem;
  font-family: "Elms Sans", sans-serif;
  position: relative;
  padding-left: 1.1rem;
}

.column-itm .column-itm_date::after {
  content: "";
  display: block;
  width: 0.6rem;
  height: 0.6rem;
  background-color: #FFE100;
  border: 0.1rem solid #333;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  border-radius: 50%;
}

@media screen and (max-width: 768px) {
  .column-itm .column-itm_date {
    font-size: 1.2rem;
    margin-bottom: 0.8rem;
    padding-left: 0.9rem;
  }
}

.column-itm .column-itm_ttl {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6667;
  text-decoration: underline;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

@media screen and (max-width: 768px) {
  .column-itm .column-itm_ttl {
    font-size: 1.4rem;
    line-height: 1.57;
  }
}

.column-itm .column-itm_tag {
  margin-top: 1.3rem;
}

@media screen and (max-width: 768px) {
  .column-itm .column-itm_tag {
    margin-top: 0.8rem;
  }
}

.column-itm .column-itm_cat {
  font-size: 1.4rem;
  line-height: 1.571;
  margin-top: 1.3rem;
}

@media screen and (max-width: 768px) {
  .column-itm .column-itm_cat {
    font-size: 1.2rem;
    margin-top: 0.8rem;
  }
}

.column-itm .column-itm_link {
  display: block;
  width: 100%;
}

.column-itm .column-itm_link:hover .column-itm_ttl {
  color: #63AFB4;
}

.faq-art {
  padding: 2rem 0;
  border-bottom: 0.1rem solid #333;
}

.faq-art .ico {
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  font-family: "Elms Sans", sans-serif;
  border: 0.1rem solid #333;
}

@media screen and (max-width: 768px) {
  .faq-art .ico {
    width: 3.8rem;
    height: 3.8rem;
  }
}

.faq-art .txt {
  font-size: 1.6rem;
  line-height: 2.25;
}

@media screen and (max-width: 768px) {
  .faq-art .txt {
    font-size: 1.4rem;
    line-height: 1.857;
  }
}

.faq-art .faq-art_ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 1rem;
  -moz-column-gap: 1rem;
  column-gap: 1rem;
  padding-right: 4.5rem;
  font-weight: 500;
  cursor: pointer;
  position: relative;
}

.faq-art .faq-art_ttl::after {
  position: absolute;
  content: '';
  width: 1.8rem;
  height: 1.2rem;
  right: 0.6rem;
  top: 50%;
  margin-top: -0.6rem;
  background: url(../img/common/icon_down.svg) center no-repeat;
  background-size: cover;
  -webkit-transition: -webkit-transform .3s ease;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
}

.faq-art .faq-art_ttl.active::after {
  -webkit-transform: scaleY(-1);
  transform: scaleY(-1);
}

.faq-art .faq-art_ttl .txt {
  display: block;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@media screen and (max-width: 768px) {
  .faq-art .faq-art_ttl {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding-right: 2.4rem;
  }
  .faq-art .faq-art_ttl::after {
    width: 1.4rem;
    height: 0.9rem;
    right: 0;
    margin-top: -0.45rem;
  }
}

.faq-art .faq-art_ctn {
  display: none;
  padding-top: 1.3rem;
}

.faq-art .faq-art_ctn .faq-cpy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 1rem;
  -moz-column-gap: 1rem;
  column-gap: 1rem;
}

.faq-art .faq-art_ctn .ico {
  color: #63AFB4;
  border-color: #63AFB4;
}

.faq-art .faq-art_ctn .txt {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.news-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 2rem 4rem;
}

@media screen and (max-width: 768px) {
  .news-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 2 0;
  }
}

.news-itm {
  width: calc(100%/2 - 2rem);
  border-bottom: 0.1rem solid #333;
  padding-bottom: 2rem;
}

@media screen and (max-width: 768px) {
  .news-itm {
    width: 100%;
    padding-bottom: 1.5rem;
  }
}

.news-itm .news-itm_date {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 1.4rem;
  font-family: "Elms Sans", sans-serif;
  border: 0.1rem solid #333;
  border-radius: 8rem;
  padding: 0.9rem 1.3rem;
  position: relative;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

@media screen and (max-width: 768px) {
  .news-itm .news-itm_date {
    font-size: 1.4rem;
    padding: 0.8rem 1.4rem;
    margin-bottom: 1.5rem;
  }
}

.news-itm .news-itm_txt {
  display: block;
  line-height: 2.125;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

@media screen and (max-width: 768px) {
  .news-itm .news-itm_txt {
    font-size: 1.4rem;
    line-height: 1.857;
    text-decoration: underline;
  }
}

.news-itm .news-itm_link {
  display: block;
}

.news-itm .news-itm_link:hover .news-itm_date {
  color: #63AFB4;
  border-color: #63AFB4;
}

.news-itm .news-itm_link:hover .news-itm_txt {
  color: #63AFB4;
}

.news-itm + .news-itm {
  margin-top: 0;
}

.construction-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 10.5rem 3rem;
}

@media screen and (max-width: 768px) {
  .construction-list {
    gap: 4rem 1.5rem;
  }
}

.construction-item {
  width: calc(33.3333% - 2rem);
  position: relative;
}

.construction-item:nth-child(1) {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.construction-item:nth-child(2) {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.construction-item:nth-child(3) {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

.construction-item:nth-child(4) {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

.construction-item:nth-child(5) {
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}

.construction-item:nth-child(6) {
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}

@media screen and (max-width: 768px) {
  .construction-item {
    width: calc(100%/2 - 0.8rem);
  }
}

.construction-item .construction-item_img {
  margin-bottom: 2.4rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  .construction-item .construction-item_img {
    margin-bottom: 1.8rem;
  }
}

.construction-item .construction-item_img::after {
  position: absolute;
  content: '';
  width: 100%;
  height: 32.4rem;
  bottom: 0.1rem;
  left: 0;
  -webkit-box-shadow: 0.4rem 0.4rem 0 #333333;
  box-shadow: 0.4rem 0.4rem 0 #333333;
}

@media screen and (max-width: 768px) {
  .construction-item .construction-item_img::after {
    height: 12.9rem;
    -webkit-box-shadow: 0.2rem 0.2rem 0 #333333;
    box-shadow: 0.2rem 0.2rem 0 #333333;
  }
}

.construction-item .construction-item_img figure {
  width: 100%;
  height: 41.4rem;
  -webkit-mask-image: url(../img/common/works_mask.webp);
  mask-image: url(../img/common/works_mask.webp);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  position: relative;
}

.construction-item .construction-item_img figure::after {
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: url(../img/common/works_mask_border.webp) left top no-repeat;
  background-size: 100% 100%;
}

.construction-item .construction-item_img figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (max-width: 768px) {
  .construction-item .construction-item_img figure {
    height: 16.5rem;
  }
}

.construction-item .construction-item_date {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 1.3rem;
  font-family: "Elms Sans", sans-serif;
  position: relative;
  padding-left: 1.1rem;
}

.construction-item .construction-item_date::after {
  content: "";
  display: block;
  width: 0.6rem;
  height: 0.6rem;
  background-color: #FFE100;
  border: 0.1rem solid #333;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  border-radius: 50%;
}

@media screen and (max-width: 768px) {
  .construction-item .construction-item_date {
    font-size: 1.2rem;
    margin-bottom: 0.8rem;
    padding-left: 0.9rem;
  }
}

.construction-item .construction-item_ttl {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6667;
  text-decoration: underline;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

@media screen and (max-width: 768px) {
  .construction-item .construction-item_ttl {
    font-size: 1.4rem;
    line-height: 1.57;
  }
}

.construction-item .construction-item_tag {
  margin-top: 1.3rem;
}

@media screen and (max-width: 768px) {
  .construction-item .construction-item_tag {
    margin-top: 0.8rem;
  }
}

.construction-item .construction-item_cat {
  font-size: 1.4rem;
  line-height: 1.571;
  margin-top: 1.3rem;
}

@media screen and (max-width: 768px) {
  .construction-item .construction-item_cat {
    font-size: 1.2rem;
    margin-top: 0.8rem;
  }
}

.construction-item .construction-item_link {
  display: block;
}

.construction-item .construction-item_link:hover .construction-item_ttl {
  color: #63AFB4;
}

.slider-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 1.7rem;
  -moz-column-gap: 1.7rem;
  column-gap: 1.7rem;
}

@media screen and (max-width: 768px) {
  .slider-nav {
    -webkit-column-gap: 1rem;
    -moz-column-gap: 1rem;
    column-gap: 1rem;
  }
}

.slider-nav .slides-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.7rem;
  width: 8.2rem;
}

.slider-nav .slides-numbers > span {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1;
  font-family: "Elms Sans", sans-serif;
}

@media screen and (max-width: 768px) {
  .slider-nav .slides-numbers {
    -webkit-column-gap: 0.5rem;
    -moz-column-gap: 0.5rem;
    column-gap: 0.5rem;
    width: 7rem;
  }
  .slider-nav .slides-numbers > span {
    font-size: 1rem;
  }
}

.slider-nav .progress-wrap {
  width: 3.4rem;
  height: 0.1rem;
  background: #C3C3C3;
  position: relative;
  overflow: hidden;
}

.slider-nav .progress-bar {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 0%;
  background: #000000;
  -webkit-transition: width 0.3s ease;
  transition: width 0.3s ease;
}

.loc {
  display: inline-block;
  padding-right: 1.1rem;
  position: relative;
}

.loc::after {
  position: absolute;
  content: '';
  width: 0.6rem;
  height: 0.8rem;
  right: 0;
  top: 55%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/icon_right.svg) right center no-repeat;
  background-size: contain;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

.loc::before {
  position: absolute;
  content: '';
  width: 100%;
  height: 0.1rem;
  left: 0;
  bottom: 0;
  background: #63AFB4;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transform-origin: right top;
  transform-origin: right top;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
}

@media screen and (min-width: 769px) {
  .loc:hover, .loc.active {
    color: #63AFB4;
  }
  .loc:hover::after, .loc.active::after {
    background: url(../img/common/icon_right_blue.svg) right center no-repeat;
    background-size: contain;
  }
  .loc:hover::before, .loc.active::before {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}

@media screen and (max-width: 768px) {
  .loc::before {
    background: #333;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}

.area-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0.7rem 2.4rem;
}

@media screen and (max-width: 768px) {
  .area-list {
    gap: 1rem 2.4rem;
    padding: 0 0 2.4rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-navs .navs-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row wrap;
    flex-flow: row wrap;
  }
}

@media screen and (min-width: 769px) {
  .sc-navs .navs-item {
    width: 50%;
  }
}

.sc-navs .navs-item .navs-item_ttl img {
  width: auto;
  max-width: unset;
  height: 4.7rem;
}

@media screen and (max-width: 768px) {
  .sc-navs .navs-item .navs-item_ttl img {
    height: 2.8rem;
  }
}

.sc-navs .navs-item .navs-item_sub {
  font-size: 2.4rem;
  line-height: 1;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .sc-navs .navs-item .navs-item_sub {
    font-size: 2rem;
    line-height: 1.2;
    margin-top: 1.8rem;
  }
}

.sc-navs .navs-item .navs-item_txt {
  line-height: 2.25;
  margin-top: 4.3rem;
}

@media screen and (max-width: 768px) {
  .sc-navs .navs-item .navs-item_txt {
    font-size: 1.4rem;
    line-height: 1.857;
    margin-top: 1.2rem;
  }
}

.sc-navs .navs-item ._button {
  position: absolute;
  right: 6rem;
  bottom: 3.8rem;
}

@media screen and (max-width: 768px) {
  .sc-navs .navs-item ._button {
    right: 2rem;
    bottom: 2rem;
  }
}

.sc-navs .navs-item .navs-item_ctn {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 1;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .sc-navs .navs-item .navs-item_img {
    width: 100%;
    height: 24rem;
  }
  .sc-navs .navs-item .navs-item_img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
}

.sc-navs .navs-item .navs-item_link {
  display: block;
  position: relative;
}

.sc-navs .navs-item .navs-item_link::after {
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: rgba(51, 51, 51, 0.5);
}

#loading {
  -webkit-transition-duration: 1s;
  transition-duration: 1s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  background-color: #D5EEF0;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
}

#loading.hide {
  opacity: 0;
  visibility: hidden;
}

#loading.top {
  background-size: cover;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

#loading.top .loading-logo {
  display: inline-block;
}

#loading.top .loading-logo img,
#loading.top .loading-logo object {
  width: 32.2rem;
  height: 29.7rem;
  display: block;
}

@media screen and (max-width: 768px) {
  #loading.top .loading-logo img,
  #loading.top .loading-logo object {
    width: 22.2rem;
    height: 20.5rem;
  }
}

#loading.top .loading-txt {
  -webkit-transition-duration: 2s;
  transition-duration: 2s;
  -webkit-transition-timing-function: ease;
  transition-timing-function: ease;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-filter: blur(10px);
  filter: blur(10px);
  -webkit-transform: translateY(10px);
  transform: translateY(10px);
  font-size: 1.8rem;
  line-height: 1;
  margin-top: 6.5rem;
  color: #63AFB4;
}

@media screen and (max-width: 768px) {
  #loading.top .loading-txt {
    line-height: 1.6667;
    text-align: center;
    margin-top: 2.5rem;
  }
}

#loading.top.active .loading-txt {
  -webkit-filter: blur(0);
  filter: blur(0);
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

.p-404 .p-contents {
  padding: 5rem 0 10rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .p-404 .p-contents {
    padding: 3rem 0 6rem;
  }
}

.p-404 .p-404_ttl {
  font-size: 6rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 2rem;
  font-family: "Elms Sans", sans-serif;
}

@media screen and (max-width: 768px) {
  .p-404 .p-404_ttl {
    font-size: 4rem;
  }
}

.p-404 .p-404_txt {
  font-size: 2rem;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .p-404 .p-404_txt {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

.c-link {
  position: relative;
}

.c-link:after {
  position: absolute;
  content: '';
  width: 100%;
  height: 0.1rem;
  left: 0;
  bottom: -0.1rem;
  background: #333;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transform-origin: right top;
  transform-origin: right top;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
}

@media screen and (min-width: 769px) {
  .c-link:hover:after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}

@media screen and (max-width: 768px) {
  .c-link:after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}

.breadcrumb {
  padding: 5rem 0 3rem;
}

.breadcrumb ul li {
  display: inline-block;
  color: #63AFB4;
}

.breadcrumb ul li a {
  display: inline-block;
  color: #333333;
}

.breadcrumb ul li + li {
  position: relative;
  padding-left: 3rem;
}

.breadcrumb ul li + li::before {
  display: inline-block;
  position: absolute;
  content: '/';
  color: #333333;
  left: 1.2rem;
}

@media screen and (max-width: 768px) {
  .breadcrumb {
    padding: 1rem 0 3rem;
    overflow: hidden;
  }
  .breadcrumb ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    overflow: hidden;
    padding: 0.4rem 0;
  }
  .breadcrumb ul li {
    line-height: 180%;
    white-space: nowrap;
    min-width: 0;
  }
  .breadcrumb ul li:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
  }
}

@media screen and (min-width: 769px) {
  .mgt_pc60 {
    margin-top: 6rem;
  }
}

@media screen and (max-width: 768px) {
  .mgt_sp30 {
    margin-top: 3rem;
  }
}

.mgt_sp60 {
  margin-top: 6rem;
}

em {
  display: inline-block;
  font-style: normal;
}

.color-blue {
  color: #63AFB4;
}

.c-under {
  position: relative;
}

.c-under:after {
  position: absolute;
  content: '';
  width: 100%;
  height: 0.1rem;
  left: 0;
  bottom: 0;
  background: #333;
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1);
  -webkit-transform-origin: left top;
  transform-origin: left top;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
}

.c-under:hover:after {
  -webkit-transform-origin: bottom right;
  transform-origin: bottom right;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
}

.p-wrap {
  padding: 5rem 0 12rem;
}

.p-wrap .heading-lv1 {
  margin-top: 6rem;
}

.p-wrap.construction {
  padding-top: 8rem;
}

@media screen and (max-width: 768px) {
  .p-wrap {
    padding: 3rem 0 7rem;
  }
  .p-wrap.construction {
    padding-top: 5rem;
  }
}

.sc-top {
  padding-bottom: 5rem;
}

.sc-top .container {
  max-width: 87rem;
}

/** section flow **/
.sc-flow {
  padding: 8rem 0 12rem;
}

@media screen and (max-width: 768px) {
  .sc-flow {
    padding: 5rem 0 7rem;
  }
}

.sc-flow .flow-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-flow: row-reverse;
  flex-flow: row-reverse;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 7rem;
  -moz-column-gap: 7rem;
  column-gap: 7rem;
  margin-top: 6rem;
}

@media screen and (max-width: 768px) {
  .sc-flow .flow-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 3rem;
    margin-top: 3rem;
  }
}

.sc-flow .flow-row_step {
  width: 69rem;
}

@media screen and (max-width: 768px) {
  .sc-flow .flow-row_step {
    width: 100%;
    max-width: 26.5rem;
    text-align: center;
  }
}

.sc-flow .flow-row_img {
  width: 41.4rem;
}

@media screen and (max-width: 768px) {
  .sc-flow .flow-row_img {
    width: 100%;
    max-width: 18.2rem;
  }
}

/** section feature **/
.sc-feature {
  padding-bottom: 4rem;
}

@media screen and (max-width: 768px) {
  .sc-feature {
    padding-bottom: 3rem;
  }
}

.sc-feature .heading-lv2 {
  margin-bottom: 6rem;
}

@media screen and (max-width: 768px) {
  .sc-feature .heading-lv2 {
    margin-bottom: 2.6rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-feature .c-btn._center {
    margin-top: 3rem;
  }
}

.sc-feature .feature-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0 3rem;
}

@media screen and (max-width: 768px) {
  .sc-feature .feature-list {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    row-gap: 1.6rem;
  }
}

.sc-feature .feature-item {
  width: calc(100%/3 - 2rem);
  padding: 3rem 3rem 4rem;
  background-color: #F9FAFB;
}

@media screen and (max-width: 768px) {
  .sc-feature .feature-item {
    width: 100%;
    padding: 2rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-feature .feature-item .feature-item_head {
    text-align: center;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  .sc-feature .feature-item .feature-item_head {
    display: block;
    padding-left: 6.2rem;
    padding-bottom: 1.7rem;
    position: relative;
    border-bottom: 0.1rem dotted #333333;
  }
}

@media screen and (min-width: 769px) {
  .sc-feature .feature-item .feature-item_head .feature-item_lbl {
    display: inline-block;
    border-radius: 2.4rem;
    background-color: #63AFB4;
    color: #fff;
    font-size: 1.8rem;
    line-height: 2;
    padding: 0.6rem 2.3rem;
    margin-bottom: 2.4rem;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
}

@media screen and (max-width: 768px) {
  .sc-feature .feature-item .feature-item_head .feature-item_lbl {
    display: inline-block;
    font-size: 1.6rem;
    color: #63AFB4;
  }
}

@media screen and (min-width: 769px) {
  .sc-feature .feature-item .feature-item_head .feature-item_img {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }
}

@media screen and (max-width: 768px) {
  .sc-feature .feature-item .feature-item_head .feature-item_img {
    position: absolute;
    left: 0;
    top: calc(50% - 0.7rem);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
  .sc-feature .feature-item .feature-item_head .feature-item_img img {
    display: inline-block;
    max-width: unset;
    width: auto;
    height: 4.5rem;
  }
}

.sc-feature .feature-item .feature-item_head .feature-item_ttl {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.25;
  margin-top: 2.8rem;
}

@media screen and (min-width: 769px) {
  .sc-feature .feature-item .feature-item_head .feature-item_ttl {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }
}

@media screen and (max-width: 768px) {
  .sc-feature .feature-item .feature-item_head .feature-item_ttl {
    font-size: 1.8rem;
    margin-top: 0.3rem;
  }
}

.sc-feature .feature-item .feature-item_txt {
  margin-top: 2rem;
  line-height: 2.125;
}

@media screen and (max-width: 768px) {
  .sc-feature .feature-item .feature-item_txt {
    font-size: 1.4rem;
    margin-top: 1rem;
    line-height: 1.857;
  }
}

@media screen and (min-width: 769px) {
  .sc-feature .feature-item:nth-child(1) .feature-item_img img {
    width: 10.1rem;
  }
  .sc-feature .feature-item:nth-child(2) .feature-item_img img {
    width: 9.5rem;
  }
  .sc-feature .feature-item:nth-child(3) .feature-item_img img {
    width: 10.6rem;
  }
}

/** sc-consultation **/
.sc-store-crate {
  background-color: #D5EEF0;
  padding: 5rem 0;
}

@media screen and (max-width: 768px) {
  .sc-store-crate {
    padding: 2rem 0;
  }
}

.sc-store-crate .store-crate-inner {
  border: 0.1rem solid #333333;
  padding: 2.8rem 4rem 4rem;
  text-align: center;
  position: relative;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-inner {
    padding: 2.5rem 2rem 3rem;
  }
}

.sc-store-crate .store-crate-title {
  font-size: 4rem;
  font-weight: 500;
  line-height: 1.8;
  margin-bottom: 0.7rem;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-title {
    font-size: 2.4rem;
    line-height: 1.4167;
    margin-bottom: 2rem;
  }
}

.sc-store-crate .store-crate-txt {
  font-size: 1.8rem;
  line-height: 2;
  margin-bottom: 3.3rem;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-txt {
    font-size: 1.6rem;
    line-height: 1.875;
    margin-bottom: 2rem;
  }
}

.sc-store-crate .store-crate-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0 4rem;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 2rem 0;
  }
}

.sc-store-crate .store-crate-item {
  width: 25.2rem;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-item {
    width: 100%;
  }
}

.sc-store-crate .store-crate-item .store-crate-item_link {
  width: 100%;
  height: 8.7rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-item .store-crate-item_link {
    height: 6rem;
    margin: 0;
  }
}

.sc-store-crate .store-crate-item .store-crate-item_link._cta {
  border: 0.1rem solid #333;
}

.sc-store-crate .store-crate-item .store-crate-item_link._cta .ttl {
  display: inline-block;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.1;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-item .store-crate-item_link._cta .ttl {
    display: none;
  }
}

.sc-store-crate .store-crate-item .store-crate-item_link._cta .tel {
  display: inline-block;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.1;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-item .store-crate-item_link._cta .tel {
    display: none;
  }
}

.sc-store-crate .store-crate-item .store-crate-item_link._cta .sch {
  display: inline-block;
  font-size: 1.2rem;
  line-height: 140%;
  margin-top: 0.4rem;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-item .store-crate-item_link._cta .sch {
    display: none;
  }
}

.sc-store-crate .store-crate-pos {
  display: inline-block;
  width: 15.2rem;
  position: absolute;
  right: -0.4rem;
  top: -7.9rem;
}

@media screen and (max-width: 768px) {
  .sc-store-crate .store-crate-pos {
    display: none;
  }
}

/** sc-column **/
.sc-column {
  padding: 8.5rem 0 12rem;
}

@media screen and (min-width: 769px) {
  .sc-column .heading-lv2 .txt {
    font-size: 1.6rem;
  }
}

.sc-column .column-head {
  position: relative;
}

@media screen and (min-width: 769px) {
  .sc-column .column-head {
    margin-bottom: 6rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding-right: 7rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-column .column-head {
    margin-bottom: 3rem;
  }
}

.sc-column .column-lbl {
  display: inline-block;
  width: 17.4rem;
  height: 17.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
}

@media screen and (max-width: 768px) {
  .sc-column .column-lbl {
    width: 9rem;
    height: 9rem;
    position: absolute;
    right: 0;
    top: 0.5rem;
  }
}

.sc-column .column-lbl .column-lbl_circle {
  position: absolute;
  width: 17.4rem;
  height: 17.4rem;
  top: 0;
  left: 0;
  z-index: 1;
  -webkit-animation: rotateClockwise 10s linear infinite;
  animation: rotateClockwise 10s linear infinite;
}

@media screen and (max-width: 768px) {
  .sc-column .column-lbl .column-lbl_circle {
    width: 9rem;
    height: 9rem;
  }
}

.sc-column .column-lbl .column-lbl_img {
  display: inline-block;
  width: 5.8rem;
}

@media screen and (max-width: 768px) {
  .sc-column .column-lbl .column-lbl_img {
    width: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-column {
    padding: 4rem 0 7rem;
  }
  .sc-column .column-head {
    margin-bottom: 3rem;
  }
}

/** sc-works **/
.sc-works {
  padding: 10rem 0 11rem;
}

@media screen and (max-width: 768px) {
  .sc-works {
    padding: 5rem 0 6rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-works .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: 11.4rem;
    -moz-column-gap: 11.4rem;
    column-gap: 11.4rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-works .container .sc-works_ctn {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
  }
}

@media screen and (max-width: 768px) {
  .sc-works .container .sc-works_ctn {
    margin-bottom: 3rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-works .container .sc-works_img {
    width: 70rem;
  }
}

.sc-works .container .sc-works_ttl {
  font-size: 4.8rem;
  font-weight: 500;
  line-height: 1.5;
  border-top: 0.1rem solid #333;
  border-bottom: 0.1rem solid #333;
  padding: 1.2rem 0;
  margin-bottom: 4rem;
}

@media screen and (max-width: 768px) {
  .sc-works .container .sc-works_ttl {
    font-size: 2.4rem;
    line-height: 1.25;
    padding: 1.6rem 0;
    text-align: center;
    margin-bottom: 3rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-works .container .works-cpy {
    position: -webkit-sticky;
    position: sticky;
    left: 0;
    top: 11rem;
  }
}

.sc-works .container .sc-works_txt {
  line-height: 2.25;
}

@media screen and (max-width: 768px) {
  .sc-works .container .sc-works_txt {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

.sc-works .container .works-img_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 5rem;
}

@media screen and (max-width: 768px) {
  .sc-works .container .works-img_list {
    row-gap: 3rem;
  }
}

.sc-works .container .works-img_itm {
  display: block;
}

.sc-works .container .works-img_itm.is-hidden {
  opacity: 0;
  height: 0;
  overflow: hidden;
  pointer-events: none;
}

.sc-works .container .works-img_itm_tl {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6667;
  position: relative;
  padding-left: 4.1rem;
  margin-top: 1.6rem;
}

.sc-works .container .works-img_itm_tl::before {
  position: absolute;
  content: '';
  width: 3.1rem;
  height: 2.5rem;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/icon_dupple.svg) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 768px) {
  .sc-works .container .works-img_itm_tl {
    font-size: 1.6rem;
    line-height: 1.5;
    padding-left: 2.5rem;
    margin-top: 1rem;
  }
  .sc-works .container .works-img_itm_tl::before {
    width: 2.1rem;
    height: 1.7rem;
  }
}

.c-txt {
  font-size: 1.8rem;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .c-txt {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

.sc-construction .container,
.construction .container {
  position: relative;
}

.sc-construction .const-pos,
.construction .const-pos {
  display: inline-block;
  position: absolute;
}

.sc-construction .const-pos.pos1,
.construction .const-pos.pos1 {
  width: 4.7rem;
  top: 4rem;
  right: 4.3rem;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

@media screen and (max-width: 768px) {
  .sc-construction .const-pos.pos1,
  .construction .const-pos.pos1 {
    width: 2rem;
    right: 1.6rem;
    top: 8rem;
  }
}

.sc-construction .const-pos.pos2,
.construction .const-pos.pos2 {
  width: 6.5rem;
  left: 1.6rem;
  top: -6rem;
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

@media screen and (max-width: 768px) {
  .sc-construction .const-pos.pos2,
  .construction .const-pos.pos2 {
    width: 2.8rem;
    left: 0;
    top: -2.5rem;
  }
}

@media screen and (min-width: 769px) {
  .construction .construction-list {
    row-gap: 10.5rem;
  }
}

@media screen and (min-width: 769px) {
  .construction .const-pos.pos1 {
    top: 11rem;
  }
}

@media screen and (max-width: 768px) {
  .construction .const-pos.pos1 {
    top: 8.5rem;
  }
}

.p-archive .sc-feature {
  padding: 5rem 0 8rem;
}

.p-archive .sc-construction {
  padding: 8rem 0 10rem;
}

.p-archive .sc-construction .heading-lv2 {
  margin: 5rem 0;
}

.p-archive .sc-construction .heading-lv2 .ja {
  line-height: 1.333;
}

@media screen and (max-width: 768px) {
  .p-archive .sc-future {
    padding-top: 1.5rem;
  }
}

@media screen and (min-width: 769px) {
  .p-wrap.sc-construction .construction-list {
    row-gap: 10.5rem;
  }
}

@media screen and (min-width: 769px) {
  .p-wrap.sc-construction .const-pos.pos1 {
    top: 12rem;
  }
}

@media screen and (max-width: 768px) {
  .p-wrap.sc-construction .const-pos.pos1 {
    top: 7rem;
  }
}

.sc-construction-area {
  padding: 3rem 0 11rem;
}

@media screen and (min-width: 769px) {
  .sc-construction-area .container {
    position: relative;
  }
  .sc-construction-area .pos {
    width: 5.6rem;
    right: 5.9rem;
    top: -1rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-construction-area {
    padding: 2rem 0 5rem;
  }
  .sc-construction-area .pos {
    display: none;
  }
}

.sc-construction-area .heading-lv3 {
  margin-bottom: 2.4rem;
}

@media screen and (max-width: 768px) {
  .sc-construction-area .heading-lv3 {
    margin-bottom: 2rem;
  }
}

.sc-construction-area .mega-area {
  background-color: #F9FAFB;
  padding: 4rem 2rem;
}

@media screen and (max-width: 768px) {
  .sc-construction-area .mega-area {
    padding: 1rem 2rem 3rem 2rem;
  }
  .sc-construction-area .mega-area .mega-menu_item_ttl {
    color: #333;
  }
}

._flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

._flex-column {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

@media screen and (min-width: 769px) {
  .p-rows .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: 6rem;
    -moz-column-gap: 6rem;
    column-gap: 6rem;
  }
  .p-rows .p-rows_sidebar {
    width: 36.2rem;
  }
  .p-rows .p-rows_content {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
  }
}

@media screen and (max-width: 768px) {
  .p-rows .p-rows_sidebar {
    margin-bottom: 3rem;
  }
}

/** header area
====================================== **/
.page-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 0 0 0 5rem;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 9;
  background: white;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

@media screen and (max-width: 768px) {
  .page-header {
    padding: 1.2rem 1.5rem 1.2rem 1.3rem;
  }
}

.logo {
  display: block;
  width: 28.1rem;
  line-height: 0;
}

@media screen and (max-width: 768px) {
  .logo {
    width: 14.4rem;
  }
}

.header-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: 3rem;
  position: relative;
}

.header-button::before {
  position: absolute;
  content: '';
  width: 0.1rem;
  height: 8rem;
  top: 0.5rem;
  left: 0;
  background-color: #E5E5E5;
}

.header-button a {
  width: 100%;
  height: 9rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.header-button a._btn {
  width: 10rem;
  text-align: center;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.33;
}

.header-button a._btn._web {
  background-color: #333;
  color: #fff;
}

.header-button a._btn._line {
  background-color: #1BCE3C;
}

.header-button a._cta {
  padding: 0 1.6rem 0 1.4rem;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.header-button a._cta .ttl {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 140%;
}

.header-button a._cta .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 0.4rem;
  -moz-column-gap: 0.4rem;
  column-gap: 0.4rem;
  margin: 0.8rem 0 0.3rem 0;
}

.header-button a._cta .tel img {
  width: 1.8rem;
  height: auto;
}

.header-button a._cta .tel > span {
  display: inline-block;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  font-style: italic;
  font-family: "Elms Sans", sans-serif;
}

.header-button a._cta .sch {
  font-size: 1.2rem;
  line-height: 140%;
}

@media screen and (max-width: 768px) {
  .header-button {
    display: none;
  }
}

.g-btn {
  margin-left: auto;
}

@media screen and (max-width: 768px) {
  .g-btn {
    padding: 0.8rem 1rem;
    border-radius: 8rem;
    border: 0.1rem solid #333333;
    margin-right: 1rem;
  }
  .g-btn .menu-arr {
    display: none;
  }
}

.g-btn_menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
}

.g-btn_menu .g-btn_menu_item .g-btn_menu_item_link {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.25;
  position: relative;
  padding-right: 2.4rem;
  cursor: pointer;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

.g-btn_menu .g-btn_menu_item .g-btn_menu_item_link::after {
  position: absolute;
  content: '';
  width: 1.8rem;
  height: 1.2rem;
  right: 0;
  top: 50%;
  margin-top: -0.6rem;
  background: url(../img/common/icon_down.svg) center no-repeat;
  background-size: cover;
}

.g-btn_menu .g-btn_menu_item .g-btn_menu_item_link:hover {
  opacity: 0.5;
}

@media screen and (max-width: 768px) {
  .g-btn_menu .g-btn_menu_item .g-btn_menu_item_link {
    font-size: 1.2rem;
    line-height: 1;
    padding-right: 1.4rem;
  }
  .g-btn_menu .g-btn_menu_item .g-btn_menu_item_link::after {
    width: 1.2rem;
    height: 0.8rem;
    margin-top: -0.4rem;
    display: block;
  }
}

.g-btn_menu .g-btn_menu_item.active .g-btn_menu_item_link::after {
  margin-top: -0.4rem;
  -webkit-transform: scaleY(-1);
  transform: scaleY(-1);
}

.button-fixed {
  width: 100%;
  padding: 0.7rem 2rem;
  border-radius: 1.5rem 1.5rem 0 0;
  -webkit-box-shadow: 0 -2px 4px 0 rgba(51, 51, 51, 0.1);
  box-shadow: 0 -2px 4px 0 rgba(51, 51, 51, 0.1);
  background-color: #fff;
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 8;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.button-fixed .button-fixed_ttl {
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0.07em;
}

.button-fixed .button-fixed_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 0.5rem;
  -moz-column-gap: 0.5rem;
  column-gap: 0.5rem;
}

.button-fixed .button-fixed_btn_itm {
  width: 8.2rem;
  height: 4.6rem;
}

.button-fixed .button-fixed_btn_itm a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  height: 100%;
  background-color: #333;
  color: #fff;
}

.button-fixed .button-fixed_btn_itm a .tl {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
  position: relative;
}

.button-fixed .button-fixed_btn_itm a .tl::before {
  position: absolute;
  content: '';
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.button-fixed .button-fixed_btn_itm a .tx {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: 1;
  margin-top: 0.9rem;
}

.button-fixed .button-fixed_btn_itm a._tel .tl {
  padding-left: 1.9rem;
}

.button-fixed .button-fixed_btn_itm a._tel .tl::before {
  width: 1.6rem;
  height: 1.7rem;
  left: 0;
  background: url(../img/common/icon_tel2.svg) left top no-repeat;
  background-size: cover;
}

.button-fixed .button-fixed_btn_itm a._web .tl {
  padding-left: 2.1rem;
}

.button-fixed .button-fixed_btn_itm a._web .tl::before {
  width: 1.3rem;
  height: 1.7rem;
  left: 0;
  background: url(../img/common/icon_web2.svg) left top no-repeat;
  background-size: cover;
}

.button-fixed .button-fixed_btn_itm a._line {
  background-color: #1BCE3C;
  color: #333333;
}

.button-fixed .button-fixed_btn_itm a._line .tl {
  padding-left: 2.5rem;
}

.button-fixed .button-fixed_btn_itm a._line .tl::before {
  width: 1.8rem;
  height: 1.6rem;
  left: 0;
  background: url(../img/common/icon_line2.svg) left top no-repeat;
  background-size: cover;
}

@media screen and (min-width: 769px) {
  .button-fixed {
    display: none;
  }
}

.mega-contents {
  display: none;
  background-color: #fff;
  width: 100%;
  max-height: calc(100vh - 9rem);
  overflow-y: auto;
  position: fixed;
  left: 0;
  top: 9rem;
  z-index: 9;
  padding: 4rem 0;
  -webkit-box-shadow: 0 0.7rem 1rem 0 rgba(51, 51, 51, 0.15);
  box-shadow: 0 0.7rem 1rem 0 rgba(51, 51, 51, 0.15);
}

@media screen and (max-width: 768px) {
  .mega-contents {
    max-height: calc(100dvh - 6rem);
    top: 6rem;
    padding: 0.3rem 0 2rem;
  }
}

.mega-area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 3.5rem 5rem;
}

@media screen and (max-width: 768px) {
  .mega-area {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 0;
  }
}

.mega-area .mega-menu_item {
  width: calc(100%/3 - 3.4rem);
}

@media screen and (max-width: 768px) {
  .mega-area .mega-menu_item {
    width: 100%;
    border-bottom: 0.1rem solid #333;
  }
}

.mega-area .mega-menu_item_ttl {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
}

@media screen and (min-width: 769px) {
  .mega-area .mega-menu_item_ttl {
    margin-bottom: 1.6rem;
    position: relative;
  }
  .mega-area .mega-menu_item_ttl::after {
    position: absolute;
    content: '';
    width: 100%;
    height: 0.1rem;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #333;
  }
  .mega-area .mega-menu_item_ttl span {
    display: inline-block;
    padding: 1.2rem 1.8rem;
    border: 0.1rem solid #333;
    border-radius: 8rem;
    background-color: #fff;
    position: relative;
    z-index: 1;
  }
}

@media screen and (max-width: 768px) {
  .mega-area .mega-menu_item_ttl {
    color: #63AFB4;
    margin: 0;
    padding: 2.4rem 0;
    position: relative;
  }
  .mega-area .mega-menu_item_ttl::before, .mega-area .mega-menu_item_ttl::after {
    position: absolute;
    content: '';
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #333;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
  }
  .mega-area .mega-menu_item_ttl::before {
    width: 1.1rem;
    height: 0.1rem;
    right: 1rem;
  }
  .mega-area .mega-menu_item_ttl::after {
    width: 0.1rem;
    height: 1.1rem;
    right: 1.5rem;
  }
  .mega-area .mega-menu_item_ttl.active::after {
    opacity: 0;
    visibility: hidden;
  }
}

.mega-area .mega-menu_item_sub .itm a {
  font-size: 1.6rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
}

@media screen and (min-width: 769px) {
  .mega-menu .mega-menu_top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-column-gap: 3.7rem;
    -moz-column-gap: 3.7rem;
    column-gap: 3.7rem;
  }
}

.mega-menu .nav-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

@media screen and (min-width: 769px) {
  .mega-menu .nav-menu {
    padding: 4rem;
    background-color: #D5EEF0;
    gap: 2.6rem 6.5rem;
    width: 97.4rem;
  }
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-menu {
    width: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 0;
    padding: 0;
  }
}

@media screen and (min-width: 769px) {
  .mega-menu .nav-menu .nav-menu_item {
    width: 17rem;
  }
}

.mega-menu .nav-menu .nav-menu_item .nav-menu_item_link {
  display: block;
  font-size: 1.6rem;
  line-height: 1.5;
  padding-bottom: 1.5rem;
  position: relative;
  border-bottom: 0.1rem solid #333;
}

.mega-menu .nav-menu .nav-menu_item .nav-menu_item_link::after {
  position: absolute;
  content: '';
}

.mega-menu .nav-menu .nav-menu_item .nav-menu_item_link span {
  display: inline-block;
  width: 100%;
  position: relative;
}

.mega-menu .nav-menu .nav-menu_item .nav-menu_item_link span::after {
  position: absolute;
  content: '';
  width: 0.6rem;
  height: 0.8rem;
  right: 0;
  top: 55%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/icon_right.svg) right center no-repeat;
  background-size: contain;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

@media screen and (min-width: 769px) {
  .mega-menu .nav-menu .nav-menu_item .nav-menu_item_link::after {
    width: 100%;
    height: 0.1rem;
    left: 0;
    bottom: -0.1rem;
    background: #63AFB4;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .mega-menu .nav-menu .nav-menu_item .nav-menu_item_link:hover:after, .mega-menu .nav-menu .nav-menu_item .nav-menu_item_link.active:after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
  .mega-menu .nav-menu .nav-menu_item .nav-menu_item_link:hover {
    color: #63AFB4;
  }
  .mega-menu .nav-menu .nav-menu_item .nav-menu_item_link:hover span::after {
    background: url(../img/common/icon_right_blue.svg) right center no-repeat;
    background-size: contain;
  }
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-menu .nav-menu_item .nav-menu_item_link {
    margin: 0;
    font-weight: 700;
    line-height: 1;
    padding: 2.5rem 0;
  }
  .mega-menu .nav-menu .nav-menu_item .nav-menu_item_link span::after {
    width: 1rem;
    height: 1.6rem;
    right: 1rem;
  }
}

.mega-menu .nav-inquiry {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  text-align: center;
}

.mega-menu .nav-inquiry .nav-inquiry_lbl img {
  max-width: 23.3rem;
}

.mega-menu .nav-inquiry .nav-inquiry_btn {
  margin-top: 1.9rem;
  height: 6.7rem;
}

.mega-menu .nav-inquiry .nav-inquiry_btn .ico {
  right: 2rem;
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-inquiry {
    display: none;
  }
}

@media screen and (min-width: 769px) {
  .mega-menu .mega-menu_bottom {
    margin-top: 4rem;
  }
}

.mega-menu .nav-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-column-gap: 6rem;
  -moz-column-gap: 6rem;
  column-gap: 6rem;
}

@media screen and (min-width: 769px) {
  .mega-menu .nav-links .nav-links_items:first-child {
    width: 69.2rem;
  }
  .mega-menu .nav-links .nav-links_items:last-child {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
  }
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-links .nav-links_items {
    width: 100%;
    border-bottom: 0.1rem solid #333;
  }
}

.mega-menu .nav-links .nav-links_items .nav-links_items_ttl {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  position: relative;
}

@media screen and (min-width: 769px) {
  .mega-menu .nav-links .nav-links_items .nav-links_items_ttl::after {
    position: absolute;
    content: '';
    width: 100%;
    height: 0.1rem;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #333;
  }
  .mega-menu .nav-links .nav-links_items .nav-links_items_ttl span {
    display: inline-block;
    border: 0.1rem solid #333;
    border-radius: 8rem;
    padding: 1.2rem 1.8rem;
    line-height: 1;
    background-color: #fff;
    position: relative;
    z-index: 1;
  }
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-links .nav-links_items .nav-links_items_ttl {
    margin: 0;
    padding: 2.5rem 0;
    position: relative;
  }
  .mega-menu .nav-links .nav-links_items .nav-links_items_ttl::before, .mega-menu .nav-links .nav-links_items .nav-links_items_ttl::after {
    position: absolute;
    content: '';
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #333;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
  }
  .mega-menu .nav-links .nav-links_items .nav-links_items_ttl::before {
    width: 1.1rem;
    height: 0.1rem;
    right: 1rem;
  }
  .mega-menu .nav-links .nav-links_items .nav-links_items_ttl::after {
    width: 0.1rem;
    height: 1.1rem;
    right: 1.5rem;
  }
  .mega-menu .nav-links .nav-links_items .nav-links_items_ttl.active::after {
    opacity: 0;
    visibility: hidden;
  }
}

.mega-menu .nav-links .nav-links_items .nav-links_items_sub {
  padding: 1rem 0 0 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-column-gap: 4rem;
  -moz-column-gap: 4rem;
  column-gap: 4rem;
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-links .nav-links_items .nav-links_items_sub {
    -webkit-column-gap: 1rem;
    -moz-column-gap: 1rem;
    column-gap: 1rem;
    padding: 0.5rem 0 3rem;
  }
}

.mega-menu .nav-links .nav-links_items .nav-links_items_sub .itm {
  line-height: 1.857;
  width: calc(100%/4 - 3rem);
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-links .nav-links_items .nav-links_items_sub .itm {
    width: calc(100%/3 - 0.7rem);
    line-height: 2.083;
  }
}

.mega-menu .nav-links .nav-links_items .nav-links_items_sub .itm a {
  display: inline-block;
  font-size: 1.4rem;
  line-height: 1;
  position: relative;
}

.mega-menu .nav-links .nav-links_items .nav-links_items_sub .itm a:after {
  position: absolute;
  content: '';
  width: 100%;
  height: 0.1rem;
  left: 0;
  bottom: -0.2rem;
  background: #333;
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1);
  -webkit-transform-origin: left top;
  transform-origin: left top;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
}

.mega-menu .nav-links .nav-links_items .nav-links_items_sub .itm a:hover:after, .mega-menu .nav-links .nav-links_items .nav-links_items_sub .itm a.active:after {
  -webkit-transform-origin: bottom right;
  transform-origin: bottom right;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
}

@media screen and (max-width: 768px) {
  .mega-menu .nav-links .nav-links_items .nav-links_items_sub .itm a {
    font-size: 1.2rem;
    line-height: 1;
  }
}

/** footer
======================================= **/
.page-footer {
  background-color: #333333;
  color: #fff;
  padding: 14.3rem 0 0;
}

@media screen and (max-width: 768px) {
  .page-footer {
    padding: 7.2rem 0 6rem;
  }
}

@media screen and (min-width: 769px) {
  .footer-top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-flow: row-reverse;
    flex-flow: row-reverse;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}

@media screen and (max-width: 768px) {
  .footer-info {
    text-align: center;
    padding-top: 4rem;
    border-top: 0.1rem solid #fff;
  }
}

.footer-info .footer-info_logo {
  display: inline-block;
  width: 29.3rem;
  line-height: 0;
  margin-bottom: 6rem;
}

.footer-info .footer-info_logo img {
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .footer-info .footer-info_logo {
    width: 24.7rem;
    margin-bottom: 3.4rem;
  }
}

.footer-info .footer-info_txt {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 140%;
  letter-spacing: 0;
  font-style: italic;
  font-family: "Elms Sans", sans-serif;
}

.footer-info .footer-info_txt._mail {
  margin-top: 1rem;
}

.footer-info .c-btn {
  width: 100%;
  height: 6.8rem;
  margin-top: 3rem;
}

.footer-info .c-btn::before, .footer-info .c-btn::after {
  background: #fff;
}

.footer-info .c-btn .ico {
  right: 1.6rem;
}

.footer-info .c-btn .c-btn_inner::before, .footer-info .c-btn .c-btn_inner::after {
  background: #fff;
}

.footer-info .footer-info_note {
  font-size: 1rem;
  line-height: 168%;
  margin-top: 6rem;
  color: #C5C5C5;
}

@media screen and (max-width: 768px) {
  .footer-info .footer-info_note {
    line-height: 170%;
    margin-top: 2.6rem;
  }
}

@media screen and (min-width: 769px) {
  .footer-nav {
    width: 85rem;
  }
}

.footer-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 3.9rem;
  -moz-column-gap: 3.9rem;
  column-gap: 3.9rem;
  margin-bottom: 7rem;
}

@media screen and (max-width: 768px) {
  .footer-menu {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 1.7rem 0;
    margin-bottom: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .footer-menu .footer-menu_item {
    width: 50%;
  }
}

.footer-menu .footer-menu_item .footer-menu_item_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  row-gap: 0.3rem;
  position: relative;
}

@media screen and (min-width: 769px) {
  .footer-menu .footer-menu_item .footer-menu_item_link:after {
    position: absolute;
    content: '';
    width: 100%;
    height: 0.1rem;
    left: 0;
    bottom: -0.5rem;
    background: #fff;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
  .footer-menu .footer-menu_item .footer-menu_item_link:hover:after, .footer-menu .footer-menu_item .footer-menu_item_link.active:after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
  }
}

@media screen and (max-width: 768px) {
  .footer-menu .footer-menu_item .footer-menu_item_link {
    display: block;
    padding-left: 1rem;
    border-left: 0.1rem solid #fff;
  }
}

.footer-menu .footer-menu_item .footer-menu_item_link .en {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 140%;
  letter-spacing: 0;
  font-style: italic;
  font-family: "Elms Sans", sans-serif;
}

@media screen and (max-width: 768px) {
  .footer-menu .footer-menu_item .footer-menu_item_link .en {
    display: block;
    font-size: 1.2rem;
  }
}

.footer-menu .footer-menu_item .footer-menu_item_link .ja {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 140%;
  letter-spacing: 0;
  position: relative;
}

@media screen and (max-width: 768px) {
  .footer-menu .footer-menu_item .footer-menu_item_link .ja {
    font-size: 1.2rem;
    margin-top: 0.3rem;
  }
  .footer-menu .footer-menu_item .footer-menu_item_link .ja:after {
    position: absolute;
    content: '';
    width: 100%;
    height: 0.1rem;
    left: 0;
    bottom: 0;
    background: #fff;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
}

@media screen and (min-width: 769px) {
  .footer-links {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-column-gap: 4.8rem;
    -moz-column-gap: 4.8rem;
    column-gap: 4.8rem;
  }
}

@media screen and (min-width: 769px) {
  .footer-links .footer-links_items {
    width: 39.2rem;
  }
  .footer-links .footer-links_items:nth-child(1) {
    width: 45rem;
  }
}

@media screen and (max-width: 768px) {
  .footer-links .footer-links_items {
    border-top: 0.1rem solid #fff;
  }
}

.footer-links .footer-links_items .footer-links_items_ttl {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 140%;
  position: relative;
}

@media screen and (min-width: 769px) {
  .footer-links .footer-links_items .footer-links_items_ttl {
    margin-bottom: 2rem;
  }
  .footer-links .footer-links_items .footer-links_items_ttl::after {
    position: absolute;
    content: '';
    width: 100%;
    height: 0.1rem;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #FFFFFF;
  }
  .footer-links .footer-links_items .footer-links_items_ttl span {
    display: inline-block;
    padding-right: 1.5rem;
    background-color: #333333;
    position: relative;
    z-index: 1;
  }
}

@media screen and (max-width: 768px) {
  .footer-links .footer-links_items .footer-links_items_ttl {
    padding: 1.5rem 0;
  }
  .footer-links .footer-links_items .footer-links_items_ttl::before, .footer-links .footer-links_items .footer-links_items_ttl::after {
    position: absolute;
    content: '';
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #fff;
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
  }
  .footer-links .footer-links_items .footer-links_items_ttl::before {
    width: 1.1rem;
    height: 0.1rem;
    right: 1rem;
  }
  .footer-links .footer-links_items .footer-links_items_ttl::after {
    width: 0.1rem;
    height: 1.1rem;
    right: 1.5rem;
  }
  .footer-links .footer-links_items .footer-links_items_ttl.active::after {
    opacity: 0;
    visibility: hidden;
  }
}

.footer-links .footer-links_items .footer-links_items_sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 0.5rem 3rem;
}

@media screen and (max-width: 768px) {
  .footer-links .footer-links_items .footer-links_items_sub {
    -webkit-column-gap: 1rem;
    -moz-column-gap: 1rem;
    column-gap: 1rem;
    padding: 0.5rem 0 3rem;
  }
}

.footer-links .footer-links_items .footer-links_items_sub li {
  width: calc(100%/3 - 2rem);
}

@media screen and (max-width: 768px) {
  .footer-links .footer-links_items .footer-links_items_sub li {
    width: calc(100%/3 - 0.7rem);
    line-height: 2.083;
  }
}

.footer-links .footer-links_items .footer-links_items_sub li a {
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1;
  position: relative;
}

.footer-links .footer-links_items .footer-links_items_sub li a:after {
  position: absolute;
  content: '';
  width: 100%;
  height: 0.1rem;
  left: 0;
  bottom: -0.2rem;
  background: #fff;
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1);
  -webkit-transform-origin: left top;
  transform-origin: left top;
  -webkit-transition: -webkit-transform .3s;
  transition: -webkit-transform .3s;
  transition: transform .3s;
  transition: transform .3s, -webkit-transform .3s;
}

.footer-links .footer-links_items .footer-links_items_sub li a:hover:after, .footer-links .footer-links_items .footer-links_items_sub li a.active:after {
  -webkit-transform-origin: bottom right;
  transform-origin: bottom right;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
}

.footer-bottom {
  border-top: 0.1rem solid #FFFFFF;
}

@media screen and (min-width: 769px) {
  .footer-bottom {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 2.8rem 0 3rem;
    margin-top: 6rem;
  }
}

@media screen and (max-width: 768px) {
  .footer-bottom {
    padding: 3rem 0 3.5rem;
    margin-top: 3rem;
    text-align: center;
  }
}

@media screen and (min-width: 769px) {
  .footer-bottom .footer-bottom_link {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
  }
}

.footer-bottom .footer-bottom_link a {
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 140%;
  letter-spacing: 0;
}

@media screen and (max-width: 768px) {
  .footer-bottom .footer-bottom_link a {
    position: relative;
  }
  .footer-bottom .footer-bottom_link a:after {
    position: absolute;
    content: '';
    width: 100%;
    height: 0.1rem;
    left: 0;
    bottom: 0;
    background: #fff;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
  }
}

.footer-bottom .c-sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 2.4rem;
  -moz-column-gap: 2.4rem;
  column-gap: 2.4rem;
}

.footer-bottom .c-sns .c-sns_itm a {
  display: inline-block;
}

.footer-bottom .c-sns .c-sns_itm a img {
  max-width: unset;
  width: auto;
  height: 3.2rem;
}

@media screen and (min-width: 769px) {
  .footer-bottom .c-sns {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
    margin-left: auto;
  }
}

@media screen and (max-width: 768px) {
  .footer-bottom .c-sns {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-bottom: 2.4rem;
  }
}

.footer-bottom .copyright {
  display: inline-block;
}

@media screen and (min-width: 769px) {
  .footer-bottom .copyright {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    margin-left: 3rem;
    font-size: 1.2rem;
    line-height: 168%;
  }
}

@media screen and (max-width: 768px) {
  .footer-bottom .copyright {
    margin-top: 1rem;
    font-size: 1rem;
    line-height: 140%;
  }
}

@media (min-width: 769px) and (max-width: 1366px) {
  .footer-nav {
    width: 87rem;
  }
  .footer-links {
    -webkit-column-gap: 4rem;
    -moz-column-gap: 4rem;
    column-gap: 4rem;
  }
  .footer-links .footer-links_items {
    width: 41rem;
  }
}

/** header area
====================================== **/
._button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 6rem;
  height: 6rem;
  border-radius: 50%;
  border: 0.1rem solid #333;
  background-color: #fff;
  cursor: pointer;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

._button .arrow {
  width: 1.5rem;
  line-height: 1;
}

._button .arrow svg, ._button .arrow img {
  display: inline-block;
  width: 100%;
  height: auto;
}

._button:hover .arrow svg, ._button:hover .arrow img {
  -webkit-animation: arrow-right 0.5s ease-in-out;
  animation: arrow-right 0.5s ease-in-out;
}

._button.prev:hover .arrow svg, ._button.prev:hover .arrow img {
  -webkit-animation: arrow-left 0.5s ease-in-out;
  animation: arrow-left 0.5s ease-in-out;
}

._button._white {
  background-color: transparent;
  border-color: #ffffff;
}

._button._white .arrow img path, ._button._white .arrow svg path {
  fill: #ffffff;
}

@media screen and (max-width: 768px) {
  ._button {
    width: 4rem;
    height: 4rem;
  }
  ._button .arrow {
    width: 1rem;
  }
}

.button-hover:hover ._button .arrow svg, .button-hover:hover ._button .arrow img {
  -webkit-animation: arrow-right 0.5s ease-in-out;
  animation: arrow-right 0.5s ease-in-out;
}

.c-btn {
  display: block;
  width: 100%;
  max-width: 40rem;
  height: 7rem;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1;
  position: relative;
  overflow: visible;
  -webkit-transition: background-color 0.3s ease;
  transition: background-color 0.3s ease;
}

.c-btn::before, .c-btn::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background: #333;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.c-btn::before {
  height: 0%;
  width: 0.1rem;
}

.c-btn::after {
  width: 0%;
  height: 0.1rem;
}

.c-btn .c-btn_inner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  width: 100%;
  height: 100%;
}

.c-btn .c-btn_inner::before, .c-btn .c-btn_inner::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  background: #333;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.c-btn .c-btn_inner::before {
  height: 0%;
  width: 0.1rem;
}

.c-btn .c-btn_inner::after {
  width: 0%;
  height: 0.1rem;
}

.c-btn .txt {
  display: inline-block;
}

.c-btn .ico {
  position: absolute;
  right: 2.8rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.c-btn .ico._arrow svg, .c-btn .ico._arrow img {
  display: block;
  width: 1.4rem;
  height: auto;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.c-btn:hover {
  opacity: 1;
}

.c-btn:hover::before, .c-btn:hover::after {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.c-btn:hover::before {
  height: 100%;
}

.c-btn:hover::after {
  width: 100%;
}

.c-btn:hover .c-btn_inner::before, .c-btn:hover .c-btn_inner::after {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}

.c-btn:hover .c-btn_inner::before {
  height: 100%;
}

.c-btn:hover .c-btn_inner::after {
  width: 100%;
}

.c-btn:hover .ico._arrow svg {
  -webkit-animation: arrow-right 0.5s ease-in-out;
  animation: arrow-right 0.5s ease-in-out;
}

.c-btn._left:hover .ico._arrow svg {
  -webkit-animation: arrow-left 0.5s ease-in-out;
  animation: arrow-left 0.5s ease-in-out;
}

.c-btn._black {
  background-color: #333;
  color: #fff;
}

.c-btn._black::before, .c-btn._black::after {
  background-color: #333;
}

.c-btn._black:hover {
  background-color: #fff;
  color: #333;
}

.c-btn._black:hover .ico svg path {
  fill: #333;
}

.c-btn._white {
  background-color: #fff;
  color: #333;
}

.c-btn._white:hover {
  background-color: #333;
  color: #fff;
}

.c-btn._white:hover .ico svg path {
  fill: #fff;
}

.c-btn._green {
  background-color: #1BCE3C;
  color: #333;
}

.c-btn._green::before, .c-btn._green::after {
  background-color: #333;
}

.c-btn._green:hover {
  background-color: #fff;
  color: #333;
}

.c-btn._green:hover .ico svg path {
  fill: #333;
}

.c-btn._sm {
  width: 25.2rem;
  height: 6.6rem;
  font-size: 1.6rem;
  cursor: pointer;
}

.c-btn._sm .ico {
  right: 1.7rem;
}

.c-btn._sm .ico._blank img, .c-btn._sm .ico._blank svg {
  width: 1.4rem;
  height: auto;
  overflow: visible;
}

.c-btn._sm:hover .ico._blank svg rect, .c-btn._sm:hover .ico._blank svg path {
  stroke: #333;
  fill: #fff;
}

.c-btn._center {
  margin: 6rem auto 0;
}

.c-btn.lh125 {
  line-height: 1.25;
}

.c-btn.fz18 {
  font-size: 1.8rem;
  line-height: 1.333;
}

@media screen and (max-width: 768px) {
  .c-btn.fz18 {
    font-size: 1.6rem;
    line-height: 1.25;
  }
}

@media screen and (max-width: 768px) {
  .c-btn {
    font-size: 1.6rem;
    max-width: 29.5rem;
    height: 6rem;
    margin: 3rem auto 0;
  }
  .c-btn .ico {
    right: 2rem;
  }
  .c-btn .ico._arrow svg, .c-btn .ico._arrow img {
    width: 1.1rem;
  }
  .c-btn._center {
    margin-top: 4rem;
  }
  .c-btn._sm {
    width: 100%;
    height: 5rem;
    font-size: 1.4rem;
    line-height: 1.2142857;
    text-align: center;
  }
  .c-btn._sm .ico {
    right: 1.3rem;
  }
  .c-btn._sm .ico._blank img, .c-btn._sm .ico._blank svg {
    width: 1.2rem;
  }
  .c-btn.sph-auto {
    height: auto;
    padding-block: 1rem;
    line-height: 1.5;
  }
}

.c-viewmore {
  width: 16.1rem;
  height: 4.4rem;
  line-height: 1.5;
  border: 0.1rem solid #333333;
  border-radius: 8rem;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 6.5rem auto 0;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

.c-viewmore > span {
  display: inline-block;
  position: relative;
  padding-right: 2.1rem;
}

.c-viewmore > span::after {
  position: absolute;
  content: '';
  width: 1.8rem;
  height: 1.2rem;
  right: 0;
  top: 50%;
  margin-top: -0.6rem;
  background: url(../img/common/icon_down.svg) center no-repeat;
  background-size: cover;
}

.c-viewmore:hover, .c-viewmore.active {
  background-color: #333;
  color: #fff;
}

.c-viewmore:hover > span::after, .c-viewmore.active > span::after {
  background: url(../img/common/icon_down_white.svg) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 768px) {
  .c-viewmore {
    width: 13.5rem;
    height: 4rem;
    font-size: 1.4rem;
    margin-top: 4rem;
  }
  .c-viewmore > span::after {
    width: 1.4rem;
    height: 0.9rem;
  }
}

.c-line {
  width: 100%;
  height: 1rem;
  border-top: 0.3rem solid #333;
  border-bottom: 0.1rem solid #333;
  position: relative;
}

.c-line.c-line_cont {
  margin: 2.5rem 0;
}

.c-line .c-line_txt {
  width: 100%;
  text-align: center;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.c-line .c-line_txt span {
  display: inline-block;
  font-size: 2.2rem;
  line-height: 1.636;
  padding: 0 5rem;
  position: relative;
  background-color: #fff;
}

.c-line .c-line_txt span::before, .c-line .c-line_txt span::after {
  position: absolute;
  content: '';
  width: 1.9rem;
  height: 6rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/splash.svg) center no-repeat;
  background-size: cover;
}

.c-line .c-line_txt span::before {
  left: 0;
  -webkit-transform: translateY(-50%) scaleX(-1);
  transform: translateY(-50%) scaleX(-1);
}

.c-line .c-line_txt span::after {
  right: 0;
}

@media screen and (max-width: 768px) {
  .c-line .c-line_txt span {
    font-size: 1.4rem;
    line-height: 1.857;
    padding: 0 4rem;
  }
}

.heading-lv1 {
  font-size: 5.4rem;
  font-weight: 500;
  line-height: 1.3333;
  letter-spacing: 0;
  margin-bottom: 5rem;
}

.heading-lv1._center {
  text-align: center;
}

@media screen and (max-width: 768px) {
  .heading-lv1 {
    font-size: 2.8rem;
    line-height: 1.357;
    margin-bottom: 2rem;
  }
}

.heading-lv2 .en {
  display: inline-block;
  margin-bottom: 4rem;
}

.heading-lv2 .ja {
  font-size: 5.4rem;
  font-weight: 500;
  line-height: 1;
}

.heading-lv2 .txt {
  font-size: 2rem;
  line-height: 1.8;
  margin-top: 3rem;
}

.heading-lv2._center {
  text-align: center;
}

@media screen and (max-width: 768px) {
  .heading-lv2 .en {
    margin-bottom: 1rem;
  }
  .heading-lv2 .ja {
    font-size: 2.8rem;
    line-height: 1.357;
  }
  .heading-lv2 .txt {
    font-size: 1.6rem;
    line-height: 1.875;
    margin-top: 2rem;
  }
}

.heading-lv3 {
  font-size: 4.8rem;
  font-weight: 500;
  line-height: 1.375;
  margin-bottom: 6rem;
}

@media screen and (max-width: 768px) {
  .heading-lv3 {
    font-size: 2.4rem;
    line-height: 1.583;
    margin-bottom: 2rem;
  }
}

.heading-lv3._center {
  text-align: center;
}

.p-lead {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
  letter-spacing: 0;
}

@media screen and (max-width: 768px) {
  .p-lead {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

.c-lbl {
  display: inline-block;
  border-radius: 2.4rem;
  padding: 0.6rem 2.4rem;
  background-color: #63AFB4;
  color: #fff;
}

.c-lbl.fz20 {
  font-size: 2rem;
  line-height: 1.8;
}

@media screen and (max-width: 768px) {
  .c-lbl.fz20 {
    font-size: 1.6rem;
    line-height: 1.5;
    padding: 0.6rem 1.4rem;
  }
}

.c-absolute {
  display: inline-block;
  position: absolute;
}

.p-title {
  margin: 2rem 0 5rem;
}

.p-title .en {
  display: inline-block;
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0;
  font-family: "Alkatra", system-ui;
  margin-bottom: 2rem;
}

.p-title .ja {
  font-size: 5.4rem;
  font-weight: 500;
  line-height: 1.33;
}

.p-title._center {
  text-align: center;
}

@media screen and (max-width: 768px) {
  .p-title {
    margin: 3rem 0;
  }
  .p-title .en {
    font-size: 1.8rem;
    margin-bottom: 0.5rem;
  }
  .p-title .ja {
    font-size: 2.8rem;
  }
}

.p-title.p-title_line {
  position: relative;
}

.p-title.p-title_line::after {
  position: absolute;
  content: '';
  width: 100%;
  height: 0.8rem;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  border-top: 0.3rem solid #333;
  border-bottom: 0.1rem solid #333;
}

.p-title.p-title_line .container {
  max-width: 58rem;
  background-color: #fff;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .p-title.p-title_line .container {
    max-width: 26.6rem;
  }
}

@media screen and (min-width: 769px) {
  .p-title.p-title_line.mw78 .container {
    max-width: 78rem;
  }
}

@media screen and (max-width: 768px) {
  .p-title.p-title_line.mw78 .container {
    max-width: 34rem;
    padding: 0 1rem;
  }
}

.c-title .en {
  display: inline-block;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1;
  font-family: "Alkatra", system-ui;
  margin-bottom: 1.2rem;
}

.c-title .ja {
  font-size: 4rem;
  font-weight: 500;
  line-height: calc(49/40);
}

@media screen and (max-width: 768px) {
  .c-title .en {
    font-size: 1.8rem;
    margin-bottom: 0.6rem;
  }
  .c-title .ja {
    font-size: 2.8rem;
    line-height: calc(38/28);
  }
}

.key-visual figure {
  width: 100%;
  height: 35rem;
  overflow: hidden;
}

.key-visual figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (max-width: 768px) {
  .key-visual figure {
    height: 17rem;
  }
}

.movie-wrap {
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  position: relative;
}

.movie-wrap iframe,
.movie-wrap video {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}

.pagination {
  margin: 11rem 0 0;
}

@media screen and (max-width: 768px) {
  .pagination {
    margin: 4rem 0 0;
  }
}

.page-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 0.8rem;
  -moz-column-gap: 0.8rem;
  column-gap: 0.8rem;
}

.page-numbers .page-numbers {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 5rem;
  height: 5rem;
  border-radius: 50%;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
  text-decoration: underline;
}

@media screen and (max-width: 768px) {
  .page-numbers .page-numbers {
    width: 3.8rem;
    height: 3.8rem;
    font-size: 1.6rem;
  }
}

.page-numbers .page-numbers svg {
  display: block;
}

.page-numbers .page-numbers.current, .page-numbers .page-numbers:hover {
  opacity: 1;
  background-color: #63AFB4;
  color: #ffffff;
  text-decoration: none;
}

.page-numbers .page-numbers.next, .page-numbers .page-numbers.prev {
  border: 0.1rem solid #333333;
  text-decoration: none;
}

.page-numbers .page-numbers.next img, .page-numbers .page-numbers.next svg, .page-numbers .page-numbers.prev img, .page-numbers .page-numbers.prev svg {
  width: 1rem;
  height: auto;
}

.page-numbers .page-numbers.next:hover, .page-numbers .page-numbers.prev:hover {
  opacity: 1;
  background-color: #333333;
}

.page-numbers .page-numbers.next:hover svg path, .page-numbers .page-numbers.prev:hover svg path {
  stroke: #fff;
}

@media screen and (max-width: 768px) {
  .page-numbers .page-numbers.next, .page-numbers .page-numbers.prev {
    width: 4.4rem;
    height: 4.4rem;
  }
  .page-numbers .page-numbers.next img, .page-numbers .page-numbers.next svg, .page-numbers .page-numbers.prev img, .page-numbers .page-numbers.prev svg {
    width: 0.8rem;
  }
}

/** header area
====================================== **/
#hambuger {
  width: 3.6rem;
  height: 3.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 12;
  cursor: pointer;
  position: relative;
  text-align: center;
  border-radius: 50%;
  background-color: #333;
}

.nav-icon ul {
  position: relative;
  width: 1.8rem;
  height: 1rem;
}

.nav-icon ul li {
  list-style: none;
  position: absolute;
  background: #fff;
  width: 100%;
  height: 0.1rem;
  border-radius: 2rem;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.nav-icon ul li:nth-of-type(1) {
  top: 0%;
}

.nav-icon ul li:nth-of-type(2) {
  top: 45%;
}

.nav-icon ul li:nth-of-type(3) {
  top: 90%;
}

.nav-icon ul li span {
  display: inline-block;
}

.nav-icon.active ul {
  opacity: 1;
  visibility: visible;
}

.nav-icon.active ul li:nth-of-type(1) {
  width: 100%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(30deg);
  transform: translate(-50%, -50%) rotate(30deg);
}

.nav-icon.active ul li:nth-of-type(3) {
  width: 100%;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-30deg);
  transform: translate(-50%, -50%) rotate(-30deg);
}

.nav-icon.active ul li:nth-of-type(2) {
  opacity: 0;
}

@media screen and (min-width: 769px) {
  #hambuger {
    display: none;
  }
}

@-webkit-keyframes scrollLine {
  0% {
    -webkit-transform: translateY(calc(100% + 4rem));
    transform: translateY(calc(100% + 4rem));
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 0;
  }
}

@keyframes scrollLine {
  0% {
    -webkit-transform: translateY(calc(100% + 4rem));
    transform: translateY(calc(100% + 4rem));
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  90% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 0;
  }
}

@-webkit-keyframes scrollTextBlink {
  0% {
    opacity: 0.4;
  }
  40% {
    opacity: 1;
  }
  100% {
    opacity: 0.4;
  }
}

@keyframes scrollTextBlink {
  0% {
    opacity: 0.4;
  }
  40% {
    opacity: 1;
  }
  100% {
    opacity: 0.4;
  }
}

@-webkit-keyframes header_animate {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
  25% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@keyframes header_animate {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
  25% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@-webkit-keyframes arrow-right {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes arrow-right {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@-webkit-keyframes arrow-left {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes arrow-left {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@-webkit-keyframes arrow-down {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes arrow-down {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }
  50.1% {
    opacity: 0;
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@-webkit-keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }
  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

@keyframes imageBlur {
  from {
    opacity: 0;
    -webkit-filter: blur(15px);
    -moz-filter: blur(15px);
    -ms-filter: blur(15px);
    -o-filter: blur(15px);
    filter: blur(15px);
  }
  to {
    opacity: 1;
    -webkit-filter: blur(0px);
    -moz-filter: blur(0px);
    -ms-filter: blur(0px);
    -o-filter: blur(0px);
    filter: blur(0px);
  }
}

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

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

@-webkit-keyframes zoomout {
  0% {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    opacity: 1;
  }
}

@keyframes zoomout {
  0% {
    -webkit-transform: scale(1.2);
    transform: scale(1.2);
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
    opacity: 1;
  }
}

@-webkit-keyframes crossfeed {
  0% {
    opacity: 1;
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@keyframes crossfeed {
  0% {
    opacity: 1;
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

/* ===== DEFAULT STATE ===== */
.modal {
  position: fixed;
  inset: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 999;
  pointer-events: none;
  visibility: hidden;
}

.modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0;
  -webkit-transition: opacity .35s ease;
  transition: opacity .35s ease;
}

.modal-content {
  position: relative;
  background: #fff;
  overflow: hidden;
  opacity: 0;
  -webkit-transform: translateY(40px);
  transform: translateY(40px);
  -webkit-transition: opacity .4s ease, -webkit-transform .4s ease;
  transition: opacity .4s ease, -webkit-transform .4s ease;
  transition: opacity .4s ease, transform .4s ease;
  transition: opacity .4s ease, transform .4s ease, -webkit-transform .4s ease;
}

@media screen and (max-width: 768px) {
  .modal-content {
    width: 90%;
  }
}

.modal-close {
  display: inline-block;
  width: 3.8rem;
  position: absolute;
  top: 2rem;
  right: 2rem;
  cursor: pointer;
  -webkit-transition: opacity .4s ease;
  transition: opacity .4s ease;
}

.modal-close:hover {
  opacity: 0.7;
}

@media screen and (max-width: 768px) {
  .modal-close {
    width: 3rem;
    top: 1rem;
    right: 1rem;
  }
}

/* ===== OPENING ===== */
.modal.show {
  pointer-events: auto;
  visibility: visible;
}

.modal.show .modal-overlay {
  opacity: 1;
}

.modal.show .modal-content {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}


.modal.closing .modal-overlay {
  opacity: 0;
}

.modal.closing .modal-content {
  opacity: 0;
  -webkit-transform: translateY(40px);
  transform: translateY(40px);
}

.modal-wrap {
  width: 100%;
  max-width: 82rem;
  padding: 6.7rem 7.6rem 5.5rem;
}

.modal-wrap.modal-advance {
  max-width: 115rem;
}

@media screen and (max-width: 768px) {
  .modal-wrap {
    padding: 4.5rem 3rem 4rem;
  }
  .modal-wrap.modal-advance {
    padding-inline: 2rem;
  }
}

.modal-title.c-line.c-line_cont {
  margin: 1.5rem 0 4.6rem;
}

@media screen and (max-width: 768px) {
  .modal-title.c-line.c-line_cont {
    margin-bottom: 3rem;
  }
}

.modal-title .c-line_txt {
  font-weight: 500;
}

.modal-title .c-line_txt span {
  font-size: 3.8rem;
  line-height: 1;
}

.modal-title .c-line_txt span:before, .modal-title .c-line_txt span::after {
  display: none;
  width: 0;
  height: 0;
}

@media screen and (max-width: 768px) {
  .modal-title .c-line_txt span {
    font-size: 2.4rem;
    padding: 0 2rem;
  }
}

.modal-area_content.noflex {
  max-height: 80vh;
}

@media screen and (min-width: 769px) {
  .modal-area_content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-column-gap: 6rem;
    -moz-column-gap: 6rem;
    column-gap: 6rem;
  }
  .modal-area_content.noflex {
    display: block;
  }
}

.modal-area_content .search-content {
  width: 100%;
  max-height: 50dvh;
  overflow-y: auto;
}

.modal-area_content .modal-area_content_map {
  width: 21.1rem;
}

@media screen and (max-width: 768px) {
  .modal-area_content .modal-area_content_map {
    margin: 0 auto 3.2rem;
    width: 100%;
    max-width: 16rem;
  }
}

.modal-area_content .modal-area_content_links {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.modal-area_content .modal-area_content_links .area-list {
  padding: 0;
}

@media screen and (min-width: 769px) {
  .modal-area_content .modal-area_content_links .area-list {
    gap: 1.5rem 2.6rem;
  }
  .modal-area_content .modal-area_content_links .area-list .itm .loc {
    font-size: 1.8rem;
    line-height: 1.3333;
  }
}

.modal-area_content .c-btn._center {
  margin-top: 4rem;
}

/** sc-future **/
.sc-future {
  padding: 13.5rem 0 25rem;
}

@media screen and (max-width: 768px) {
  .sc-future {
    padding: 5rem 0 7rem;
  }
}

.sc-future .container {
  position: relative;
}

@media screen and (min-width: 769px) {
  .sc-future .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    -webkit-column-gap: 12rem;
    -moz-column-gap: 12rem;
    column-gap: 12rem;
  }
}

.sc-future .const-pos {
  display: inline-block;
  position: absolute;
}

.sc-future .const-pos.pos1 {
  width: 5.5rem;
  right: 1.9rem;
  bottom: -11rem;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

@media screen and (max-width: 768px) {
  .sc-future .const-pos.pos1 {
    width: 3rem;
    right: auto;
    left: 4.1rem;
    bottom: auto;
    top: 0;
  }
}

.sc-future .const-pos.pos2 {
  width: 6.5rem;
  right: 8.9rem;
  bottom: -11rem;
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

@media screen and (max-width: 768px) {
  .sc-future .const-pos.pos2 {
    width: 3.2rem;
    right: 3.7rem;
    bottom: auto;
    top: 0.5rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-future .future-head {
    width: 45rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-future .future-head {
    margin-bottom: 3rem;
  }
}

.sc-future .future-head .future-ttl {
  font-size: 4.8rem;
  font-weight: 500;
  line-height: 1.375;
  margin-bottom: 4rem;
}

@media screen and (max-width: 768px) {
  .sc-future .future-head .future-ttl {
    font-size: 2.4rem;
    line-height: 1.4167;
    margin-bottom: 2rem;
    text-align: center;
  }
}

@media screen and (min-width: 769px) {
  .sc-future .future-head .future-ttl.future-ttl_about {
    font-size: 4rem;
  }
}

.sc-future .future-head .future-txt {
  font-size: 1.8rem;
  line-height: 1.888889;
}

.sc-future .future-head .future-txt.future-link {
  margin: 0 0 -0.3rem 0;
}

.sc-future .future-head .future-txt a, .sc-future .future-head .future-txt span {
  display: inline-block;
  font-size: 1.8rem;
  line-height: 2;
  margin: 0 1.5rem 0.3rem 0;
}

.sc-future .future-head .future-txt a::after, .sc-future .future-head .future-txt span::after {
  bottom: 0.5rem;
}

.sc-future .future-head .future-txt a.is-disabled, .sc-future .future-head .future-txt span.is-disabled {
  color: #666;
}

.sc-future .future-head .future-txt .tx {
  display: inline-block;
  margin-left: 1rem;
}

@media screen and (max-width: 768px) {
  .sc-future .future-head .future-txt {
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .sc-future .future-head .future-txt a, .sc-future .future-head .future-txt span {
    font-size: 1.6rem;
  }
  .sc-future .future-head .future-txt .tx {
    margin-left: 0;
    display: block;
  }
}

.sc-future .future-area {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding-top: 1.5rem;
}

.sc-future .future-area .future-area_ttl {
  font-size: 2rem;
  font-weight: 500;
  line-height: 140%;
  margin-bottom: 2.5rem;
}

@media screen and (max-width: 768px) {
  .sc-future .future-area .future-area_ttl {
    font-size: 1.8rem;
    line-height: 1.5556;
    margin-bottom: 1.6rem;
    text-align: center;
  }
}

.sc-future .future-area .future-area_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 1.2rem;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .sc-future .future-area .future-area_list {
    gap: 1.1rem;
  }
  .sc-future .future-area .future-area_list .future-area_item {
    width: calc(50% - 0.55rem);
  }
  .sc-future .future-area .future-area_list .future-area_item .c-btn {
    margin: 0;
  }
}

.sc-future .future-area_map {
  width: 52.4rem;
  position: absolute;
  right: -0.4rem;
  top: -6rem;
}

@media screen and (max-width: 768px) {
  .sc-future .future-area_map {
    display: none;
  }
}

.sc-future.noSelectArea .future-head {
  width: 100% !important;
  max-width: 72rem !important;
}

.sc-future.noSelectArea .future-area_map {
  top: -8rem;
}

@media screen and (min-width: 769px) {
  .sc-future.noSelectArea {
    padding-top: 1.5rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-future.noSelectArea {
    padding-top: 0 !important;
    padding-bottom: 5rem;
  }
  .sc-future.noSelectArea .future-head {
    margin-bottom: 0;
  }
  .sc-future.noSelectArea .future-area {
    padding: 0;
  }
}

.sc-future.futureIntro {
  padding: 0 0 10rem;
}

@media screen and (max-width: 768px) {
  .sc-future.futureIntro {
    padding: 5rem 0 7rem !important;
  }
}

@media screen and (min-width: 769px) {
  .sc-future.futureIntro .container {
    position: relative;
    max-width: 126.6rem;
    padding: 4rem 5rem 4rem 6rem;
    border: 0.1rem solid #333333;
    -webkit-box-shadow: 5px 5px 0 #333333;
    box-shadow: 5px 5px 0 #333333;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}

.sc-future.futureIntro .future-lbl {
  display: inline-block;
  background-color: #63AFB4;
  padding: 0.6rem 2.3rem;
  border-radius: 2.4rem;
  color: #fff;
  font-size: 1.8rem;
  line-height: 2;
  position: absolute;
  left: 6rem;
  top: -2.5rem;
}

@media screen and (max-width: 768px) {
  .sc-future.futureIntro .future-lbl {
    font-size: 1.6rem;
    line-height: 1.5;
    padding: 0.6rem 1.4rem;
    top: -5rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
}

.sc-future.futureIntro .future-head .future-ttl {
  margin: 0;
  line-height: 1.55;
}

.sc-future.futureIntro .future-area {
  font-size: 1.8rem;
  line-height: 2;
  padding: 0;
}

@media screen and (max-width: 768px) {
  .sc-future.futureIntro .future-area {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

@media screen and (min-width: 769px) {
  .sc-future.futureIntro .const-pos.pos1 {
    left: 12rem;
    bottom: -6rem;
  }
  .sc-future.futureIntro .const-pos.pos2 {
    left: 3.9rem;
    bottom: -6rem;
  }
}

/** sc-faq **/
.sc-faq {
  padding: 8rem 0 10rem;
}

@media screen and (max-width: 768px) {
  .sc-faq {
    padding: 5rem 0 7rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-faq .heading-lv2 .txt {
    margin-top: 5rem;
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-faq .heading-lv2 .txt {
    margin-top: 2rem;
  }
}

.sc-faq .c-btn {
  margin-top: 4rem;
}

@media screen and (min-width: 769px) {
  .sc-faq .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-column-gap: 10.2rem;
    -moz-column-gap: 10.2rem;
    column-gap: 10.2rem;
  }
}

.sc-faq .container .faq-head {
  width: 40rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  .sc-faq .container .faq-head {
    width: 100%;
    margin-bottom: 1rem;
  }
  .sc-faq .container .faq-head .c-btn {
    display: none;
  }
}

.sc-faq .container .faq-pos {
  display: inline-block;
  position: absolute;
}

.sc-faq .container .faq-pos.pos1 {
  width: 7.3rem;
  left: 22.8rem;
  top: 41.1rem;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

@media screen and (max-width: 768px) {
  .sc-faq .container .faq-pos.pos1 {
    width: 2.6rem;
    left: auto;
    right: 1.8rem;
    top: -2.5rem;
  }
}

.sc-faq .container .faq-pos.pos2 {
  width: 5.7rem;
  left: 9rem;
  top: 48rem;
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

@media screen and (max-width: 768px) {
  .sc-faq .container .faq-pos.pos2 {
    width: 2.3rem;
    top: 0.6rem;
    right: 5.7rem;
    left: auto;
  }
}

.sc-faq .container .faq-content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

/** sc-technology **/
.sc-technology {
  padding: 8rem 0 10rem;
}

@media screen and (max-width: 768px) {
  .sc-technology {
    padding: 5rem 0 7rem;
  }
}

.sc-technology .technology-lbl {
  text-align: center;
  margin-bottom: 2.2rem;
}

.sc-technology .technology-lbl span {
  display: inline-block;
  font-size: 2rem;
  line-height: 1.8;
  background-color: #63AFB4;
  color: #fff;
  padding: 0.6rem 2.3rem;
  border-radius: 2.4rem;
}

@media screen and (max-width: 768px) {
  .sc-technology .technology-lbl {
    margin-bottom: 2rem;
  }
  .sc-technology .technology-lbl span {
    font-size: 1.6rem;
  }
}

.sc-technology .heading-lv2 {
  margin-bottom: 2rem;
}

.sc-technology .heading-lv2 .ja {
  font-size: 4.8rem;
  line-height: 1.375;
}

@media screen and (max-width: 768px) {
  .sc-technology .heading-lv2 .ja {
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-technology .c-txt {
    text-align: left !important;
  }
}

.sc-technology .technology-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 6rem;
  -moz-column-gap: 6rem;
  column-gap: 6rem;
  margin-top: 6rem;
}

@media screen and (max-width: 768px) {
  .sc-technology .technology-list {
    display: block;
    margin-top: 3rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-technology .technology-item {
    width: calc(100%/3 - 4rem);
  }
}

.sc-technology .technology-item .technology-item_img {
  width: 31.1rem;
  margin: 0 auto 4rem;
}

.sc-technology .technology-item .technology-item_img figcaption {
  display: block;
  text-align: right;
  font-size: 1.2rem;
}

@media screen and (max-width: 768px) {
  .sc-technology .technology-item .technology-item_img {
    width: 19.3rem;
    margin-bottom: 3rem;
  }
  .sc-technology .technology-item .technology-item_img figcaption {
    margin-right: -3rem;
  }
}

.sc-technology .technology-item .technology-item_ttl {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.25;
  text-align: center;
  margin-bottom: 3rem;
}

@media screen and (max-width: 768px) {
  .sc-technology .technology-item .technology-item_ttl {
    font-size: 2rem;
    line-height: 1.5;
    margin-bottom: 1.4rem;
  }
}

@media screen and (min-width: 769px) {
  .sc-technology .technology-item .technology-item_txt {
    line-height: 2.125;
  }
}

@media screen and (max-width: 768px) {
  .sc-technology .technology-item .technology-item_txt {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

.sc-technology .technology-item + .technology-item {
  position: relative;
}

@media screen and (min-width: 769px) {
  .sc-technology .technology-item + .technology-item::before {
    position: absolute;
    content: '';
    width: 0.1rem;
    height: 100%;
    top: 0;
    left: -3rem;
    border-left: 1px solid transparent;
    -o-border-image: repeating-linear-gradient(to bottom, #333 0, #333 3px, transparent 3px, transparent 8px) 1;
    border-image: repeating-linear-gradient(to bottom, #333 0, #333 3px, transparent 3px, transparent 8px) 1;
  }
}

@media screen and (max-width: 768px) {
  .sc-technology .technology-item + .technology-item {
    margin-top: 3rem;
    padding-top: 3rem;
    background-image: repeating-linear-gradient(to right, #333 0, #333 6px, transparent 6px, transparent 12px);
    background-position: top left;
    background-size: 12px 1px;
    background-repeat: repeat-x;
  }
}

/** sc-visual **/
.sc-works.visual {
  padding: 8rem 0 10rem;
}

.sc-works.visual .container {
  display: block;
}

@media screen and (max-width: 768px) {
  .sc-works.visual {
    padding: 5rem 0 7rem;
  }
  .sc-works.visual .works-list {
    margin-top: 2.5rem;
  }
}

.sc-works.visual .heading-lv2 {
  margin-bottom: 3rem;
}

@media screen and (max-width: 768px) {
  .sc-works.visual .heading-lv2 {
    margin-bottom: 2rem;
  }
}

@media screen and (max-width: 768px) {
  .sc-works.visual .c-txt {
    text-align: left !important;
  }
}

.sc-works.visual .c-btn {
  font-size: 1.8rem;
  line-height: 1.33;
}

@media screen and (max-width: 768px) {
  .sc-works.visual .c-btn {
    font-size: 1.6rem;
  }
}

.works-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 6rem 4rem;
  margin-top: 5rem;
}

@media screen and (max-width: 768px) {
  .works-list {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    row-gap: 3rem;
  }
}

.works-item {
  width: calc(100%/2 - 2rem);
}

@media screen and (max-width: 768px) {
  .works-item {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.works-item .works-item_img {
  border: 0.1rem solid #333333;
  -webkit-box-shadow: 0.4rem 0.4rem 0 #333333;
  box-shadow: 0.4rem 0.4rem 0 #333333;
  width: 100%;
  height: 40rem;
}

.works-item .works-item_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (max-width: 768px) {
  .works-item .works-item_img {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    height: 21.8rem;
  }
}

.works-item .works-item_ttl {
  margin-top: 2.2rem;
}

@media screen and (max-width: 768px) {
  .works-item .works-item_ttl {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
    margin-top: 0.8rem;
  }
}

.works-item .works-item_ttl a {
  display: inline-block;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6667;
  text-decoration: underline;
  position: relative;
  padding-left: 4.1rem;
}

.works-item .works-item_ttl a::before {
  position: absolute;
  content: '';
  width: 3.1rem;
  height: 2.5rem;
  left: 0;
  top: 0.4rem;
  background: url(../img/common/icon_dupple.svg) center no-repeat;
  background-size: cover;
}

@media screen and (max-width: 768px) {
  .works-item .works-item_ttl a {
    font-size: 1.4rem;
    line-height: 1.5;
    padding-left: 2.5rem;
  }
  .works-item .works-item_ttl a::before {
    width: 2.1rem;
    height: 1.7rem;
  }
}

.works-item .works-item_cat {
  margin-top: 1rem;
}

.works-item .works-item_cat ._cat {
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .works-item .works-item_cat {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    margin-top: 1.8rem;
  }
  .works-item .works-item_cat ._cat {
    font-size: 1.2rem;
  }
}

.status-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 1rem;
  margin-bottom: 1.7rem;
}

.status-box .status-box_head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 2.4rem;
  -moz-column-gap: 2.4rem;
  column-gap: 2.4rem;
}

.status-box .status-box_ttl {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.944;
}

.status-box .status-box_ttl span {
  display: inline-block;
  font-size: 2.2rem;
  line-height: 1.59;
}

.status-box .c-btn {
  width: 18rem;
  height: 5rem;
}

.status-box .c-btn .c-btn_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 1.8rem;
  -moz-column-gap: 1.8rem;
  column-gap: 1.8rem;
}

.status-box .c-btn .ico {
  position: static;
  -webkit-transform: translate(0);
  transform: translate(0);
}

.status-box .status-box_txt {
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 180%;
}

@media screen and (max-width: 768px) {
  .status-box {
    margin-bottom: 4rem;
  }
  .status-box .status-box_head {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .status-box .c-btn {
    margin-top: 2rem;
  }
}

.cat-feature {
  position: relative;
}

.cat-feature .cat-feature_img {
  width: 100%;
  height: 35rem;
  overflow: hidden;
  position: relative;
}

.cat-feature .cat-feature_img::after {
  position: absolute;
  content: '';
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(5.97%, rgba(0, 0, 0, 0)), color-stop(50.12%, rgba(0, 0, 0, 0.4)), color-stop(94.28%, rgba(0, 0, 0, 0)));
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 5.97%, rgba(0, 0, 0, 0.4) 50.12%, rgba(0, 0, 0, 0) 94.28%);
  -webkit-backdrop-filter: blur(7px);
  backdrop-filter: blur(7px);
}

.cat-feature .cat-feature_img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (max-width: 768px) {
  .cat-feature .cat-feature_img {
    height: 17rem;
  }
  .cat-feature .cat-feature_img::after {
    background: -webkit-gradient(linear, left bottom, left top, color-stop(8.57%, rgba(0, 0, 0, 0)), color-stop(49.4%, rgba(0, 0, 0, 0.3)), color-stop(90.24%, rgba(0, 0, 0, 0)));
    background: linear-gradient(360deg, rgba(0, 0, 0, 0) 8.57%, rgba(0, 0, 0, 0.3) 49.4%, rgba(0, 0, 0, 0) 90.24%);
  }
}

.cat-feature .cat-feature_txt {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.53;
  width: 100%;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .cat-feature .cat-feature_txt {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

@media screen and (max-width: 768px) {
  .p-category .heading-lv1 {
    margin-bottom: 4rem;
  }
}

.p-category .sc-feature {
  padding-top: 6rem;
  padding-bottom: 8rem;
}

@media screen and (max-width: 768px) {
  .p-category .sc-feature {
    padding-top: 2.5rem;
    padding-bottom: 3rem;
  }
}

@media screen and (min-width: 769px) {
  .p-category .sc-future .container {
    -webkit-column-gap: 9rem;
    -moz-column-gap: 9rem;
    column-gap: 9rem;
  }
  .p-category .sc-future .future-head {
    width: 52rem;
  }
  .p-category .sc-future .future-head .future-ttl {
    font-size: 4rem;
  }
}

@media screen and (max-width: 768px) {
  .p-category .sc-future {
    padding-top: 2rem;
  }
  .p-category .sc-future .const-pos.pos1 {
    top: 0.5rem;
  }
  .p-category .sc-future .const-pos.pos2 {
    top: 1.2rem;
  }
}

@media screen and (min-width: 769px) {
  .search-ctrl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 1.8rem 0;
  }
  .search-ctrl:first-of-type {
    padding-top: 0;
  }
  .search-ctrl:last-of-type {
    padding-bottom: 0;
  }
  .search-ctrl._center {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .search-ctrl._center .search-ctrl_lbl {
    margin: 0;
  }
}

@media screen and (max-width: 768px) {
  .search-ctrl + .search-ctrl {
    margin-top: 2rem;
  }
}

@media screen and (min-width: 769px) {
  .search-ctrl .search-ctrl_lbl {
    width: 13.8rem;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.66667;
    margin-top: -0.8rem;
  }
}

@media screen and (max-width: 768px) {
  .search-ctrl .search-ctrl_lbl {
    font-size: 1.6rem;
    margin-bottom: 1.2rem;
  }
}

.search-ctrl .search-ctrl_ctn {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.search-ctrl .search-ctrl_ctn .wpcf7-checkbox {
  display: block;
  margin: -1.4rem 0 0 -2rem;
}

.search-ctrl .search-ctrl_ctn .wpcf7-checkbox .wpcf7-list-item {
  display: inline-block;
  line-height: 1.25;
  margin: 1.4rem 0 0 2rem;
}

@media screen and (max-width: 768px) {
  .search-ctrl .search-ctrl_ctn .wpcf7-checkbox {
    margin: -1rem 0 0 -2rem;
    font-size: 1.4rem;
    line-height: 1.42857;
  }
  .search-ctrl .search-ctrl_ctn .wpcf7-checkbox .wpcf7-list-item {
    margin: 1rem 0 0 2rem;
  }
}

.sub-content {
  padding: 2.5rem;
  display: none;
  background-color: #D5EEF0;
  margin-top: 2.2rem;
}

@media screen and (max-width: 768px) {
  .sub-content {
    padding: 2rem 1.5rem;
    margin-top: 1.6rem;
  }
  .sub-content .wpcf7-checkbox {
    margin: -1rem 0 0 -1.2rem !important;
  }
  .sub-content .wpcf7-checkbox .wpcf7-list-item {
    margin: 1rem 0 0 1.2rem !important;
  }
}

/** home
======================================= **/
.main-visual {
  width: 100%;
  height: 70rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  .main-visual {
    height: calc(100vh - 12rem);
  }
}

.main-visual .mv-img {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.main-visual .mv-ctn {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  width: 100%;
}

.main-visual .mv-ctn .mv-ttl {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
  background-color: #63AFB4;
  border-radius: 3.3rem;
  overflow: hidden;
  margin-bottom: 4rem;
}

.main-visual .mv-ctn .mv-ttl .lb {
  display: inline-block;
  line-height: 1;
  padding: 1rem 2rem 1rem 3.3rem;
  color: #fff;
}

.main-visual .mv-ctn .mv-ttl .tl {
  display: inline-block;
  background-color: #fff;
  color: #333;
  line-height: 1;
  border-radius: 3.3rem;
  padding: 1.7rem 3.8rem;
}

@media screen and (max-width: 768px) {
  .main-visual .mv-ctn .mv-ttl {
    display: inline-block;
    font-size: 2rem;
    margin-bottom: 3rem;
    position: relative;
    background-color: transparent;
    border-radius: 0;
    overflow: visible;
  }
  .main-visual .mv-ctn .mv-ttl .lb {
    background-color: #63AFB4;
    padding: 0;
    border-radius: 1.5rem;
    width: 12.2rem;
    height: 3rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    top: -1.5rem;
  }
  .main-visual .mv-ctn .mv-ttl .tl {
    padding: 2rem 1.9rem;
    border-radius: 3rem;
  }
}

.main-visual .mv-ctn .mv-logo img {
  max-width: 53rem;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .main-visual .mv-ctn .mv-logo img {
    max-width: 28.9rem;
  }
}

.main-visual .mv-ctn .mv-txt {
  margin-top: 6.8rem;
  line-height: 1;
  font-size: 4.8rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.58;
  text-shadow: 0 2px 1px rgba(0, 0, 0, 0.25);
}

.main-visual .mv-ctn .mv-txt span {
  display: inline-block;
  position: relative;
}

.main-visual .mv-ctn .mv-txt span::after {
  position: absolute;
  content: '';
  left: 0;
  bottom: 0.8rem;
  width: 100%;
  height: 0.7rem;
  background-color: #D5EEF0;
  border: 0.1rem solid #fff;
  z-index: -1;
}

.main-visual .mv-ctn .mv-txt img {
  max-width: 65.3rem;
}

@media screen and (max-width: 768px) {
  .main-visual .mv-ctn .mv-txt {
    font-size: 2.6rem;
    line-height: 1.69;
    letter-spacing: 0;
    margin-top: 2.2rem;
  }
  .main-visual .mv-ctn .mv-txt span::after {
    bottom: 0.1rem;
    height: 0.4rem;
  }
  .main-visual .mv-ctn .mv-txt img {
    max-width: 33.8rem;
  }
}

.main-visual .mv-scroll {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  bottom: 0;
  z-index: 1;
  color: #fff;
}

.main-visual .mv-scroll > .text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
  font-family: "Elms Sans", sans-serif;
  padding: 1.4rem 0 0.8rem 1rem;
  --line-total-height: 6rem;
  
  --line-move-height: 3rem;
  
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  position: relative;
  /* line */
}

.main-visual .mv-scroll > .text::after {
  content: '';
  position: absolute;
  width: 0.1rem;
  height: calc(100% + 3rem);
  top: -3rem;
  left: 0;
  background-color: #C3C3C3;
}

.main-visual .mv-scroll > .text::before {
  content: '';
  position: absolute;
  width: 0.1rem;
  height: var(--line-move-height);
  left: 0;
  top: -3rem;
  background-color: #333;
  z-index: 2;
  -webkit-animation: scrollLine 3s linear infinite;
  animation: scrollLine 3s linear infinite;
}

.main-visual .mv-scroll > .text > span {
  display: inline-block;
  -webkit-animation: scrollTextBlink 2s ease-in-out infinite;
  animation: scrollTextBlink 2s ease-in-out infinite;
}

.main-visual .mv-scroll > .text > span:nth-child(1) {
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
}

.main-visual .mv-scroll > .text > span:nth-child(2) {
  -webkit-animation-delay: 0.15s;
  animation-delay: 0.15s;
}

.main-visual .mv-scroll > .text > span:nth-child(3) {
  -webkit-animation-delay: 0.3s;
  animation-delay: 0.3s;
}

.main-visual .mv-scroll > .text > span:nth-child(4) {
  -webkit-animation-delay: 0.45s;
  animation-delay: 0.45s;
}

.main-visual .mv-scroll > .text > span:nth-child(5) {
  -webkit-animation-delay: 0.6s;
  animation-delay: 0.6s;
}

.main-visual .mv-scroll > .text > span:nth-child(6) {
  -webkit-animation-delay: 0.75s;
  animation-delay: 0.75s;
}

.main-visual .mv-slider {
  width: 100%;
  height: 100%;
  overflow: hidden;
  opacity: 0;
  -webkit-transition: opacity 0.6s ease;
  transition: opacity 0.6s ease;
}

.main-visual .mv-slider .slick-list,
.main-visual .mv-slider .slick-track {
  height: 100% !important;
}

.main-visual .mv-slider .mv-slider_item {
  width: 100%;
  overflow: hidden;
}

.main-visual .mv-slider .mv-slider_item .mv-slider_image {
  width: 100%;
  height: 100%;
  -webkit-animation-name: crossfeed;
  animation-name: crossfeed;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-direction: normal;
  animation-direction: normal;
  position: relative;
}

.main-visual .mv-slider .mv-slider_item .mv-slider_image picture,
.main-visual .mv-slider .mv-slider_item .mv-slider_image figure {
  display: block;
  width: 100%;
  height: 100%;
}

.main-visual .mv-slider .mv-slider_item .mv-slider_image img {
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%;
}

.main-visual .mv-slider .mv-slider_item.slick-active .mv-slider_image {
  -webkit-animation-name: zoomout;
  animation-name: zoomout;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-duration: 4s;
  animation-duration: 4s;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-direction: normal;
  animation-direction: normal;
}

.main-visual .mv-slider.is-ready {
  opacity: 1;
}

.p-top {
  /** sc-case-study **/
  /** sc-about **/
  /** sc-construction **/
  /** sc-news **/
  /** sc-service **/
}

.p-top .sc-case-study {
  padding: 13.3rem 0 10rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study {
    padding: 6.4rem 0 0;
  }
}

.p-top .sc-case-study .heading-lv2 .ja {
  line-height: 1.444;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .heading-lv2 {
    margin-bottom: 2.7rem;
  }
  .p-top .sc-case-study .heading-lv2 .en {
    margin-bottom: 4rem;
  }
  .p-top .sc-case-study .heading-lv2 .ja {
    font-size: 2.4rem;
    line-height: 1.5;
  }
  .p-top .sc-case-study .heading-lv2 .txt {
    font-size: 1.4rem;
    margin-top: 4rem;
  }
}

.p-top .sc-case-study .container {
  position: relative;
}

.p-top .sc-case-study .container .case-pos {
  display: inline-block;
  position: absolute;
}

.p-top .sc-case-study .container .case-pos.pos1 {
  width: 4.7rem;
  left: 5.6rem;
  top: 0.1rem;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .container .case-pos.pos1 {
    width: 2.7rem;
    left: 6.4rem;
    top: -3.4rem;
  }
}

.p-top .sc-case-study .container .case-pos.pos2 {
  width: 4.8rem;
  left: 25.8rem;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
  top: -2rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .container .case-pos.pos2 {
    width: 2.4rem;
    left: 2rem;
    top: 8.1rem;
  }
}

.p-top .sc-case-study .container .case-pos.pos3 {
  width: 6.2rem;
  left: 16.5rem;
  top: 9.6rem;
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .container .case-pos.pos3 {
    width: 3.3rem;
    left: 6.3rem;
    top: 13rem;
  }
}

.p-top .sc-case-study .container .case-pos.pos4 {
  width: 3.9rem;
  right: 6.3rem;
  top: -1rem;
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .container .case-pos.pos4 {
    width: 2.3rem;
    right: 6.6rem;
    top: -3.4rem;
  }
}

.p-top .sc-case-study .container .case-pos.pos5 {
  width: 5.9rem;
  right: 15.6rem;
  top: 8.8rem;
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .container .case-pos.pos5 {
    width: 2.7rem;
    right: 3.1rem;
    top: 8rem;
  }
}

.p-top .sc-case-study .container .case-pos.pos6 {
  width: 4.9rem;
  right: 26.3rem;
  top: -3rem;
  -webkit-transition-delay: 0.7s;
  transition-delay: 0.7s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .container .case-pos.pos6 {
    width: 2.3rem;
    right: 7rem;
    top: 13.3rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .sc-case-study .wrap-slider {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-flow: column-reverse;
    flex-flow: column-reverse;
    margin-top: -4rem;
  }
  .p-top .sc-case-study .wrap-slider .container {
    width: 100%;
    margin-bottom: 4rem;
  }
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .wrap-slider .container {
    margin-top: 4.4rem;
  }
}

@media screen and (min-width: 769px) {
  .p-top .sc-case-study .slider-nav {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    position: relative;
    z-index: 2;
  }
}

.p-top .sc-case-study .case-study-slider .slick-list {
  overflow: visible;
}

.p-top .sc-case-study .case-study-slider .case-study-slider_item {
  width: 53rem;
  margin: 0 1.5rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .case-study-slider .case-study-slider_item {
    width: 23rem;
    margin: 0 0.5rem;
  }
}

.p-top .sc-case-study .case-study-slider .case-study-slider_item .item-img {
  width: 100%;
  height: 34.3rem;
  overflow: hidden;
  border: 0.1rem solid #333333;
}

.p-top .sc-case-study .case-study-slider .case-study-slider_item .item-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .case-study-slider .case-study-slider_item .item-img {
    height: 15rem;
  }
}

.p-top .sc-case-study .case-study-slider .case-study-slider_item .item-location {
  position: absolute;
  left: 0;
  bottom: -2rem;
  background-color: #fff;
  border: 0.1rem solid #333333;
  -webkit-box-shadow: 3px 3px 0 #333333;
  box-shadow: 3px 3px 0 #333333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-top .sc-case-study .case-study-slider .case-study-slider_item .item-location dt {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.8;
  padding: 0.3rem 1.8rem 0.3rem 1.4rem;
}

.p-top .sc-case-study .case-study-slider .case-study-slider_item .item-location dd {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
  padding: 0.3rem 1.8rem 0.3rem 1.4rem;
  border-left: 0.1rem solid #333333;
}

@media screen and (max-width: 768px) {
  .p-top .sc-case-study .case-study-slider .case-study-slider_item .item-location {
    background-color: transparent;
    -webkit-box-shadow: none;
    box-shadow: none;
    border: none;
    display: block;
    bottom: -2.4rem;
  }
  .p-top .sc-case-study .case-study-slider .case-study-slider_item .item-location dt {
    background-color: #fff;
    display: inline-block;
    font-size: 1.6rem;
    line-height: 1.125;
    padding: 0.5rem 0.7rem;
    border: 0.1rem solid #333333;
    -webkit-box-shadow: 0.2rem 0.2rem 0 #333333;
    box-shadow: 0.2rem 0.2rem 0 #333333;
  }
  .p-top .sc-case-study .case-study-slider .case-study-slider_item .item-location dd {
    background-color: #fff;
    margin-top: -0.2rem;
    font-size: 1.4rem;
    line-height: 1.142857;
    padding: 0.4rem 0.8rem;
    border: 0.1rem solid #333333;
    -webkit-box-shadow: 0.2rem 0.2rem 0 #333333;
    box-shadow: 0.2rem 0.2rem 0 #333333;
    z-index: 1;
    position: relative;
  }
}

.p-top .sc-about {
  padding: 0 0 12rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about {
    padding-bottom: 5rem;
  }
}

.p-top .sc-about .about-wrap {
  background-color: #D5EEF0;
  padding: 9.2rem 6rem 6rem;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .about-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 2rem 0;
    padding: 5rem 2rem 4rem;
  }
}

.p-top .sc-about .about-wrap .sc-lbl {
  position: absolute;
  left: 5.9rem;
  top: -1.7rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .about-wrap .sc-lbl {
    left: 2rem;
  }
}

.p-top .sc-about .about-wrap .about-head {
  width: 44rem;
}

.p-top .sc-about .about-wrap .about-head .about-head_ms {
  display: inline-block;
  background-color: #63AFB4;
  color: #fff;
  font-size: 2rem;
  line-height: 1.8;
  padding: 0.6rem 2.6rem;
  border-radius: 2.4rem;
  margin-bottom: 2.6rem;
}

.p-top .sc-about .about-wrap .about-head .about-head_ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: 1.475;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .about-wrap .about-head {
    width: 100%;
    text-align: center;
  }
  .p-top .sc-about .about-wrap .about-head .about-head_ms {
    font-size: 1.6rem;
    line-height: 1.5;
    padding: 0.5rem 1.4rem;
    margin-bottom: 2rem;
  }
  .p-top .sc-about .about-wrap .about-head .about-head_ttl {
    font-size: 2.4rem;
    line-height: 1.416;
  }
}

.p-top .sc-about .about-wrap .about-content {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.p-top .sc-about .about-wrap .about-content .intro-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  background-color: #fff;
  border-radius: 1.2rem;
  border: 0.1rem solid #333333;
  overflow: hidden;
  margin-bottom: 4rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .about-wrap .about-content .intro-list {
    display: block;
    margin-bottom: 2.4rem;
  }
}

.p-top .sc-about .about-wrap .about-content .intro-list li {
  width: 33.33333%;
  padding: 2rem 1.5rem;
  text-align: center;
  line-height: 1.375;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-top .sc-about .about-wrap .about-content .intro-list li + li {
  border-left: 0.1rem solid #333333;
}

.p-top .sc-about .about-wrap .about-content .intro-list li .lg {
  display: block;
  font-size: 2rem;
  line-height: 1.2;
  color: #63AFB4;
  margin-top: 0.4rem;
}

.p-top .sc-about .about-wrap .about-content .intro-list li .lg sup {
  display: inline-block;
  color: #333;
  font-size: 1.2rem;
}

.p-top .sc-about .about-wrap .about-content .intro-list li .note {
  display: block;
  font-size: 1.2rem;
  line-height: 140%;
  margin-top: 0.6rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .about-wrap .about-content .intro-list li {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    padding: 1.2rem 1.5rem;
    font-size: 1.6rem;
    line-height: 1.375;
  }
  .p-top .sc-about .about-wrap .about-content .intro-list li + li {
    border-left: none;
    border-top: 0.1rem solid #333333;
  }
  .p-top .sc-about .about-wrap .about-content .intro-list li .lg {
    display: inline-block;
    font-size: 2rem;
    margin: 0;
  }
  .p-top .sc-about .about-wrap .about-content .intro-list li .note {
    width: 100%;
    margin-top: 0;
    font-size: 1.2rem;
    line-height: 140%;
  }
}

.p-top .sc-about .about-wrap .about-content .intro-cpy {
  line-height: 2.125;
}

.p-top .sc-about .about-wrap .about-content .intro-cpy p span {
  background-color: #fff;
  padding: 0 0.4rem;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .about-wrap .about-content .intro-cpy {
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .p-top .sc-about .about-wrap .about-content .intro-cpy p span {
    padding: 0 0.2rem;
  }
  .p-top .sc-about .about-wrap .about-content .intro-cpy p + p {
    margin-top: 2.8rem;
  }
}

.p-top .sc-about .about-wrap .about-pos {
  width: 20.4rem;
  position: absolute;
  right: 3.2rem;
  bottom: -0.3rem;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .about-wrap .about-pos {
    width: 10.6rem;
    right: 0.6rem;
    top: -5.3rem;
    bottom: auto;
  }
  .p-top .sc-about .about-wrap .about-pos::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 1.9rem;
    left: 0;
    bottom: 0;
    background: -webkit-gradient(linear, left bottom, left top, from(#D5EEF0), to(#D5EEF000));
    background: linear-gradient(to top, #D5EEF0, #D5EEF000);
  }
}

.p-top .sc-about .c-btn {
  margin-top: 3.5rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-about .c-btn {
    margin-top: 3rem;
  }
}

.p-top .sc-construction {
  padding: 0 0 11rem;
}

.p-top .sc-construction .container {
  position: relative;
}

.p-top .sc-construction .c-line {
  margin-bottom: 5.5rem;
}

.p-top .sc-construction .heading-lv2 {
  margin-bottom: 5rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-construction {
    padding: 0 0 7rem;
  }
  .p-top .sc-construction .heading-lv2 {
    margin-bottom: 3rem;
  }
}

.p-top .sc-news {
  padding: 9.5rem 0 11rem;
}

.p-top .sc-news .heading-lv2 {
  margin-bottom: 5rem;
}

.p-top .sc-news .heading-lv2 .en {
  margin-bottom: 3rem;
}

.p-top .sc-news .news-content {
  padding: 3rem 5rem 6rem;
  background-color: #F9FAFB;
  position: relative;
}

.p-top .sc-news .news-content .news-pos {
  display: inline-block;
  position: absolute;
}

.p-top .sc-news .news-content .news-pos.pos1 {
  width: 8.7rem;
  right: 29.1rem;
  top: -10rem;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.p-top .sc-news .news-content .news-pos.pos2 {
  width: 21.7rem;
  right: 3.6rem;
  top: -12.9rem;
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-news {
    padding: 6rem 0 5rem;
  }
  .p-top .sc-news .heading-lv2 {
    margin-bottom: 2rem;
  }
  .p-top .sc-news .heading-lv2 .en {
    margin-bottom: 1rem;
  }
  .p-top .sc-news .news-content {
    padding: 4rem 2rem;
  }
  .p-top .sc-news .news-content .news-pos.pos1 {
    width: 4.1rem;
    right: 11.2rem;
    top: -5.4rem;
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
  }
  .p-top .sc-news .news-content .news-pos.pos2 {
    width: 10.3rem;
    right: -0.9rem;
    top: -6.8rem;
    -webkit-transition-delay: 0.4s;
    transition-delay: 0.4s;
  }
}

@media screen and (min-width: 769px) {
  .p-top .sc-news .c-btn {
    margin-top: 5rem;
  }
}

.p-top .sc-service {
  padding: 0 0 12rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-service {
    padding: 0 0 7rem;
  }
}

.p-top .sc-service .c-line {
  margin-bottom: 6.5rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-service .c-line {
    margin-bottom: 4rem;
  }
}

.p-top .sc-service .c-line .c-line_txt span {
  padding: 0 2.5rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-service .c-line .c-line_txt span {
    font-size: 1.6rem;
    line-height: 1.625;
  }
}

@media screen and (min-width: 769px) {
  .p-top .sc-service .c-link {
    display: inline-block;
    line-height: 1.25;
  }
}

@media screen and (max-width: 768px) {
  .p-top .sc-service .c-link::after {
    display: none;
  }
}

.p-top .sc-service .heading-lv2 {
  margin: 0 0 3rem;
}

@media screen and (max-width: 768px) {
  .p-top .sc-service .heading-lv2 {
    margin-bottom: 2rem;
  }
}

.p-top .sc-service .service-wrap {
  background-color: #D5EEF0;
  padding: 4rem 2rem;
  position: relative;
}

.p-top .sc-service .service-inner {
  max-width: 81.2rem;
  margin: 0 auto;
  font-size: 1.4rem;
  line-height: 2.42857;
}

@media screen and (max-width: 768px) {
  .p-top .sc-service .service-inner {
    line-height: 1.857;
  }
}

.p-top .sc-service .service-pos {
  display: inline-block;
  position: absolute;
}

.p-top .sc-service .service-pos.pos1 {
  width: 5.6rem;
  right: 6.1rem;
  top: -8.7rem;
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-service .service-pos.pos1 {
    width: 2.3rem;
    right: 2rem;
    top: -3.2rem;
  }
}

.p-top .sc-service .service-pos.pos2 {
  width: 8.3rem;
  left: 3.1rem;
  bottom: -0.1rem;
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

@media screen and (max-width: 768px) {
  .p-top .sc-service .service-pos.pos2 {
    width: 3.7rem;
    left: 2.5rem;
    bottom: -2.9rem;
  }
}

.p-top .sc-works .c-btn {
  margin-top: 5rem;
}

.p-construction .post-main {
  background-color: #D5EEF0;
  padding: 6.4rem 0;
  margin-top: 6rem;
}

@media screen and (max-width: 768px) {
  .p-construction .post-main {
    padding: 4.8rem 0 0;
    margin-top: 1.5rem;
  }
}

.p-construction .post-main .container {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 11.4rem;
  -moz-column-gap: 11.4rem;
  column-gap: 11.4rem;
}

@media screen and (max-width: 768px) {
  .p-construction .post-main .container {
    display: block;
  }
}

.p-construction .post-main .post-main_lbl {
  display: inline-block;
  font-size: 1.8rem;
  font-weight: 500;
  background-color: #63AFB4;
  color: #fff;
  border-radius: 5rem;
  padding: 0.6rem 2.3rem;
  position: absolute;
  left: 1.5rem;
  top: -8.4rem;
}

@media screen and (max-width: 768px) {
  .p-construction .post-main .post-main_lbl {
    font-size: 1.6rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    top: -6.6rem;
  }
}

@media screen and (min-width: 769px) {
  .p-construction .post-main .post-main_img {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 70rem;
    margin-top: 4.3rem;
    height: 46.5rem;
  }
  .p-construction .post-main .post-main_img figure {
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
}

@media screen and (max-width: 768px) {
  .p-construction .post-main .post-main_img {
    margin: 4.7rem -2rem 0;
  }
}

.p-construction .post-main .post-main_cat {
  margin-bottom: 1.5rem;
}

.p-construction .post-main .post-main_cat ._cat {
  font-size: 1.4rem;
  line-height: 1.7142857;
}

@media screen and (max-width: 768px) {
  .p-construction .post-main .post-main_cat ._cat {
    font-size: 1.2rem;
  }
}

.p-construction .post-main .post-main_title {
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .p-construction .post-main .post-main_title {
    font-size: 2.4rem;
    line-height: calc(34/24);
  }
}

.p-construction .post-main .post-main_tag {
  margin: 1.5rem 0 1rem -0.5rem;
}

.p-construction .post-main .post-main_tag .c-area_itm {
  margin: 0 0 0.5rem 0.5rem;
}

.p-construction .post-main .post-main_tag ._tag {
  background-color: #fff;
}

.p-construction .post-main .post-main_detail .info-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
  padding: 1.5rem 0;
  border-bottom: 0.1rem solid #333333;
}

.p-construction .post-main .post-main_detail .info-row .info-row_tl {
  width: 10rem;
}

.p-construction .post-main .post-main_detail .info-row .info-row_tx {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@media screen and (max-width: 768px) {
  .p-construction .post-main .post-main_detail .info-row {
    padding: 1rem 0;
    font-size: 1.4rem;
  }
  .p-construction .post-main .post-main_detail .info-row .info-row_tl {
    width: 6rem;
  }
}

.post-body {
  padding: 8rem 0 13rem;
}

@media screen and (max-width: 768px) {
  .post-body {
    padding: 3rem 0 8rem;
  }
}

.post-body .inner {
  max-width: 86.3rem;
  padding: 0 1.5rem;
  margin-inline: auto;
}

@media screen and (max-width: 768px) {
  .post-body .inner {
    padding: 0 2rem;
  }
}

.post-body .post-body_head {
  margin-bottom: 10rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_head {
    margin-bottom: 9rem;
  }
}

.post-body .c-btn {
  margin-top: 9.5rem;
}

@media screen and (max-width: 768px) {
  .post-body .c-btn {
    margin-top: 8rem;
  }
}

.post-body .post-body_content h2 {
  font-size: 2.4rem;
  font-weight: 700;
  padding-left: 2.6rem;
  margin-bottom: 5rem;
  margin-top: 10rem;
  position: relative;
}

.post-body .post-body_content h2::before {
  position: absolute;
  content: '';
  width: 1.6rem;
  height: 0.8rem;
  left: 0;
  top: 1.5rem;
  background-color: #63AFB4;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content h2 {
    font-size: 2rem;
    margin-bottom: 4rem;
    margin-top: 8rem;
  }
  .post-body .post-body_content h2::before {
    top: 1.2rem;
  }
}

.post-body .post-body_content h3 {
  font-size: 2rem;
  font-weight: 700;
  margin: 5rem 0 3rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content h3 {
    font-size: 1.8rem;
    margin: 4rem 0 3rem;
  }
}

.post-body .post-body_content p {
  font-size: 1.8rem;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content p {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

.post-body .post-body_content .is-layout-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content .is-layout-flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

.post-body .post-body_content .wp-block-columns {
  margin: 5rem 0;
}

@media screen and (min-width: 769px) {
  .post-body .post-body_content .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
  }
}

.post-body .post-body_content .wp-block-columns p {
  font-size: 1.4rem;
  line-height: 1.7857;
  margin-top: 1rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content .wp-block-columns {
    margin: 4rem 0;
  }
}

.post-body .post-body_content .wp-block-columns-is-layout-flex {
  gap: 5rem 3rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content .wp-block-columns-is-layout-flex {
    gap: 4rem 0;
  }
}

.post-body .post-body_content .wp-caption-text {
  font-size: 1.4rem;
  line-height: 1.7857;
  margin-top: 1rem;
}

.post-body .post-body_content ul {
  margin: 3rem 0 3rem 2rem;
}

.post-body .post-body_content ul li {
  list-style: disc;
  font-size: 1.8rem;
  line-height: 2;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content ul li {
    font-size: 1.6rem;
  }
}

.post-body .post-body_content .tbl-note {
  font-size: 1.4rem;
  color: #868663;
  margin-bottom: 1rem;
  margin-top: 4rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content .table-outer {
    position: relative;
    margin: 6rem 0 4rem;
  }
  .post-body .post-body_content .table-outer::before {
    content: '※表は横に動かせます';
    position: absolute;
    top: -3rem;
    left: 0;
    font-size: 1.4rem;
    color: #868663;
  }
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content .tbl-wrap,
  .post-body .post-body_content .wp-block-table {
    width: 100%;
    padding-bottom: 1rem;
    margin: 0 0 4rem;
    overflow-x: auto;
  }
}

.post-body .post-body_content table {
  width: 100%;
  margin: 5rem 0;
}

.post-body .post-body_content table tr:first-of-type td {
  background-color: #D5EEF0;
}

.post-body .post-body_content table th,
.post-body .post-body_content table td {
  padding: 1.5rem 1.2rem;
  text-align: left;
  vertical-align: middle;
  border: 0.1rem solid #000;
  width: 25%;
  line-height: normal;
}

.post-body .post-body_content table th {
  background-color: #D5EEF0;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content table {
    width: 833px;
    margin: 0;
  }
}

.post-body .post-body_content .ez-toc-counter {
  max-width: 40.2rem;
  border: 0.1rem solid #000 !important;
  -webkit-box-shadow: 5px 5px 0 #333333 !important;
  box-shadow: 5px 5px 0 #333333 !important;
  padding: 2rem 3.5rem 3rem 2.5rem !important;
  margin: 5rem 0 10rem;
}

.post-body .post-body_content .ez-toc-counter .ez-toc-title {
  font-size: 1.8rem;
  margin-bottom: 0.4rem;
}

.post-body .post-body_content .ez-toc-counter .ez-toc-list {
  margin-left: 2rem;
  margin-top: 0;
  margin-bottom: 0;
}

.post-body .post-body_content .ez-toc-counter .ez-toc-list li {
  list-style: disc !important;
  font-size: 1.4rem !important;
  line-height: 2 !important;
}

.post-body .post-body_content .ez-toc-counter .ez-toc-list li a {
  text-decoration: underline !important;
  font-size: 100% !important;
}

.post-body .post-body_content .ez-toc-counter .ez-toc-list li a:before {
  display: none;
}

.post-body .post-body_content .ez-toc-counter .ez-toc-list li a:hover {
  text-decoration: none;
}

.post-body .post-body_content .wp-block-gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 4rem;
}

.post-body .post-body_content .wp-block-gallery .wp-block-image {
  width: calc(50% - 2rem);
}

@media screen and (max-width: 768px) {
  .post-body .post-body_content .wp-block-gallery {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 4rem 0;
  }
  .post-body .post-body_content .wp-block-gallery .wp-block-image {
    width: 100% !important;
  }
}

.post-body .post-body_info {
  padding: 5.4rem 5rem 4rem;
  border: 0.1rem solid #333333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0 5rem;
  -webkit-box-shadow: 5px 5px 0 #333333;
  box-shadow: 5px 5px 0 #333333;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_info {
    display: block;
    padding: 3rem;
  }
}

.post-body .post-body_info .info-img {
  width: 21.4rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_info .info-img {
    width: 18rem;
    margin: 0 auto 2.4rem;
  }
}

.post-body .post-body_info .info-ctn {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.post-body .post-body_info .info-cat {
  margin-bottom: 1.5rem;
}

.post-body .post-body_info .info-cat ._cat {
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_info .info-cat ._cat {
    font-size: 1.2rem;
  }
}

.post-body .post-body_info .info-ttl {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_info .info-ttl {
    font-size: 1.8rem;
  }
}

@media screen and (max-width: 768px) {
  .post-body .post-body_info .info-add {
    font-size: 1.4rem;
    word-break: break-all;
  }
}

.post-body .post-body_info .c-sns {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-column-gap: 2rem;
  -moz-column-gap: 2rem;
  column-gap: 2rem;
  margin-top: 1.7rem;
}

.post-body .post-body_info .c-sns .c-sns_itm a {
  display: block;
}

.post-body .post-body_info .c-sns .c-sns_itm a img,
.post-body .post-body_info .c-sns .c-sns_itm a svg {
  display: block;
  width: auto;
  height: 1.8rem;
}

.post-body .post-body_info .c-sns .c-sns_itm a img path,
.post-body .post-body_info .c-sns .c-sns_itm a svg path {
  fill: #333333;
}

@media screen and (max-width: 768px) {
  .post-body .post-body_info .c-sns {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin-top: 1.5rem;
  }
}

.post-body .c-btn + .c-btn {
  margin-top: 4rem;
}

@media screen and (max-width: 768px) {
  .post-body .c-btn + .c-btn {
    margin-top: 1.6rem;
  }
}

.post-body.post-works {
  padding-bottom: 8rem;
}

.aligncenter {
  text-align: center;
}

.sc-archivements {
  padding: 10rem 0;
}

.sc-archivements .heading-lv2 {
  margin-bottom: 5rem;
}

@media screen and (min-width: 769px) {
  .sc-archivements .construction-list .construction-item:nth-child(4),
  .sc-archivements .construction-list .column-itm:nth-child(4),
  .sc-archivements .column-list .construction-item:nth-child(4),
  .sc-archivements .column-list .column-itm:nth-child(4) {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .sc-archivements {
    padding: 8rem 0;
  }
  .sc-archivements .heading-lv2 {
    margin-bottom: 3rem;
  }
}

.p-column .post-main {
  padding-top: 6.4rem;
  margin-top: 6rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-column .post-main {
    padding-top: 4.8rem;
    margin-top: 1.7rem;
  }
}

.p-column .post-main::after {
  position: absolute;
  content: '';
  width: 100%;
  height: 63.5rem;
  left: 0;
  top: 0;
  background-color: #D5EEF0;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .p-column .post-main::after {
    height: 100%;
  }
}

.p-column .post-main .inner {
  max-width: 86.3rem;
  padding: 0 1.5rem;
  margin-inline: auto;
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .inner {
    padding: 0 2rem;
  }
}

.p-column .post-main .post-main_lbl {
  display: inline-block;
  font-size: 1.8rem;
  line-height: 2;
  padding: 0.6rem 2.3rem;
  background-color: #63AFB4;
  color: #fff;
  border-radius: 2.4rem;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  top: -9rem;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .post-main_lbl {
    font-size: 1.6rem;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    top: -7rem;
  }
}

.p-column .post-main .post-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 1.5rem;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .post-meta {
    display: block;
  }
}

.p-column .post-main .post-date {
  margin: 0;
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .post-date {
    font-size: 1.2rem;
    line-height: 180%;
  }
}

.p-column .post-main .post-cat ._cat {
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .post-cat ._cat {
    font-size: 1.2rem;
    line-height: 2;
  }
}

.p-column .post-main .post-title {
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.53;
  margin-bottom: 1.5rem;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .post-title {
    font-size: 2.4rem;
    line-height: 1.5;
  }
}

.p-column .post-main .post-feature {
  margin-bottom: 5rem;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .post-feature {
    margin: 0 -2rem;
  }
}

.p-column .post-main .post-tag {
  margin: 0 0 4rem -0.5rem;
}

.p-column .post-main .post-tag ._tag {
  margin: 0 0 0.5rem 0.5rem;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  .p-column .post-main .post-tag {
    margin-bottom: 3rem;
  }
}

@media screen and (min-width: 769px) {
  .p-column .post-body {
    padding-top: 0;
  }
}

.p-works .post-main {
  position: relative;
  background-color: #D5EEF0;
  padding: 6.4rem 0;
  margin-top: 6rem;
}

@media screen and (max-width: 768px) {
  .p-works .post-main {
    padding: 4.8rem 0;
    margin-top: 1.5rem;
  }
}

.p-works .post-main .inner {
  max-width: 86.3rem;
  padding: 0 1.5rem;
  margin-inline: auto;
}

.p-works .post-main .post-main_lbl {
  display: inline-block;
  font-size: 1.8rem;
  line-height: 2;
  padding: 0.6rem 2.3rem;
  background-color: #63AFB4;
  color: #fff;
  border-radius: 2.4rem;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  top: -2.6rem;
}

@media screen and (max-width: 768px) {
  .p-works .post-main .post-main_lbl {
    font-size: 1.6rem;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    top: -2rem;
  }
}

.p-works .post-main .post-cat {
  margin-bottom: 1.5rem;
}

.p-works .post-main .post-cat ._cat {
  font-size: 1.4rem;
}

@media screen and (max-width: 768px) {
  .p-works .post-main .post-cat ._cat {
    font-size: 1.2rem;
    line-height: 2;
  }
}

.p-works .post-main .post-title {
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.53;
}

@media screen and (max-width: 768px) {
  .p-works .post-main .post-title {
    font-size: 2.4rem;
    line-height: 1.5;
    word-break: break-all;
  }
}

.p-works .post-main .c-txt {
  margin-top: 4rem;
}

@media screen and (max-width: 768px) {
  .p-works .post-main .c-txt {
    margin-top: 1.5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-works .post-body {
    padding: 6rem 0 8rem;
  }
}

@media screen and (min-width: 769px) {
  .p-works .post-body.post-works .wp-block-image {
    height: 40rem;
    overflow: hidden;
  }
  .p-works .post-body.post-works .wp-block-image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
}

/** home
======================================= **/
/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox */
input[type=number] {
  -moz-appearance: textfield;
}

select {
  /* Reset Select */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: 0;
  border: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  /* Personalize */
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: 1rem;
  background-image: none;
  cursor: pointer;
}

/* Remove IE arrow */
select::-ms-expand {
  display: none;
}

select {
  color: #ACACAC;
}

select option {
  color: #1B1D1E;
}

select:has(option:checked:not([value])),
select:has(option:checked:not([value=""])) {
  color: #1B1D1E;
}

select:has(option:checked:not([value])) option,
select:has(option:checked:not([value=""])) option {
  color: #1B1D1E;
}

input[type=checkbox] {
  position: relative;
  border: 0.1rem solid #333;
  cursor: pointer;
  line-height: 0;
  margin: 0 0.6rem 0 0;
  outline: 0;
  padding: 0;
  vertical-align: text-top;
  height: 2.2rem;
  width: 2.2rem;
  -webkit-appearance: none;
  background: #fff;
  border-radius: 0.4rem;
}

@media screen and (max-width: 768px) {
  input[type=checkbox] {
    height: 2rem;
    width: 2rem;
  }
}

input[type=checkbox]:checked {
  opacity: 1;
  border-color: #545454;
}

input[type=checkbox]:checked:before {
  opacity: 1;
}

input[type=checkbox]:before {
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 1.7rem;
  height: 1.3rem;
  opacity: 0;
  background: url(../img/common/icon_check.svg) left top no-repeat;
  background-size: cover;
}

input[type=radio] {
  position: relative;
  cursor: pointer;
  line-height: 0;
  margin: 0 0.8rem 0 0;
  outline: 0;
  padding: 1rem;
  vertical-align: middle;
  border-radius: 50%;
  -webkit-appearance: none;
  border: 0.1rem solid #545454;
  background-color: #fff;
  vertical-align: middle;
}

@media screen and (max-width: 768px) {
  input[type=radio] {
    padding: 0.9rem;
  }
}

input[type=radio]:before {
  position: absolute;
  content: '';
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  height: 1.2rem;
  width: 1.2rem;
  border-radius: 50%;
  background-color: #63AFB4;
  z-index: 2;
  opacity: 0;
  vertical-align: middle;
}

@media screen and (max-width: 768px) {
  input[type=radio]:before {
    height: 1rem;
    width: 1rem;
  }
}

input[type=radio]:hover {
  opacity: 1;
}

input[type=radio]:checked:before {
  opacity: 1;
}

.c-select {
  background: #fff url(../img/common/icon_down.svg) 94% center no-repeat;
  background-size: 1rem 0.5rem;
}

.ipt {
  width: 100%;
  padding: 1rem 2rem;
  outline: none;
  background: #fff;
  color: #5B5B5B;
  border: 0.1rem solid #333;
  border-radius: 0.3rem;
}

.ipt.medium {
  max-width: 28rem;
}

.ipt.c-select {
  border: 0.1rem solid #333;
  padding: 1rem 2rem;
  background: #fff url(../img/common/icon_down.svg) 98% center no-repeat;
  background-size: 2.2rem 1.4rem;
}

@media screen and (max-width: 768px) {
  .ipt.c-select {
    background-size: 2.2rem 1.4rem;
  }
}

.ipt.are {
  height: 10.5rem;
  resize: none;
}

@media screen and (max-width: 768px) {
  .ipt {
    font-size: 1.6rem;
    line-height: 180%;
  }
  .ipt.medium {
    max-width: 100%;
  }
  .ipt.are {
    height: 16rem;
  }
}

.ipt::-webkit-input-placeholder {
  color: #5B5B5B !important;
  opacity: 1;
}

.ipt::-webkit-input-placeholder, .ipt::-moz-placeholder, .ipt::-ms-placeholder, .ipt::placeholder {
  color: #5B5B5B !important;
  opacity: 1;
}

.ipt:focus {
  border-color: #3F96E8;
}

.ipt:focus::-webkit-input-placeholder {
  color: #5B5B5B;
  opacity: 1;
}

.ipt:focus::-webkit-input-placeholder, .ipt:focus::-moz-placeholder, .ipt:focus::-ms-placeholder, .ipt:focus::placeholder {
  color: #5B5B5B;
  opacity: 1;
}

input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #5B5B5B !important;
  opacity: 1;
}

input::-moz-placeholder, textarea::-moz-placeholder {
  color: #5B5B5B !important;
  opacity: 1;
}

input:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #5B5B5B !important;
  opacity: 1;
}

input::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #5B5B5B !important;
  opacity: 1;
}

input::placeholder,
textarea::placeholder {
  color: #5B5B5B !important;
  opacity: 1;
}

.req {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 4rem;
  height: 2.2rem;
  font-size: 1.2rem;
  line-height: 150%;
  background: #D52626;
  color: #fff;
  margin-left: auto;
  vertical-align: middle;
}

.req.not-req {
  background: #545454;
}

.upload__file .wpcf7-file {
  position: absolute;
  width: 100%;
  height: 100%;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  border: 0;
  left: 0;
  top: 0;
  opacity: 0;
  z-index: 5;
}


.upload__file .app-resume,
.upload__file .app-career {
  display: inline-block;
  position: relative;
  width: 100%;
  
}

.upload__file .wpcf7-form-control-wrap {
  display: inline-block;
  position: relative;
  width: 100%;
  
}


.upload__file .wpcf7-form-control-wrap::before {
  
  content: attr(data-file-name);
  display: inline-block;
  background-color: #ffffff;
  color: #333333;
  border: 0.1rem solid #333;
  border-radius: 0.3rem;
  cursor: pointer;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 180%;
  text-align: left;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 1rem 2rem;
}

.upload__file .app-resume::before,
.upload__file .app-career::before {
  
  content: attr(data-file-name);
  display: inline-block;
  background-color: #ffffff;
  color: #333333;
  border: 0.1rem solid #333;
  border-radius: 0.3rem;
  cursor: pointer;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 180%;
  text-align: left;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 1rem 2rem;
}

.upload__file .app-resume:hover::before,
.upload__file .app-career:hover::before {
  background-color: #333;
  color: #fff;
  border-style: solid;
}


.upload__file .wpcf7-form-control-wrap:hover::before {
  background-color: #333;
  color: #fff;
  border-style: solid;
}

input[type="submit"],
input[type="button"],
button {
  outline: none;
  padding: 0;
  border: none;
  cursor: pointer;
}

.f-btn {
  width: 19.4rem;
  height: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: #333333;
  color: #fff;
  border-radius: 0.3rem;
  border: 0.1rem solid #333333 !important;
}

.f-btn:hover {
  background-color: #fff;
  color: #333333;
}

@media screen and (max-width: 768px) {
  .f-btn {
    font-size: 1.6rem;
  }
}

.c-form_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 4rem;
  -moz-column-gap: 4rem;
  column-gap: 4rem;
  margin-top: 5rem;
}

@media screen and (max-width: 768px) {
  .c-form_btn {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    row-gap: 2rem;
    margin-top: 4rem;
  }
}

@media screen and (min-width: 769px) {
  .c-form_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .c-form_flex .c-form_ctrl {
    width: 28rem;
  }
}

.cfrow + .cfrow {
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .cfrow + .cfrow {
    margin-top: 2rem;
  }
}

.cfrow .mgt {
  margin-top: 1rem;
}

@media screen and (max-width: 768px) {
  .cfrow .c-form_ctrl + .c-form_ctrl {
    margin-top: 2rem;
  }
}

.industry-box {
  background-color: #F9FAFB;
  padding: 1.5rem 2rem;
}

.industry-box .industry-box_ttl {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 180%;
  margin-bottom: 1.2rem;
}

.industry-box + .industry-box {
  margin-top: 2rem;
}

.c-form_ctrl .c-form_ctrl_lbl {
  font-size: 1.6rem;
  line-height: 180%;
  margin-bottom: 0.7rem;
}

@media screen and (max-width: 768px) {
  .c-form_ctrl .c-form_ctrl_ctn {
    font-size: 1.4rem;
  }
}

.c-form_privacy {
  margin-top: 4rem;
  font-size: 1.4rem;
  line-height: calc(26/14);
}

@media screen and (max-width: 768px) {
  .c-form_privacy a {
    text-decoration: underline;
  }
  .c-form_privacy a::after {
    display: none;
  }
}

.c-form_checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 1.6rem;
  font-size: 1.4rem;
  line-height: calc(26/14);
}

.c-form_checkbox label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
}

.c-form_checkbox a {
  display: inline-block;
  color: #006BB4;
  text-decoration: underline;
}

.c-form_checkbox .req {
  margin-left: 1rem;
}

.c-form_checkbox .wpcf7-form-control-wrap {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
}

.c-form_checkbox .wpcf7-list-item {
  margin-left: 0;
}

.c-form_checkbox .your-agreeformError {
  position: static !important;
}

.c-form_checkbox .formErrorContent {
  position: absolute !important;
  bottom: -3rem;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}

@media screen and (max-width: 768px) {
  .c-form_checkbox .formErrorContent {
    bottom: -4.5rem;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
}

.c-form_lead {
  margin-bottom: 4rem;
}

.wpcf7-radio,
.wpcf7-checkbox {
  display: block;
}

.wpcf7-radio._grid,
.wpcf7-checkbox._grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.2rem 3.5rem;
}

@media screen and (max-width: 768px) {
  .wpcf7-radio._grid,
  .wpcf7-checkbox._grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem 3rem;
  }
}

.wpcf7-checkbox {
  margin: 0 0 -0.6rem -2rem;
}

.wpcf7-checkbox .wpcf7-list-item {
  display: inline-block;
  margin: 0 0 0.6rem 2rem;
}

.wpcf7-checkbox .wpcf7-list-item .wpcf7-list-item-label {
  line-height: 180%;
}

.wpcf7-radio .wpcf7-list-item > label,
.wpcf7-checkbox .wpcf7-list-item > label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.wpcf7-radio {
  display: block;
}

.wpcf7-radio .wpcf7-list-item {
  display: block;
}

.wpcf7-radio .wpcf7-list-item > label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.wpcf7-radio._inline {
  margin: -0.9rem 0 0 -1.6rem;
}

.wpcf7-radio._inline .wpcf7-list-item {
  display: inline-block;
  margin: 0.9rem 0 0 1.6rem;
}

.wpcf7-response-output {
  display: none;
}

.formErrorContent,
.field-error {
  font-size: 1.3rem;
  line-height: 1;
  margin-top: 0.8rem;
  color: #DA4432;
}

@media screen and (max-width: 768px) {
  .formErrorContent,
  .field-error {
    font-size: 1.2rem;
    margin-top: 1rem;
    line-height: 1.35;
  }
}

.is-error input,
.is-error .are,
.is-error select,
.is-error .policy-checkbox .wpcf7-list-item-label:before {
  border-color: #DA4432;
  background-color: #FFEAEA;
}

.upload__file .wpcf7-form-control-wrap.is-error::before {
  border-color: #DA4432;
  color: #DA4432;
  background-color: #FFEAEA;
}

.is-error select {
  color: #DA4432 !important;
  background: #FFEAEA url(../img/common/icon_down.svg) 98% center no-repeat !important;
}

.is-error input::-webkit-input-placeholder {
  color: #DA4432 !important;
  opacity: 1;
}

.is-error input::-webkit-input-placeholder,
.is-error input::-moz-placeholder,
.is-error input::-ms-placeholder,
.is-error input::placeholder {
  color: #DA4432 !important;
  opacity: 1;
}

.is-error .ipt::-webkit-input-placeholder {
  color: #DA4432 !important;
}

.is-error .ipt::-webkit-input-placeholder,
.is-error .ipt::-moz-placeholder,
.is-error .ipt::-ms-placeholder,
.is-error .ipt::placeholder {
  color: #DA4432 !important;
}

.c-form {
  max-width: 60.2rem;
  margin: 0 auto;
}

.c-confirm .cfrow + .cfrow {
  margin: 0;
}

.c-confirm .c-form_flex {
  display: contents;
}

.c-confirm .c-form_flex .c-form_ctrl {
  width: 100%;
}

.c-confirm .c-form_flex .c-form_ctrl:first-of-type {
  border-top: none;
}

.c-confirm .c-form_ctrl {
  padding: 2.4rem 0;
  border-bottom: 0.1rem solid #333;
}

.c-confirm .c-form_ctrl + .c-form_ctrl {
  margin-top: 0;
}

.c-confirm .c-form_ctrl:first-of-type {
  border-top: 0.1rem solid #545454;
}

.c-confirm .c-form_ctrl_ctn {
  margin-top: 1rem;
}

@media screen and (max-width: 768px) {
  .c-confirm .c-form_ctrl_ctn {
    font-size: 1.4rem;
  }
}

.c-confirm .c-back {
  color: #000000 !important;
  line-height: 210%;
  text-decoration: underline;
  margin-top: 4rem;
}

.c-thanks {
  text-align: center;
}

.c-thanks p + p {
  margin-top: 4rem;
}

.c-thanks .c-btn {
  margin-top: 8rem;
}

.p-contact {
  padding-bottom: 12rem;
}

@media screen and (max-width: 768px) {
  .p-contact {
    padding-bottom: 7rem;
  }
}

.p-title_wrap {
  margin-bottom: 6rem;
}

@media screen and (max-width: 768px) {
  .p-title_wrap {
    margin-bottom: 3rem;
  }
}

.p-title_wrap .p-title {
  margin-bottom: 0;
}

.p-title_wrap .p-title_sub {
  text-align: center;
  font-size: 4rem;
  font-weight: 500;
  line-height: 1;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .p-title_wrap .p-title_sub {
    font-size: 2.4rem;
    line-height: calc(38/24);
    margin-top: 0;
  }
}

.p-title_wrap .p-title_lead {
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
  margin-top: 4rem;
}

@media screen and (max-width: 768px) {
  .p-title_wrap .p-title_lead {
    font-size: 1.6rem;
    line-height: 1.875;
  }
}

.p-title_wrap .c-btn {
  margin-top: 3rem;
}

.blk-consulting {
  background-color: #D5EEF0;
  padding: 5.6rem 10.6rem 6.6rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  .blk-consulting {
    padding: 3rem 2rem 5rem;
    margin: 0 -2rem;
  }
}

.blk-consulting .blk-consulting_head {
  text-align: center;
  margin-bottom: 1rem;
}

@media screen and (max-width: 768px) {
  .blk-consulting .blk-consulting_head {
    margin-bottom: 2rem;
  }
}

.blk-consulting .blk-consulting_head .blk-consulting_ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: 1.55;
  margin-bottom: 1.3rem;
}

@media screen and (max-width: 768px) {
  .blk-consulting .blk-consulting_head .blk-consulting_ttl {
    font-size: 2.4rem;
    line-height: calc(34/24);
    margin-bottom: 3rem;
  }
}

@media screen and (min-width: 769px) {
  .blk-consulting .blk-consulting_info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
  .blk-consulting .blk-consulting_info .blk-consulting_info_cols {
    width: 49.2rem;
  }
}

@media screen and (max-width: 768px) {
  .blk-consulting .blk-consulting_info .blk-consulting_info_cols + .blk-consulting_info_cols {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid transparent;
    -o-border-image: repeating-linear-gradient(to right, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
    border-image: repeating-linear-gradient(to right, #333 0, #333 1px, transparent 1px, transparent 5px) 1;
  }
}

.blk-consulting .blk-consulting_info .blk-consulting_info_phone {
  text-align: center;
  display: block;
}

@media screen and (min-width: 769px) {
  .blk-consulting .blk-consulting_info .blk-consulting_info_phone {
    width: 100%;
    height: 16.7rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    border-radius: 1.2rem;
    border: 0.1rem solid #333333;
  }
}

.blk-consulting .blk-consulting_info .blk-consulting_info_phone .txt-splash {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 2.25;
  margin-bottom: 1rem;
}

@media screen and (max-width: 768px) {
  .blk-consulting .blk-consulting_info .blk-consulting_info_phone .txt-splash {
    margin-bottom: 0.3rem;
  }
}

.blk-consulting .blk-consulting_info .blk-consulting_info_phone .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 0.6rem;
  -moz-column-gap: 0.6rem;
  column-gap: 0.6rem;
  margin-bottom: 1rem;
}

.blk-consulting .blk-consulting_info .blk-consulting_info_phone .tel .ico {
  display: inline-block;
  width: 2.4rem;
}

.blk-consulting .blk-consulting_info .blk-consulting_info_phone .tel .num {
  display: inline-block;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1;
  font-style: italic;
  font-family: "Elms Sans", sans-serif;
}

.blk-consulting .blk-consulting_info .blk-consulting_info_phone .sch {
  display: block;
  font-size: 1.6rem;
  line-height: 140%;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .blk-consulting .blk-consulting_info .blk-consulting_info_phone .sch {
    font-size: 1.4rem;
    margin-top: 0.6rem;
  }
}

@media screen and (max-width: 768px) {
  .blk-consulting .blk-consulting_info .blk-consulting_info_phone .c-btn {
    margin-top: 0;
  }
  .blk-consulting .blk-consulting_info .blk-consulting_info_phone .c-btn .icoL {
    display: inline-block;
    width: 2.4rem;
    margin-right: 0.8rem;
  }
}

.blk-consulting .blk-consulting_info .cta-wrap_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 1.7rem;
}

.blk-consulting .blk-consulting_info .cta-wrap_btn .c-btn {
  margin-top: 0;
}

@media screen and (min-width: 769px) {
  .blk-consulting .blk-consulting_info .cta-wrap_btn .c-btn {
    max-width: unset;
    width: 100%;
    height: 7.5rem;
  }
}

.blk-consulting .blk-consulting_info .cta-wrap_btn_itm_tooltip {
  margin: 0 auto 1.2rem;
  width: 15.3rem;
  display: block;
}

@media screen and (max-width: 768px) {
  .blk-consulting .blk-consulting_info .cta-wrap_btn_itm_tooltip {
    width: 12.7rem;
    margin-bottom: 1rem;
  }
}

.blk-consulting .pos2 {
  width: 6.5rem;
  right: 11.7rem;
  top: -2.7rem;
}

@media screen and (max-width: 768px) {
  .blk-consulting .pos2 {
    width: 3.2rem;
    right: 3.7rem;
    top: 9.9rem;
  }
}

.blk-consulting .pos1 {
  width: 5.5rem;
  right: 4.7rem;
  top: -2.7rem;
}

@media screen and (max-width: 768px) {
  .blk-consulting .pos1 {
    width: 3rem;
    left: 4.1rem;
    right: auto;
    top: 9.4rem;
  }
}

.blk-contact {
  max-width: 105.4rem;
  margin: 7rem auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  gap: 7rem;
}

@media screen and (max-width: 768px) {
  .blk-contact {
    margin-top: 5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 3rem 0;
  }
}

@media screen and (min-width: 769px) {
  .blk-contact .blk-contact_item {
    width: calc(50% - 3.5rem);
    min-height: 23rem;
  }
  .blk-contact .blk-contact_item:last-of-type .blk-contact_item_link {
    position: relative;
  }
  .blk-contact .blk-contact_item:last-of-type .blk-contact_item_link ._button {
    position: absolute;
    bottom: 3rem;
    right: 0;
  }
}

.blk-contact .blk-contact_item_ttl {
  display: block;
  font-size: 2.8rem;
  font-weight: 500;
  line-height: calc(30/28);
  padding: 3rem 4rem;
}

@media screen and (max-width: 768px) {
  .blk-contact .blk-contact_item_ttl {
    font-size: 2.4rem;
    line-height: calc(30/24);
    padding: 2.2rem 2rem;
  }
}

.blk-contact .blk-contact_item_ctn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding: 3rem 0 0 4rem;
  border-top: 0.1rem solid #333333;
}

@media screen and (max-width: 768px) {
  .blk-contact .blk-contact_item_ctn {
    display: block;
    padding: 1.5rem 0 0 2rem;
  }
  .blk-contact .blk-contact_item_ctn .txt {
    display: block;
    margin-bottom: 1rem;
  }
}

.blk-contact ._button {
  margin: 0 4rem 0 auto;
}

@media screen and (max-width: 768px) {
  .blk-contact ._button {
    margin: 0 2rem 0 auto;
  }
}

.blk-contact .blk-contact_item_link {
  display: block;
  border: 0.1rem solid #333333;
  -webkit-box-shadow: 0.3rem 0.3rem 0 0 #333333;
  box-shadow: 0.3rem 0.3rem 0 0 #333333;
  padding-bottom: 3rem;
  height: 100%;
}

@media screen and (max-width: 768px) {
  .blk-contact .blk-contact_item_link {
    padding-bottom: 2rem;
  }
}

.wpcf7-turnstile {
  text-align: center;
  margin-top: 4rem;
}

/** home
======================================= **/
.p-about .p-about_concept {
  padding: 9rem 0;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept {
    padding: 3rem 0 0;
  }
}

@media screen and (min-width: 769px) {
  .p-about .p-about_concept .about-cpt_top {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.p-about .p-about_concept .about-cpt_ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: 1.55;
  margin-top: 2.2rem;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept .about-cpt_ttl {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-top: 2rem;
  }
}

.p-about .p-about_concept .about-cpt_head {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept .about-cpt_head {
    text-align: center;
    margin-bottom: 2rem;
  }
}

.p-about .p-about_concept .about-cpt_content {
  width: 68.8rem;
  font-size: 1.8rem;
  line-height: 2;
}

.p-about .p-about_concept .about-cpt_content p + p {
  margin-top: 1rem;
}

.p-about .p-about_concept .about-cpt_content .movie-wrap {
  margin-top: 5rem;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept .about-cpt_content {
    width: 100%;
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .p-about .p-about_concept .about-cpt_content .movie-wrap {
    margin-top: 3rem;
  }
}

.p-about .p-about_concept .about-wrap {
  background-color: #D5EEF0;
  padding: 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 9rem;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept .about-wrap {
    display: block;
    padding: 2rem 2rem 3rem;
    margin-top: 5rem;
  }
}

.p-about .p-about_concept .about-wrap .about-head {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@media screen and (min-width: 769px) {
  .p-about .p-about_concept .about-wrap .about-content {
    width: 84.8rem;
  }
}

.p-about .p-about_concept .about-wrap .about-head_ttl {
  font-size: 3rem;
  font-weight: 500;
  line-height: 1.6;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept .about-wrap .about-head_ttl {
    font-size: 1.8rem;
    line-height: 1.555;
    text-align: center;
    margin-bottom: 1rem;
  }
}

.p-about .p-about_concept .about-wrap .intro-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  background-color: #fff;
  border-radius: 1.2rem;
  border: 0.1rem solid #333333;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept .about-wrap .intro-list {
    display: block;
  }
}

.p-about .p-about_concept .about-wrap .intro-list li {
  width: 33.33333%;
  padding: 2rem 1.5rem;
  text-align: center;
  line-height: 1.375;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.p-about .p-about_concept .about-wrap .intro-list li + li {
  border-left: 0.1rem solid #333333;
}

.p-about .p-about_concept .about-wrap .intro-list li .lg {
  display: block;
  font-size: 2rem;
  line-height: 1.4;
  color: #63AFB4;
  margin-top: 1rem;
}

@media screen and (max-width: 768px) {
  .p-about .p-about_concept .about-wrap .intro-list li {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    padding: 1.6rem 1.5rem;
    font-size: 1.6rem;
    line-height: 1.375;
  }
  .p-about .p-about_concept .about-wrap .intro-list li + li {
    border-left: none;
    border-top: 0.1rem solid #333333;
  }
  .p-about .p-about_concept .about-wrap .intro-list li .lg {
    display: inline-block;
    font-size: 1.8rem;
    margin: 0.4rem 0 0;
  }
}

@media screen and (min-width: 769px) {
  .p-about .sc-future .future-head .future-ttl {
    font-size: 4rem;
  }
}

@media screen and (max-width: 768px) {
  .p-about .sc-future .const-pos.pos1 {
    left: 2.8rem;
    top: -1.7rem;
  }
}

@media screen and (max-width: 768px) {
  .p-about .sc-future .const-pos.pos2 {
    right: 2rem;
    top: -1.7rem;
  }
}

.p-about .sc-feature {
  padding: 6rem 0 8rem;
}

@media screen and (max-width: 768px) {
  .p-about .sc-feature {
    padding-top: 3rem;
  }
}

.p-about .sc-ai-generator {
  margin: 3rem 0 0;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator {
    margin: 0;
  }
}

.p-about .sc-ai-generator .ai-generator_lead {
  font-weight: 500;
  text-align: center;
  margin-bottom: 1.8rem;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_lead .c-lbl {
    padding: 0.9rem 2.2rem;
    border-radius: 4.8rem;
  }
}

.p-about .sc-ai-generator .ai-generator_title {
  font-size: 4.8rem;
  font-weight: 500;
  line-height: 1.375;
  margin-bottom: 3.7rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_title {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-bottom: 2rem;
  }
}

.p-about .sc-ai-generator .ai-generator_catlist {
  background-color: #fff;
  max-width: 64rem;
  margin: 0 auto 4rem;
  border-radius: 1.2rem;
  border: 0.1rem solid #333333;
  padding: 1rem 2rem;
}

.p-about .sc-ai-generator .ai-generator_catlist ul {
  display: block;
  text-align: center;
  margin: 0 0 -0.7rem 0;
}

.p-about .sc-ai-generator .ai-generator_catlist ul li {
  display: inline-block;
  margin: 0 0 0.7rem 0;
}

.p-about .sc-ai-generator .ai-generator_catlist ul li a {
  display: inline-block;
  line-height: 1.125;
  padding: 1rem 2rem;
  text-decoration: underline;
}

.p-about .sc-ai-generator .ai-generator_catlist ul li a:hover, .p-about .sc-ai-generator .ai-generator_catlist ul li a.active {
  opacity: 1;
  border-radius: 0.6rem;
  background-color: #333333;
  color: #fff;
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_catlist {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    border: none;
    padding: 0;
    background-color: transparent;
    margin-bottom: 2rem;
  }
  .p-about .sc-ai-generator .ai-generator_catlist select {
    max-width: 22.1rem;
    border-radius: 0.8rem;
    color: #333333;
  }
  .p-about .sc-ai-generator .ai-generator_catlist .cats-ttl {
    display: inline-block;
    font-size: 1.2rem;
  }
}

.p-about .sc-ai-generator .ai-generator_img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
}

.p-about .sc-ai-generator .ai-generator_img li {
  width: calc(50% - 1.5rem);
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_img {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 1.6rem 0;
  }
  .p-about .sc-ai-generator .ai-generator_img li {
    width: 100%;
  }
}

.p-about .sc-ai-generator .ai-generator_note {
  font-size: 1.4rem;
  line-height: 180%;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_note {
    font-size: 1.2rem;
    margin-top: 1.2rem;
  }
}

.p-about .sc-ai-generator .ai-generator_bottom {
  margin-top: 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
}

.p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_left {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  line-height: 2.125;
}

.p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_left span {
  display: inline-block;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_left {
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_left span {
    display: inline;
  }
}

@media screen and (min-width: 769px) {
  .p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_right {
    width: 49rem;
    padding: 0 4.5rem;
    text-align: center;
  }
  .p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_right .c-btn {
    margin-top: 1.4rem;
  }
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_right {
    text-align: center;
    margin: 0;
  }
  .p-about .sc-ai-generator .ai-generator_bottom .ai-generator_bottom_right .c-btn {
    margin-top: 1rem;
  }
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_bottom {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 2.4rem 0;
    margin-top: 2.4rem;
  }
}

.p-about .sc-ai-generator .ai-generator_wrap {
  padding: 6rem;
  background-color: #D5EEF0;
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_wrap {
    padding: 3rem 2rem 4rem;
  }
}

.p-about .sc-ai-generator .ai-generator_wrap picture {
  display: block;
}

.p-about .sc-ai-generator .ai-generator_wrap .pos1 {
  width: 12.3rem;
  left: 5.9rem;
  top: -8.3rem;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_wrap .pos1 {
    width: 4.8rem;
    left: 0.5rem;
    top: -5.4rem;
  }
}

.p-about .sc-ai-generator .ai-generator_wrap .pos2 {
  width: 11.3rem;
  right: 6.9rem;
  top: -7.4rem;
}

@media screen and (max-width: 768px) {
  .p-about .sc-ai-generator .ai-generator_wrap .pos2 {
    width: 5.2rem;
    right: 0.4rem;
    top: -5.2rem;
  }
}

@media screen and (min-width: 769px) {
  .p-about .sc-flow .flow-row {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
  }
  .p-about .sc-flow .flow-row_img {
    width: 45rem;
  }
  .p-about .sc-flow .flow-row_img .tx {
    font-size: 1.8rem;
    line-height: 2;
  }
  .p-about .sc-flow .flow-row_step {
    width: 68rem;
  }
  .p-about .sc-flow .flow-bottom {
    position: absolute;
    left: 0;
    bottom: 0;
  }
  .p-about .sc-flow .c-btn {
    margin-top: 2.8rem;
  }
}

@media screen and (max-width: 768px) {
  .p-about .sc-flow .flow-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .p-about .sc-flow .flow-row .flow-row_step {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
  }
  .p-about .sc-flow .flow-row .flow-row_img {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    max-width: 100%;
  }
  .p-about .sc-flow .flow-row .flow-row_img p {
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .p-about .sc-flow .flow-row .flow-bottom {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
    width: 100%;
    text-align: center;
  }
  .p-about .sc-flow .flow-row .flow-bottom p {
    font-size: 1.6rem;
    line-height: 1.875;
    text-align: left;
  }
}

.txt-splash {
  display: inline-block;
  position: relative;
  padding: 0 1.5rem;
}

.txt-splash::before, .txt-splash::after {
  position: absolute;
  content: '';
  width: 0.9rem;
  height: 1.7rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/line_splash.svg) left top no-repeat;
  background-size: cover;
}

.txt-splash::before {
  left: 0;
}

.txt-splash::after {
  right: 0;
  -webkit-transform: translateY(-50%) scaleX(-1);
  transform: translateY(-50%) scaleX(-1);
}

@media screen and (max-width: 768px) {
  .txt-splash {
    font-size: 1.4rem;
  }
}

.ai-generator_ctn {
  display: none;
}

.p-news .p-news_content {
  padding: 0 0 12rem;
}

@media screen and (max-width: 768px) {
  .p-news .p-news_content {
    padding: 0 0 7rem;
  }
}

.p-news .p-news_content .container {
  max-width: 103rem;
}

.p-news .news-list {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 2rem 0;
}

@media screen and (max-width: 768px) {
  .p-news .news-list {
    gap: 1.2rem 0;
  }
}

.p-news .news-itm {
  width: 100%;
  padding: 0;
  border: none;
}

.p-news .news-itm .news-item_date {
  width: 12rem;
  height: 3.6rem;
  font-weight: 500;
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-family: "Elms Sans", sans-serif;
  background-color: #63AFB4;
  color: #fff;
  border-radius: 8rem;
}

@media screen and (max-width: 768px) {
  .p-news .news-itm .news-item_date {
    display: inline-block;
    font-size: 1.4rem;
    width: auto;
    height: auto;
    padding: 0.8rem 1.8rem;
    margin-bottom: 1rem;
  }
}

.p-news .news-itm .news-item_title {
  display: inline-block;
  line-height: 2.125;
  text-decoration: underline;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@media screen and (max-width: 768px) {
  .p-news .news-itm .news-item_title {
    font-size: 1.6rem;
    line-height: 1.625;
  }
}

.p-news .news-itm .news-itm_link {
  padding: 4rem 3rem;
  background-color: #F9FAFB;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 2rem;
  -moz-column-gap: 2rem;
  column-gap: 2rem;
}

.p-news .news-itm .news-itm_link ._button {
  width: 4rem;
  height: 4rem;
  margin-left: auto;
}

.p-news .news-itm .news-itm_link ._button .arrow {
  width: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.p-news .news-itm .news-itm_link:hover ._button .arrow svg, .p-news .news-itm .news-itm_link:hover ._button .arrow img {
  -webkit-animation: arrow-right 0.5s ease-in-out;
  animation: arrow-right 0.5s ease-in-out;
}

@media screen and (max-width: 768px) {
  .p-news .news-itm .news-itm_link {
    padding: 2rem 2rem 2.4rem;
    display: block;
  }
  .p-news .news-itm .news-itm_link ._button {
    display: none;
  }
}

.p-news .news-post {
  padding-top: 3rem;
}

@media screen and (max-width: 768px) {
  .p-news .news-post {
    padding-top: 1rem;
  }
}

.p-news .news-post .container {
  max-width: 103rem;
}

.p-news .news-post .news-post_head {
  padding-bottom: 4rem;
  margin-bottom: 6rem;
  border-bottom: 0.1rem solid #333333;
}

@media screen and (max-width: 768px) {
  .p-news .news-post .news-post_head {
    padding-bottom: 2.8rem;
    margin-bottom: 4rem;
  }
}

.p-news .news-post .news-post_title {
  font-size: 3.4rem;
  font-weight: 500;
  line-height: 1.588;
  margin-bottom: 2.5rem;
}

@media screen and (max-width: 768px) {
  .p-news .news-post .news-post_title {
    font-size: 2.6rem;
    line-height: 1.4615;
    margin-bottom: 1.8rem;
  }
}

.p-news .news-post .news-post_date {
  display: inline-block;
  color: #63AFB4;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1;
  font-family: "Elms Sans", sans-serif;
}

@media screen and (max-width: 768px) {
  .p-news .news-post .news-post_date {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 768px) {
  .p-flow .p-title {
    margin-top: 0;
  }
}

.p-flow .p-title ._flex {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  text-align: center;
}

.p-flow .p-title .c-lbl {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin: auto;
}

@media screen and (max-width: 768px) {
  .p-flow .p-title .c-lbl {
    font-size: 1.4rem;
    padding: 0.5rem 1.4rem;
    margin-bottom: 0.6rem;
    margin-top: 0.7rem;
  }
}

.p-flow .p-flow_concept {
  padding: 5rem 0 7rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept {
    padding: 3rem 0 5rem;
  }
}

.p-flow .p-flow_concept .flow-concept_img {
  text-align: center;
  margin-top: 5rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-concept_img {
    margin-top: 3rem;
  }
}

.p-flow .p-flow_concept .flow-consult {
  margin-top: 10rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult {
    margin-top: 5rem;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: 1;
  text-align: center;
  margin-bottom: 4rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_ttl {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-bottom: 2rem;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_wrap {
  max-width: 106.5rem;
  margin: 0 auto;
  padding: 4rem;
  background-color: #D5EEF0;
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_wrap {
    padding: 3rem 2rem;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
  margin-top: 2rem;
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cta li {
  width: 40rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_cta {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 2rem 0;
  }
  .p-flow .p-flow_concept .flow-consult .flow-consult_cta li {
    width: 100%;
  }
  .p-flow .p-flow_concept .flow-consult .flow-consult_cta li .c-btn {
    margin-top: 0;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cpy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 3rem;
  -moz-column-gap: 3rem;
  column-gap: 3rem;
  margin-top: 3.3rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_cpy {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 1.5rem 0;
    margin-top: 2.4rem;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cpy .txt-large {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.6667;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_cpy .txt-large {
    font-size: 1.8rem;
    line-height: 1.556;
    text-align: center;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 0.4rem;
  -moz-column-gap: 0.4rem;
  column-gap: 0.4rem;
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta .tel img {
  display: inline-block;
  width: 2.9rem;
  height: auto;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta .tel img {
    width: 2.3rem;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta .tel span {
  display: inline-block;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1;
  font-style: italic;
  font-family: "Elms Sans", sans-serif;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta .tel span {
    font-size: 2.8rem;
    text-decoration: underline;
  }
}

.p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta .sch {
  display: inline-block;
  margin: 1rem 0 0 3.7rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .flow-consult_cpy ._cta .sch {
    font-size: 1.4rem;
    margin: 1.4rem 0 0 2.4rem;
  }
}

.p-flow .p-flow_concept .flow-consult .pos1-1 {
  width: 17.1rem;
  left: 1.7rem;
  top: -9.6rem;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .pos1-1 {
    width: 3rem;
    left: 1.5rem;
    top: -6.7rem;
    z-index: 1;
  }
}

.p-flow .p-flow_concept .flow-consult .pos1-2 {
  width: 3.7rem;
  left: 4.3rem;
  top: -1.6rem;
}

.p-flow .p-flow_concept .flow-consult .pos2 {
  width: 22.2rem;
  right: -4.9rem;
  top: -12.1rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_concept .flow-consult .pos2 {
    width: 4rem;
    right: 0.8rem;
    top: -6.6rem;
  }
}

.p-flow .p-flow_step {
  padding: 11rem 0;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step {
    padding: 5rem 0 7rem;
  }
}

@media screen and (min-width: 769px) {
  .p-flow .p-flow_step .container {
    position: relative;
  }
  .p-flow .p-flow_step .container::after {
    position: absolute;
    content: '';
    width: 0.1rem;
    height: 100%;
    left: 50%;
    top: 0;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #333333;
  }
}

.p-flow .p-flow_step .flow-step {
  background-color: #F9FAFB;
  padding: 6rem;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 7.6rem;
  -moz-column-gap: 7.6rem;
  column-gap: 7.6rem;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 2rem;
    padding: 0 2rem 2rem;
  }
}

.p-flow .p-flow_step .flow-step .flow-step_ctn {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

@media screen and (min-width: 769px) {
  .p-flow .p-flow_step .flow-step .flow-step_img {
    width: 38.3rem;
  }
}

.p-flow .p-flow_step .flow-step .flow-step_head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 2.4rem;
  -moz-column-gap: 2.4rem;
  column-gap: 2.4rem;
  margin: -6rem 0 3rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step .flow-step_head {
    margin: 0 0 2rem 0;
    -webkit-column-gap: 2rem;
    -moz-column-gap: 2rem;
    column-gap: 2rem;
  }
}

.p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_icon {
  width: 8.8rem;
  height: 11.2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #63AFB4;
  font-weight: 500;
  font-family: "Alkatra", system-ui;
  background: url(../img/flow/step_bg.png) left top no-repeat;
  background-size: cover;
  padding-bottom: 0.8rem;
}

.p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_icon .txt {
  display: inline-block;
  font-size: 2rem;
}

.p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_icon .num {
  display: inline-block;
  font-size: 4.2rem;
  line-height: 1;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_icon {
    width: 6.2rem;
    height: 8.4rem;
    background: url(../img/flow/step_bg_sp.png) left top no-repeat;
    background-size: cover;
  }
  .p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_icon .txt {
    font-size: 1.4rem;
  }
  .p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_icon .num {
    font-size: 2.8rem;
  }
}

.p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_ttl {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.25;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_ttl {
    font-size: 1.8rem;
    line-height: 1.66667;
    margin-top: 0.5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    row-gap: 0.6rem;
  }
}

.p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_note {
  display: inline-block;
  padding: 1rem 1.6rem;
  border-radius: 2.4rem;
  background-color: #63AFB4;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
  margin-left: 2rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step .flow-step_head .flow-step_head_note {
    font-size: 1.4rem;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    margin-top: 0;
    margin-left: 0;
  }
}

.p-flow .p-flow_step .flow-step .note {
  font-size: 1.4rem;
  line-height: 180%;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step .note {
    font-size: 1.2rem;
    margin-top: 1rem;
  }
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step .c-txt {
    font-size: 1.4rem;
    line-height: 1.857;
  }
}

.p-flow .p-flow_step .flow-step + .flow-step {
  margin-top: 6.2rem;
}

@media screen and (max-width: 768px) {
  .p-flow .p-flow_step .flow-step + .flow-step {
    margin-top: 2rem;
  }
}

/** home
======================================= **/
.p-faq {
  padding-bottom: 12rem;
}

@media screen and (max-width: 768px) {
  .p-faq {
    padding-bottom: 7rem;
  }
  .p-faq .p-title {
    margin-bottom: 5rem;
  }
}

.p-faq .faq-cats {
  background-color: #D5EEF0;
}

@media screen and (min-width: 769px) {
  .p-faq .faq-cats {
    position: -webkit-sticky;
    position: sticky;
    top: 9rem;
    padding: 4rem 3rem 5rem;
  }
}

@media screen and (max-width: 768px) {
  .p-faq .faq-cats {
    padding: 3rem 2.5rem;
  }
}

.p-faq .faq-cats .faq-cats_ttl {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1;
  font-family: "Alkatra", system-ui;
  padding-bottom: 1.2rem;
  border-bottom: 0.1rem solid #333333;
}

@media screen and (max-width: 768px) {
  .p-faq .faq-cats .faq-cats_ttl {
    font-size: 2rem;
    padding-bottom: 1rem;
  }
}

.p-faq .faq-cats .faq-cats_list {
  padding: 3rem 1rem 0;
}

@media screen and (max-width: 768px) {
  .p-faq .faq-cats .faq-cats_list {
    padding: 2rem 0.5rem 0;
  }
}

.p-faq .faq-cats .faq-cats_list li a {
  display: inline-block;
  position: relative;
}

.p-faq .faq-cats .faq-cats_list li a::before {
  position: absolute;
  content: '';
  width: 1.4rem;
  height: 1.1rem;
  right: -3.2rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/common/icon_btn_black.svg) left top no-repeat;
  background-size: cover;
}

@media screen and (max-width: 768px) {
  .p-faq .faq-cats .faq-cats_list li a {
    font-size: 1.6rem;
    line-height: calc(18/16);
  }
  .p-faq .faq-cats .faq-cats_list li a::before {
    -webkit-transform: translateY(-50%) rotate(90deg);
    transform: translateY(-50%) rotate(90deg);
  }
}

.p-faq .faq-cats .faq-cats_list li + li {
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .p-faq .faq-cats .faq-cats_list li + li {
    margin-top: 2rem;
  }
}

.p-faq .faq-sc {
  padding: 4rem;
  background-color: #F9FAFB;
}

@media screen and (max-width: 768px) {
  .p-faq .faq-sc {
    padding: 3rem 2rem;
    margin: 0 -2rem;
  }
}

.p-faq .faq-sc .faq-sc_title {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1;
  padding-bottom: 2rem;
  margin-bottom: 1rem;
  border-bottom: 0.1rem dashed #333333;
}

@media screen and (max-width: 768px) {
  .p-faq .faq-sc .faq-sc_title {
    font-size: 2rem;
    line-height: calc(26/14);
    text-align: center;
  }
}

.p-faq .faq-sc + .faq-sc {
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .p-faq .faq-sc + .faq-sc {
    margin-top: 3rem;
  }
}

.backtop {
  display: inline-block;
  width: 4rem;
  position: fixed;
  right: 2rem;
  bottom: 8rem;
  z-index: 5;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  cursor: pointer;
}

.backtop.is-show {
  opacity: 1;
  visibility: visible;
}

@media screen and (min-width: 769px) {
  .backtop {
    display: none !important;
  }
}

/** home
======================================= **/
.p-company {
  overflow: hidden;
}

.p-company .p-company_greeting {
  padding: 12rem 0;
  margin-top: 7rem;
  background-color: #D5EEF0;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_greeting {
    padding: 8.6rem 0 14.4rem;
  }
}

.p-company .p-company_greeting .container {
  position: relative;
  max-width: 117.6rem;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_greeting .c-title {
    margin-bottom: 6rem;
  }
}

@media screen and (min-width: 769px) {
  .p-company .p-company_greeting .greeting-ctn {
    width: 85.4rem;
    margin-left: auto;
  }
}

.p-company .p-company_greeting .greeting-ctn p + p {
  margin-top: 4rem;
}

.p-company .p-company_greeting .greeting-ctn p.name {
  text-align: right;
  font-size: 2rem;
  line-height: 180%;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_greeting .greeting-ctn p.name {
    font-size: 1.6rem;
  }
}

.p-company .p-company_greeting .greeting-ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: calc(59/40);
  margin-bottom: 6rem;
}

.p-company .p-company_greeting .greeting-ttl span {
  display: inline-block;
  position: relative;
  z-index: 1;
}

.p-company .p-company_greeting .greeting-ttl span::after {
  position: absolute;
  content: '';
  left: 0;
  bottom: 0.8rem;
  width: 100%;
  height: 0.7rem;
  background-color: #fff;
  z-index: -1;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_greeting .greeting-ttl {
    font-size: 2.8rem;
    line-height: calc(44/24);
    margin-bottom: 5rem;
  }
}

.p-company .p-company_greeting .pos1 {
  width: 32.9rem;
  top: -17rem;
  right: -6.4rem;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_greeting .pos1 {
    width: 25.5rem;
    top: -6rem;
    right: -6.7rem;
  }
}

.p-company .p-company_greeting .pos2 {
  width: 12.5rem;
  bottom: -6.2rem;
  left: 8.3rem;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_greeting .pos2 {
    width: 9.5rem;
    bottom: -10.5rem;
    left: 5.5rem;
  }
}

.p-company .p-company_outline {
  padding: 12rem 0;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_outline {
    padding: 10rem 0 12rem;
  }
  .p-company .p-company_outline .c-title {
    margin-bottom: 3rem;
  }
}

@media screen and (min-width: 769px) {
  .p-company .p-company_outline .outline-ctn {
    width: 85.4rem;
    margin-left: auto;
  }
}

.p-company .p-company_outline .container {
  max-width: 117.6rem;
}

.p-company .p-company_outline .outline-art {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 2.5rem 1rem;
  border-bottom: 0.1rem solid #A9AFBA;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_outline .outline-art {
    padding: 2.9rem 0;
    font-size: 1.4rem;
    line-height: 180%;
  }
}

.p-company .p-company_outline .outline-art .outline-art_ttl {
  width: 19.8rem;
}

@media screen and (max-width: 768px) {
  .p-company .p-company_outline .outline-art .outline-art_ttl {
    width: 13rem;
  }
}

.p-company .p-company_outline .outline-art .outline-art_ttl span {
  display: inline-block;
  padding-left: 2.1rem;
  position: relative;
}

.p-company .p-company_outline .outline-art .outline-art_ttl span::before {
  position: absolute;
  content: '';
  width: 0.6rem;
  height: 0.6rem;
  background-color: #FFE100;
  border: 0.1rem solid #333333;
  border-radius: 50%;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.p-company .p-company_outline .outline-art .outline-art_txt {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.p-privacy .p-privacy_content {
  padding: 2rem 0 12rem;
}

@media screen and (max-width: 768px) {
  .p-privacy .p-privacy_content {
    padding: 0 0 7rem;
  }
}

.p-privacy .p-privacy_content .container {
  max-width: 83rem;
}

.p-privacy .p-privacy_content h2 {
  font-size: 2.4rem;
  font-weight: 500;
  margin: 4rem 0 2rem;
}

@media screen and (max-width: 768px) {
  .p-privacy .p-privacy_content h2 {
    font-size: 1.8rem;
    margin: 3rem 0 1rem;
  }
}

.p-privacy .p-privacy_content ul, .p-privacy .p-privacy_content ol {
  padding-left: 2rem;
  margin: 4rem 0;
}

.p-privacy .p-privacy_content ul li, .p-privacy .p-privacy_content ol li {
  font-size: 1.6rem;
  line-height: 180%;
}

.p-privacy .p-privacy_content ul li {
  list-style: disc;
}

.p-privacy .p-privacy_content ol li {
  list-style: decimal;
}

.p-privacy .p-privacy_content p {
  font-size: 1.6rem;
  line-height: 180%;
}

.p-privacy .p-privacy_content p + p {
  margin-top: 4rem;
}

@media screen and (max-width: 768px) {
  .p-privacy .p-privacy_content p {
    line-height: 1.875;
  }
  .p-privacy .p-privacy_content p + p {
    margin-top: 3rem;
  }
}

/** home
======================================= **/
.p-recruit {
  padding-bottom: 10rem;
}

.p-recruit_intro {
  text-align: center;
  padding: 10rem 0 18rem;
  margin-bottom: 5rem;
  background: url(../img/recruit/intro_bg_pc.png) left top no-repeat;
  background-size: cover;
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-recruit_intro {
    padding: 3rem 0 4.6rem;
    background: url(../img/recruit/intro_bg_sp.png) left top no-repeat;
    background-size: cover;
  }
}

.p-recruit_intro .recruit-intro_ttl {
  font-size: 4.8rem;
  font-weight: 500;
  line-height: 180%;
  margin-bottom: 5rem;
}

@media screen and (max-width: 768px) {
  .p-recruit_intro .recruit-intro_ttl {
    font-size: 2.4rem;
    line-height: calc(38/24);
    margin-bottom: 3rem;
  }
}

.p-recruit_intro .recruit-intro_ctn {
  font-size: 1.8rem;
  line-height: calc(34/18);
}

.p-recruit_intro .recruit-intro_ctn p + p {
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .p-recruit_intro .recruit-intro_ctn {
    font-size: 1.6rem;
    line-height: 1.875;
  }
  .p-recruit_intro .recruit-intro_ctn p + p {
    margin-top: 2.5rem;
  }
}

.p-recruit_intro .pos1 {
  width: 20.1rem;
  left: 8.2rem;
  top: 26.8rem;
}

.p-recruit_intro .pos2 {
  width: 30.9rem;
  left: 0;
  bottom: 11.1rem;
}

.p-recruit_intro .pos3 {
  width: 28.3rem;
  right: 2.3rem;
  top: 13.7rem;
}

.p-recruit_intro .pos4 {
  width: 22.7rem;
  right: 9.5rem;
  bottom: 24.5rem;
}

@media screen and (max-width: 768px) {
  .p-recruit_intro .c-absolute {
    display: none;
  }
}

@media screen and (max-width: 768px) {
  .p-recruit_requirements .p-title {
    margin-bottom: 4rem;
  }
}

.c-anchor {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 6.4rem;
}

@media screen and (max-width: 768px) {
  .c-anchor {
    display: block;
    margin-bottom: 3rem;
  }
}

.c-anchor .c-anchor_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (min-width: 769px) {
  .c-anchor .c-anchor_list {
    border-radius: 1.2rem;
    border: 0.1rem solid #63AFB4;
  }
}

@media screen and (max-width: 768px) {
  .c-anchor .c-anchor_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    border: none;
    row-gap: 1.5rem;
  }
}

.c-anchor .c-anchor_list .c-anchor_itm {
  width: 28rem;
  height: 8rem;
}

@media screen and (max-width: 768px) {
  .c-anchor .c-anchor_list .c-anchor_itm {
    width: 100%;
    height: 5rem;
  }
}

@media screen and (min-width: 769px) {
  .c-anchor .c-anchor_list .c-anchor_itm:first-of-type .c-anchor_itm_link {
    border-radius: 1.2rem 0 0 1.2rem;
  }
  .c-anchor .c-anchor_list .c-anchor_itm:last-of-type .c-anchor_itm_link {
    border-radius: 0 1.2rem 1.2rem 0;
  }
}

@media screen and (min-width: 769px) {
  .c-anchor .c-anchor_list .c-anchor_itm:not(:last-child) {
    border-right: 0.1rem solid #63AFB4;
  }
}

.c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: relative;
}

@media screen and (min-width: 769px) {
  .c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link::after {
    position: absolute;
    content: '';
    width: 2.3rem;
    height: 2.3rem;
    left: 50%;
    bottom: -1.15rem;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-image: url(../img/common/anchor_arrow.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    z-index: -1;
  }
}

.c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link:hover, .c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link.active {
  opacity: 1;
  background-color: #63AFB4;
  color: #fff;
}

@media screen and (min-width: 769px) {
  .c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link:hover::after, .c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link.active::after {
    opacity: 1;
    visibility: visible;
  }
}

.c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link:hover .ico img,
.c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link:hover .ico svg, .c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link.active .ico img,
.c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link.active .ico svg {
  -webkit-filter: brightness(0) invert(1);
  filter: brightness(0) invert(1);
}

@media screen and (max-width: 768px) {
  .c-anchor .c-anchor_list .c-anchor_itm .c-anchor_itm_link {
    border-radius: 1.2rem;
    border: 0.1rem solid #63AFB4;
  }
}

.c-anchor .c-anchor_list .c-anchor_itm .txt {
  display: inline-block;
  font-size: 1.8rem;
}

.c-anchor .c-anchor_list .c-anchor_itm .ico {
  display: inline-block;
  width: 1.5rem;
  height: 1.1rem;
  position: absolute;
  right: 3rem;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(90deg);
  transform: translateY(-50%) rotate(90deg);
}

.c-anchor .c-anchor_list .c-anchor_itm .ico img,
.c-anchor .c-anchor_list .c-anchor_itm .ico svg {
  display: block;
  width: 100%;
  height: auto;
}

@media screen and (max-width: 768px) {
  .c-anchor .c-anchor_list .c-anchor_itm .ico {
    right: 1.8rem;
  }
}

.requirements-article {
  background-color: #F9FAFB;
  padding: 6rem 13rem 9rem;
}

@media screen and (max-width: 768px) {
  .requirements-article {
    padding: 4rem 2rem;
    margin-left: -2rem;
    margin-right: -2rem;
  }
}

.requirements-article + .requirements-article {
  margin-top: 4rem;
}

.requirements-article .requirements-article_ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 2rem 0;
  margin-bottom: 7rem;
}

@media screen and (max-width: 768px) {
  .requirements-article .requirements-article_ttl {
    row-gap: 1.6rem;
    margin-bottom: 3rem;
  }
}

.requirements-article .requirements-article_ttl .lbl {
  display: inline-block;
  padding: 0.5rem 1.5rem;
  background-color: #fff;
  border: 0.2rem solid #63AFB4;
  color: #63AFB4;
  font-size: 2.2rem;
  line-height: calc(25/22);
  font-weight: 500;
  -webkit-box-shadow: 0.2rem 0.2rem 0 0 #63AFB4;
  box-shadow: 0.2rem 0.2rem 0 0 #63AFB4;
}

@media screen and (max-width: 768px) {
  .requirements-article .requirements-article_ttl .lbl {
    font-size: 1.6rem;
    line-height: calc(25/16);
    padding: 0.4rem 2rem;
  }
}

.requirements-article .requirements-article_ttl .ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: 140%;
}

@media screen and (max-width: 768px) {
  .requirements-article .requirements-article_ttl .ttl {
    font-size: 2.4rem;
    line-height: calc(30/24);
  }
}

.requirements-article .requirements-article_dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0 4rem;
}

@media screen and (max-width: 768px) {
  .requirements-article .requirements-article_dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: 1.2rem 0;
    border-bottom: 0.1rem solid #A9AFBA;
    padding: 0 0 1.2rem 0;
  }
  .requirements-article .requirements-article_dl + .requirements-article_dl {
    margin-top: 2rem;
  }
}

.requirements-article .requirements-article_dl:first-of-type .requirements-article_dd {
  border-top: none;
  padding-top: 0;
}

.requirements-article .requirements-article_dl .requirements-article_dt {
  width: 16.8rem;
  height: 3.6rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background-color: #63AFB4;
  border-radius: 8rem;
  line-height: 1;
  font-weight: 500;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .requirements-article .requirements-article_dl .requirements-article_dt {
    font-size: 1.4rem;
    padding: 0.6rem 1.7rem;
    width: auto;
    display: inline-block;
    height: auto;
    line-height: calc(16/14);
  }
}

.requirements-article .requirements-article_dl .requirements-article_dd {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  line-height: 180%;
  padding: 2rem 0;
  border-top: 0.1rem solid #A9AFBA;
  border-bottom: 0.1rem solid #A9AFBA;
}

@media screen and (max-width: 768px) {
  .requirements-article .requirements-article_dl .requirements-article_dd {
    font-size: 1.4rem;
    padding: 0 0 0 1.7rem;
    border-top: none;
    border-bottom: none;
  }
}

.p-recruit_cta {
  padding: 10rem 1.5rem 0;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta {
    padding: 4rem 2rem 0;
  }
  .p-recruit_cta .c-btn {
    margin-top: 1.5rem;
  }
}

.p-recruit_cta .recruit-cta_box {
  max-width: 94rem;
  margin: 0 auto;
  background-color: #D5EEF0;
  -webkit-box-shadow: 4px 4px 0 0 #63afb4;
  box-shadow: 4px 4px 0 0 #63afb4;
  text-align: center;
  position: relative;
}

.p-recruit_cta .recruit-cta_box::before, .p-recruit_cta .recruit-cta_box::after {
  position: absolute;
  content: '';
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  top: 2.5rem;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box::before, .p-recruit_cta .recruit-cta_box::after {
    width: 0.8rem;
    height: 0.8rem;
    top: 1.4rem;
  }
}

.p-recruit_cta .recruit-cta_box::before {
  left: 3rem;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box::before {
    left: 1.4rem;
  }
}

.p-recruit_cta .recruit-cta_box::after {
  right: 3rem;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box::after {
    right: 1.4rem;
  }
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_inner {
  padding: 4.6rem 4rem 6.4rem;
  position: relative;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box .recruit-cta_box_inner {
    padding: 3.3rem 2rem 4rem;
  }
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::before, .p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::after {
  position: absolute;
  content: '';
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  bottom: 2.5rem;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::before, .p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::after {
    width: 0.8rem;
    height: 0.8rem;
    bottom: 1.4rem;
  }
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::before {
  left: 3rem;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::before {
    left: 1.4rem;
  }
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::after {
  right: 3rem;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box .recruit-cta_box_inner::after {
    right: 1.4rem;
  }
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl {
  font-size: 4rem;
  font-weight: 500;
  line-height: 160%;
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl {
    font-size: 2rem;
    line-height: 140%;
  }
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span {
  display: inline-block;
  padding: 0 8.5rem;
  position: relative;
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span::before, .p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span::after {
  position: absolute;
  content: '';
  width: 2.8rem;
  height: 8.7rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  background: url(../img/recruit/splash.svg) left top no-repeat;
  background-size: cover;
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span::before {
  left: 0;
}

.p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span::after {
  right: 0;
  -webkit-transform: translateY(-50%) scaleX(-1);
  transform: translateY(-50%) scaleX(-1);
}

@media screen and (max-width: 768px) {
  .p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span {
    padding: 0 2.6rem;
  }
  .p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span::before, .p-recruit_cta .recruit-cta_box .recruit-cta_box_ttl span::after {
    width: 1rem;
    height: 3rem;
    background: url(../img/recruit/splash_sp.svg) left top no-repeat;
    background-size: cover;
  }
}
