@charset "UTF-8";
html {
  -webkit-text-size-adjust: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -moz-tab-size: 4;
  -o-tab-size: 4;
     tab-size: 4;
  word-break: normal;
}

*,
:after,
:before {
  background-repeat: no-repeat;
  -webkit-box-sizing: inherit;
          box-sizing: inherit;
}

:after,
:before {
  text-decoration: inherit;
  vertical-align: inherit;
}

* {
  margin: 0;
  padding: 0;
}

hr {
  color: inherit;
  height: 0;
  overflow: visible;
}

details,
main {
  display: block;
}

summary {
  display: list-item;
}

small {
  font-size: 80%;
}

[hidden] {
  display: none;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

a {
  background-color: transparent;
}

a:active,
a:hover {
  outline-width: 0;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
}

pre {
  font-size: 1em;
}

b,
strong {
  font-weight: bolder;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

table {
  border-color: inherit;
  text-indent: 0;
}

iframe {
  border-style: none;
}

input {
  border-radius: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

textarea {
  overflow: auto;
  resize: vertical;
}

button,
input,
optgroup,
select,
textarea {
  font: inherit;
}

optgroup {
  font-weight: 700;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

[role=button],
[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
  outline: 1px dotted ButtonText;
}

[type=reset],
[type=submit],
button,
html [type=button] {
  -webkit-appearance: button;
}

button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline-width: 0;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
}

select::-ms-expand {
  display: none;
}

select::-ms-value {
  color: currentColor;
}

legend {
  border: 0;
  color: inherit;
  display: table;
  max-width: 100%;
  white-space: normal;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  color: inherit;
  font: inherit;
}

[disabled] {
  cursor: default;
}

img {
  border-style: none;
}

progress {
  vertical-align: baseline;
}

[aria-busy=true] {
  cursor: progress;
}

[aria-controls] {
  cursor: pointer;
}

[aria-disabled=true] {
  cursor: default;
}

* {
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: justify;
  text-box: trim-both cap alphabetic;
  line-height: 1.6;
  letter-spacing: 0.05em;
}
@media print, screen and (min-width: 1280px) {
  * {
    line-height: 1.8;
  }
}

html {
  font-size: 56.5%;
  overflow-x: hidden;
}
@media print, screen and (min-width: 1024px) {
  html {
    font-size: 62.5%;
  }
}

body {
  position: relative;
  font-size: 1.6rem;
  overflow-x: hidden;
}

li {
  list-style: none;
}

a {
  display: block;
  width: 100%;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  text-decoration: none;
  -webkit-transition: 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
  transition: 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
}
a *, a::before, a::after {
  -webkit-transition: 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
  transition: 0.5s cubic-bezier(0.25, 0.8, 0.25, 1);
}
@media print, screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

address {
  font-style: normal;
}

span {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  text-align: inherit;
  line-height: inherit;
}

img,
iframe,
video {
  display: block;
  width: 100%;
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content;
  height: auto;
}

br.under480 {
  display: block;
}
@media print, screen and (min-width: 480px) {
  br.under480 {
    display: none;
  }
}
@media print, screen and (min-width: 768px) {
  br.under768 {
    display: none;
  }
}
br.over768 {
  display: none;
}
@media print, screen and (min-width: 768px) {
  br.over768 {
    display: block;
  }
}
br.between768-1024 {
  display: none;
}
@media print, screen and (min-width: 768px) {
  br.between768-1024 {
    display: block;
  }
}
@media print, screen and (min-width: 1024px) {
  br.between768-1024 {
    display: none;
  }
}
br.over1280 {
  display: none;
}
@media print, screen and (min-width: 1280px) {
  br.over1280 {
    display: block;
  }
}

.container {
  width: 100%;
  max-width: 1920px;
  margin: auto;
}

.inner {
  width: 90%;
  margin: auto;
}
@media print, screen and (min-width: 1024px) {
  .inner {
    padding-right: 4rem;
  }
}
@media print, screen and (min-width: 1600px) {
  .inner {
    padding-right: 0;
  }
}
.inner.max800 {
  max-width: 800px;
}
.inner.max1080 {
  max-width: 1080px;
}
.inner.max1200 {
  max-width: 1200px;
}
.inner.max1400 {
  max-width: 1400px;
}

header.top_section_title {
  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;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(2vw, 2rem) 0;
}
@media print, screen and (min-width: 768px) {
  header.top_section_title {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
header.top_section_title h2 {
  color: #1f2f54;
  font-size: clamp(2rem, 3.2vw, 3.2rem);
  font-weight: bold;
  line-height: 1;
  opacity: 0;
  -webkit-transform: translateX(2rem);
          transform: translateX(2rem);
  -webkit-transition: 1s;
  transition: 1s;
}
header.top_section_title span {
  color: #1f2f54;
  font-family: "Inter", sans-serif;
  font-size: clamp(2.8rem, 4.8vw, 4.8rem);
  font-weight: bold;
  line-height: 1;
  opacity: 0;
  -webkit-transform: translateX(-2rem);
          transform: translateX(-2rem);
  -webkit-transition: 1s;
  transition: 1s;
}
header.top_section_title span::first-letter {
  color: #0000d2;
}
header.top_section_title.is-active h2 {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition-delay: 0.25s;
          transition-delay: 0.25s;
}
header.top_section_title.is-active span {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

section.page_top {
  padding-top: clamp(5rem, 6vw, 10rem);
  background-color: #e3e5ea;
}
@media print, screen and (min-width: 768px) {
  section.page_top {
    padding-bottom: 0;
  }
}
section.page_top header.page_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  gap: clamp(2rem, 4vw, 4rem) 0;
}
section.page_top header.page_title h1 {
  color: #1f2f54;
  font-size: clamp(2rem, 2vw, 2.4rem);
  line-height: 1;
}
section.page_top header.page_title span {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #1f2f54;
  font-family: "Inter", sans-serif;
  font-size: clamp(2.4rem, 2.8vw, 4.8rem);
  font-weight: bold;
  line-height: 1;
}
section.page_top header.page_title span::first-letter {
  color: #0000d2;
}
section.page_top header.page_title span::after {
  content: "";
  width: 100vw;
  height: 0.1rem;
  background-color: #333;
  position: absolute;
  top: 50%;
  left: calc(100% + clamp(2rem, 4vw, 4rem));
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
section.page_top p.page_lead {
  margin-top: clamp(4rem, 5vw, 8rem);
  font-size: clamp(1.8rem, 1.8vw, 3.2rem);
  font-weight: bold;
}
section.page_top nav.breadcrumb {
  display: none;
}
@media print, screen and (min-width: 768px) {
  section.page_top nav.breadcrumb {
    display: block;
    margin-top: clamp(2rem, 4vw, 4rem);
    padding: 2rem 0;
  }
}
section.page_top nav.breadcrumb ol {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1em;
}
section.page_top nav.breadcrumb ol li {
  color: #1f2f54;
}
section.page_top nav.breadcrumb ol li:not(:last-of-type) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1em;
}
section.page_top nav.breadcrumb ol li:not(:last-of-type)::after {
  content: ">";
}
section.page_top nav.breadcrumb ol li a:hover {
  text-decoration: underline;
}
section.page_top .catch_area {
  margin-top: clamp(4rem, 5vw, 8rem);
  padding: clamp(4rem, 5vw, 8rem) 0;
  background: center/cover no-repeat;
}
@media print, screen and (min-width: 768px) {
  section.page_top .catch_area {
    margin-top: 0;
  }
}
@media print, screen and (min-width: 1024px) {
  section.page_top .catch_area {
    aspect-ratio: 1920/530;
    display: grid;
    place-items: center;
  }
}
section.page_top .catch_area.company {
  background-image: url(../img/company/catch_bg.webp);
}
section.page_top .catch_area.strength {
  background-image: url(../img/strength/catch_bg.webp);
}
section.page_top .catch_area.business {
  background-image: url(../img/business/catch_bg.webp);
}
section.page_top .catch_area.achievements {
  background-image: url(../img/achievements/catch_bg.webp);
}
section.page_top .catch_area.news {
  background-image: url(../img/news/catch_bg.webp);
}
section.page_top .catch_area.contact {
  background-image: url(../img/contact/catch_bg.webp);
}
section.page_top .catch_area.privacy {
  background-image: url(../img/privacy/catch_bg.webp);
}
section.page_top .catch_area.smp {
  background-image: url(../img/smp/catch_bg.webp);
}
section.page_top .catch_area.partners {
  background-image: url(../img/partners/catch_bg.webp);
}
section.page_top .catch_area.sitemap {
  background-image: url(../img/sitemap/catch_bg.webp);
}
section.page_top .catch_area.page404 {
  background-image: url(../img/page404/catch_bg.webp);
}
@media print, screen and (min-width: 1024px) {
  section.page_top .catch_area.news, section.page_top .catch_area.contact, section.page_top .catch_area.privacy, section.page_top .catch_area.smp, section.page_top .catch_area.partners, section.page_top .catch_area.sitemap, section.page_top .catch_area.page404 {
    aspect-ratio: 1920/320;
  }
}
section.page_top .catch_area p {
  margin: 0 auto;
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content;
  color: #fff;
}
@media print, screen and (min-width: 768px) {
  section.page_top .catch_area p {
    text-align: center;
  }
}

header.page_section_title {
  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;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(4vw, 2rem) 0;
}
header.page_section_title h2 {
  font-size: clamp(1.8rem, 1.8vw, 2.4rem);
  line-height: 1;
  opacity: 0;
  -webkit-transform: translateX(2rem);
          transform: translateX(2rem);
}
header.page_section_title h2.color_white {
  color: #fff;
}
header.page_section_title span {
  color: #1f2f54;
  font-family: "Inter", sans-serif;
  font-size: clamp(2.4rem, 2.8vw, 4.8rem);
  line-height: 1;
  opacity: 0;
  -webkit-transform: translateX(-2rem);
          transform: translateX(-2rem);
}
header.page_section_title span::first-letter {
  color: #0000d2;
}
header.page_section_title span.color_white {
  color: #fff;
}
header.page_section_title span.color_white::first-letter {
  color: #fff;
}
header.page_section_title.is-active h2 {
  -webkit-animation: fade 1s 0.25s forwards;
          animation: fade 1s 0.25s forwards;
}
header.page_section_title.is-active span {
  -webkit-animation: fade 1s forwards;
          animation: fade 1s forwards;
}

p.section_info {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(1.8rem, 1.8vw, 3.2rem);
  font-weight: bold;
}

.btn {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.btn a {
  width: min(80vw, 35rem);
  aspect-ratio: 350/120;
  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: 0 clamp(1.6rem, 3.2vw, 3.2rem);
  border-radius: 0.6rem;
}
.btn a span.arrow {
  height: 3em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: grid;
  place-items: center;
}
.btn a span.arrow::before {
  content: "";
  width: 40%;
  aspect-ratio: 13/7;
  -webkit-mask: url(../img/btn_arrow.svg) center/contain no-repeat;
          mask: url(../img/btn_arrow.svg) center/contain no-repeat;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.btn.color_navy a {
  background-color: #1f2f54;
}
.btn.color_navy a p {
  color: #fff;
}
.btn.color_navy a p span {
  border-bottom: 0.1rem solid #fff;
}
.btn.color_navy a span.arrow {
  background-color: #fff;
  border: 0.1rem solid #fff;
}
.btn.color_navy a span.arrow::before {
  background-color: #0000d2;
}
.btn.color_navy a:hover span.arrow {
  background-color: #1f2f54;
}
.btn.color_navy a:hover span.arrow::before {
  background-color: #fff;
}
.btn.color_white a {
  background-color: #fff;
}
.btn.color_white a p {
  color: #1f2f54;
}
.btn.color_white a p span {
  border-bottom: 0.1rem solid #1f2f54;
}
.btn.color_white a span.arrow {
  background-color: #0000d2;
  border: 0.1rem solid #0000d2;
}
.btn.color_white a span.arrow::before {
  background-color: #fff;
}
.btn.color_white a:hover span.arrow {
  background-color: #fff;
}
.btn.color_white a:hover span.arrow::before {
  background-color: #0000d2;
}
.btn.color_recruit a {
  background: -webkit-gradient(linear, left top, right top, from(#ffa63c), to(#ea5136));
  background: linear-gradient(to right, #ffa63c, #ea5136);
}
.btn.color_recruit a p {
  color: #fff;
}
.btn.color_recruit a p span {
  border-bottom: 0.1rem solid #fff;
}
.btn.color_recruit a span.arrow {
  background-color: #fff;
  border: 0.1rem solid #fff;
}
.btn.color_recruit a span.arrow::before {
  background-color: #0000d2;
}
.btn.color_recruit a:hover span.arrow {
  background-color: transparent;
}
.btn.color_recruit a:hover span.arrow::before {
  background-color: #fff;
}

.instagram_link {
  width: 100%;
  max-width: 34rem;
}
.instagram_link 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;
  gap: 0 2rem;
  background-color: #fff;
  border: 0.1rem solid #fff;
  border-radius: 1.6rem;
  padding: 2rem 0;
}
.instagram_link a span.icon.logo {
  width: 4.3rem;
  aspect-ratio: 1/1;
  background: url(../img/icon_logo.svg) center/contain no-repeat;
}
.instagram_link a span.icon.instagram {
  width: 3.2rem;
  aspect-ratio: 1/1;
  background: url(../img/icon_instagram.svg) center/contain no-repeat;
}
.instagram_link a p {
  color: #333;
  text-align: center;
}
.instagram_link a:hover {
  background-color: #1f2f54;
}
.instagram_link a:hover p {
  color: #fff;
}

#header {
  position: fixed;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  z-index: 9999999999;
  width: 100%;
  max-width: 1920px;
  height: 8rem;
  background: #fff;
  -webkit-box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
          box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}
#header .inner {
  width: 100%;
  height: 100%;
  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;
  gap: 0 5%;
  padding: 0 !important;
}
#header .header_logo {
  margin-left: clamp(2rem, 4vw, 4rem);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#header .header_logo a:hover {
  opacity: 0.5;
}
#header .header_logo a img {
  width: auto;
  height: 4rem;
}
@media print, screen and (min-width: 1024px) {
  #header .header_logo a img {
    height: min(4vw, 6.2rem);
  }
}
#header nav.header_nav {
  display: none;
}
@media print, screen and (min-width: 1024px) {
  #header nav.header_nav {
    display: block;
    height: 100%;
  }
}
#header nav.header_nav ul {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(2vw, 3rem);
}
#header nav.header_nav ul li a {
  position: relative;
  font-size: min(1.4vw, 1.6rem);
  line-height: 1;
}
#header nav.header_nav ul li a:not(.nav_contact)::before {
  content: "";
  width: 100%;
  height: 0.2rem;
  background-color: #0000d2;
  border-radius: 9999px;
  position: absolute;
  top: calc(100% + 0.75rem);
  left: 0;
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
  -webkit-transform-origin: left;
          transform-origin: left;
}
#header nav.header_nav ul li a:not(.nav_contact):hover::before {
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
}
#header nav.header_nav ul li.contact {
  -ms-flex-item-align: stretch;
      align-self: stretch;
  margin-left: min(2.5vw, 4rem);
}
#header nav.header_nav ul li.contact a {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
  color: #fff;
  font-size: 1.8rem;
  background-color: #0000d2;
  border: 0.1rem solid #0000d2;
  padding: 0 clamp(3rem, 4vw, 6rem);
}
@media print, screen and (min-width: 1024px) {
  #header nav.header_nav ul li.contact a {
    font-size: min(1.5vw, 1.8rem);
  }
}
#header nav.header_nav ul li.contact a::after {
  content: "";
  width: 3rem;
  aspect-ratio: 30/24;
  -webkit-mask: url(../img/icon_mail.svg) center/contain no-repeat;
          mask: url(../img/icon_mail.svg) center/contain no-repeat;
  background-color: #fff;
}
#header nav.header_nav ul li.contact a:hover {
  color: #0000d2;
  background-color: #fff;
}
#header nav.header_nav ul li.contact a:hover::after {
  background-color: #0000d2;
}
#header button.hamburger {
  position: relative;
  margin-right: clamp(2rem, 4vw, 4rem);
  display: block;
  width: 4rem;
  height: 100%;
}
@media print, screen and (min-width: 1024px) {
  #header button.hamburger {
    display: none;
  }
}
#header button.hamburger span {
  display: block;
  width: 100%;
  height: 0.2rem;
  background-color: #0000d2;
  border-radius: 9999px;
  position: absolute;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#header button.hamburger span:nth-of-type(1) {
  top: 50%;
}
#header button.hamburger span:nth-of-type(2) {
  top: calc(50% - 1rem);
}
#header button.hamburger span:nth-of-type(3) {
  top: calc(50% + 1rem);
}
#header button.hamburger.active span:nth-of-type(1) {
  opacity: 0;
}
#header button.hamburger.active span:nth-of-type(2) {
  top: 50%;
  -webkit-transform: translate(0, -50%) rotate(45deg);
          transform: translate(0, -50%) rotate(45deg);
}
#header button.hamburger.active span:nth-of-type(3) {
  top: 50%;
  -webkit-transform: translate(0, -50%) rotate(-45deg);
          transform: translate(0, -50%) rotate(-45deg);
}
#header .overlay {
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  height: calc(100dvh - 8rem);
  background-color: rgba(0, 0, 210, 0.95);
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateX(100vw);
          transform: translateX(100vw);
  -webkit-transition: 0.5s;
  transition: 0.5s;
  overflow-y: scroll;
}
#header .overlay.active {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
#header nav.sp_nav {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 4rem 8rem;
  padding: clamp(4rem, 5vw, 8rem) clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #header nav.sp_nav {
    grid-template-columns: repeat(3, auto);
    place-items: flex-start;
  }
}
@media print, screen and (min-width: 768px) {
  #header nav.sp_nav ul.main_link {
    width: 100%;
  }
}
#header nav.sp_nav ul.main_link > li + li {
  margin-top: clamp(4rem, 5vw, 8rem);
}
#header nav.sp_nav ul.main_link > li > a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
}
#header nav.sp_nav ul.main_link > li > a::before {
  content: "";
  width: 0.2rem;
  height: 1.5em;
  background-color: #fff;
  border-radius: 9999px;
  position: absolute;
  top: 50%;
  left: -1rem;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  opacity: 0;
}
#header nav.sp_nav ul.main_link > li > a.nav_recruit::after {
  content: "";
  width: 0.7em;
  aspect-ratio: 1/1;
  -webkit-mask: url(../img/icon_window.svg) center/contain no-repeat;
          mask: url(../img/icon_window.svg) center/contain no-repeat;
  background-color: #fff;
}
#header nav.sp_nav ul.sub_link {
  margin-top: 1.2em;
}
#header nav.sp_nav ul.sub_link li + li {
  margin-top: 1.2em;
}
#header nav.sp_nav ul.sub_link li a {
  color: #fff;
}
#header nav.sp_nav ul.sub_link li a::before {
  content: ">";
  margin-right: 1rem;
}
#header .recruit_btn {
  display: none;
}
@media print, screen and (min-width: 1024px) {
  #header .recruit_btn {
    display: block;
    width: min(5vw, 9.5rem);
    position: absolute;
    top: 50vh;
    right: 1rem;
    -webkit-transform: translate(0, -50%) !important;
            transform: translate(0, -50%) !important;
    opacity: 0;
    -webkit-animation: fade 1s 3s forwards;
            animation: fade 1s 3s forwards;
  }
}
#header .recruit_btn a {
  position: relative;
  border-radius: 2.25vw;
  overflow: hidden;
}
#header .recruit_btn a::before {
  content: "";
  width: 100%;
  height: 100%;
  background: linear-gradient(-50deg, transparent 30%, rgba(255, 255, 255, 0.8) 50%, transparent 70%);
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#header .recruit_btn a:hover::before {
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
}

