@charset "UTF-8";
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  background: transparent;
  font-size: 100%;
  vertical-align: baseline;
}

body {
  line-height: 1;
}

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

nav ul {
  list-style: none;
}

ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

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

/* change colours to suit your needs */
ins {
  background-color: #f5f5f5;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #f5f5f5;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

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

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0;
  border: 0;
  border-top: 1px solid #cccccc;
}

input,
select {
  vertical-align: middle;
}

:root {
  --letter-spacing: 0.06em;
  --padding-container: 2.4rem;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  letter-spacing: var(--letter-spacing);
}

html {
  font-size: min(2.666667vw, 15px);
  -webkit-text-size-adjust: 100%;
}

body {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100svh;
  margin-bottom: 7.6rem;
  color: #333333;
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.667;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-feature-settings: "palt" 1;
}
body.is-fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  overflow-y: scroll;
}

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

a {
  color: inherit;
}

@keyframes fadeIn {
  0% {
    transform: translateY(10px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
.js-animation-group[data-animation=fadein] > * {
  transform: translateY(10px);
  opacity: 0;
}
.js-animation-group[data-animation=fadein] > *.is-show {
  animation: fadeIn 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) both;
}

.js-animation[data-animation=fadein] {
  transform: translateY(10px);
  opacity: 0;
}
.js-animation[data-animation=fadein].is-show {
  animation: fadeIn 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) both;
}

.js-animation-container[data-animation=fadein] > * {
  transform: translateY(10px);
  opacity: 0;
}
.js-animation-container[data-animation=fadein] > *.is-show {
  animation: fadeIn 0.5s cubic-bezier(0.39, 0.575, 0.565, 1) both;
}

.l-container {
  margin-inline: auto;
  padding-right: var(--padding-container, 2.4rem);
  padding-left: var(--padding-container, 2.4rem);
}

.l-header {
  z-index: 100;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
}

.l-main {
  overflow: hidden;
  background-color: #aacdf5;
}

.c-achivement {
  display: flex;
  position: relative;
  align-items: center;
  border-radius: 2rem;
}
.c-achivement:nth-child(1), .c-achivement:nth-child(4) {
  background-color: #008dd1;
}
.c-achivement:nth-child(2), .c-achivement:nth-child(3) {
  background-color: #004486;
}
.c-achivement__image {
  z-index: 1;
  position: absolute;
}
.c-achivement__text {
  display: block;
  z-index: 2;
  position: relative;
  margin-left: auto;
}
.c-achivement__note {
  position: absolute;
  top: 100%;
  left: 0;
  padding-left: 1.2em;
  font-size: 2.66667vw;
  letter-spacing: -0.02em;
  text-align: left;
  text-indent: -1em;
}
.c-achivement.-founding {
  padding: 2rem 1.7rem 1.7rem;
}
.c-achivement.-founding .c-achivement__image {
  top: 50%;
  left: -1.55rem;
  width: 35.832%;
  translate: 0 -50%;
}
.c-achivement.-founding .c-achivement__text {
  width: 67.432%;
}
.c-achivement.-sales {
  margin-bottom: 0.5em;
  padding: 1.65rem 1.65rem 1.1rem;
}
.c-achivement.-sales .c-achivement__image {
  bottom: 1.3rem;
  left: 0.9rem;
  width: 35.283%;
}
.c-achivement.-sales .c-achivement__text {
  width: 62.37%;
}
.c-achivement.-waterーsaving {
  padding: 1.75rem 1.75rem 1.8rem;
}
.c-achivement.-waterーsaving .c-achivement__image {
  bottom: -0.75rem;
  left: -0.65rem;
  width: 34.735%;
}
.c-achivement.-waterーsaving .c-achivement__text {
  width: 62.683%;
}
.c-achivement.-co2 {
  padding: 1.4rem 1.6rem 1.65rem;
}
.c-achivement.-co2 .c-achivement__image {
  top: -0.95rem;
  right: -0.15rem;
  width: 52.834%;
}
.c-achivement.-co2 .c-achivement__text {
  width: 97.723%;
}

.c-backtop {
  display: grid;
  display: none;
  z-index: 80;
  position: -webkit-sticky;
  position: sticky;
  bottom: 9rem;
  place-content: center;
  width: 5rem;
  height: 5rem;
  margin-top: -2.5rem;
  margin-right: 2.3rem;
  margin-left: auto;
  border: 0.1rem solid #fff;
  border-radius: 50%;
  background: linear-gradient(-51deg, rgb(0, 70, 151) 42%, rgb(2, 188, 197));
  cursor: pointer;
  transition: 0.5s scale cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-backtop::before {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 25%;
  height: 25%;
  translate: -50% -25%;
  rotate: -45deg;
  border-top: 0.15em solid currentColor;
  border-right: 0.15em solid currentColor;
  content: "";
  color: #fff;
}

.c-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 6rem;
  padding: 0.5em 1em;
  gap: 0.75em;
  border-radius: 10rem;
  color: #fff;
  font-weight: bold;
  font-size: 1.5rem;
  line-height: 1.3333;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
}
.c-button::after {
  display: inline-block;
  width: 0.65em;
  height: 0.65em;
  rotate: 45deg;
  border-top: 0.15em solid currentColor;
  border-right: 0.15em solid currentColor;
  content: "";
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-button.-green {
  position: relative;
  background-color: #1dc4ac;
  transition: 0.5s opacity cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-button.-green::after {
  position: absolute;
  top: 50%;
  right: 1.6rem;
  translate: 0 -50%;
}
.c-button.-blue {
  position: relative;
  background-color: #009ce7;
  transition: 0.5s opacity cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-button.-blue::after {
  position: absolute;
  top: 50%;
  right: 1.6rem;
  translate: 0 -50%;
}
.c-button.-navy {
  background-color: #02288b;
}
.c-button.-white {
  position: relative;
  min-height: 5rem;
  overflow: hidden;
  background-color: #fff;
  box-shadow: 0 0 2.45rem rgba(159, 173, 192, 0.47);
  color: #02288b;
  text-align: center;
  transition: 0.5s color cubic-bezier(0.075, 0.82, 0.165, 1), 0.5s box-shadow cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-button.-white::before {
  z-index: -1;
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  translate: 101% 0;
  background: #013c99;
  content: "";
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-button.-white::after {
  border-color: #009ce7;
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1), 0.5s border-color cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-button.-prev, .c-button.-next {
  display: grid !important;
  place-content: center;
  width: 5rem !important;
  height: 5rem !important;
  border-radius: 50%;
  background-color: #009ce7;
  --swiper-navigation-color: #fff;
  position: relative;
  min-height: unset;
  padding: 0;
  transition: 0.5s scale cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-button.-prev::after, .c-button.-next::after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 25%;
  height: 25%;
}
.c-button.-prev::after {
  translate: -25% -50%;
  rotate: -135deg;
}
.c-button.-next::after {
  translate: -75% -50%;
}

.c-description {
  font-weight: bold;
  line-height: 1.75;
  text-align: center;
}

.c-dl {
  padding: 0 2.3rem;
  border-radius: 1rem;
  background-color: #fff;
  --letter-spacing: 0;
}
.c-dl__wrap {
  display: grid;
  padding: 2.4rem 0;
  gap: 0.75em;
}
.c-dl__wrap dt {
  color: #004486;
  font-weight: bold;
  font-size: 128.57%;
}
.c-dl__wrap + .c-dl__wrap {
  border-top: 1px solid #d5d5d5;
}
.c-dl__wrap dd strong {
  display: block;
}
.c-dl__wrap dd ul {
  display: flex;
  flex-direction: column;
  gap: 0.75em;
}
.c-dl__wrap dd ul.work-place {
  gap: 0;
}
.c-dl__wrap dd ul.salary {
  flex-wrap: wrap;
  gap: 0;
}
.c-dl__wrap dd ul.salary li {
  flex: inherit;
  width: auto;
  max-width: calc(100% - 2rem);
}
.c-dl__wrap dd ul.allowance {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0 1em;
}
.c-dl__wrap dd ul.allowance li::before {
  margin-right: 0.25em;
  margin-left: 0.5em;
  content: "・";
}
.c-dl__wrap dd small {
  display: block;
  font-size: 85.7%;
}

.c-entry {
  width: 100%;
  padding: 1.3rem 1.2rem;
  background-color: #fff;
  box-shadow: -0.08vw 0.2533333333vw 9.0666666667vw 0.9066666667vw rgba(31, 33, 36, 0.19);
}
.c-entry__buttons.-pc {
  display: none;
}
.c-entry__buttons.-sp {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.15rem;
}
.c-entry__button a {
  display: inline-grid;
  place-content: center;
  width: 100%;
  height: 5rem;
  color: #fff;
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 1.357;
  text-align: center;
  text-decoration: none;
  --letter-spacing: 0;
  border-radius: 1rem;
  pointer-events: auto;
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-entry__button a span {
  display: block;
  font-size: 1.4rem;
}
.c-entry__button.-navy a {
  background-color: #02288b;
}
.c-entry__button.-green a {
  background-color: #1dc4ac;
}

.c-gnav li {
  border-bottom: 1px solid #2346a1;
}
.c-gnav li a {
  display: block;
  padding: 2rem 3.2rem;
  color: #fff;
  text-decoration: none;
}
.c-gnav__title {
  color: #1dc4ac;
  font-weight: bold;
  font-size: 1.5rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.c-gnav__sub-title {
  font-weight: bold;
  font-size: 1.8rem;
  line-height: 1.67;
}

.c-hamburger {
  display: grid;
  place-content: center;
  width: 4rem;
  height: 4rem;
  padding: 0;
  border: none;
  background: transparent;
  cursor: pointer;
}
.c-hamburger__line {
  display: block;
  position: relative;
  width: 2.8rem;
  height: 0.4rem;
  border-radius: 99px;
  background-color: #02288b;
  content: "";
}
.c-hamburger__line::before, .c-hamburger__line::after {
  display: block;
  position: absolute;
  width: 2.8rem;
  height: 0.4rem;
  border-radius: 99px;
  background-color: #02288b;
  content: "";
  transition: 0.5s rotate cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-hamburger__line::before {
  top: -0.95rem;
}
.c-hamburger__line::after {
  bottom: -0.95rem;
}
.c-hamburger[aria-expanded=true] .c-hamburger__line {
  background-color: transparent;
}
.c-hamburger[aria-expanded=true] .c-hamburger__line::before {
  top: 50%;
  rotate: -45deg;
  opacity: 1;
}
.c-hamburger[aria-expanded=true] .c-hamburger__line::after {
  top: 50%;
  rotate: 45deg;
  opacity: 1;
}

.c-heading {
  margin-bottom: 0.5em;
  padding: 0 var(--padding-container, 2.4rem) 0.5em;
  border-bottom: 0.2rem solid currentColor;
  color: var(--text-color, #013c99);
  font-size: 2.6rem;
  line-height: 1.46;
  letter-spacing: 0.1em;
  text-align: center;
}
.c-heading--sub {
  margin-top: 2em;
  margin-bottom: 0.5em;
  font-size: 2.3rem;
  text-align: center;
}
.c-heading--line {
  margin-top: 1.5em;
  margin-bottom: 0.5em;
  color: #02288b;
  font-size: 2.3rem;
  letter-spacing: 0.12em;
  text-align: center;
}
.c-heading--line::after {
  display: block;
  width: 4rem;
  height: 0.3rem;
  margin-top: 0.3em;
  margin-inline: auto;
  background: linear-gradient(135deg, #02288b 40%, #009ce7 60%);
  content: "";
}
.c-heading--h4 {
  margin-top: 1em;
  margin-bottom: 0.5em;
  font-size: 1.7rem;
  text-align: center;
}

.c-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2.4rem;
  gap: 1.75rem;
  background-color: #fff;
  text-align: center;
}
.c-links__sns {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.55rem;
}
.c-links__sns img {
  width: 4.5rem;
}
.c-links__sns a {
  display: block;
  transition: 0.5s scale cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-links__corporate {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.1em;
  color: #333333;
  font-weight: bold;
  text-decoration: none;
  transition: 0.3s opacity cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-links__corporate::after {
  width: 1.1em;
  height: 1.1em;
  background: url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20id='b'%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%20512%20512'%3e%3cg%20id='c'%3e%3cpath%20d='M96,0v416h416V0H96ZM472,376H136V40h336v336Z'%20style='fill:%23333;'/%3e%3cpolygon%20points='40%20472%2040%20296%2040%20136%2040%2096%200%2096%200%20512%20416%20512%20416%20472%20376%20472%2040%20472'%20style='fill:%23333;'/%3e%3cpolygon%20points='232.812%20312.829%20350.671%20194.969%20350.671%20279.766%20390.671%20279.766%20390.671%20126.688%20237.594%20126.688%20237.594%20166.688%20322.39%20166.688%20204.531%20284.547%20232.812%20312.829'%20style='fill:%23333;'/%3e%3c/g%3e%3c/svg%3e") no-repeat center center/contain;
  content: "";
}

.c-movie-list__item a {
  text-decoration: none;
}
.c-movie-list__item p {
  margin-top: 0.5em;
  color: #333333;
  font-weight: bold;
  line-height: 1.545;
}
.c-movie-list__thumb {
  position: relative;
  aspect-ratio: 416/234;
  overflow: hidden;
  border: 1px solid #e6e6e6;
  border-radius: 0.5rem;
}
.c-movie-list__thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  scale: 1.001;
  transition: 0.5s scale cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-movie-list__thumb::after {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  width: 4.1rem;
  height: 4.1rem;
  background: url(../images/icon_play.webp) no-repeat center center/contain;
  content: "";
}

.c-news {
  position: relative;
  width: 100%;
  height: 4.3rem;
  background-color: #ffd800;
}
.c-news__heading {
  box-sizing: border-box;
  display: flex;
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  flex-direction: column;
  align-items: center;
  width: 22.67%;
  height: 100%;
  background-color: #02288b;
  color: #fff;
  -webkit-clip-path: polygon(0 0, 100% 0, calc(100% - 2.5rem) 100%, 0% 100%);
  padding-right: 2rem;
          clip-path: polygon(0 0, 100% 0, calc(100% - 2.5rem) 100%, 0% 100%);
}
.c-news__heading h2 {
  font-size: 1.5rem;
  text-transform: uppercase;
  --letter-spacing: 0.1em;
}
.c-news__buttons {
  display: flex;
  align-items: center;
  gap: 1em;
  --swiper-navigation-size: 1rem;
  --swiper-navigation-color: #fff;
}
.c-news__buttons .swiper-button-prev,
.c-news__buttons .swiper-button-next {
  position: static;
  margin-top: 0;
}
.swiper-vertical .c-news__buttons .swiper-button-prev {
  rotate: -90deg;
}
.swiper-vertical .c-news__buttons .swiper-button-next {
  rotate: -90deg;
}
.c-news__item {
  display: flex !important;
  flex-direction: column;
  justify-content: center;
  font-size: 1.2rem;
  line-height: 1.4;
}
.c-news .swiper-wrapper {
  padding-left: calc(22.67% + 1.8rem);
}

.c-overlay {
  display: none;
  z-index: 90;
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.7);
}

.c-pagenav {
  display: none;
  margin-top: 1.2rem;
}
.c-pagenav li {
  position: relative;
  width: 1.4rem;
  height: 3.4rem;
  pointer-events: auto;
}
.c-pagenav li a {
  display: inline-block;
  display: grid;
  z-index: 2;
  place-content: center;
  width: auto;
  min-width: 14.5rem;
  height: 100%;
  padding: 0 1em;
  translate: 100% 0;
  border-radius: 99px 0 0 99px;
  background-color: #fff;
  box-shadow: 0px 0px 10px 0px rgba(20, 40, 54, 0.23);
  color: #006ac8;
  font-weight: bold;
  font-size: 1.5rem;
  text-decoration: none;
  text-transform: uppercase;
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-pagenav li span {
  display: block;
  position: absolute;
  top: 50%;
  right: 2rem;
  width: 1.4rem;
  height: 1.4rem;
  translate: 0 -50%;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0px 0px 10px 0px rgba(20, 40, 54, 0.23);
}
.c-pagenav li.is-active {
  width: auto;
}
.c-pagenav li.is-active span {
  display: none;
}
.c-pagenav li.is-active a {
  translate: 0 0;
  pointer-events: none;
}

.c-projects__item.swiper-slide {
  width: 78.8rem;
}
.c-projects__buttons {
  display: flex;
  z-index: 3;
  position: absolute;
  top: 16rem;
  left: 0;
  justify-content: space-between;
  width: 100%;
  pointer-events: none;
}
.c-projects__buttons .c-button {
  pointer-events: auto;
}

.c-project {
  display: block;
  display: grid;
  position: relative;
  grid-template-rows: 18.15rem 1fr;
  min-height: 40.9rem;
  border-radius: 1.3rem;
  background-color: #000;
  color: #fff;
  text-align: left;
  text-decoration: none;
}
a.c-project {
  cursor: pointer;
}

.c-project__head {
  position: relative;
  grid-row: 1/2;
  align-self: end;
}
.c-project__image {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 18.15rem;
  overflow: hidden;
  border-radius: 1.3rem 1.3rem 0 0;
}
.c-project__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-project__lead {
  display: grid;
  z-index: 2;
  position: relative;
  align-items: center;
  width: min(var(--sp-width) + 3.25rem, 100% - 3.5rem);
  padding: 0.65rem 0.85rem 0.65rem 2.4rem;
  border-radius: 0 9.9rem 9.9rem 0;
  background-color: var(--bg-color);
}
.c-project__title {
  z-index: 2;
  position: relative;
  padding: 1rem 2.4rem 1.6rem;
  font-size: 2.1rem;
  line-height: 1.38;
}
.c-project__description {
  padding: 1.6rem 2.5rem 3rem;
  font-size: 1.4rem;
}
.c-project__more {
  display: inline-flex;
  z-index: 1;
  position: absolute;
  right: -1.1rem;
  bottom: -2.5rem;
  align-items: center;
  justify-content: center;
  width: 17rem;
  min-height: 5rem;
  padding: 0.5em 1em;
  overflow: hidden;
  gap: 0.75em;
  border-radius: 10rem;
  background-color: #fff;
  box-shadow: 0 0 4.9rem rgba(159, 173, 192, 0.47);
  color: #02288b;
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 1.3333;
  text-align: center;
  text-decoration: none;
}
.c-project__more::before {
  z-index: -1;
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  translate: 101% 0;
  background: #013c99;
  content: "";
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1);
}
.c-project__more::after {
  display: inline-block;
  width: 0.65em;
  height: 0.65em;
  rotate: 45deg;
  border-top: 0.15em solid currentColor;
  border-right: 0.15em solid currentColor;
  border-color: #009ce7;
  content: "";
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1), 0.5s border-color cubic-bezier(0.075, 0.82, 0.165, 1);
}

.c-section__inner {
  z-index: 2;
  position: relative;
  padding: 4.4rem 0 2.8rem;
  background-color: #fff;
  box-shadow: 0px 0px 49px rgba(159, 173, 192, 0.47);
}
.c-section__inner .c-tag {
  position: absolute;
  top: 0;
  left: 0;
  translate: 0 -50%;
}
.c-section__inner > * {
  margin-top: 1em;
}
.c-section__inner > *:first-child {
  margin-top: 0;
}
.c-section__inner > *.c-heading {
  margin-top: 0;
}
.c-section__contents {
  padding-right: var(--padding-container, 2.4rem);
  padding-left: var(--padding-container, 2.4rem);
}
.c-section.-right .c-section__inner {
  margin-right: calc(-1 * var(--padding-container, 2.4rem));
  border-radius: 3rem 0 0 3rem;
}
.c-section.-right .c-section__inner .c-tag {
  position: absolute;
  top: 0;
  left: -0.65rem;
}
.c-section.-left .c-section__inner {
  margin-left: calc(-1 * var(--padding-container, 2.4rem));
  border-radius: 0 3rem 3rem 0;
}
.c-section + .c-section {
  margin-top: 9.25rem;
}

.c-stories .swiper {
  padding: 1.3rem 1.2rem 0;
}
.c-stories .swiper-wrapper {
  align-items: stretch !important;
}
.c-stories .swiper-slide {
  height: auto;
}
.c-stories__buttons {
  display: flex;
  z-index: 3;
  position: absolute;
  top: 8.7rem;
  left: 0;
  justify-content: space-between;
  width: 100%;
  pointer-events: none;
}
.c-stories__buttons .c-button {
  pointer-events: auto;
}

.c-story {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 2.8rem min(2.8rem, 4vw);
  border-radius: 1rem;
  background-image: repeating-linear-gradient(0deg, #e7eef5 0, #e7eef5 0.1rem, transparent 0.1rem, transparent 0.8rem), repeating-linear-gradient(90deg, #e7eef5 0, #e7eef5 0.1rem, transparent 0.1rem, transparent 0.8rem);
  background-color: #eef3f8;
  text-align: left;
  text-decoration: none;
}
.c-story:hover {
  opacity: 0.7;
}
.c-story__division {
  display: grid;
  position: absolute;
  top: -1.3rem;
  right: -0.5rem;
  place-content: center;
  width: 11rem;
  height: 3.3rem;
  background-color: var(--bg-color, #009ce7);
  color: #fff;
  font-weight: bold;
  --letter-spacing: 0;
  font-size: 1.6rem;
}
.c-story__head {
  display: grid;
  place-items: center;
  margin-bottom: 1.6rem;
  gap: 1.2rem;
}
.c-story__image {
  width: 14.2rem;
}
.c-story__title {
  width: 100%;
  padding-bottom: 0.75em;
  border-bottom: 0.1rem solid #02288b;
  font-size: 1.9rem;
  line-height: 1.5;
}
.c-story__title .c-story_shortlength_title {
  letter-spacing: -0.1em;
}
.c-story__title .c-story_shortlength_title01 {
  letter-spacing: -0.03em;
}
.c-story__background {
  width: 100%;
}
.c-story__description {
  margin-bottom: 2rem;
}
.c-story__figure {
  margin-bottom: 2.7rem;
}
.c-story__more {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: auto;
  margin-inline: auto;
  color: #02288b;
  font-weight: bold;
  text-decoration: underline;
  text-decoration-thickness: 0.125em;
  text-underline-offset: 0.4em;
}

.c-tag {
  --letter-spacing: 0.12em;
  padding: 0.1em 1em 0.1em 2.15em;
  background-color: var(--bg-color, #02288b);
  color: var(--text-color, #fff);
  font-weight: bold;
  font-size: 2.4rem;
  line-height: 1.16;
  text-transform: uppercase;
  -webkit-clip-path: polygon(0 0, 100% 0, calc(100% - 0.75em) 100%, 0% 100%);
  width: -webkit-min-content;
  width: -moz-min-content;
  width: min-content;
  text-indent: -1.85em;
          clip-path: polygon(0 0, 100% 0, calc(100% - 0.75em) 100%, 0% 100%);
}

.p-challenge {
  position: relative;
}
.p-challenge::before {
  position: absolute;
  top: -54.5rem;
  right: 0;
  width: 100%;
  height: 180%;
  background: url(../images/fig_green-circle-sp.webp) no-repeat center top/100%;
  content: "";
}
.p-challenge::after {
  z-index: 0;
  position: absolute;
  top: 80.15rem;
  left: 0;
  width: 100%;
  height: 280.8vw;
  background: url(../images/bg_blue-square02-sp.webp) no-repeat top left/100%;
  content: "";
}
.p-challenge .c-section__inner {
  z-index: 1;
  padding-top: 6.15rem;
}
.p-challenge__img01 {
  display: block;
}
.p-challenge__img02 {
  display: block;
}
.p-challenge__achivement {
  display: grid;
  max-width: 72.9333vw;
  margin-top: 1.6rem;
  margin-inline: auto;
  gap: 9vw;
}
.p-challenge__button {
  display: flex;
  width: calc(100% - 3rem);
  max-width: 72.9333vw;
  margin-top: 3.25rem;
  margin-inline: auto;
}

.p-drawer {
  display: none;
  z-index: 95;
  position: absolute;
  top: 6rem;
  left: 0;
  width: 100%;
  height: calc(100svh - 6rem);
  overflow: auto;
  background-color: #02288b;
}
.p-drawer__entry {
  display: grid;
  max-width: 28rem;
  margin-inline: auto;
  padding: 3.3rem 0;
  gap: 1.5rem;
}
.p-drawer__copy {
  display: grid;
  place-content: center;
  height: 4.5rem;
  background-color: #333333;
  color: #fff;
  font-size: 1.2rem;
}

.p-floating {
  z-index: 99;
  position: fixed;
  bottom: 0;
  width: 100%;
  pointer-events: none;
}

.p-footer {
  margin-top: -2.5rem;
}
.p-footer__copy {
  display: grid;
  place-content: center;
  padding: 1em;
  background-color: #333333;
  color: #fff;
  font-size: 1.2rem;
}

.p-header {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  height: 6rem;
  padding: 0 1rem;
  background-color: #fff;
}
.p-header__logo {
  display: flex;
  align-items: flex-end;
  gap: 1em;
}
.p-header__logo img {
  width: 15.6rem;
}
.p-header__logo p {
  position: relative;
  top: -0.1em;
  font-size: 1.1rem;
  line-height: 1.18;
}
.p-header__logo a {
  transition: 0.3s opacity cubic-bezier(0.075, 0.82, 0.165, 1);
}

.p-information {
  position: relative;
  padding-top: 9.7rem;
  padding-bottom: 5.3rem;
  background: linear-gradient(#0098e0, #013c99 48%);
}
.p-information .c-tag {
  position: absolute;
  top: 2.7rem;
  left: 0;
}
.p-information__entry {
  display: grid;
  max-width: 28rem;
  margin-top: 3.2rem;
  margin-inline: auto;
  gap: 1.5rem;
}
.p-information__detail {
  max-width: 107.5rem;
  margin-inline: auto;
}

.p-issue {
  z-index: 1;
  position: relative;
}
.p-issue .c-section__inner {
  z-index: 1;
  position: relative;
}
.p-issue .c-section__inner::before {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 27.1rem;
  background-color: #02288b;
  content: "";
  -webkit-clip-path: polygon(0 30%, 100% 0, 100% 100%, 0% 100%);
  z-index: -1;
  border-radius: 0 0 0 3rem;
          clip-path: polygon(0 30%, 100% 0, 100% 100%, 0% 100%);
}
.p-issue__img01 {
  display: block;
}
.p-issue__img02 {
  display: block;
}
.p-issue__conclusion {
  position: relative;
  margin-top: 10rem;
  color: #fff;
  font-weight: bold;
  font-size: 1.7rem;
  line-height: 1.8;
  text-align: center;
}

.p-mainvisual {
  position: relative;
  background-color: #aacdf5;
}
.p-mainvisual::before {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 180%;
  background: url(../images/fig_mv-blue-circle-sp.webp) no-repeat center top/100%;
  content: "";
}
.p-mainvisual::after {
  z-index: 0;
  position: absolute;
  top: calc(100% - 30vw);
  left: 0;
  width: 100%;
  height: 193.4667vw;
  background: url(../images/bg_blue-square01-sp.webp) no-repeat top left/100%;
  content: "";
}
.p-mainvisual__inner {
  z-index: 1;
  position: relative;
  padding-top: 54.26667vw;
  padding-bottom: 6rem;
}
.p-mainvisual__bg {
  z-index: 0;
  position: absolute;
  top: 16.53333vw;
  left: 50%;
  width: 89.73333vw;
  translate: -50% 0;
  -webkit-mask-image: radial-gradient(circle, rgb(0, 0, 0) 40%, rgba(0, 0, 0, 0) 80%);
          mask-image: radial-gradient(circle, rgb(0, 0, 0) 40%, rgba(0, 0, 0, 0) 80%);
}
.p-mainvisual__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-mainvisual__ring {
  position: absolute;
  top: -3.2vw;
  left: 50%;
  width: 120.53333%;
  max-width: unset;
  translate: -50% 0;
  -webkit-mask-image: linear-gradient(to bottom, black 74%, rgba(0, 0, 0, 0.2) 83%, transparent 86%);
  z-index: 1;
          mask-image: linear-gradient(to bottom, black 74%, rgba(0, 0, 0, 0.2) 83%, transparent 86%);
}
.p-mainvisual__ring img {
  animation: rotateAnimation 120s linear infinite;
}
.p-mainvisual__copy {
  z-index: 2;
  width: 28.9rem;
  margin-inline: auto;
  translate: 0 -50%;
}
.p-mainvisual__copy img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.p-mainvisual__text {
  margin-top: 30vw;
  font-size: 1.5rem;
  text-align: center;
  --letter-spacing: 0.14em;
  z-index: 2;
  color: #fff;
  line-height: 1.8;
}
.p-mainvisual__movie {
  z-index: 3;
  position: absolute;
  top: 78.1vw;
  left: 2.958vw;
  width: 27.46667vw;
  filter: drop-shadow(4.4vw 4.4vw 3.6vw rgba(17, 37, 89, 0.41));
  transition: 0.5s translate cubic-bezier(0.075, 0.82, 0.165, 1);
}

@keyframes rotateAnimation {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.p-movie__movies {
  margin-top: 3rem;
}
.p-movie__buttons {
  display: flex;
  z-index: 2;
  position: absolute;
  top: 0;
  right: 1.85rem;
  margin-top: 0;
  gap: 1.65rem;
  translate: 0 -50%;
}
.p-movie .c-description {
  padding-right: var(--padding-container, 2.4rem);
  padding-left: var(--padding-container, 2.4rem);
}
.p-movie .c-movie-list {
  width: 100%;
  padding-right: var(--padding-container, 2.4rem);
  padding-left: var(--padding-container, 2.4rem);
}
.p-movie .c-section__inner {
  position: relative;
}

.p-people {
  position: relative;
}
.p-people::before {
  position: absolute;
  top: -40.7rem;
  right: 0;
  width: 100%;
  height: 180%;
  background: url(../images/fig_green-circle-sp.webp) no-repeat center top/100%;
  content: "";
}
.p-people__stories {
  position: relative;
  max-width: 32.6rem;
  margin-top: 3rem;
  margin-inline: auto;
}
.p-people__button {
  display: block;
  width: calc(100% - 3rem);
  max-width: 72.9333vw;
  margin-top: 3.25rem;
  margin-inline: auto;
  padding: 0.75em;
  line-height: 1.5;
}
.p-people__button::after {
  margin-left: 0.5em;
}

.p-project {
  position: relative;
}
.p-project .c-section__inner {
  padding-bottom: 5.6rem;
}
.p-project .c-section__inner:has(a.c-project) {
  padding-bottom: 0;
}
.p-project::before {
  position: absolute;
  top: -64.75rem;
  left: 0;
  width: 100%;
  height: 180%;
  background: url(../images/fig_purple-circle-sp.webp) no-repeat center top/100%;
  content: "";
}
.p-project__list {
  position: relative;
  margin-top: 3rem;
  margin-right: calc(-1 * var(--padding-container, 2.4rem));
  margin-left: calc(-1 * var(--padding-container, 2.4rem));
}
.p-project__list .swiper {
  padding-right: 2.5rem;
  padding-left: 2.5rem;
}
.p-project__list .swiper-wrapper:has(a.c-project) {
  padding-bottom: 5.6rem;
}

.u-bg-color--white {
  background-color: #fff;
}
.u-bg-color--navy {
  background-color: #02288b;
}
.u-bg-color--blue {
  background-color: #009ce7;
}
.u-bg-color--black {
  background-color: #333333;
}

.u-color--white {
  color: #fff;
}
.u-color--navy {
  color: #02288b;
}
.u-color--blue {
  color: #009ce7;
}
.u-color--black {
  color: #333333;
}

.u-display--ib {
  display: inline-block;
}
.u-display--sp {
  display: block;
}
.u-display--pc {
  display: none;
}
.u-display--pc880 {
  display: none;
}

.u-font--normal {
  font-weight: 400;
}
.u-font--medium {
  font-weight: 500;
}
.u-font--bold {
  font-weight: 700;
}

.u-lh-150 {
  line-height: 1.5;
}

.u-mt-0 {
  margin-top: 0 !important;
}

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

.u-mt-1 {
  margin-top: 0.5rem !important;
}

.u-mb-1 {
  margin-bottom: 0.5rem !important;
}

.u-mt-2 {
  margin-top: 1rem !important;
}

.u-mb-2 {
  margin-bottom: 1rem !important;
}

.u-mt-3 {
  margin-top: 1.5rem !important;
}

.u-mb-3 {
  margin-bottom: 1.5rem !important;
}

.u-mt-4 {
  margin-top: 2rem !important;
}

.u-mb-4 {
  margin-bottom: 2rem !important;
}

.u-mt-5 {
  margin-top: 2.5rem !important;
}

.u-mb-5 {
  margin-bottom: 2.5rem !important;
}

.u-mt-6 {
  margin-top: 3rem !important;
}

.u-mb-6 {
  margin-bottom: 3rem !important;
}

.u-mt-7 {
  margin-top: 3.5rem !important;
}

.u-mb-7 {
  margin-bottom: 3.5rem !important;
}

.u-mt-8 {
  margin-top: 4rem !important;
}

.u-mb-8 {
  margin-bottom: 4rem !important;
}

.u-mt-9 {
  margin-top: 4.5rem !important;
}

.u-mb-9 {
  margin-bottom: 4.5rem !important;
}

.u-mt-10 {
  margin-top: 5rem !important;
}

.u-mb-10 {
  margin-bottom: 5rem !important;
}

.u-mt-11 {
  margin-top: 5.5rem !important;
}

.u-mb-11 {
  margin-bottom: 5.5rem !important;
}

.u-mt-12 {
  margin-top: 6rem !important;
}

.u-mb-12 {
  margin-bottom: 6rem !important;
}

.u-mt-13 {
  margin-top: 6.5rem !important;
}

.u-mb-13 {
  margin-bottom: 6.5rem !important;
}

.u-mt-14 {
  margin-top: 7rem !important;
}

.u-mb-14 {
  margin-bottom: 7rem !important;
}

.u-mt-15 {
  margin-top: 7.5rem !important;
}

.u-mb-15 {
  margin-bottom: 7.5rem !important;
}

.u-mt-16 {
  margin-top: 8rem !important;
}

.u-mb-16 {
  margin-bottom: 8rem !important;
}

.u-mt-17 {
  margin-top: 8.5rem !important;
}

.u-mb-17 {
  margin-bottom: 8.5rem !important;
}

.u-mt-18 {
  margin-top: 9rem !important;
}

.u-mb-18 {
  margin-bottom: 9rem !important;
}

.u-mt-19 {
  margin-top: 9.5rem !important;
}

.u-mb-19 {
  margin-bottom: 9.5rem !important;
}

.u-mt-20 {
  margin-top: 10rem !important;
}

.u-mb-20 {
  margin-bottom: 10rem !important;
}

.u-marker--yellow {
  background: linear-gradient(transparent 70%, #fbe536 70%, #fbe536 85%, transparent 100%);
}

.u-text--left {
  text-align: left;
}
.u-text--center {
  text-align: center;
}
.u-text--right {
  text-align: right;
}
.u-text--uppercase {
  text-transform: uppercase;
}
.u-text--lg {
  font-size: 120%;
}

.u-whitespace--normal {
  white-space: normal;
}
.u-whitespace--nowrap {
  white-space: nowrap;
}
@media (hover: hover) and (min-width: 769px){
  .c-entry__button a:hover {
    translate: -1rem 0;
  }
}
@media (min-width: 769px){
  :root {
    --padding-container: 4.8rem;
  }
  html {
    font-size: clamp(7.5px, 0.714286vw, 10px);
  }
  body {
    margin-bottom: 0;
    font-size: max(14px, 1.8rem);
  }
  .l-container {
    max-width: calc(108rem + 2 * var(--padding-container, 2.4rem));
  }
  .c-achivement {
    aspect-ratio: 470/265;
    border-radius: 4rem;
  }
  .c-achivement__note {
    padding-left: 1.5em;
    font-size: 1.4rem;
  }
  .c-achivement.-founding {
    padding-right: 2.8rem;
  }
  .c-achivement.-founding .c-achivement__image {
    left: -2.6rem;
    width: 18rem;
  }
  .c-achivement.-founding .c-achivement__text {
    width: 27.9rem;
  }
  .c-achivement.-sales {
    margin-bottom: 0;
    padding-right: 3.2rem;
  }
  .c-achivement.-sales .c-achivement__image {
    bottom: 1.8rem;
    left: 1.5rem;
    width: 17rem;
  }
  .c-achivement.-sales .c-achivement__text {
    width: 25.4rem;
  }
  .c-achivement.-waterーsaving {
    padding-right: 3.6rem;
  }
  .c-achivement.-waterーsaving .c-achivement__image {
    bottom: -1.7rem;
    left: -1.1rem;
    width: 15.4rem;
  }
  .c-achivement.-waterーsaving .c-achivement__text {
    width: 25.1rem;
  }
  .c-achivement.-co2 {
    padding-right: 4rem;
  }
  .c-achivement.-co2 .c-achivement__image {
    top: -1.8rem;
    right: -0.03rem;
    width: 24.9rem;
  }
  .c-achivement.-co2 .c-achivement__text {
    width: 39.1rem;
  }
  .c-backtop {
    bottom: 3.2rem;
    width: 8rem;
    height: 8rem;
    margin-top: -4rem;
    margin-right: 3.2rem;
  }
  .c-button {
    min-height: 8.6rem;
    padding: 0.5em 1.5em;
    font-size: 2.4rem;
    line-height: 1.4;
  }
  .c-button.-green::after {
    right: 2.4rem;
  }
  .c-button.-blue::after {
    right: 2.4rem;
  }
  .c-button.-white {
    min-height: 8.6rem;
    box-shadow: 0 0 4.9rem rgba(159, 173, 192, 0.47);
  }
  .c-button.-prev, .c-button.-next {
    width: 7rem !important;
    height: 7rem !important;
  }
  .c-description {
    font-size: 2.2rem;
  }
  .c-dl {
    padding: 1.5rem 5.6rem;
    border-radius: 2rem;
    font-size: max(14px, 1.6rem);
  }
  .c-dl__wrap {
    grid-template-columns: 16rem 1fr;
    padding: 3.6rem 0;
    gap: 0;
  }
  .c-dl__wrap dt {
    font-size: 137.5%;
  }
  .c-dl__wrap dd strong {
    font-size: 1.8rem;
  }
  .c-dl__wrap dd ul {
    flex-direction: row;
    gap: 4rem;
  }
  .c-dl__wrap dd ul li {
    flex-basis: auto;
    width: calc(50% - 2rem);
    max-width: calc(50% - 2rem);
  }
  .c-dl__wrap dd ul.work-place {
    gap: 4rem;
  }
  .c-dl__wrap dd ul.salary {
    gap: 2rem 4rem;
  }
  .c-dl__wrap dd ul.salary li {
    width: calc(50% - 2rem);
    max-width: calc(50% - 2rem);
  }
  .c-dl__wrap dd small {
    font-size: 87.5%;
  }
  .c-entry {
    padding: 0;
    background-color: transparent;
    box-shadow: none;
  }
  .c-entry__buttons.-pc {
    display: grid;
    place-items: end;
    gap: 1.1rem;
    translate: 1rem 0;
  }
  .c-entry__buttons.-sp {
    display: none;
  }
  .c-entry__button a {
    width: 18.6rem;
    height: 4.2rem;
    padding: 0 1rem 0 0;
    border-radius: 2.1rem 0 0 2.1rem;
    box-shadow: 0px 0px 10px 0px rgba(20, 40, 54, 0.23);
    font-size: 2rem;
  }
  .c-heading {
    border-bottom: 0.4rem solid currentColor;
    font-size: 5.4rem;
  }
  .c-heading--sub {
    font-size: 3.8rem;
  }
  .c-heading--line {
    font-size: 3.8rem;
  }
  .c-heading--line::after {
    width: 8rem;
    height: 0.4rem;
  }
  .c-heading--h4 {
    font-size: 2.8rem;
  }
  .c-links {
    gap: 4.5rem;
  }
  .c-links {
    flex-direction: row;
    justify-content: center;
  }
  .c-links__sns {
    gap: 2.5rem;
  }
  .c-links__sns img {
    width: 5rem;
  }
  .c-movie-list__item p {
    font-size: 2.2rem;
  }
  .c-movie-list__thumb {
    border-radius: 1rem;
  }
  .c-movie-list__thumb::after {
    width: 6.2rem;
    height: 6.2rem;
  }
  .c-news {
    height: 4.2rem;
  }
  .c-news__heading {
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    -webkit-clip-path: polygon(0 0, 100% 0, calc(100% - 4.7rem) 100%, 0% 100%);
    padding-right: 4.7rem;
    gap: 1em;
            clip-path: polygon(0 0, 100% 0, calc(100% - 4.7rem) 100%, 0% 100%);
  }
  .c-news__heading h2 {
    font-size: 2.2rem;
  }
  .c-news__buttons {
    gap: 0.5em;
    --swiper-navigation-size: 1.3rem;
  }
  .c-news__item {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 1em;
    font-size: 1.6rem;
  }
  .c-news .swiper-wrapper {
    padding-left: 22.67%;
  }
  .c-pagenav {
    display: grid;
    row-gap: 0.3em;
    place-items: end;
  }
  .c-projects__buttons {
    top: 50%;
    left: 50%;
    width: 97.6rem;
    translate: -50% -50%;
  }
  .c-project {
    grid-template-rows: 1fr;
    aspect-ratio: 788/460;
    border-radius: 2rem;
    background-color: transparent;
  }
  .c-project__image {
    z-index: -1;
    height: 100%;
    inset: 0;
    border-radius: 2rem;
  }
  .c-project__lead {
    width: calc(var(--pc-width) + 7rem);
    padding: 0.65rem 2.5rem 0.65rem 4.5rem;
  }
  .c-project__title {
    padding: 1.5rem 4.5rem;
    font-size: 3rem;
  }
  .c-project__description {
    padding: 0 4.5rem 3.2rem;
    font-size: 1.8rem;
  }
  .c-project__more {
    right: 0.5rem;
    bottom: -4.2rem;
    width: 22rem;
    min-height: 6rem;
    padding: 0.5em 1.5em;
    font-size: 1.8rem;
    line-height: 1.4;
  }
  .c-section__inner {
    padding: 9.6rem 0 7.4rem;
  }
  .c-section__inner .c-tag {
    top: -2.4rem;
    translate: 0 0;
  }
  .c-section__contents {
    text-align: center;
  }
  .c-section.-right .c-section__inner {
    margin-right: calc(50% - 50vw);
    border-radius: 6rem 0 0 6rem;
  }
  .c-section.-right .c-section__inner .c-tag {
    top: -2.4rem;
    left: -1.15rem;
  }
  .c-section.-left .c-section__inner {
    margin-left: calc(50% - 50vw);
    border-radius: 0 6rem 6rem 0;
  }
  .c-section + .c-section {
    margin-top: 17.4rem;
  }
  .c-stories .swiper {
    padding: 1rem 1.7rem 0;
  }
  .c-stories__buttons {
    top: 50%;
    left: -4.1rem;
    width: calc(100% + 8.2rem);
    translate: 0 -50%;
  }
  .c-story {
    padding: 5.6rem 3rem 3.6rem;
    border-radius: 2rem;
  }
  .c-story__division {
    top: -1rem;
    right: 0;
    width: 14.35rem;
    height: 4.336rem;
    font-size: 2.065rem;
  }
  .c-story__head {
    grid-template-columns: auto 1fr;
    align-items: start;
    margin-bottom: 2rem;
    gap: 0.8rem 2rem;
  }
  .c-story__image {
    grid-row: 1/3;
    width: 17.5rem;
    margin-top: -2.4rem;
    margin-left: -5.2rem;
  }
  .c-story__title {
    padding-bottom: 0.5em;
    font-size: min(2.2rem, 1.8vw);
    letter-spacing: -0.04em;
  }
  .c-story__background {
    grid-column: 2/3;
  }
  .c-story__description {
    margin-bottom: 2.4rem;
  }
  .c-story__figure {
    margin-bottom: 4rem;
  }
  .c-tag {
    font-size: 6.27rem;
    white-space: nowrap;
  }
  .p-challenge::before {
    width: 121.6rem;
    height: 167.9rem;
    background: url(../images/fig_green-circle.webp) no-repeat center top/100%;
  }
  .p-challenge::after {
    top: auto;
    bottom: -105.1rem;
    height: 150.429vw;
    background: url(../images/bg_blue-square02.webp) no-repeat top left/100%;
  }
  .p-challenge .c-section__inner {
    padding-top: 9.6rem;
  }
  .p-challenge__img01 {
    max-width: 97rem;
    margin-inline: auto;
  }
  .p-challenge__img02 {
    max-width: 103.6rem;
    margin-inline: auto;
    translate: -1.2% 0;
  }
  .p-challenge__achivement {
    grid-template-columns: 1fr 1fr;
    max-width: 98rem;
    margin-top: 5.6rem;
    margin-inline: auto;
    gap: 7rem 4rem;
  }
  .p-challenge__button {
    max-width: 101rem;
    margin-top: 6.8rem;
  }
  .p-floating {
    z-index: 101;
    top: 5.4rem;
    right: 0;
    bottom: auto;
    width: auto;
  }
  .p-footer {
    margin-top: -4rem;
  }
  .p-footer__copy {
    padding: 0.75em;
    font-size: 1.6rem;
  }
  .p-header {
    grid-template-columns: auto;
    height: 8.4rem;
    padding: 0 2.4rem;
  }
  .p-header__logo {
    gap: 2em;
  }
  .p-header__logo img {
    width: 19.9rem;
  }
  .p-header__logo p {
    font-size: 2.2rem;
  }
  .p-header__hamburger {
    display: none;
  }
  .p-information {
    padding-top: 19.5rem;
    padding-bottom: 10.4rem;
  }
  .p-information .c-tag {
    top: 3.8rem;
  }
  .p-information__entry {
    grid-template-columns: auto auto;
    justify-content: center;
    max-width: unset;
    margin-top: 5.4rem;
    gap: 4.6rem;
  }
  .p-information__entry .c-button {
    min-width: 44rem;
  }
  .p-issue .c-section__inner::before {
    height: 42.3rem;
    -webkit-clip-path: polygon(0 45%, 100% 0, 100% 100%, 0% 100%);
    border-radius: 0 0 0 6rem;
            clip-path: polygon(0 45%, 100% 0, 100% 100%, 0% 100%);
  }
  .p-issue__img01 {
    max-width: 100rem;
    margin-inline: auto;
  }
  .p-issue__img02 {
    max-width: 100rem;
    margin-inline: auto;
  }
  .p-issue__conclusion {
    margin-top: 17rem;
    font-size: 3rem;
  }
  .p-mainvisual::before {
    background: url(../images/fig_mv-blue-circle.webp) no-repeat;
    background-position: left -73.49vw top -93.333333vw;
    background-size: 193.8% auto;
  }
  .p-mainvisual::after {
    top: calc(100% - 23.4rem);
    height: 117.857vw;
    background: url(../images/bg_blue-square01.webp) no-repeat top left/100%;
  }
  .p-mainvisual__inner {
    display: grid;
    place-content: center;
    place-items: center;
    height: 88.21429vw;
    padding-top: 0;
    padding-bottom: 0;
  }
  .p-mainvisual__bg {
    top: 6.5vw;
    width: 88.21429vw;
    translate: -52% 0;
  }
  .p-mainvisual__ring {
    top: -15.4vw;
    width: 123.35714%;
  }
  .p-mainvisual__ring img {
    animation: rotateAnimation 200s linear infinite;
  }
  .p-mainvisual__copy {
    width: 44vw;
    translate: 0 0;
  }
  .p-mainvisual__text {
    margin-top: 7.8rem;
    line-height: 1.9;
    --letter-spacing: 0.18em;
    font-size: max(14px, 1.57vw);
  }
  .p-mainvisual__movie {
    top: 60.7vw;
    left: 4vw;
    width: 18.57143vw;
  }
  .p-movie .c-movie-list {
    padding-right: 2.4rem;
    padding-left: 2.4rem;
  }
  .p-people::before {
    top: -108.5rem;
    width: 121.6rem;
    height: 167.9rem;
    background: url(../images/fig_green-circle.webp) no-repeat center top/100%;
  }
  .p-people__stories {
    max-width: 110.3rem;
    margin-top: 5.8rem;
  }
  .p-people__button {
    display: flex;
    max-width: 101rem;
    margin: 6.8rem auto 0;
    padding: 0.5em 1em;
  }
  .p-people__button::after {
    margin-left: 0;
  }
  .p-project .c-section__inner {
    padding-bottom: 9.1rem;
  }
  .p-project::before {
    top: -118.4rem;
    width: 91.6rem;
    height: 167.9rem;
    background: url(../images/fig_purple-circle.webp) no-repeat center top/100%;
  }
  .p-project__list {
    margin-top: 5.8rem;
  }
  .p-project__list .swiper {
    padding-right: 0;
    overflow: visible;
    -webkit-mask-image: linear-gradient(to right, transparent 0.05%, black 5%, black 95%, transparent 99.5%);
    margin-left: calc(100% - 100vw);
    padding-left: calc(100vw - 100%);
            mask-image: linear-gradient(to right, transparent 0.05%, black 5%, black 95%, transparent 99.5%);
  }
  .p-project__list .swiper-wrapper:has(a.c-project) {
    padding-bottom: 9.1rem;
  }
  .u-display--sp {
    display: none;
  }
  .u-display--pc {
    display: block;
  }
  .u-mt-1 {
    margin-top: 1rem !important;
  }
  .u-mb-1 {
    margin-bottom: 1rem !important;
  }
  .u-mt-2 {
    margin-top: 2rem !important;
  }
  .u-mb-2 {
    margin-bottom: 2rem !important;
  }
  .u-mt-3 {
    margin-top: 3rem !important;
  }
  .u-mb-3 {
    margin-bottom: 3rem !important;
  }
  .u-mt-4 {
    margin-top: 4rem !important;
  }
  .u-mb-4 {
    margin-bottom: 4rem !important;
  }
  .u-mt-5 {
    margin-top: 5rem !important;
  }
  .u-mb-5 {
    margin-bottom: 5rem !important;
  }
  .u-mt-6 {
    margin-top: 6rem !important;
  }
  .u-mb-6 {
    margin-bottom: 6rem !important;
  }
  .u-mt-7 {
    margin-top: 7rem !important;
  }
  .u-mb-7 {
    margin-bottom: 7rem !important;
  }
  .u-mt-8 {
    margin-top: 8rem !important;
  }
  .u-mb-8 {
    margin-bottom: 8rem !important;
  }
  .u-mt-9 {
    margin-top: 9rem !important;
  }
  .u-mb-9 {
    margin-bottom: 9rem !important;
  }
  .u-mt-10 {
    margin-top: 10rem !important;
  }
  .u-mb-10 {
    margin-bottom: 10rem !important;
  }
  .u-mt-11 {
    margin-top: 11rem !important;
  }
  .u-mb-11 {
    margin-bottom: 11rem !important;
  }
  .u-mt-12 {
    margin-top: 12rem !important;
  }
  .u-mb-12 {
    margin-bottom: 12rem !important;
  }
  .u-mt-13 {
    margin-top: 13rem !important;
  }
  .u-mb-13 {
    margin-bottom: 13rem !important;
  }
  .u-mt-14 {
    margin-top: 14rem !important;
  }
  .u-mb-14 {
    margin-bottom: 14rem !important;
  }
  .u-mt-15 {
    margin-top: 15rem !important;
  }
  .u-mb-15 {
    margin-bottom: 15rem !important;
  }
  .u-mt-16 {
    margin-top: 16rem !important;
  }
  .u-mb-16 {
    margin-bottom: 16rem !important;
  }
  .u-mt-17 {
    margin-top: 17rem !important;
  }
  .u-mb-17 {
    margin-bottom: 17rem !important;
  }
  .u-mt-18 {
    margin-top: 18rem !important;
  }
  .u-mb-18 {
    margin-bottom: 18rem !important;
  }
  .u-mt-19 {
    margin-top: 19rem !important;
  }
  .u-mb-19 {
    margin-bottom: 19rem !important;
  }
  .u-mt-20 {
    margin-top: 20rem !important;
  }
  .u-mb-20 {
    margin-bottom: 20rem !important;
  }
}
@media screen and (min-width: 769px) and (max-width: 814px){
  .c-story__title {
    font-size: 2.05rem;
  }
}
@media screen and (min-width: 769px) and (max-width: 815px){
  .c-story__image {
    width: 10vw;
  }
}
@media screen and (min-width: 769px) and (max-width: 910px){
  .c-story {
    padding: 5.6rem 2rem 3.6rem 3.5rem;
  }
}
@media screen and (min-width: 816px) and (max-width: 834px){
  .c-story__image {
    width: 11.5vw;
  }
}
@media screen and (min-width: 835px) and (max-width: 1103px){
  .c-story__image {
    width: 12.5vw;
  }
}
@media (min-width: 880px){
  .c-dl__wrap dd ul.salary li {
    max-width: calc(24% - 3rem);
  }
  .u-display--pc880 {
    display: block;
  }
}
@media (min-width: 1024px){
  .l-container {
    max-width: calc(50% + 38rem + 2 * var(--padding-container, 2.4rem));
  }
  .p-mainvisual__inner {
    height: 123.5rem;
  }
  .p-mainvisual__bg {
    top: 6rem;
    width: 127.6rem;
  }
  .p-mainvisual__ring {
    top: -21.6rem;
    width: 172.7rem;
  }
  .p-mainvisual__copy {
    width: 61.6rem;
  }
  .p-mainvisual__text {
    font-size: 2.2rem;
  }
  .p-mainvisual__movie {
    top: 85.4rem;
    left: min(10vw, 50% - 65rem);
    width: 26rem;
  }
  .p-movie__inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    max-width: 140rem;
    margin-inline: auto;
    padding-right: 4rem;
    padding-left: 4rem;
  }
  .p-movie__heading {
    margin-right: 4.4rem;
    margin-bottom: 0;
    padding-right: 4.4rem;
    padding-bottom: 0;
    border-right: 0.4rem solid currentColor;
    border-bottom: 0;
  }
  .p-movie__movies {
    grid-row: 2;
    grid-column: 1/4;
    margin-top: 6.8rem;
  }
  .p-movie__buttons {
    position: static;
    gap: 3.5rem;
    translate: 0 0;
  }
  .p-movie .c-description {
    padding: 0;
    text-align: left;
  }
  .p-movie .c-movie-list {
    padding: 0;
  }
}
@media (hover: hover){
  .c-backtop:hover {
    scale: 1.1;
  }
  .c-button:hover:not(.-prev, .-next)::after {
    translate: 1rem 0;
  }
  .c-button.-green:hover {
    opacity: 0.7;
  }
  .c-button.-green:hover::after {
    translate: 0.5rem -50%;
  }
  .c-button.-blue:hover {
    opacity: 0.7;
  }
  .c-button.-blue:hover::after {
    translate: 0.5rem -50%;
  }
  .c-button.-white:hover {
    box-shadow: none;
    color: #fff;
  }
  .c-button.-white:hover::before {
    translate: 0 0;
  }
  .c-button.-white:hover::after {
    border-color: #fff;
  }
  .c-button.-prev:hover, .c-button.-next:hover {
    scale: 1.1;
  }
  .c-links__sns a:hover {
    scale: 1.1;
  }
  .c-links__corporate:hover {
    opacity: 0.7;
  }
  .c-movie-list__item a:hover .c-movie-list__thumb img {
    scale: 1.1;
  }
  .c-pagenav li:hover {
    position: relative;
    width: auto;
  }
  .c-pagenav li:hover span {
    display: none;
  }
  .c-pagenav li:hover a {
    translate: 0 0;
  }
  a.c-project:hover .c-project__more {
    box-shadow: none;
    color: #fff;
  }
  a.c-project:hover .c-project__more::before {
    translate: 0 0;
  }
  a.c-project:hover .c-project__more::after {
    border-color: #fff;
  }
  .p-header__logo a:hover {
    opacity: 0.7;
  }
  .p-mainvisual__movie:hover {
    translate: 0 -3%;
  }
}/**
 * Swiper 8.4.7
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2023 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: January 30, 2023
 */

@font-face {
  font-style: normal;
  font-weight: 400;
  src: url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA');
  font-family: 'swiper-icons';
}
:root {
  --swiper-theme-color: #007aff;
}
.swiper {
  /* Fix of Webkit flickering */
  z-index: 1;
  position: relative;
  margin-right: auto;
  margin-left: auto;
  padding: 0;
  overflow: hidden;
  list-style: none;
}
.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}
.swiper-wrapper {
  box-sizing: content-box;
  display: flex;
  z-index: 1;
  position: relative;
  width: 100%;
  height: 100%;
  transition-property: transform;
}
.swiper-android .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}
.swiper-pointer-events {
  touch-action: pan-y;
}
.swiper-pointer-events.swiper-vertical {
  touch-action: pan-x;
}
.swiper-slide {
  position: relative;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  transition-property: transform;
}
.swiper-slide-invisible-blank {
  visibility: hidden;
}
/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}
.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}
.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
/* 3D Effects */
.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}
.swiper-3d .swiper-wrapper,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}
.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}
/* CSS Mode */
.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */
}
.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}
.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}
.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}
.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}
.swiper-centered > .swiper-wrapper::before {
  flex-shrink: 0;
  order: 9999;
  content: '';
}
.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-start: var(--swiper-centered-offset-before);
          margin-inline-start: var(--swiper-centered-offset-before);
}
.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  width: var(--swiper-centered-offset-after);
  height: 100%;
  min-height: 1px;
}
.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  -webkit-margin-before: var(--swiper-centered-offset-before);
          margin-block-start: var(--swiper-centered-offset-before);
}
.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}
.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}
.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}
.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  pointer-events: none;
}
.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  width: var(--swiper-virtual-size);
  height: 1px;
}
.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}
:root {
  --swiper-navigation-size: 44px;
  /*
  --swiper-navigation-color: var(--swiper-theme-color);
  */
}
.swiper-button-prev,
.swiper-button-next {
  display: flex;
  z-index: 10;
  position: absolute;
  top: 50%;
  align-items: center;
  justify-content: center;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
  cursor: pointer;
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  cursor: auto;
  opacity: 0.35;
  pointer-events: none;
}
.swiper-button-prev.swiper-button-hidden,
.swiper-button-next.swiper-button-hidden {
  cursor: auto;
  opacity: 0;
  pointer-events: none;
}
.swiper-navigation-disabled .swiper-button-prev,
.swiper-navigation-disabled .swiper-button-next {
  display: none !important;
}
.swiper-button-prev:after,
.swiper-button-next:after {
  font-variant: initial;
  font-size: var(--swiper-navigation-size);
  line-height: 1;
  font-family: swiper-icons;
  letter-spacing: 0;
  text-transform: none !important;
}
.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  right: auto;
  left: 10px;
}
.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
  content: 'prev';
}
.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}
.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
  content: 'next';
}
.swiper-button-lock {
  display: none;
}
:root {
  /*
  --swiper-pagination-color: var(--swiper-theme-color);
  --swiper-pagination-bullet-size: 8px;
  --swiper-pagination-bullet-width: 8px;
  --swiper-pagination-bullet-height: 8px;
  --swiper-pagination-bullet-inactive-color: #000;
  --swiper-pagination-bullet-inactive-opacity: 0.2;
  --swiper-pagination-bullet-opacity: 1;
  --swiper-pagination-bullet-horizontal-gap: 4px;
  --swiper-pagination-bullet-vertical-gap: 6px;
  */
}
.swiper-pagination {
  z-index: 10;
  position: absolute;
  transform: translate3d(0, 0, 0);
  text-align: center;
  transition: 300ms opacity;
}
.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}
.swiper-pagination-disabled > .swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}
/* Common Styles */
.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 10px;
  left: 0;
  width: 100%;
}
/* Bullets */
.swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0;
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  position: relative;
  transform: scale(0.33);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}