section.footer-contact {
  background-color: #d6d9e0;
  padding: clamp(6rem, 8vw, 15rem) 0;
}
@media print, screen and (min-width: 768px) {
  section.footer-contact {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
@media print, screen and (min-width: 768px) {
  section.footer-contact header.top_section_title {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
section.footer-contact header.top_section_title span i {
  display: inline-block;
  margin-left: 1rem;
  font-size: clamp(2.8rem, 2.8vw, 4.8rem);
  height: 1em;
  aspect-ratio: 30/24;
  -webkit-mask: url(../img/icon_mail.svg) center/contain no-repeat;
          mask: url(../img/icon_mail.svg) center/contain no-repeat;
  background-color: #1f2f54;
  position: relative;
  top: 0.1em;
}
section.footer-contact .btn_area {
  margin-top: clamp(5rem, 6vw, 10rem);
}
section.footer-contact hr {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
  max-width: 93rem;
}
section.footer-contact .tel_area {
  margin-top: clamp(5rem, 6vw, 10rem);
  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;
  gap: 1rem;
}
section.footer-contact .tel_area p.number a {
  color: #0000d2;
  font-size: 3.2rem;
}
section.footer-contact p.lead {
  margin: 4rem auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 480px) {
  section.footer-contact p.lead {
    text-align: center;
  }
}
section.footer-contact .instagram_link {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
}

#footer {
  padding-top: clamp(6rem, 8vw, 15rem);
  background-color: #1a1a1a;
}
#footer * {
  color: #fff;
}
@media print, screen and (min-width: 768px) {
  #footer .inner {
    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;
    gap: clamp(4rem, 5vw, 8rem) 0;
  }
}
@media print, screen and (min-width: 1024px) {
  #footer .inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0 clamp(6rem, 8vw, 15rem);
  }
}
@media print, screen and (min-width: 1280px) {
  #footer .inner {
    gap: 0 8rem;
  }
}
#footer .area-left {
  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;
  gap: 4rem 0;
}
@media print, screen and (min-width: 1024px) {
  #footer .area-left {
    width: 35%;
    max-width: 40rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}
@media print, screen and (min-width: 1280px) {
  #footer .area-left {
    width: 30%;
  }
}
#footer .area-left p.logo {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  width: 100%;
}
#footer .area-left p.logo a {
  width: 100%;
  aspect-ratio: 423/96;
  display: grid;
  place-items: center;
  background-color: #fff;
  padding: 0 2rem;
}
#footer .area-left p.logo a:hover {
  opacity: 0.5;
}
#footer .area-left p.logo a img {
  max-width: none;
}
#footer .area-left ul.address_list li + li {
  margin-top: 4rem;
}
#footer .area-left ul.address_list li address {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1em;
}
#footer .area-left ul.address_list li address p.name::before {
  content: "[";
  margin-right: 0.25rem;
}
#footer .area-left ul.address_list li address p.name::after {
  content: "]";
  margin-left: 0.25rem;
}
#footer .area-left ul.address_list li address p.address {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1em;
}
#footer .area-left ul.address_list li address p.number {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1em;
}
#footer .area-right {
  display: none;
}
@media print, screen and (min-width: 768px) {
  #footer .area-right {
    display: block;
  }
}
@media print, screen and (min-width: 1024px) {
  #footer .area-right {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    max-width: -webkit-fit-content;
    max-width: -moz-fit-content;
    max-width: fit-content;
  }
}
#footer .area-right nav.footer_nav {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#footer .area-right nav.footer_nav ul {
  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;
}
#footer .area-right nav.footer_nav ul li a:not(.nav_recruit) {
  text-underline-offset: 0.3em;
}
#footer .area-right nav.footer_nav ul li a:not(.nav_recruit):hover {
  text-decoration: underline;
}
#footer .area-right nav.footer_nav ul.group01 {
  gap: clamp(1.6rem, 3.2vw, 3.2rem);
}
@media print, screen and (min-width: 1024px) {
  #footer .area-right nav.footer_nav ul.group01 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
  }
}
@media print, screen and (min-width: 1280px) {
  #footer .area-right nav.footer_nav ul.group01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    gap: 0 min(1.65vw, 3.2rem);
  }
}
@media print, screen and (min-width: 1400px) {
  #footer .area-right nav.footer_nav ul.group01 {
    margin-left: min(1.25vw, 2rem);
  }
}
@media print, screen and (min-width: 1280px) {
  #footer .area-right nav.footer_nav ul.group01 li.recruit {
    margin-left: min(2.65vw, 5rem);
  }
}
#footer .area-right nav.footer_nav ul.group01 li a {
  position: relative;
  white-space: nowrap;
}
#footer .area-right nav.footer_nav ul.group01 li a.nav_recruit {
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
  background: -webkit-gradient(linear, left top, right top, from(#ffa63c), to(#ea5136));
  background: linear-gradient(to right, #ffa63c, #ea5136);
  padding: 1em min(1.5vw, 1.5em);
}
#footer .area-right nav.footer_nav ul.group01 li a.nav_recruit:hover {
  opacity: 0.5;
}
#footer .area-right nav.footer_nav ul.group02 {
  margin-top: clamp(5rem, 6vw, 10rem);
}
@media print, screen and (min-width: 1024px) {
  #footer .area-right nav.footer_nav ul.group02 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(1.6rem, 3.2vw, 3.2rem) 0;
  }
}
@media print, screen and (min-width: 1280px) {
  #footer .area-right nav.footer_nav ul.group02 {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media print, screen and (min-width: 1400px) {
  #footer .area-right nav.footer_nav ul.group02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
#footer .area-right nav.footer_nav ul.group02 li {
  position: relative;
}
#footer .area-right nav.footer_nav ul.group02 li::before {
  content: "";
  width: 0.1rem;
  height: 1.2em;
  background: #fff;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
@media print, screen and (min-width: 1400px) {
  #footer .area-right nav.footer_nav ul.group02 li:first-of-type::before {
    content: none;
  }
}
#footer .area-right nav.footer_nav ul.group02 li:last-of-type::after {
  content: "";
  width: 0.1rem;
  height: 1.2em;
  background: #fff;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
@media print, screen and (min-width: 1024px) {
  #footer .area-right nav.footer_nav ul.group02 li:last-of-type::after {
    content: none;
  }
}
#footer .area-right nav.footer_nav ul.group02 li a {
  padding: 0 min(1.25vw, 2rem);
}
@media print, screen and (min-width: 1400px) {
  #footer .area-right nav.footer_nav ul.group02 li a {
    font-size: min(1vw, 1.6rem);
  }
}
#footer .to-top {
  position: fixed;
  right: min(4vw, 2.5rem);
  bottom: min(4vw, 2.5rem);
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(20rem);
          transform: translateY(20rem);
  -webkit-transition: 1s;
  transition: 1s;
}
#footer .to-top.active {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
#footer .to-top a {
  position: relative;
  width: clamp(4rem, 4vw, 6.4rem);
  aspect-ratio: 1/1;
  background-color: #808080;
}
#footer .to-top a::before {
  content: "";
  width: 35%;
  aspect-ratio: 1/1;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
  top: 45%;
  left: 50%;
  -webkit-transform: translate(-50%, 0) rotate(-45deg);
          transform: translate(-50%, 0) rotate(-45deg);
}
#footer small.copyright {
  margin-top: clamp(6rem, 8vw, 15rem);
  display: block;
  font-size: 1.2rem;
  text-align: center;
  padding: 1em;
  background-color: #0000d2;
}

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

@keyframes zoom {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@-webkit-keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}
@keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}
@-webkit-keyframes rotation {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes rotation {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
#page_top #header .overlay a.nav_top::before {
  opacity: 1;
}
#page_top main {
  padding-top: 0 !important;
}
#page_top .circle_link {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#page_top .circle_link a {
  position: relative;
  width: 14rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  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: #f7931e;
}
#page_top .circle_link a span {
  margin-top: 0.75em;
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: 0;
}
#page_top .circle_link a::before {
  content: "";
  width: 100%;
  height: 100%;
  -webkit-mask: url(../img/top/circle_bg.webp) center/contain no-repeat;
          mask: url(../img/top/circle_bg.webp) center/contain no-repeat;
  background-color: #fff;
  -webkit-animation: rotation 10s linear infinite;
          animation: rotation 10s linear infinite;
  position: absolute;
  top: 0;
  left: 0;
}
#page_top .circle_link a:hover {
  color: #fff;
}
#page_top .circle_link a:hover::before {
  background-color: #f7931e;
}
#page_top section.mv {
  position: relative;
}
#page_top section.mv .swiper_container {
  position: relative;
}
#page_top section.mv .swiper_container .swiper-slide img {
  height: 100dvh;
  -o-object-fit: cover;
     object-fit: cover;
}
@media print, screen and (min-width: 768px) {
  #page_top section.mv .swiper_container .swiper-slide img {
    aspect-ratio: 1920/928;
    height: min(65vw, 92.5rem);
  }
}
#page_top section.mv .swiper_container .swiper-slide img.slide01 {
  -o-object-position: 45%;
     object-position: 45%;
}
#page_top section.mv .swiper_container .swiper-slide img.slide02 {
  -o-object-position: 50%;
     object-position: 50%;
}
#page_top section.mv .swiper_container .swiper-slide img.slide03 {
  -o-object-position: 25%;
     object-position: 25%;
}
#page_top section.mv .swiper_container .swiper-slide-active img, #page_top section.mv .swiper_container .swiper-slide-prev img {
  -webkit-animation: zoom 8s linear forwards;
          animation: zoom 8s linear forwards;
}
#page_top section.mv .inner {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  z-index: 10;
  height: 100%;
  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: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
}
@media print, screen and (min-width: 768px) {
  #page_top section.mv .inner {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
#page_top section.mv header.catch {
  margin-top: calc(clamp(5rem, 6vw, 10rem) + 6rem);
}
@media print, screen and (min-width: 768px) {
  #page_top section.mv header.catch {
    margin-top: 16rem;
  }
}
#page_top section.mv header.catch h2,
#page_top section.mv header.catch h3 {
  color: #fff;
  font-weight: bold;
  opacity: 0;
  -webkit-transform: translateX(2.5rem);
          transform: translateX(2.5rem);
  -webkit-animation: fade 1s forwards;
          animation: fade 1s forwards;
}
#page_top section.mv header.catch h2 {
  font-size: clamp(2.6rem, 6.4vw, 6.4rem);
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}
#page_top section.mv header.catch h3 {
  margin-top: 2.5rem;
  font-size: clamp(2rem, 3.2vw, 3.2rem);
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}
#page_top section.mv span.en_catch {
  margin-bottom: clamp(5rem, 6vw, 10rem);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
  color: #fff;
  font-family: "Inter", sans-serif;
  font-size: clamp(2.4rem, 6vw, 11.2rem);
  font-weight: bold;
  text-align: center;
  line-height: 1.2;
  text-shadow: 0.4rem 0.4rem 0.2rem rgba(0, 0, 0, 0.5);
  opacity: 0;
  -webkit-transform: translateY(2rem);
          transform: translateY(2rem);
  -webkit-animation: fade 1s 3s forwards;
          animation: fade 1s 3s forwards;
}
@media print, screen and (min-width: 768px) {
  #page_top section.mv span.en_catch {
    margin-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
    font-size: min(4.5vw, 8rem);
  }
}
#page_top section.mv .circle_link {
  opacity: 0;
  -webkit-animation: fade 1s 3s forwards;
          animation: fade 1s 3s forwards;
}
@media print, screen and (min-width: 768px) {
  #page_top section.mv .circle_link {
    position: absolute;
    top: 20rem;
    right: 0;
  }
}
#page_top section.mv button.youtube {
  position: relative;
  z-index: 100;
  margin: 4rem auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 2rem;
  color: #fff;
  font-size: 1.8rem;
  text-align: center;
  line-height: 1.4;
  background: -webkit-gradient(linear, left top, right top, from(#161573), color-stop(#2352a2), color-stop(#3173b9), color-stop(#81b5e1), to(#85cee8));
  background: linear-gradient(to right, #161573, #2352a2, #3173b9, #81b5e1, #85cee8);
  border-radius: 1rem;
  padding: 2.5rem 4rem;
  overflow: hidden;
  opacity: 0;
  -webkit-animation: fade 1s 3s forwards;
          animation: fade 1s 3s forwards;
}
@media print, screen and (min-width: 768px) {
  #page_top section.mv button.youtube {
    position: absolute;
    right: 0;
    bottom: clamp(2rem, 4vw, 4rem);
    font-size: min(2vw, 2.4rem);
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
  }
}
#page_top section.mv button.youtube::before {
  content: "";
  width: 100%;
  height: 100%;
  background: linear-gradient(-50deg, transparent 30%, rgba(255, 255, 255, 0.8) 50%, transparent 70%);
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page_top section.mv button.youtube:hover::before {
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
}
#page_top section.mv button.youtube .icon {
  width: 5rem;
  aspect-ratio: 1/1;
  background: url(../img/icon_logo.svg) center/contain no-repeat;
}
#page_top section.mv .modal_area {
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 99999;
  width: 100dvw;
  height: calc(100dvh - 6rem);
  background-color: rgba(0, 0, 0, 0.7);
  display: grid;
  place-items: center;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page_top section.mv .modal_area.active {
  opacity: 1;
  visibility: visible;
}
#page_top section.mv .modal_area figure {
  width: 90%;
  max-width: 800px;
  background-color: #fff;
  padding: clamp(2rem, 4vw, 4rem);
}
#page_top section.mv .modal_area figure iframe {
  max-width: none;
  aspect-ratio: 560/315;
}
#page_top section.mv .modal_area .close_btn {
  position: absolute;
  top: 5vw;
  right: 5vw;
  width: 4rem;
  aspect-ratio: 1/1;
}
#page_top section.mv .modal_area .close_btn span {
  display: block;
  width: 4rem;
  height: 2px;
  background-color: #fff;
  border-radius: 9999px;
  position: absolute;
  top: 50%;
  left: 50%;
}
#page_top section.mv .modal_area .close_btn span:nth-of-type(1) {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
#page_top section.mv .modal_area .close_btn span:nth-of-type(2) {
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}
#page_top section.news {
  padding: clamp(4rem, 5vw, 8rem) 0 clamp(5rem, 6vw, 10rem);
  background-color: #b3b3b3;
}
#page_top section.news header.top_section_title span {
  color: #8f9499;
}
#page_top section.news ul.news_list {
  margin-top: 4rem;
  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;
  background-color: #fff;
  padding: 2rem 0 clamp(2rem, 4vw, 4rem);
}
#page_top section.news ul.news_list li {
  width: 90%;
  max-width: 975px;
  border-bottom: 0.1rem solid #4d4d4d;
}
#page_top section.news ul.news_list li:nth-of-type(n + 4) {
  display: none;
}
#page_top section.news ul.news_list li a {
  padding: clamp(2rem, 4vw, 4rem) 0;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.news ul.news_list li a {
    padding: clamp(2rem, 4vw, 4rem);
  }
}
#page_top section.news ul.news_list li a:hover {
  background-color: rgba(8, 116, 220, 0.1);
}
#page_top section.news ul.news_list li article {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1em 1.5em;
}
#page_top section.news ul.news_list li article .meta_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1.5em;
}
#page_top section.news ul.news_list li article .meta_area span.category {
  width: 10rem;
  color: #fff;
  text-align: center;
  border-radius: 9999px;
  padding: 0.3em 0;
}
#page_top section.news ul.news_list li article .meta_area span.category.news {
  background-color: #0874dc;
}
#page_top section.news ul.news_list li article .meta_area span.category.recruit {
  background-color: #f68f43;
}
#page_top section.news ul.news_list li article .meta_area span.category.update {
  background-color: #1f2f54;
}
#page_top section.news ul.news_list li article .title_area {
  width: 100%;
}
#page_top section.news ul.news_list li article .title_area h3.title {
  text-decoration: underline;
}
@media print, screen and (min-width: 768px) {
  #page_top section.news ul.news_list li article .title_area h3.title {
    width: auto;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media print, screen and (min-width: 1024px) {
  #page_top section.news ul.news_list li article .title_area h3.title {
    text-decoration: none;
  }
}
#page_top section.news ul.news_list li article .title_area h3.title.pdf {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding-right: 3em;
}
#page_top section.news ul.news_list li article .title_area h3.title.pdf::after {
  content: "";
  height: 2.5em;
  aspect-ratio: 4/5;
  -webkit-mask: url(../img/icon_pdf.svg) center/contain no-repeat;
          mask: url(../img/icon_pdf.svg) center/contain no-repeat;
  background-color: #333;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
#page_top section.news .btn_area {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page_top section.company {
  padding: clamp(4rem, 5vw, 8rem) 0;
  background: url(../img/top/company_bg.webp) center/cover no-repeat;
}
@media print, screen and (min-width: 1280px) {
  #page_top section.company {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0;
  }
}
#page_top section.company header.top_section_title h2,
#page_top section.company header.top_section_title span {
  color: #fff;
}
#page_top section.company .flex {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media print, screen and (min-width: 768px) {
  #page_top section.company .flex {
    position: relative;
  }
}
#page_top section.company .flex h3 {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin-top: clamp(4rem, 5vw, 8rem);
  color: #fff;
  font-size: clamp(2.2rem, 6vw, 6rem);
  font-weight: bold;
  text-align: left;
  text-shadow: 0.7rem 0.7rem 0.5rem rgba(0, 0, 0, 0.5);
}
#page_top section.company .flex h3 span {
  margin-top: 4rem;
  font-family: "Inter", sans-serif;
  font-size: clamp(2.4rem, 6vw, 11.2rem);
  font-weight: bold;
  text-shadow: 0.7rem 0.7rem 0.5rem rgba(0, 0, 0, 0.5);
  line-height: 1.2;
}
#page_top section.company .flex p {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  color: #fff;
  font-size: 1.8rem;
  text-shadow: 0.7rem 0.7rem 0.5rem rgba(0, 0, 0, 0.5);
}
@media print, screen and (min-width: 768px) {
  #page_top section.company .flex p {
    width: 60%;
    max-width: 575px;
  }
}
#page_top section.company .flex .circle_link {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  margin-top: 4rem;
}
@media print, screen and (min-width: 768px) {
  #page_top section.company .flex .circle_link {
    margin: 0;
    position: absolute;
    top: 0;
    right: 0;
  }
}
#page_top section.strength {
  padding: clamp(5rem, 6vw, 10rem) 0 0;
  background-color: #e6e5e2;
}
@media print, screen and (min-width: 768px) {
  #page_top section.strength {
    padding-bottom: clamp(5rem, 6vw, 10rem);
  }
}
#page_top section.strength .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#page_top section.strength .text_area {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.strength .text_area {
    width: 50%;
    padding-right: clamp(6rem, 7vw, 12rem);
  }
}
#page_top section.strength .text_area p {
  margin-top: clamp(4rem, 5vw, 8rem);
  font-size: 1.8rem;
}
#page_top section.strength .text_area ul.strength_list {
  margin-top: 2.5rem;
}
#page_top section.strength .text_area ul.strength_list li {
  position: relative;
}
#page_top section.strength .text_area ul.strength_list li::before {
  content: "";
  width: 100vw;
  height: 100%;
  background-color: #0000d2;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media print, screen and (min-width: 1024px) {
  #page_top section.strength .text_area ul.strength_list li::before {
    left: auto;
    right: 0;
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}
#page_top section.strength .text_area ul.strength_list li + li {
  margin-top: 1rem;
}
#page_top section.strength .text_area ul.strength_list li span {
  display: block;
  position: relative;
  z-index: 10;
  color: #fff;
  font-size: clamp(2rem, 2.4vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  line-height: 1;
  padding: 0.75em 0;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.strength .text_area ul.strength_list li span {
    margin-left: auto;
    width: 15em;
    text-align: left;
    padding-right: 1em;
  }
}
#page_top section.strength .text_area ul.strength_list li span::before {
  content: "・";
}
#page_top section.strength .image_area {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  position: relative;
  margin-top: 4rem;
  width: 100%;
  aspect-ratio: 962/765;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.strength .image_area {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin: 0;
    margin-right: calc(50% - 50vw);
    width: 50%;
    aspect-ratio: unset;
  }
}
#page_top section.strength .image_area img {
  max-width: none;
  width: 100vw;
  position: absolute;
  top: 0.1rem;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media print, screen and (min-width: 1024px) {
  #page_top section.strength .image_area img {
    width: 100%;
    left: 0;
    -webkit-transform: translate(0);
            transform: translate(0);
  }
}
#page_top section.strength .btn_area {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin-top: clamp(5rem, 6vw, 10rem);
}
@media print, screen and (min-width: 768px) {
  #page_top section.strength .btn_area {
    width: 100%;
  }
}
@media print, screen and (min-width: 1024px) {
  #page_top section.strength .btn_area .btn {
    margin: 0;
  }
}
#page_top section.business {
  background: url(../img/top/business_bg.webp) center/cover no-repeat;
}
@media print, screen and (min-width: 768px) {
  #page_top section.business .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
}
#page_top section.business .text_area {
  padding: clamp(4rem, 5vw, 8rem) 0;
}
@media print, screen and (min-width: 768px) {
  #page_top section.business .text_area {
    width: 50%;
    padding-right: clamp(3rem, 4vw, 6rem);
  }
}
#page_top section.business .text_area header.top_section_title h2 {
  color: #fff;
}
#page_top section.business .text_area header.top_section_title span {
  color: #ccc;
}
#page_top section.business .text_area ul.link_list {
  margin-top: clamp(4rem, 5vw, 8rem);
}
#page_top section.business .text_area ul.link_list li {
  border-bottom: 0.2rem solid #fff;
}
#page_top section.business .text_area ul.link_list li + li {
  margin-top: clamp(2rem, 4vw, 4rem);
}
#page_top section.business .text_area ul.link_list li a {
  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;
  color: #fff;
  font-size: clamp(2rem, 3.2vw, 3.2rem);
  padding-bottom: 0.5em;
}
#page_top section.business .text_area ul.link_list li a span {
  width: min(8vw, 4.8rem);
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background-color: #fff;
  border: 0.1rem solid #fff;
}
#page_top section.business .text_area ul.link_list li a span::before {
  content: "";
  width: 40%;
  aspect-ratio: 13/7;
  -webkit-mask: url(../img/btn_arrow.svg) center/contain no-repeat;
          mask: url(../img/btn_arrow.svg) center/contain no-repeat;
  background-color: #0000d2;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page_top section.business .text_area ul.link_list li a:hover span {
  background-color: transparent;
}
#page_top section.business .text_area ul.link_list li a:hover span::before {
  background-color: #fff;
}
#page_top section.business .text_area .btn_area {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page_top section.business .slider-area {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.5rem;
}
@media print, screen and (min-width: 768px) {
  #page_top section.business .slider-area {
    width: 50%;
    margin-left: 0;
    padding-left: clamp(3rem, 4vw, 6rem);
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    height: 100%;
  }
}
#page_top section.business .slider-area .swiper-container {
  pointer-events: none;
}
@media print, screen and (min-width: 768px) {
  #page_top section.business .slider-area .swiper-container {
    width: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 100%;
  }
}
#page_top section.business .slider-area .swiper-container .swiper {
  height: 100%;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media print, screen and (min-width: 768px) {
  #page_top section.business .slider-area .swiper-container .swiper {
    height: 100vh;
    max-height: 650px;
  }
}
@media print, screen and (min-width: 1024px) {
  #page_top section.business .slider-area .swiper-container .swiper {
    max-height: min(70vw, 845px);
  }
}
#page_top section.business .slider-area .swiper-container .swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
  height: 100%;
}
#page_top section.business .slider-area .swiper-container .swiper-slide {
  aspect-ratio: 10/8;
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  #page_top section.business .slider-area .swiper-container .swiper-slide {
    aspect-ratio: unset;
  }
}
#page_top section.business .slider-area .swiper-container .swiper-slide img {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media print, screen and (min-width: 768px) {
  #page_top section.business .slider-area .swiper-container .swiper-slide img {
    height: auto;
  }
}
#page_top section.achievements {
  position: relative;
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page_top section.achievements {
    padding-top: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page_top section.achievements::before {
  content: "";
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(55%, transparent), color-stop(55%, #1f2f54));
  background: linear-gradient(to bottom, transparent 55%, #1f2f54 55%);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -10;
}
#page_top section.achievements ul.link_list {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  place-items: center;
  gap: 2rem 1rem;
}
@media print, screen and (min-width: 768px) {
  #page_top section.achievements ul.link_list {
    grid-template-columns: repeat(3, 1fr);
  }
}
#page_top section.achievements ul.link_list li {
  width: 100%;
  max-width: 45.5rem;
}
#page_top section.achievements ul.link_list li a {
  position: relative;
  width: 100%;
  aspect-ratio: 456/209;
  color: #fff;
  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;
  font-size: 2.4rem;
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  #page_top section.achievements ul.link_list li a {
    aspect-ratio: 456/418;
  }
}
#page_top section.achievements ul.link_list li a::before {
  content: "";
  width: 100%;
  height: 100%;
  background: center/cover no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