.swiper-pagination-bullet {
  display: inline-block;
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  border-radius: 50%;
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}
button.swiper-pagination-bullet {
  margin: 0;
  padding: 0;
  border: none;
  box-shadow: none;
  -webkit-appearance: none;
          -moz-appearance: none;
       appearance: none;
}
.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}
.swiper-pagination-bullet:only-child {
  display: none !important;
}
.swiper-pagination-bullet-active {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  opacity: var(--swiper-pagination-bullet-opacity, 1);
}
.swiper-vertical > .swiper-pagination-bullets,
.swiper-pagination-vertical.swiper-pagination-bullets {
  top: 50%;
  right: 10px;
  transform: translate3d(0px, -50%, 0);
}
.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
  display: block;
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
}
.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  width: 8px;
  transform: translateY(-50%);
}
.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 200ms transform, 200ms top;
}
.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}
.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms left;
}
.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 200ms transform, 200ms right;
}
/* Progress */
.swiper-pagination-progressbar {
  position: absolute;
  background: rgba(0, 0, 0, 0.25);
}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}
.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}
.swiper-horizontal > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
}
.swiper-vertical > .swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
}
.swiper-pagination-lock {
  display: none;
}
/* Scrollbar */
.swiper-scrollbar {
  position: relative;
  border-radius: 10px;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1);
}
.swiper-scrollbar-disabled > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}
.swiper-horizontal > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
  z-index: 50;
  position: absolute;
  bottom: 3px;
  left: 1%;
  width: 98%;
  height: 5px;
}
.swiper-vertical > .swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-vertical {
  z-index: 50;
  position: absolute;
  top: 1%;
  right: 3px;
  width: 5px;
  height: 98%;
}
.swiper-scrollbar-drag {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.5);
}
.swiper-scrollbar-cursor-drag {
  cursor: move;
}
.swiper-scrollbar-lock {
  display: none;
}
.swiper-zoom-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-align: center;
}
.swiper-zoom-container > img,
.swiper-zoom-container > svg,
.swiper-zoom-container > canvas {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.swiper-slide-zoomed {
  cursor: move;
}
/* Preloader */
:root {
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  */
}
.swiper-lazy-preloader {
  box-sizing: border-box;
  z-index: 10;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 42px;
  height: 42px;
  margin-top: -21px;
  margin-left: -21px;
  transform-origin: 50%;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}
.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}
.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}
.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}
@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* a11y */
.swiper .swiper-notification {
  z-index: -1000;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
}
.swiper-free-mode > .swiper-wrapper {
  margin: 0 auto;
  transition-timing-function: ease-out;
}
.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}
.swiper-grid-column > .swiper-wrapper {
  flex-direction: column;
  flex-wrap: wrap;
}
.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}
.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}
.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}
.swiper-cube {
  overflow: visible;
}
.swiper-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  visibility: hidden;
  z-index: 1;
  width: 100%;
  height: 100%;
  transform-origin: 0 0;
          backface-visibility: hidden;
}
.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0;
}
.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}
.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-next,
.swiper-cube .swiper-slide-prev,
.swiper-cube .swiper-slide-next + .swiper-slide {
  visibility: visible;
  pointer-events: auto;
}
.swiper-cube .swiper-slide-shadow-top,
.swiper-cube .swiper-slide-shadow-bottom,
.swiper-cube .swiper-slide-shadow-left,
.swiper-cube .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.swiper-cube .swiper-cube-shadow {
  z-index: 0;
  position: absolute;
  bottom: 0px;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.6;
}
.swiper-cube .swiper-cube-shadow:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: #000;
  content: '';
  filter: blur(50px);
}
.swiper-flip {
  overflow: visible;
}
.swiper-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  z-index: 1;
          backface-visibility: hidden;
}
.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}
.swiper-flip .swiper-slide-active,
.swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}
.swiper-flip .swiper-slide-shadow-top,
.swiper-flip .swiper-slide-shadow-bottom,
.swiper-flip .swiper-slide-shadow-left,
.swiper-flip .swiper-slide-shadow-right {
  z-index: 0;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.swiper-creative .swiper-slide {
  -webkit-backface-visibility: hidden;
  overflow: hidden;
          backface-visibility: hidden;
  transition-property: transform, opacity, height;
}
.swiper-cards {
  overflow: visible;
}
.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  -webkit-backface-visibility: hidden;
  overflow: hidden;
          backface-visibility: hidden;
}