#page_top section.achievements ul.link_list li a:hover::before {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-filter: brightness(1.3);
          filter: brightness(1.3);
}
#page_top section.achievements ul.link_list li a.bg01::before {
  background-image: url(../img/top/achievement_img01.webp);
}
#page_top section.achievements ul.link_list li a.bg02::before {
  background-image: url(../img/top/achievement_img02.webp);
}
#page_top section.achievements ul.link_list li a.bg03::before {
  background-image: url(../img/top/achievement_img03.webp);
}
#page_top section.achievements ul.link_list li a span {
  font-size: 1.8rem;
}
#page_top section.achievements .btn_area {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page_top section.awards {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page_top section.awards {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page_top section.awards .flex {
  margin-top: clamp(3rem, 4vw, 6rem);
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  place-items: center;
  gap: 4rem 0;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.awards .flex {
    grid-template-columns: repeat(2, 1fr);
    place-items: unset;
  }
}
#page_top section.awards .image_area {
  width: 100%;
  max-width: 62.5rem;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.awards .text_area {
    padding-left: clamp(3rem, 4vw, 6rem);
  }
}
#page_top section.awards .text_area h3 {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #1f2f54;
  font-size: 2.4rem;
  font-weight: bold;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.awards .text_area h3 {
    margin: 0;
  }
}
#page_top section.awards .text_area > p {
  margin: 4rem auto 0;
  max-width: 55rem;
  font-size: 1.8rem;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.awards .text_area > p {
    margin: 4rem 0 0;
  }
}
#page_top section.awards .btn_area {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: clamp(5rem, 6vw, 10rem) 4rem;
}
@media print, screen and (min-width: 1024px) {
  #page_top section.awards .btn_area .btn {
    margin: 0;
  }
}
#page_top section.recruit {
  padding: clamp(5rem, 6vw, 10rem) 0;
  background: url(../img/top/recruit_bg.webp) center/cover no-repeat;
}
@media print, screen and (min-width: 1280px) {
  #page_top section.recruit {
    padding-top: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page_top section.recruit header.top_section_title h2,
#page_top section.recruit header.top_section_title span {
  color: #fff;
}
#page_top section.recruit .inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media print, screen and (min-width: 768px) {
  #page_top section.recruit .inner {
    position: relative;
  }
}
@media print, screen and (min-width: 1280px) {
  #page_top section.recruit .inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 0 clamp(4rem, 5vw, 8rem);
  }
}
#page_top section.recruit .text_area {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}
@media print, screen and (min-width: 1280px) {
  #page_top section.recruit .text_area {
    width: 75%;
  }
}
#page_top section.recruit .text_area h3 {
  margin-top: clamp(4rem, 5vw, 8rem);
  color: #fff;
  font-size: clamp(2.2rem, 4vw, 6rem);
  font-weight: bold;
  text-shadow: 0.7rem 0.7rem 0.5rem rgba(0, 0, 0, 0.5);
}
#page_top section.recruit .text_area .flex {
  margin-top: clamp(4rem, 5vw, 8rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4rem 0;
}
@media print, screen and (min-width: 768px) {
  #page_top section.recruit .text_area .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 0 clamp(4rem, 5vw, 8rem);
  }
}
#page_top section.recruit .text_area .flex > p {
  color: #fff;
  font-size: 1.8rem;
  text-shadow: 0.7rem 0.7rem 0.5rem rgba(0, 0, 0, 0.5);
}
@media print, screen and (min-width: 768px) {
  #page_top section.recruit .text_area .flex > p {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page_top section.recruit .text_area .flex .instagram_link {
  margin: 0 auto;
}
#page_top section.recruit .image_area {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  margin: 4rem auto 0;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  place-items: center;
  gap: 2rem clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page_top section.recruit .image_area {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media print, screen and (min-width: 1280px) {
  #page_top section.recruit .image_area {
    grid-template-columns: repeat(1, 1fr);
    margin-right: -8vw;
  }
}
#page_top section.recruit .circle_link {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin-top: 4rem;
}
@media print, screen and (min-width: 768px) {
  #page_top section.recruit .circle_link {
    margin-top: 0;
    position: absolute;
    top: 0;
    right: 0;
  }
}

#page-company #header nav.header_nav a.nav_company::before {
  opacity: 1;
  -webkit-transform: scale(1);
          transform: scale(1);
}
#page-company #header .overlay a.nav_company::before {
  opacity: 1;
}
#page-company #footer nav.footer_nav a.nav_company {
  text-decoration: underline;
}
#page-company section.greetings {
  padding: clamp(6rem, 7vw, 12rem) 0;
  background: url(../img/company/greeting_bg.webp) center/cover no-repeat;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.greetings {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0 clamp(5rem, 6vw, 10rem);
  }
}
#page-company section.greetings .flex {
  margin-top: clamp(5rem, 6vw, 10rem);
  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;
  gap: 4rem;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greetings .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0 clamp(6rem, 8vw, 15rem);
  }
}
#page-company section.greetings .flex .area-image {
  width: 100%;
  max-width: 47.5rem;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greetings .flex .area-image {
    width: 40%;
  }
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greetings .flex .area-text {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.greetings .flex .area-text * {
  color: #fff;
}
#page-company section.greetings .flex .area-text h3 {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(2rem, 3.2vw, 3.2rem);
  font-weight: bold;
  text-align: center;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greetings .flex .area-text h3 {
    margin: 0;
    text-align: left;
  }
}
#page-company section.greetings .flex .area-text h3 span {
  display: inline-block;
}
#page-company section.greetings .flex .area-text p.message {
  margin-top: 4rem;
}
#page-company section.greetings .flex .area-text p.message span {
  display: block;
  text-align: right;
}
#page-company section.greetings .flex .area-text p.ceo-name {
  margin: 4rem 0 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#page-company section.greetings .flex .area-text p.ceo-name img {
  margin-top: 0.5rem;
  height: 3rem;
}
#page-company section.policy {
  position: relative;
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #f2f2f2;
}
#page-company section.policy::after {
  content: "";
  width: 90%;
  max-width: 1400px;
  height: 0.1rem;
  background-color: #000;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media print, screen and (min-width: 1024px) {
  #page-company section.policy .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
}
@media print, screen and (min-width: 1024px) {
  #page-company section.policy header.page_section_title {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.policy ul {
  margin: 4rem auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.policy ul {
    margin: 0;
    width: 65%;
    max-width: 700px;
  }
}
#page-company section.policy ul li + li {
  margin-top: 2rem;
}
#page-company section.policy ul li dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media print, screen and (min-width: 480px) {
  #page-company section.policy ul li dl {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1em 0;
  }
}
@media print, screen and (min-width: 1024px) {
  #page-company section.policy ul li dl {
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
}
#page-company section.policy ul li dl dt {
  color: #0000d2;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
}
@media print, screen and (min-width: 480px) {
  #page-company section.policy ul li dl dt {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
#page-company section.policy ul li dl dt:not(:first-of-type) {
  margin-top: 1em;
}
@media print, screen and (min-width: 480px) {
  #page-company section.policy ul li dl dt:not(:first-of-type) {
    margin-top: 0;
  }
}
#page-company section.policy ul li dl dd {
  margin: 1em 0 0 1em;
  font-size: clamp(1.8rem, 2vw, 2.4rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media print, screen and (min-width: 480px) {
  #page-company section.policy ul li dl dd {
    margin: 0;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.policy ul li dl dd::before {
  content: "-";
  margin: 0 0.25em;
}
#page-company section.philosophy {
  position: relative;
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #f2f2f2;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.philosophy {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.philosophy::after {
  content: "";
  width: 90%;
  max-width: 1400px;
  height: 0.1rem;
  background-color: #000;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media print, screen and (min-width: 1024px) {
  #page-company section.philosophy .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
  }
}
@media print, screen and (min-width: 1024px) {
  #page-company section.philosophy header.page_section_title {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.philosophy .detail {
  margin: 4rem auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.philosophy .detail {
    margin: 0;
    width: 65%;
    max-width: 700px;
  }
}
#page-company section.philosophy .detail p {
  color: #1f2f54;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  font-weight: bold;
}
#page-company section.philosophy .detail ul {
  margin-top: clamp(2rem, 4vw, 4rem);
  counter-reset: item;
}
#page-company section.philosophy .detail ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 1.8rem;
}
#page-company section.philosophy .detail ul li + li {
  margin-top: 1.5rem;
}
#page-company section.philosophy .detail ul li::before {
  counter-increment: item;
  content: counter(item) ".";
  margin-right: 0.5em;
}
#page-company ul.anchor-link {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem 1rem;
}
@media print, screen and (min-width: 1024px) {
  #page-company ul.anchor-link {
    grid-template-columns: repeat(4, 1fr);
    gap: 2.5rem;
  }
}
#page-company ul.anchor-link li a {
  position: relative;
  color: #1f2f54;
  font-size: clamp(1.6rem, 1.6vw, 2rem);
  font-weight: bold;
  text-align: center;
  border: 0.1rem solid #1f2f54;
  padding: 1em 0;
}
#page-company ul.anchor-link li a::after {
  content: "";
  width: 0.6em;
  aspect-ratio: 1/1;
  border-right: 0.2rem solid #1f2f54;
  border-bottom: 0.2rem solid #1f2f54;
  position: absolute;
  top: 50%;
  right: min(4vw, 2rem);
  -webkit-transform: translate(0, -50%) rotate(45deg);
          transform: translate(0, -50%) rotate(45deg);
}
@media print, screen and (min-width: 1024px) {
  #page-company ul.anchor-link li a::after {
    content: none;
  }
}
#page-company ul.anchor-link li a:hover {
  color: #fff;
  background-color: #1f2f54;
}
#page-company ul.anchor-link li a:hover::after {
  border-color: #fff;
}
#page-company section.profile {
  padding-top: clamp(5rem, 6vw, 10rem);
}
@media print, screen and (min-width: 1280px) {
  #page-company section.profile {
    padding-bottom: clamp(4rem, 5vw, 8rem);
  }
}
#page-company section.profile .inner {
  max-width: 865px;
}
#page-company section.profile dl {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.8rem;
}
#page-company section.profile dl dt {
  width: 100%;
  background-color: #d6d9e0;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.profile dl dt {
    width: min(30vw, 30rem);
  }
}
#page-company section.profile dl dt span {
  margin: 0 auto;
  display: block;
  width: 7em;
  -moz-text-align-last: justify;
       text-align-last: justify;
}
#page-company section.profile dl dd {
  width: 100%;
  background-color: #f2f2f2;
}
#page-company section.profile dl dd:not(.no-space) {
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.profile dl dd {
    width: calc(100% - min(30vw, 30rem) - 0.8rem);
  }
}
#page-company section.profile dl dd ul.address_list li {
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
#page-company section.profile dl dd ul.address_list li:first-of-type {
  border-bottom: 0.8rem solid #fff;
}
#page-company section.profile dl dd ul.address_list li address {
  margin-top: 1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1em;
}
#page-company section.profile dl dd ul.address_list li address p.number {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1em;
}
#page-company section.profile dl dd ul.service_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1em 0;
}
#page-company section.profile dl dd ul.service_list li:not(:last-of-type)::after {
  content: "/";
  margin: 0 0.25em;
}
#page-company section.profile dl dd ul.partners_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1em 0;
}
#page-company section.iso {
  position: relative;
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.iso {
    padding: clamp(4rem, 5vw, 8rem) 0 calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.iso::after {
  content: "";
  width: 90%;
  max-width: 1400px;
  height: 0.1rem;
  background-color: #000;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
#page-company section.iso figure.image_area {
  margin-top: clamp(5rem, 6vw, 10rem);
  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;
  gap: clamp(5rem, 6vw, 10rem) 0;
}
#page-company section.iso figure.image_area a {
  position: relative;
}
#page-company section.iso figure.image_area a::before {
  content: "";
  width: 5rem;
  aspect-ratio: 1/1;
  background: url(../img/company/icon_glass.svg) center/3.5rem no-repeat #1a1a1a;
  position: absolute;
  right: 0;
  bottom: 0;
}
#page-company section.iso figure.image_area a:hover::before {
  background-color: #007aff;
}
#page-company section.iso figure.image_area img {
  max-width: 21.2rem;
}
#page-company section.iso figure.image_area figcaption {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.8rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.iso figure.image_area figcaption {
    text-align: center;
  }
}
#page-company section.history {
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #f2f2f2;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.history {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.history .inner {
  max-width: 865px;
}
#page-company section.history ol {
  margin-top: clamp(4rem, 5vw, 8rem);
}
#page-company section.history ol li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.8rem;
}
#page-company section.history ol li + li {
  margin-top: 0.8rem;
}
#page-company section.history ol li p.time {
  width: 100%;
  background-color: #d6d9e0;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.history ol li p.time {
    width: min(30vw, 30rem);
  }
}
#page-company section.history ol li p.event {
  width: 100%;
  background-color: #fff;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.history ol li p.event {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.organization {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.organization {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.organization figure {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: 100%;
  max-width: 765px;
  overflow-x: scroll;
}
@media print, screen and (min-width: 768px) {
  #page-company section.organization figure {
    overflow-x: auto;
  }
}
#page-company section.organization figure img {
  margin: 0 auto;
  width: 50rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.organization figure img {
    width: 100%;
  }
}
#page-company section.officer {
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #f2f2f2;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.officer {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.officer .inner {
  max-width: 670px;
}
#page-company section.officer .officer_list {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-company section.officer .officer_list dl {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 0.8rem;
}
#page-company section.officer .officer_list dl + dl {
  margin-top: 0.8rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.officer .officer_list dl {
    grid-template-columns: repeat(2, 1fr);
  }
}
#page-company section.officer .officer_list dl dt {
  background-color: #d6d9e0;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
#page-company section.officer .officer_list dl dd {
  background-color: #fff;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
#page-company section.qualified {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.qualified {
    padding-bottom: clamp(3rem, 4vw, 6rem);
  }
}
#page-company section.qualified .inner {
  max-width: 670px;
}
#page-company section.qualified ul {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-company section.qualified ul::after {
  content: "（2026年6月現在）";
  display: block;
  text-align: right;
  padding-right: clamp(3rem, 4vw, 6rem);
  margin-top: 1em;
}
#page-company section.qualified ul li {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
}
#page-company section.qualified ul li + li {
  margin-top: 0.8rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.qualified ul li {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 0.8rem;
  }
}
#page-company section.qualified ul li.border {
  position: relative;
}
#page-company section.qualified ul li.border::before {
  content: "";
  width: 105%;
  height: 0.1rem;
  background-color: #1a1a1a;
  position: absolute;
  top: -0.4rem;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
#page-company section.qualified ul li span.qualification {
  background-color: #d6d9e0;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.qualified ul li span.qualification {
    padding: 1.2em clamp(2rem, 4vw, 4rem);
  }
}
#page-company section.qualified ul li span.amount {
  background-color: #f2f2f2;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.qualified ul li span.amount {
    text-align: right;
    padding: 1.2em clamp(3rem, 4vw, 6rem);
  }
}
#page-company section.qualified .image_area {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1rem;
}
#page-company section.qualified .image_area img {
  width: calc((100% - 2rem) / 3);
}
@media print, screen and (min-width: 768px) {
  #page-company section.qualified .image_area img {
    width: calc((100% - 4rem) / 5);
  }
}
#page-company section.awards {
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #f2f2f2;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.awards {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-company section.awards .awards-detail {
  margin-top: clamp(5rem, 6vw, 10rem);
}
@media print, screen and (min-width: 1280px) {
  #page-company section.awards .awards-detail:not(:first-of-type) {
    margin-top: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-company section.awards .awards-detail h3 {
  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;
  gap: min(4vw, 2rem) 0;
  font-size: clamp(2rem, 2vw, 3.2rem);
  font-weight: bold;
  border-bottom: 0.1rem solid #1a1a1a;
  padding: 1em 0;
}
@media print, screen and (min-width: 768px) {
  #page-company section.awards .awards-detail h3 {
    -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;
    gap: 0 1em;
  }
}
#page-company section.awards .awards-detail h3 span {
  color: #0000d2;
}
#page-company section.awards .awards-detail h3 span a {
  text-decoration: underline;
}
#page-company section.awards .awards-detail h3 span a:hover {
  opacity: 0.5;
}
#page-company section.awards .awards-detail ul {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
  width: 100%;
  max-width: 860px;
}
#page-company section.awards .awards-detail ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.8rem;
}
#page-company section.awards .awards-detail ul li + li {
  margin-top: 0.8rem;
}
#page-company section.awards .awards-detail ul li p.when {
  width: 100%;
  background-color: #d6d9e0;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.awards .awards-detail ul li p.when {
    width: min(30vw, 30rem);
    padding: 1.2em clamp(3rem, 4vw, 6rem);
  }
}
#page-company section.awards .awards-detail ul li p.result {
  width: 100%;
  background-color: #fff;
  padding: 1.2em clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.awards .awards-detail ul li p.result {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.awards .awards-detail#awards03 ul::after {
  content: "※女子の部は第9回大会をもって終了";
  display: block;
  margin-top: 1em;
}
@media print, screen and (min-width: 768px) {
  #page-company section.awards .awards-detail#awards03 ul::after {
    padding-left: clamp(3rem, 4vw, 6rem);
  }
}
#page-company section.awards .competition-scene {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-company section.awards .competition-scene figure .images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.awards .competition-scene figure .images {
    grid-template-columns: repeat(4, 1fr);
  }
}
#page-company section.awards .competition-scene figure figcaption {
  margin: clamp(2rem, 4vw, 4rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#page-company section.awards .competition-scene .instagram_link {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
}
#page-company section.access {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.access {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.access ul.access_list {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-company section.access ul.access_list > li:not(:last-of-type) {
  padding-bottom: clamp(5rem, 6vw, 10rem);
  border-bottom: 0.1rem solid #000;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.access ul.access_list > li:not(:last-of-type) {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.access ul.access_list > li:not(:first-of-type) {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-company section.access ul.access_list > li .flex {
  margin: 0 auto;
  width: 100%;
  max-width: 1000px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 2rem clamp(2rem, 4vw, 4rem);
}
#page-company section.access ul.access_list > li .flex .area-address {
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  #page-company section.access ul.access_list > li .flex .area-address {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    -ms-flex-item-align: baseline;
        align-self: baseline;
    border-bottom: 0.1rem solid #000;
    padding-bottom: 4rem;
  }
}
#page-company section.access ul.access_list > li .flex .area-address > p {
  font-size: 2.4rem;
}
#page-company section.access ul.access_list > li .flex .area-address address {
  margin-top: 1.5em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1em;
}
#page-company section.access ul.access_list > li .flex .area-address address p.number {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1em;
}
#page-company section.access ul.access_list > li .flex .area-image {
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  #page-company section.access ul.access_list > li .flex .area-image {
    width: 50%;
  }
}
#page-company section.access ul.access_list > li .flex .area-map {
  width: 100%;
}
#page-company section.access ul.access_list > li .flex .area-map figure iframe {
  aspect-ratio: 1000/400;
  max-width: none;
  min-height: 40rem;
}
#page-company section.access ul.access_list > li ul.access-way {
  margin-top: clamp(4rem, 5vw, 8rem);
  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;
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #page-company section.access ul.access_list > li ul.access-way {
    margin-top: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-company section.access ul.access_list > li ul.access-way.justify-center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media print, screen and (min-width: 768px) {
  #page-company section.access ul.access_list > li ul.access-way li {
    width: calc((100% - 4rem) / 2);
  }
}
#page-company section.access ul.access_list > li ul.access-way li figure {
  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;
  gap: 1em 0;
}
#page-company section.access ul.access_list > li ul.access-way li figure figcaption {
  font-size: 1.8rem;
  text-align: center;
}

#page-strength #header nav.header_nav a.nav_strength::before {
  -webkit-transform: scale(1);
          transform: scale(1);
}
#page-strength #header .overlay a.nav_strength::before {
  opacity: 1;
}
#page-strength #footer nav.footer_nav a.nav_strength {
  text-decoration: underline;
}
#page-strength section.strength {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.strength {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0;
  }
}
#page-strength section.strength h3 {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(2.2rem, 3.2vw, 3.2rem);
  font-weight: bold;
  text-align: center;
}
#page-strength section.strength h3 span {
  color: #0000d2;
  padding: 0 0.25em;
}
#page-strength section.strength ul.strength_list {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-strength section.strength ul.strength_list > li + li {
  margin-top: clamp(5rem, 6vw, 10rem);
}
@media print, screen and (min-width: 768px) {
  #page-strength section.strength ul.strength_list > li + li {
    margin-top: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-strength section.strength ul.strength_list > li p.number {
  font-family: "Inter", sans-serif;
  font-size: clamp(1.6rem, 2.4vw, 2.4rem);
  font-weight: bold;
  line-height: 1;
  border-bottom: 0.1rem solid #0000d2;
  padding-bottom: clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.strength ul.strength_list > li p.number {
    padding-left: clamp(5rem, 6vw, 10rem);
  }
}
#page-strength section.strength ul.strength_list > li p.number::first-letter {
  color: #0000d2;
}
#page-strength section.strength ul.strength_list > li p.number span {
  color: #0000d2;
  font-size: clamp(2.4rem, 4.8vw, 4.8rem);
  padding-left: 0.25em;
}
#page-strength section.strength ul.strength_list > li .flex {
  margin-top: clamp(2rem, 4vw, 4rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem 0;
}
@media print, screen and (min-width: 768px) {
  #page-strength section.strength ul.strength_list > li .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 clamp(2rem, 4vw, 4rem);
  }
}
@media print, screen and (min-width: 768px) {
  #page-strength section.strength ul.strength_list > li .text_area {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.strength ul.strength_list > li .text_area {
    padding-left: clamp(5rem, 6vw, 10rem);
  }
}
#page-strength section.strength ul.strength_list > li .text_area .title {
  max-width: 56.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
#page-strength section.strength ul.strength_list > li .text_area .title h4 {
  width: 8em;
  color: #fff;
  font-size: clamp(1.8rem, 1.8vw, 2.4rem);
  font-weight: bold;
  background-color: #0000d2;
  padding: 1em 0.5em;
}
#page-strength section.strength ul.strength_list > li .text_area .title h4::before {
  content: "・";
}
#page-strength section.strength ul.strength_list > li .text_area .title span {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: grid;
  place-items: center left;
  color: #00357c;
  font-size: clamp(1.6rem, 1.6vw, 2rem);
  background-color: #e5e5fa;
  padding: 0 1em;
}
#page-strength section.strength ul.strength_list > li .text_area p {
  margin-top: clamp(2rem, 4vw, 4rem);
}
#page-strength section.strength ul.strength_list > li .text_area ul {
  margin-top: clamp(3rem, 4vw, 6rem);
}
#page-strength section.strength ul.strength_list > li .text_area ul li {
  font-size: clamp(1.6rem, 1.6vw, 2rem);
  line-height: 1;
}
#page-strength section.strength ul.strength_list > li .text_area ul li + li {
  margin-top: 1em;
}
#page-strength section.strength ul.strength_list > li .text_area ul li::before {
  content: "●";
}
@media print, screen and (min-width: 768px) {
  #page-strength section.strength ul.strength_list > li .image_area {
    width: 50%;
  }
}
#page-strength section.efforts {
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #f2f2f2;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.efforts {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-strength section.efforts h3 {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(2.4rem, 3.2vw, 3.2rem);
  font-weight: bold;
  text-align: center;
  border-bottom: 0.1rem solid #0000d2;
  padding: 0 1em 0.5em;
}
#page-strength section.efforts h3 span {
  color: #0000d2;
}
#page-strength section.efforts .flex {
  margin-top: clamp(5rem, 6vw, 10rem);
  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;
  gap: 4rem calc(2 * clamp(4rem, 5vw, 8rem));
}
@media print, screen and (min-width: 768px) {
  #page-strength section.efforts .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.efforts .flex {
    margin-top: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
@media print, screen and (min-width: 768px) {
  #page-strength section.efforts .image_area {
    width: 45%;
    max-width: 54rem;
  }
}
@media print, screen and (min-width: 768px) {
  #page-strength section.efforts .text_area {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-strength section.efforts .text_area p strong {
  display: block;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  margin-bottom: clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts .text_area p strong {
    margin-bottom: clamp(5rem, 6vw, 10rem);
  }
}
#page-strength section.efforts ul {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 4rem;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul {
    position: relative;
    width: 100%;
    max-width: 980px;
    aspect-ratio: 980/420;
    background: url(../img/strength/efforts_bg.webp) center/contain no-repeat;
  }
}
#page-strength section.efforts ul li {
  position: relative;
  width: 100%;
  max-width: 35rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul li {
    position: absolute;
    width: auto;
  }
}
#page-strength section.efforts ul li span.number {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 10rem;
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  font-size: 3.2rem;
  font-weight: 900;
  border: 1rem solid;
  border-radius: 50%;
  background-color: #fff;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul li span.number {
    position: absolute;
    opacity: 1;
    visibility: hidden;
  }
}
#page-strength section.efforts ul li dl {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background-color: #fff;
  border-radius: 9999px;
  border-top: 0.1rem solid #000;
  border-bottom: 0.1rem solid #000;
  border-right: 0.1rem dashed #000;
  border-left: none;
  padding: 1.5rem 0 1.5rem 12.5rem;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul li dl {
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
  }
}
#page-strength section.efforts ul li dl dt {
  font-size: clamp(1.8rem, 2.5vw, 2.5rem);
  line-height: 1;
}
#page-strength section.efforts ul li dl dd {
  margin-top: 2rem;
  font-size: clamp(1.6rem, 2vw, 2rem);
  line-height: 1.2;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul li:nth-of-type(1) {
    top: 12.5%;
    left: 23%;
  }
}
#page-strength section.efforts ul li:nth-of-type(1) span.number {
  color: #00dcb3;
  border-color: #00dcb3;
}
#page-strength section.efforts ul li:nth-of-type(1) dl dt {
  color: #00dcb3;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul li:nth-of-type(2) {
    top: 65%;
    left: 8%;
  }
}
#page-strength section.efforts ul li:nth-of-type(2) span.number {
  color: #00c5c8;
  border-color: #00c5c8;
}
#page-strength section.efforts ul li:nth-of-type(2) dl dt {
  color: #00c5c8;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul li:nth-of-type(3) {
    top: 12.5%;
    right: 11%;
  }
}
#page-strength section.efforts ul li:nth-of-type(3) span.number {
  color: #009cf1;
  border-color: #009cf1;
}
#page-strength section.efforts ul li:nth-of-type(3) dl dt {
  color: #009cf1;
}
@media print, screen and (min-width: 1024px) {
  #page-strength section.efforts ul li:nth-of-type(4) {
    top: 65%;
    right: 28%;
  }
}
#page-strength section.efforts ul li:nth-of-type(4) span.number {
  color: #007ddf;
  border-color: #007ddf;
}
#page-strength section.efforts ul li:nth-of-type(4) dl dt {
  color: #007ddf;
}
#page-strength section.competition {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-strength section.competition h3 {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(2.4rem, 3.2vw, 3.2rem);
  font-weight: bold;
  text-align: center;
  border-bottom: 0.1rem solid #0000d2;
  padding: 0 1em 0.5em;
}
#page-strength section.competition h3 span {
  color: #0000d2;
}
#page-strength section.competition h3 span a {
  display: inline;
  text-decoration: underline;
}
#page-strength section.competition h3 span a:hover {
  opacity: 0.5;
}
#page-strength section.competition p.introduction {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: 100%;
  max-width: 94rem;
}
#page-strength section.competition ul.skill_list {
  margin-top: clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition ul.skill_list {
    margin-top: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-strength section.competition ul.skill_list > li {
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #eaebef;
}
#page-strength section.competition ul.skill_list > li + li {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-strength section.competition ul.skill_list > li h4 {
  color: #fff;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  background-color: #1f2f54;
  padding: 1em 0;
}
#page-strength section.competition ul.skill_list > li .inner {
  margin-top: clamp(4rem, 5vw, 8rem);
  max-width: 1240px;
  padding-right: 0;
}
#page-strength section.competition ul.skill_list > li p.description {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
}
@media print, screen and (min-width: 768px) {
  #page-strength section.competition ul.skill_list > li p.description {
    text-align: center;
  }
}
#page-strength section.competition ul.skill_list > li .flex {
  margin-top: clamp(4rem, 5vw, 8rem);
  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;
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition ul.skill_list > li .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
#page-strength section.competition ul.skill_list > li .flex .image_area {
  max-width: 54rem;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition ul.skill_list > li .flex .image_area {
    width: 45%;
  }
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area {
  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-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.5rem;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition ul.skill_list > li .flex ul.card_area {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li {
  width: 20rem;
  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;
  gap: 2.5rem 0;
  background-color: #fff;
  border: 0.1rem solid #999;
  padding: clamp(2rem, 4vw, 4rem) 2rem;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition ul.skill_list > li .flex ul.card_area li {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: auto;
    max-width: 20rem;
    padding: clamp(2rem, 4vw, 4rem) min(1.15vw, 2rem);
  }
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li .icon {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 10rem;
  height: 8.6rem;
  background: center/contain no-repeat;
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li .icon.icon01 {
  background-image: url(../img/strength/icon_helmet.webp);
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li .icon.icon02 {
  background-image: url(../img/strength/icon_tools.webp);
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li .icon.icon03 {
  background-image: url(../img/strength/icon_pass.webp);
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li h5 {
  width: 100%;
  color: #fff;
  font-weight: bold;
  text-align: center;
  background-color: #1f2f54;
  padding: 1em 0;
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition ul.skill_list > li .flex ul.card_area li h5 {
    font-size: min(1.15vw, 1.6rem);
  }
}
@media print, screen and (min-width: 1280px) {
  #page-strength section.competition ul.skill_list > li .flex ul.card_area li p {
    font-size: min(1.15vw, 1.6rem);
  }
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li p span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#page-strength section.competition ul.skill_list > li .flex ul.card_area li p span::before {
  content: "・";
}
#page-strength section.competition ul.skill_list > li p.note {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
}
#page-strength section.competition .btn_area {
  margin-top: clamp(5rem, 6vw, 10rem);
}

#page-business #header nav.header_nav a.nav_business::before {
  -webkit-transform: scale(1);
          transform: scale(1);
}
#page-business #header .overlay a.nav_business::before {
  opacity: 1;
}
#page-business #footer nav.footer_nav a.nav_business {
  text-decoration: underline;
}
#page-business section.business {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-business section.business {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0 calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-business section.business p.lead {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(2.2rem, 3.2vw, 3.2rem);
  font-weight: bold;
  text-align: center;
}
#page-business section.business p.lead span {
  color: #0000d2;
  padding: 0 0.25em;
}
#page-business section.business ul.business_list {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  place-items: center;
  gap: 2rem 0;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business ul.business_list {
    grid-template-columns: repeat(3, 1fr);
    gap: 0 1.5rem;
  }
}
#page-business section.business ul.business_list li {
  width: 100%;
  max-width: 45.5rem;
}
#page-business section.business ul.business_list li a {
  position: relative;
  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;
  padding: 4rem 0 2rem;
  background: center/cover no-repeat;
  overflow: hidden;
}
@media print, screen and (min-width: 1024px) {
  #page-business section.business ul.business_list li a {
    position: relative;
    aspect-ratio: 1/1;
    padding: 0;
  }
}
#page-business section.business ul.business_list li a::before {
  content: "";
  width: 100%;
  height: 100%;
  background: center/cover no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
#page-business section.business ul.business_list li a[href="#business01"]::before {
  background-image: url(../img/business/business_img01.webp);
}
#page-business section.business ul.business_list li a[href="#business02"]::before {
  background-image: url(../img/business/business_img02.webp);
}
#page-business section.business ul.business_list li a[href="#business03"]::before {
  background-image: url(../img/business/business_img03.webp);
}
#page-business section.business ul.business_list li a:hover::before {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
  -webkit-filter: brightness(1.3) saturate(1.2);
          filter: brightness(1.3) saturate(1.2);
}
#page-business section.business ul.business_list li a p {
  color: #fff;
  font-size: clamp(2.4rem, 3.2vw, 3.2rem);
  font-weight: bold;
}
#page-business section.business ul.business_list li a span {
  margin-top: 2rem;
  color: #fff;
  font-size: 1.8rem;
  text-align: center;
}
#page-business section.business ul.business_list li a span.arrow {
  position: relative;
  margin-top: 4rem;
  width: 4.8rem;
  aspect-ratio: 1/1;
  background-color: #fff;
  border-radius: 50%;
}
@media print, screen and (min-width: 1024px) {
  #page-business section.business ul.business_list li a span.arrow {
    position: absolute;
    left: 50%;
    bottom: 4rem;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
#page-business section.business ul.business_list li a span.arrow::before {
  content: "";
  width: 40%;
  aspect-ratio: 13/7;
  -webkit-mask: url(../img/btn_arrow.svg) center/contain no-repeat;
          mask: url(../img/btn_arrow.svg) center/contain no-repeat;
  background-color: #0000d2;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}
#page-business section.business .closing-block > p {
  background-color: #1f2f54;
  padding: 0 2rem;
}
#page-business section.business .closing-block > p strong {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #fff;
  font-size: clamp(2rem, 2vw, 3.2rem);
  font-weight: bold;
  padding: 1em 0;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business .closing-block > p strong {
    position: relative;
    margin: 0 min(5vw, 9.5rem) 0 auto;
  }
  #page-business section.business .closing-block > p strong::before {
    content: "";
    width: 100vw;
    height: 0.1rem;
    background-color: #fff;
    position: absolute;
    top: 50%;
    right: calc(100% + clamp(4rem, 5vw, 8rem));
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
  }
}
#page-business section.business .closing-block .flex {
  margin-top: clamp(6rem, 8vw, 15rem);
  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;
  gap: 4rem 0;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business .closing-block .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0 clamp(3rem, 4vw, 6rem);
  }
}
#page-business section.business .closing-block .image_area {
  width: 100%;
  max-width: 70rem;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business .closing-block .image_area {
    width: 50%;
  }
}
@media print, screen and (min-width: 768px) {
  #page-business section.business .closing-block .text_area {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-business section.business .closing-block .text_area p {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business .closing-block .text_area p {
    margin: 0;
  }
}
#page-business section.business .closing-block .text_area .btn_area {
  margin-top: clamp(6rem, 7vw, 12rem);
  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-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-business section.business .closing-block .text_area .btn_area {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
#page-business section.business .closing-block .text_area .btn_area .btn {
  margin: 0;
}
#page-business section.business-detail h3 {
  position: relative;
  color: #0000d2;
  font-size: clamp(2.4rem, 3.2vw, 3.2rem);
  font-weight: bold;
  text-align: center;
  padding-bottom: 0.5em;
}
#page-business section.business-detail h3::after {
  content: "";
  width: 4rem;
  height: 0.3rem;
  background-color: #0000d2;
  position: absolute;
  left: 50%;
  bottom: 0;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
#page-business section.business-detail p.introduction {
  margin-top: clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail p.introduction {
    text-align: center;
  }
}
#page-business section.business-detail ul.point_list {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  place-items: center;
  gap: 2rem 0;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail ul.point_list {
    grid-template-columns: repeat(3, 1fr);
    gap: 0 1.5rem;
  }
}
#page-business section.business-detail ul.point_list li {
  width: 100%;
  max-width: 46rem;
  aspect-ratio: 460/230;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: clamp(1.8rem, 2vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  background: center/cover no-repeat;
}
#page-business section.business-detail dl.works-type {
  margin-top: clamp(4rem, 5vw, 8rem);
  background-color: #bcc1cc;
  border-radius: clamp(1.6rem, 3.2vw, 3.2rem);
  padding: clamp(4rem, 5vw, 8rem) clamp(2rem, 4vw, 4rem);
}
#page-business section.business-detail dl.works-type dt {
  color: #fff;
  font-size: clamp(1.8rem, 2.4vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  background-color: #1f2f54;
  padding: 1em 0;
}
#page-business section.business-detail dl.works-type dd {
  margin-top: clamp(4rem, 5vw, 8rem);
}
#page-business section.business-detail dl.works-type dd ul {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  place-items: center;
  gap: clamp(4rem, 5vw, 8rem) clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail dl.works-type dd ul {
    grid-template-columns: repeat(2, 1fr);
    place-items: start;
    justify-items: center;
  }
}
@media print, screen and (min-width: 1280px) {
  #page-business section.business-detail dl.works-type dd ul {
    grid-template-columns: repeat(3, minmax(auto, 34rem));
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
#page-business section.business-detail dl.works-type dd ul li {
  width: 100%;
  max-width: 34rem;
  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;
  gap: 2rem;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail dl.works-type dd ul li {
    -ms-flex-item-align: stretch;
        align-self: stretch;
    max-width: none;
  }
}
@media print, screen and (min-width: 1280px) {
  #page-business section.business-detail dl.works-type dd ul li {
    max-width: 34rem;
  }
}
#page-business section.business-detail dl.works-type dd ul li p.name {
  width: 100%;
  color: #1f2f54;
  font-size: clamp(1.8rem, 1.5vw, 2rem);
  font-weight: bold;
  text-align: center;
  background-color: #fff;
  padding: 0.5em 0;
}
#page-business section.business-detail dl.works-type dd ul li p.description {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail dl.works-type dd ul li p.description {
    text-align: center;
  }
}
#page-business section.business-detail dl.works-type dd ul li p.description span {
  display: block;
}
#page-business section.business-detail dl.works-type dd ul li p.description span + span {
  margin-top: 1em;
}
#page-business section.business-detail dl.works-type dd ul li .image {
  width: 24.2rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail dl.works-type dd ul li .image {
    margin-top: auto;
  }
}
#page-business section.business-detail#business01 {
  margin-top: clamp(5rem, 6vw, 10rem);
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #dde0e5;
}
@media print, screen and (min-width: 1280px) {
  #page-business section.business-detail#business01 {
    margin-top: calc(2 * clamp(4rem, 5vw, 8rem));
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0;
  }
}
#page-business section.business-detail#business01 ul.point_list li:nth-of-type(1) {
  background-image: url(../img/business/point_bg01-01.webp);
}
#page-business section.business-detail#business01 ul.point_list li:nth-of-type(2) {
  background-image: url(../img/business/point_bg01-02.webp);
}
#page-business section.business-detail#business01 ul.point_list li:nth-of-type(3) {
  background-image: url(../img/business/point_bg01-03.webp);
}
#page-business section.business-detail#business01 .example_area,
#page-business section.business-detail#business01 .process_area,
#page-business section.business-detail#business01 .flow_area {
  margin-top: calc(2 * clamp(4rem, 5vw, 8rem));
}
#page-business section.business-detail#business01 .example_area h4,
#page-business section.business-detail#business01 .process_area h4,
#page-business section.business-detail#business01 .flow_area h4 {
  position: relative;
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #1f2f54;
  font-size: clamp(1.8rem, 1.8vw, 2.4rem);
  font-weight: bold;
  padding-bottom: 0.5em;
}
#page-business section.business-detail#business01 .example_area h4::after,
#page-business section.business-detail#business01 .process_area h4::after,
#page-business section.business-detail#business01 .flow_area h4::after {
  content: "";
  width: min(80vw, 34rem);
  height: 0.2rem;
  background-color: #1f2f54;
  position: absolute;
  left: 50%;
  bottom: 0;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
#page-business section.business-detail#business01 .example_area ul {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-business section.business-detail#business01 .example_area ul li {
  background-color: #1f2f54;
}
#page-business section.business-detail#business01 .example_area ul li + li {
  margin-top: clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .example_area ul li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
#page-business section.business-detail#business01 .example_area ul li dl {
  padding: clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .example_area ul li dl {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media print, screen and (min-width: 1400px) {
  #page-business section.business-detail#business01 .example_area ul li dl {
    padding: clamp(4rem, 5vw, 8rem) clamp(3rem, 4vw, 6rem);
  }
}
#page-business section.business-detail#business01 .example_area ul li dl dt,
#page-business section.business-detail#business01 .example_area ul li dl dd {
  color: #fff;
}
#page-business section.business-detail#business01 .example_area ul li dl dt {
  font-size: clamp(1.6rem, 2vw, 2rem);
  background-color: #4c5976;
  border: 0.1rem solid #fff;
  padding: 0.5em 1em;
}
#page-business section.business-detail#business01 .example_area ul li dl dd {
  margin-top: clamp(2rem, 4vw, 4rem);
}
#page-business section.business-detail#business01 .example_area ul li .image {
  aspect-ratio: 538/374;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .example_area ul li .image {
    width: 50%;
    max-width: 53.8rem;
    -ms-flex-item-align: stretch;
        align-self: stretch;
  }
}
#page-business section.business-detail#business01 .example_area ul li .image img {
  max-width: none;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .example_area ul li .image img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
  }
}
#page-business section.business-detail#business01 .process_area ol {
  margin-top: clamp(4rem, 5vw, 8rem);
}
#page-business section.business-detail#business01 .process_area ol li {
  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;
  gap: clamp(2rem, 4vw, 4rem) 0;
}
#page-business section.business-detail#business01 .process_area ol li + li {
  margin-top: clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .process_area ol li {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0 clamp(5rem, 6vw, 10rem);
  }
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .process_area ol li dl {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-business section.business-detail#business01 .process_area ol li dl dt {
  color: #333;
  font-size: clamp(1.8rem, 2.1vw, 2.1rem);
  font-weight: bold;
  border-bottom: 0.1rem solid #1f2f54;
  padding-bottom: 0.5em;
}
#page-business section.business-detail#business01 .process_area ol li dl dd {
  margin-top: clamp(2rem, 4vw, 4rem);
  width: 100%;
  max-width: 66rem;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .process_area ol li .image {
    width: 40%;
    max-width: 40.8rem;
  }
}
#page-business section.business-detail#business01 .flow_area {
  border-radius: clamp(1.6rem, 3.2vw, 3.2rem);
  background-color: #fff;
  padding: clamp(5rem, 6vw, 10rem) 2rem;
}
#page-business section.business-detail#business01 .flow_area p {
  margin: clamp(2rem, 4vw, 4rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .flow_area p {
    text-align: center;
  }
}
#page-business section.business-detail#business01 .flow_area figure {
  margin: clamp(3rem, 4vw, 6rem) auto 0;
  width: 100%;
  max-width: 71.8rem;
  overflow: scroll;
}
#page-business section.business-detail#business01 .flow_area figure img {
  width: 50rem;
  max-width: none;
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  #page-business section.business-detail#business01 .flow_area figure img {
    width: 100%;
  }
}
#page-business section.business-detail#business02 {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-business section.business-detail#business02 {
    padding-bottom: calc(2 * clamp(4rem, 5vw, 8rem));
  }
}
#page-business section.business-detail#business02 ul.point_list li:nth-of-type(1) {
  background-image: url(../img/business/point_bg02-01.webp);
}
#page-business section.business-detail#business02 ul.point_list li:nth-of-type(2) {
  background-image: url(../img/business/point_bg02-02.webp);
}
#page-business section.business-detail#business02 ul.point_list li:nth-of-type(3) {
  background-image: url(../img/business/point_bg02-03.webp);
}
#page-business section.business-detail#business03 {
  padding: clamp(5rem, 6vw, 10rem) 0;
  background-color: #dde0e5;
}
@media print, screen and (min-width: 1280px) {
  #page-business section.business-detail#business03 {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-business section.business-detail#business03 ul.point_list li:nth-of-type(1) {
  background-image: url(../img/business/point_bg03-01.webp);
}
#page-business section.business-detail#business03 ul.point_list li:nth-of-type(2) {
  background-image: url(../img/business/point_bg03-02.webp);
}
#page-business section.business-detail#business03 ul.point_list li:nth-of-type(3) {
  background-image: url(../img/business/point_bg03-03.webp);
}

#page-achievements #header nav.header_nav a.nav_achievements::before {
  -webkit-transform: scale(1);
          transform: scale(1);
}
#page-achievements #header .overlay a.nav_achievements::before {
  opacity: 1;
}
#page-achievements #footer nav.footer_nav a.nav_achievements {
  text-decoration: underline;
}
#page-achievements section.achievements {
  padding: clamp(4rem, 5vw, 8rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-achievements section.achievements {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0 calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-achievements section.achievements ul.anchor_list {
  margin-top: clamp(4rem, 5vw, 8rem);
  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;
  gap: 1.5rem;
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements ul.anchor_list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 2.5rem;
  }
}
#page-achievements section.achievements ul.anchor_list li {
  width: 100%;
  max-width: 40rem;
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements ul.anchor_list li {
    width: calc((100% - 2.5rem) / 2);
  }
}
@media print, screen and (min-width: 1024px) {
  #page-achievements section.achievements ul.anchor_list li {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-achievements section.achievements ul.anchor_list li a {
  position: relative;
  color: #1f2f54;
  font-size: clamp(1.6rem, 1.6vw, 2rem);
  font-weight: bold;
  text-align: center;
  line-height: 1.25;
  border: 0.1rem solid #1f2f54;
  padding: 1em 0;
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements ul.anchor_list li a {
    height: 7.5rem;
    display: grid;
    place-items: center;
    padding: 0;
  }
}
#page-achievements section.achievements ul.anchor_list li a::after {
  content: "";
  width: 0.6em;
  aspect-ratio: 1/1;
  border-right: 0.2rem solid #1f2f54;
  border-bottom: 0.2rem solid #1f2f54;
  position: absolute;
  top: 50%;
  right: 2rem;
  -webkit-transform: translate(0, -50%) rotate(45deg);
          transform: translate(0, -50%) rotate(45deg);
}
@media print, screen and (min-width: 1024px) {
  #page-achievements section.achievements ul.anchor_list li a::after {
    content: none;
  }
}
#page-achievements section.achievements ul.anchor_list li a:hover {
  color: #fff;
  background-color: #1f2f54;
}
#page-achievements section.achievements ul.anchor_list li a:hover::after {
  color: #fff;
}
#page-achievements section.achievements .achievements_detail {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-achievements section.achievements .achievements_detail h3 {
  font-size: clamp(2rem, 2vw, 3.2rem);
  font-weight: bold;
  text-align: center;
  border-bottom: 0.1rem solid #1a1a1a;
  padding: 1em 0;
}
#page-achievements section.achievements .achievements_detail table {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
  display: block;
  width: 100%;
  max-width: 1000px;
  border: 0.1rem solid #d6d9e0;
}
#page-achievements section.achievements .achievements_detail table thead,
#page-achievements section.achievements .achievements_detail table tbody,
#page-achievements section.achievements .achievements_detail table tr,
#page-achievements section.achievements .achievements_detail table th,
#page-achievements section.achievements .achievements_detail table td {
  display: block;
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements .achievements_detail table tr {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
#page-achievements section.achievements .achievements_detail table th,
#page-achievements section.achievements .achievements_detail table td {
  padding: 1em clamp(2rem, 4vw, 4rem);
}
#page-achievements section.achievements .achievements_detail table th {
  background-color: #d6d9e0;
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements .achievements_detail table th {
    width: 16rem;
  }
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements .achievements_detail table td {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-achievements section.achievements .achievements_detail table thead th {
  font-weight: bold;
  text-align: center;
}
#page-achievements section.achievements .achievements_detail table thead th:nth-of-type(2) {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background-color: #fff;
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements .achievements_detail table tbody th {
    display: grid;
    place-items: center;
    border-top: 0.1rem solid #fff;
  }
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements .achievements_detail table tbody td {
    border-top: 0.1rem solid #d6d9e0;
  }
}
#page-achievements section.achievements .achievements_detail table tbody td ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#page-achievements section.achievements .achievements_detail table tbody td ul li::before {
  content: "・";
}
#page-achievements section.achievements .achievements_detail p.intro_text {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
  width: 100%;
  max-width: 1000px;
}
#page-achievements section.achievements .achievements_detail ul.intro_list {
  margin: 4rem auto 0;
  width: 100%;
  max-width: 1000px;
}
#page-achievements section.achievements .achievements_detail ul.intro_list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#page-achievements section.achievements .achievements_detail ul.intro_list li::before {
  content: "●";
}
#page-achievements section.achievements .achievements_detail ul.achievements_list {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
  width: 100%;
  max-width: 1000px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
#page-achievements section.achievements .achievements_detail ul.achievements_list li {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media print, screen and (min-width: 768px) {
  #page-achievements section.achievements .achievements_detail ul.achievements_list li {
    width: 50%;
  }
}
#page-achievements section.achievements .achievements_detail ul.achievements_list li::before {
  content: "・";
}

#page-news #header nav.header_nav a.nav_news::before {
  -webkit-transform: scale(1);
          transform: scale(1);
}
#page-news #header .overlay a.nav_news::before {
  opacity: 1;
}
#page-news #footer nav.footer_nav a.nav_news {
  text-decoration: underline;
}
#page-news section.news {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-news section.news {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0 calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-news section.news ul.tab_list {
  margin-top: clamp(4rem, 5vw, 8rem);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}
#page-news section.news ul.tab_list li {
  border-left: 0.1rem solid #ccc;
}
#page-news section.news ul.tab_list li:last-of-type {
  border-right: 0.1rem solid #ccc;
}
#page-news section.news ul.tab_list li button {
  display: block;
  width: 100%;
  text-align: center;
  padding: 1.2em 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-news section.news ul.tab_list li button:hover, #page-news section.news ul.tab_list li button.is-active {
  color: #fff;
}
#page-news section.news ul.tab_list li button[data-tab=all]:hover, #page-news section.news ul.tab_list li button[data-tab=all].is-active {
  background-color: #666;
}
#page-news section.news ul.tab_list li button[data-tab=news]:hover, #page-news section.news ul.tab_list li button[data-tab=news].is-active {
  background-color: #0874dc;
}
#page-news section.news ul.tab_list li button[data-tab=recruit]:hover, #page-news section.news ul.tab_list li button[data-tab=recruit].is-active {
  background-color: #f68f43;
}
#page-news section.news ul.tab_list li button[data-tab=update]:hover, #page-news section.news ul.tab_list li button[data-tab=update].is-active {
  background-color: #1f2f54;
}
#page-news section.news ul.news_list {
  margin-top: 2rem;
}
#page-news section.news ul.news_list li {
  padding: clamp(4rem, 5vw, 8rem) 0 4rem;
  border-bottom: 0.1rem solid #000;
}
#page-news section.news ul.news_list li article {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  gap: 2rem 0;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news ul.news_list li article {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 clamp(2rem, 4vw, 4rem);
  }
}
#page-news section.news ul.news_list li article .image_area {
  aspect-ratio: 330/245;
  border: 0.1rem solid #ccc;
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news ul.news_list li article .image_area {
    width: 40%;
    max-width: 33rem;
  }
}
#page-news section.news ul.news_list li article .image_area img {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top;
     object-position: top;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news ul.news_list li article .text_area {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#page-news section.news ul.news_list li article .text_area .meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1em;
}
#page-news section.news ul.news_list li article .text_area .meta time {
  color: #333;
}
#page-news section.news ul.news_list li article .text_area .meta span.category {
  margin-left: 1em;
  display: inline-block;
  width: 15rem;
  color: #fff;
  text-align: center;
  border-radius: 9999px;
  padding: 0.5em 0;
}
#page-news section.news ul.news_list li article .text_area .meta span.category.news {
  background-color: #0874dc;
}
#page-news section.news ul.news_list li article .text_area .meta span.category.recruit {
  background-color: #f68f43;
}
#page-news section.news ul.news_list li article .text_area .meta span.category.update {
  background-color: #1f2f54;
}
#page-news section.news ul.news_list li article .text_area h3.title {
  margin-top: 2.5rem;
  width: 100%;
  color: #000;
  font-size: 2rem;
}
#page-news section.news ul.news_list li article .text_area p.description {
  margin-top: 4rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  color: #333;
  text-box: unset;
  overflow: hidden;
}
#page-news section.news ul.news_list li article .text_area span.spacer {
  display: block;
  height: 2.5rem;
}
#page-news section.news ul.news_list li article .text_area p.link {
  margin: auto 0 2rem 0;
}
#page-news section.news ul.news_list li article .text_area p.link a {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #000;
  text-decoration: underline;
}
#page-news section.news ul.news_list li article .text_area p.link a:hover {
  opacity: 0.5;
}
#page-news section.news ul.news_list li article .text_area p.link.pdf a {
  position: relative;
}
#page-news section.news ul.news_list li article .text_area p.link.pdf a::after {
  content: "";
  height: 2em;
  aspect-ratio: 4/5;
  -webkit-mask: url(../img/icon_pdf.svg) center/contain no-repeat;
          mask: url(../img/icon_pdf.svg) center/contain no-repeat;
  background-color: #000;
  position: absolute;
  top: 50%;
  left: calc(100% + 1rem);
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
#page-news section.news ul.pagination {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2rem;
}
#page-news section.news ul.pagination li button {
  display: grid;
  place-items: center;
  width: 4.8rem;
  aspect-ratio: 1/1;
  color: #fff;
  background-color: #8d8d8d;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-news section.news ul.pagination li button:hover, #page-news section.news ul.pagination li button.pagination-on {
  background-color: #1f2f54;
}
#page-news section.news-detail {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-news section.news-detail {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0 calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-news section.news-detail .detail_area {
  margin-top: clamp(5rem, 6vw, 10rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border: 0.2rem solid #1f2f54;
  padding: clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-news section.news-detail .detail_area {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 clamp(2rem, 4vw, 4rem);
    padding: clamp(3rem, 4vw, 6rem);
  }
}
#page-news section.news-detail .detail_area .area-left,
#page-news section.news-detail .detail_area .area-right {
  display: contents;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news-detail .detail_area .area-left,
  #page-news section.news-detail .detail_area .area-right {
    display: block;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-news section.news-detail .detail_area .meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1em;
}
#page-news section.news-detail .detail_area .meta time {
  color: #333;
}
#page-news section.news-detail .detail_area .meta span.category {
  margin-left: 1em;
  display: inline-block;
  width: 15rem;
  color: #fff;
  text-align: center;
  border-radius: 9999px;
  padding: 0.5em 0;
}
#page-news section.news-detail .detail_area .meta span.category.news {
  background-color: #0874dc;
}
#page-news section.news-detail .detail_area .meta span.category.recruit {
  background-color: #f68f43;
}
#page-news section.news-detail .detail_area .meta span.category.update {
  background-color: #1f2f54;
}
#page-news section.news-detail .detail_area h3.title {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
  margin-top: 2rem;
  color: #000;
  font-size: 2rem;
}
#page-news section.news-detail .detail_area .image {
  -webkit-box-ordinal-group: 6;
      -ms-flex-order: 5;
          order: 5;
  margin-top: 4rem;
  aspect-ratio: 470/280;
  overflow: hidden;
}
#page-news section.news-detail .detail_area .image img {
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top;
     object-position: top;
}
#page-news section.news-detail .detail_area p.link {
  -webkit-box-ordinal-group: 5;
      -ms-flex-order: 4;
          order: 4;
  margin-top: 4rem;
}
#page-news section.news-detail .detail_area p.link a {
  color: #000;
  text-decoration: underline;
}
#page-news section.news-detail .detail_area p.link a:hover {
  opacity: 0.5;
}
#page-news section.news-detail .detail_area p.description {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
  margin-top: 4rem;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news-detail .detail_area p.description {
    margin-top: 0;
  }
}
#page-news section.news-detail .btn_area {
  margin-top: clamp(5rem, 6vw, 10rem);
}

#page-contact #header nav.header_nav a.nav_contact {
  color: #0000d2;
  background-color: #fff;
}
#page-contact #header nav.header_nav a.nav_contact::after {
  background-color: #0000d2;
}
#page-contact #header .overlay a.nav_contact::before {
  opacity: 1;
}
#page-contact #footer nav.footer_nav a.nav_contact {
  text-decoration: underline;
}
#page-contact section.contact {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-contact section.contact {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0 calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-contact section.contact section.contact-tel {
  padding: clamp(5rem, 6vw, 10rem) 0;
  border-bottom: 0.1rem solid #0000d2;
}
#page-contact section.contact section.contact-tel h3 {
  color: #0000d2;
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
}
#page-contact section.contact section.contact-tel p {
  margin: 4rem auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#page-contact section.contact section.contact-tel .tel-link {
  margin-top: 4rem;
}
#page-contact section.contact section.contact-tel .tel-link a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 0 1rem;
  background-color: #e3e5ea;
  padding: clamp(2rem, 4vw, 4rem) 0;
}
#page-contact section.contact section.contact-tel .tel-link a::before {
  content: "";
  width: 4rem;
  aspect-ratio: 1/1;
  background: url(../img/contact/icon_tel.svg) center/contain no-repeat;
  position: relative;
  top: 0.8rem;
}
#page-contact section.contact section.contact-tel .tel-link a span {
  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;
  color: #0000d2;
  font-size: clamp(2.4rem, 3.2vw, 3.2rem);
  font-weight: bold;
}
#page-contact section.contact section.contact-tel .tel-link a span small {
  color: initial;
  font-size: clamp(1.4rem, 1.7vw, 1.7rem);
}
#page-contact section.contact section.contact-mail {
  padding-top: clamp(5rem, 6vw, 10rem);
}
#page-contact section.contact section.contact-mail h3 {
  color: #0000d2;
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
}
#page-contact section.contact section.contact-mail > p {
  margin: 4rem auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact section.contact-mail > p {
    text-align: center;
  }
}
#page-contact section.contact section.contact-mail > p span {
  display: inline-block;
  margin-right: 0.25em;
  color: #fff;
  background-color: #ed1c24;
  border-radius: 0.8rem;
  padding: 0.4em 0.8em;
}
#page-contact section.contact section.contact-mail > p a {
  display: inline;
  color: #0000d2;
  font-weight: bold;
  text-decoration: underline;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact section.contact-mail > p a {
    text-decoration: none;
  }
}
#page-contact section.contact section.contact-mail form {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-contact section.contact section.contact-mail form .input_area dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem clamp(2rem, 4vw, 4rem);
}
#page-contact section.contact section.contact-mail form .input_area dl + dl {
  margin-top: 4rem;
}
#page-contact section.contact section.contact-mail form .input_area dl dt {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact section.contact-mail form .input_area dl dt {
    width: 22rem;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-item-align: baseline;
        align-self: baseline;
    padding-top: 0.5em;
  }
}
#page-contact section.contact section.contact-mail form .input_area dl dt::after {
  content: "必須";
  color: #fff;
  border-radius: 0.8rem;
  padding: 0.4em 0.8em;
}
#page-contact section.contact section.contact-mail form .input_area dl dt.required::after {
  background-color: #ed1c24;
}
#page-contact section.contact section.contact-mail form .input_area dl dd {
  width: 100%;
  border: 0.2rem solid #ccc;
  border-radius: 1rem;
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact section.contact-mail form .input_area dl dd {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    width: auto;
  }
}
#page-contact section.contact section.contact-mail form .input_area dl dd select,
#page-contact section.contact section.contact-mail form .input_area dl dd input,
#page-contact section.contact section.contact-mail form .input_area dl dd textarea {
  display: block;
  width: 100%;
  font-size: 2rem;
  text-box: unset;
  padding: 0.5em 1em;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  cursor: pointer;
}
#page-contact section.contact section.contact-mail form .input_area dl dd select:hover,
#page-contact section.contact section.contact-mail form .input_area dl dd input:hover,
#page-contact section.contact section.contact-mail form .input_area dl dd textarea:hover {
  background-color: rgba(0, 0, 210, 0.1);
}
#page-contact section.contact section.contact-mail form .input_area dl dd textarea {
  field-sizing: content;
  min-height: 20rem;
}
#page-contact section.contact section.contact-mail form .privacy_area {
  margin-top: clamp(5rem, 6vw, 10rem);
  padding: clamp(2rem, 4vw, 4rem) 1em;
  background-color: #e3e5ea;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact section.contact-mail form .privacy_area {
    padding: clamp(2rem, 4vw, 4rem) clamp(3rem, 4vw, 6.4rem);
  }
}
@media print, screen and (min-width: 1280px) {
  #page-contact section.contact section.contact-mail form .privacy_area {
    margin-top: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-contact section.contact section.contact-mail form .privacy_area p {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact section.contact-mail form .privacy_area p {
    text-align: center;
  }
}
#page-contact section.contact section.contact-mail form .privacy_area p a {
  display: inline;
  color: #0000d2;
}
#page-contact section.contact section.contact-mail form .privacy_area p a:hover {
  text-decoration: underline;
}
#page-contact section.contact section.contact-mail form .privacy_area label {
  margin-top: 1em;
  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;
  gap: 0 min(2vw, 2rem);
  background-color: #fff;
  padding: 1em 0;
  cursor: pointer;
}
#page-contact section.contact section.contact-mail form .privacy_area label:hover {
  text-decoration: underline;
}
#page-contact section.contact section.contact-mail form .privacy_area label input {
  width: 1.5em;
  height: 1.5em;
  accent-color: #0000d2;
}
#page-contact section.contact section.contact-mail form .btn_area {
  margin-top: clamp(3rem, 4vw, 6.4rem);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(2rem, 4vw, 4rem);
}
#page-contact section.contact section.contact-mail form .btn_area button {
  color: #fff;
  font-size: clamp(1.6rem, 2.4vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  border: 0.1rem solid;
  padding: 1.5em 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-contact section.contact section.contact-mail form .btn_area button[type=reset], #page-contact section.contact section.contact-mail form .btn_area button[type=button] {
  background-color: #333;
  border-color: #333;
}
#page-contact section.contact section.contact-mail form .btn_area button[type=reset]:hover, #page-contact section.contact section.contact-mail form .btn_area button[type=button]:hover {
  color: #333;
  background-color: #fff;
}
#page-contact section.contact section.contact-mail form .btn_area button[type=submit] {
  background-color: #0000d2;
  border-color: #0000d2;
}
#page-contact section.contact section.contact-mail form .btn_area button[type=submit]:hover {
  color: #0000d2;
  background-color: #fff;
}
#page-contact section.contact section.contact-mail form.confirm .input_area select,
#page-contact section.contact section.contact-mail form.confirm .input_area input,
#page-contact section.contact section.contact-mail form.confirm .input_area textarea,
#page-contact section.contact section.contact-mail form.confirm .input_area label,
#page-contact section.contact section.contact-mail form.confirm .privacy_area select,
#page-contact section.contact section.contact-mail form.confirm .privacy_area input,
#page-contact section.contact section.contact-mail form.confirm .privacy_area textarea,
#page-contact section.contact section.contact-mail form.confirm .privacy_area label {
  pointer-events: none;
}
#page-contact section.contact section.contact-mail .btn_area.completed {
  margin-top: clamp(5rem, 6vw, 10rem);
  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-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem 4rem;
}
#page-contact section.contact section.contact-mail .btn_area.completed .btn {
  margin: 0;
}

#page-privacy #header .overlay a.nav_privacy::before {
  opacity: 1;
}
#page-privacy #footer nav.footer_nav a.nav_privacy {
  text-decoration: underline;
}
#page-privacy section.privacy {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-privacy section.privacy {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-privacy section.privacy p.info {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 768px) {
  #page-privacy section.privacy p.info {
    text-align: center;
  }
}
#page-privacy section.privacy .privacy_list {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-privacy section.privacy .privacy_list p.center {
  text-align: center;
}
#page-privacy section.privacy .privacy_list p.note {
  margin-top: 4rem;
}
#page-privacy section.privacy .privacy_list ul {
  margin-top: 4rem;
}
#page-privacy section.privacy .privacy_list ul li + li {
  margin-top: 4rem;
}
#page-privacy section.privacy .mtb80 {
  margin: clamp(4rem, 5vw, 8rem) 0;
  text-align: center;
}
#page-privacy section.privacy .mb200 {
  margin-bottom: clamp(5rem, 6vw, 10rem);
}
@media print, screen and (min-width: 1280px) {
  #page-privacy section.privacy .mb200 {
    margin-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}

#page-smp #header .overlay a.nav_smp::before {
  opacity: 1;
}
#page-smp #footer nav.footer_nav a.nav_smp {
  text-decoration: underline;
}
#page-smp section.smp {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-smp section.smp {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-smp section.smp p.info {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#page-smp section.smp ul {
  margin-top: clamp(5rem, 6vw, 10rem);
  counter-reset: item;
}
#page-smp section.smp ul li + li {
  margin-top: 1em;
}
#page-smp section.smp ul li::before {
  counter-increment: item;
  content: counter(item) ".";
  margin-right: 0.25em;
}
#page-smp section.smp dl {
  margin-top: clamp(4rem, 5vw, 8rem);
}
#page-smp section.smp dl dt {
  font-weight: bold;
}
#page-smp section.smp dl dt:not(:first-of-type) {
  margin-top: clamp(4rem, 5vw, 8rem);
}
#page-smp section.smp dl dd {
  margin-top: 1.5em;
  text-align: left;
}
#page-smp section.smp dl dd a {
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  text-decoration: underline;
}
#page-smp section.smp dl dd a:hover {
  opacity: 0.5;
}

#page-partners #header .overlay a.nav_partners::before {
  opacity: 1;
}
#page-partners #footer nav.footer_nav a.nav_partners {
  text-decoration: underline;
}
#page-partners section.partners {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-partners section.partners {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-partners section.partners .inner {
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content;
}
#page-partners section.partners p {
  margin-top: clamp(5rem, 6vw, 10rem);
}
#page-partners section.partners p a {
  margin-top: 1em;
}
#page-partners section.partners dl {
  margin-top: clamp(3rem, 4vw, 6rem);
}
#page-partners section.partners dl dt:not(:first-of-type) {
  margin-top: clamp(2rem, 4vw, 4rem);
}
#page-partners section.partners dl dt::before {
  content: "【";
}
#page-partners section.partners dl dt::after {
  content: "】";
}
#page-partners section.partners dl dd {
  margin-top: 1.5em;
}
#page-partners section.partners dl dd ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
}
#page-partners section.partners a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
}
#page-partners section.partners a::before {
  content: "";
  height: 2.5em;
  aspect-ratio: 4/5;
  -webkit-mask: center/contain no-repeat;
          mask: center/contain no-repeat;
  background-color: #333;
}
#page-partners section.partners a:hover {
  color: #0000d2;
}
#page-partners section.partners a:hover::before {
  background-color: #0000d2;
}
#page-partners section.partners a[href*=pdf]::before {
  -webkit-mask-image: url(../img/icon_pdf.svg);
          mask-image: url(../img/icon_pdf.svg);
}
#page-partners section.partners a[href*=xlsx]::before {
  -webkit-mask-image: url(../img/icon_excel.svg);
          mask-image: url(../img/icon_excel.svg);
}

#page-sitemap #header .overlay a.nav_sitemap::before {
  opacity: 1;
}
#page-sitemap #footer nav.footer_nav a.nav_sitemap {
  text-decoration: underline;
}
#page-sitemap section.sitemap {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-sitemap section.sitemap {
    padding-bottom: calc(2 * clamp(5rem, 6vw, 10rem));
  }
}
#page-sitemap section.sitemap p {
  margin-top: clamp(5rem, 6vw, 10rem);
  text-align: center;
}
#page-sitemap section.sitemap .link_list {
  margin: clamp(5rem, 6vw, 10rem) auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 4rem clamp(4rem, 5vw, 8rem);
}
@media print, screen and (min-width: 768px) {
  #page-sitemap section.sitemap .link_list {
    grid-template-columns: repeat(3, 1fr);
    place-items: flex-start;
  }
}
#page-sitemap section.sitemap ul.main-link {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 4rem 0;
}
#page-sitemap section.sitemap ul.main-link > li > a {
  position: relative;
  font-size: 2rem;
  border-bottom: 0.1rem solid #acacac;
  padding: 0.5em 0 0.5em 1.5em;
}
@media print, screen and (min-width: 768px) {
  #page-sitemap section.sitemap ul.main-link > li > a {
    font-size: min(1.8vw, 1.8rem);
  }
}
#page-sitemap section.sitemap ul.main-link > li > a::before, #page-sitemap section.sitemap ul.main-link > li > a::after {
  content: "";
  width: 1.2em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
#page-sitemap section.sitemap ul.main-link > li > a::before {
  background-color: #0000d2;
  z-index: 10;
}
#page-sitemap section.sitemap ul.main-link > li > a::after {
  background: url(../img/icon_logo.svg) center/125% no-repeat;
  border: 0.1rem solid #afafaf;
}
#page-sitemap section.sitemap ul.main-link > li > a:hover {
  color: #0000d2;
}
#page-sitemap section.sitemap ul.main-link > li > a:hover::before {
  opacity: 0;
}
#page-sitemap section.sitemap ul.main-link > li > a[target=_blank] span {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
}
#page-sitemap section.sitemap ul.main-link > li > a[target=_blank] span::after {
  content: "";
  width: 0.6em;
  aspect-ratio: 1/1;
  -webkit-mask: url(../img/icon_window.svg) center/contain no-repeat;
          mask: url(../img/icon_window.svg) center/contain no-repeat;
  background-color: #333;
}
#page-sitemap section.sitemap ul.main-link > li > a[target=_blank]:hover span::after {
  background-color: #0000d2;
}
#page-sitemap section.sitemap ul.sub-link {
  margin-top: 2rem;
}
#page-sitemap section.sitemap ul.sub-link li + li {
  margin-top: 1.5rem;
}
@media print, screen and (min-width: 768px) {
  #page-sitemap section.sitemap ul.sub-link li a {
    font-size: min(1.6vw, 1.6rem);
  }
}
#page-sitemap section.sitemap ul.sub-link li a:hover {
  opacity: 0.5;
}
#page-sitemap section.sitemap ul.sub-link li a::before {
  content: ">";
  margin-right: 1rem;
}

#page-404 section.page404 {
  padding: clamp(5rem, 6vw, 10rem) 0;
}
@media print, screen and (min-width: 1280px) {
  #page-404 section.page404 {
    padding: calc(2 * clamp(4rem, 5vw, 8rem)) 0;
  }
}
#page-404 section.page404 p.note {
  margin: clamp(4rem, 5vw, 8rem) auto 0;
}
@media print, screen and (min-width: 768px) {
  #page-404 section.page404 p.note {
    text-align: center;
  }
}
#page-404 section.page404 .btn_area {
  margin-top: clamp(4rem, 5vw, 8rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(2rem, 4vw, 4rem);
}
#page-404 section.page404 .btn_area .btn {
  margin: 0;
}
#page-404 section.page404 .btn_area .btn:nth-of-type(1) {
  width: 100%;
}
@media print, screen and (min-width: 1024px) {
  #page-404 section.page404 .btn_area .btn:nth-of-type(1) {
    width: auto;
  }
}
#page-404 section.page404 .btn_area .btn:nth-of-type(1) a {
  margin: auto;
}
@media print, screen and (min-width: 1024px) {
  #page-404 section.page404 .btn_area .btn a {
    width: min(26vw, 35rem);
  }
}/*# sourceMappingURL=style.css.map */