@charset "UTF-8";
/*! destyle.css v4.0.0 | MIT License | https://github.com/nicolas-cusan/destyle.css */
/* Reset box-model and set borders */
/* ============================================ */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

/* Document */
/* ============================================ */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 * 3. Remove gray overlay on links for iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -webkit-tap-highlight-color: transparent; /* 3*/
}

/* Sections */
/* ============================================ */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/* Vertical rhythm */
/* ============================================ */
p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

/* Headings */
/* ============================================ */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

/* Lists (enumeration) */
/* ============================================ */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Lists (definition) */
/* ============================================ */
dt {
  font-weight: bold;
}

dd {
  margin-left: 0;
}

/* Grouping content */
/* ============================================ */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

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

address {
  font-style: inherit;
}

/* Text-level semantics */
/* ============================================ */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  text-decoration: underline dotted; /* 2 */
}

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

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

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

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Replaced content */
/* ============================================ */
/**
 * Prevent vertical alignment issues.
 */
svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

/* Forms */
/* ============================================ */
/**
 * Reset form fields to make them styleable.
 * 1. Make form elements stylable across systems iOS especially.
 * 2. Inherit text-transform from parent.
 */
button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none; /* 1 */
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit; /* 2 */
}

/**
 * Correct cursors for clickable elements.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

button:disabled,
[type=button]:disabled,
[type=reset]:disabled,
[type=submit]:disabled {
  cursor: default;
}

/**
 * Improve outlines for Firefox and unify style with input elements & buttons.
 */
:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

/**
 * Remove padding
 */
option {
  padding: 0;
}

/**
 * Reset to invisible
 */
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}

legend {
  padding: 0;
}

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

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

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

/**
 * Correct the outline style in Safari.
 */
[type=search] {
  outline-offset: -2px; /* 1 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

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

/**
 * Fix appearance for Firefox
 */
[type=number] {
  -moz-appearance: textfield;
}

/**
 * Clickable labels
 */
label[for] {
  cursor: pointer;
}

/* Interactive */
/* ============================================ */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/*
 * Remove outline for editable content.
 */
[contenteditable]:focus {
  outline: auto;
}

/* Tables */
/* ============================================ */
/**
1. Correct table border color inheritance in all Chrome and Safari.
*/
table {
  border-color: inherit; /* 1 */
  border-collapse: collapse;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
  font-weight: bold;
}

input:focus-visible {
  outline: none;
}

html {
  font-size: 100%;
  scroll-padding-top: 120px;
}
@media (max-width: 767.98px) {
  html {
    scroll-padding-top: 80px;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  line-height: 1.6;
  font-size: 1rem;
  color: #3b3b3b;
}

img {
  max-width: 100%;
  width: 100%;
}

.swiper {
  position: relative;
  height: auto;
}
.swiper-wrapper {
  display: flex;
  transition-timing-function: ease;
}
.swiper-slide {
  flex-shrink: 0;
  position: relative;
}

.swiper-button-prev,
.swiper-button-next {
  width: 30px;
  height: 30px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  cursor: pointer;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
}
.swiper-button-prev:after,
.swiper-button-next:after {
  display: none;
}

.swiper-pagination {
  position: relative;
  margin-top: 20px;
  text-align: center;
}
.swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  display: inline-block;
  background: #ccc;
  border-radius: 50%;
  opacity: 0.5;
  margin: 0 4px;
  transition: 0.3s;
}
.swiper-pagination-bullet-active {
  background: #000;
  opacity: 1;
}

.header {
  position: fixed;
  z-index: 1000;
  top: 20px;
  left: 220px;
  right: 20px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 20px 400px 20px 10px;
  border-radius: 20px;
}
@media (max-width: 1279.98px) {
  .header {
    padding: 20px 270px 20px 10px;
  }
}
.header__menu {
  display: flex;
  gap: 32px;
  background: rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(30px) brightness(1.4);
  font-size: 15px;
  font-weight: 500;
  line-height: 1.5;
  padding: 20px 45px;
  border-radius: 100px;
}
@media (max-width: 1279.98px) {
  .header__menu {
    gap: 15px;
    padding: 20px 20px;
  }
}
@media (max-width: 1023.98px) {
  .header__menu {
    display: none;
  }
}
.header__nav {
  position: fixed;
  z-index: 1002;
  top: 40px;
  right: 40px;
  display: flex;
  align-items: center;
  gap: 20px;
}
@media (max-width: 1279.98px) {
  .header__nav {
    gap: 10px;
  }
}
@media (max-width: 767.98px) {
  .header__nav {
    top: 20px;
    right: 20px;
  }
}
.header__nav-item a {
  transition: all 0.3s ease;
}
.header__nav-item a:hover {
  color: #50A4A1;
}
@media (max-width: 1279.98px) {
  .header__lang {
    display: none;
  }
}
.header__lang select {
  background: #000;
  color: #fff;
  font-family: "Poppins", sans-serif;
  border: solid 1px #fff;
  text-align: center;
  padding: 0.2em 0.7em;
  border-radius: 40px;
  font-size: 14px;
}
.header__entry {
  font-family: "Poppins", sans-serif;
  font-size: 17px;
  font-weight: 500;
  color: #fff;
  background: #50A4A1;
  line-height: 1;
  padding: 20px 30px;
  border-radius: 100px;
  border: solid 1px #50A4A1;
  transition: all 0.3s ease;
}
@media (max-width: 767.98px) {
  .header__entry {
    padding: 8px 10px;
    font-size: 13px;
  }
}
.header__entry:hover {
  color: #50A4A1;
  background: #fff;
}

@media (max-width: 1279.98px) {
  .menu-open .header__lang {
    display: block;
    opacity: 1;
    visibility: visible;
  }
}
.menu-open .header__lang-item a {
  color: #3b3b3b;
  border: solid 1px #3b3b3b;
  background: #fff;
}
.menu-open .header__lang-item.--active a {
  background: linear-gradient(90deg, #53C1B7 0%, #4C9E97 100%);
  border: none;
  color: #fff;
}

.footer {
  padding: 120px 0;
  background: #3B3B3B;
  position: relative;
  z-index: 1;
}
@media (max-width: 1023.98px) {
  .footer {
    padding: 80px 0;
  }
}
@media (max-width: 767.98px) {
  .footer {
    padding: 40px 0;
  }
}
.footer__nav {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 44px;
}
@media (max-width: 1023.98px) {
  .footer__nav {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575.98px) {
  .footer__nav {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
.footer__nav-section {
  border-top: solid 1px #6A6A6A;
  position: relative;
  padding-top: 30px;
}
@media (max-width: 575.98px) {
  .footer__nav-section {
    padding-top: 20px;
  }
}
.footer__nav-section:before {
  content: "";
  position: absolute;
  width: 20px;
  height: 1px;
  background: #50A4A1;
  top: -1px;
  left: 0;
}
.footer__nav-title a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #fff;
  font-size: 21px;
  font-weight: 600;
  margin-bottom: 25px;
}
@media (max-width: 1023.98px) {
  .footer__nav-title a {
    font-size: 18px;
  }
}
@media (max-width: 767.98px) {
  .footer__nav-title a {
    font-size: 17px;
  }
}
.footer__nav-title a small {
  font-size: 15px;
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  color: #50A4A1;
}
@media (max-width: 767.98px) {
  .footer__nav-title a small {
    font-size: 13px;
  }
}
.footer__nav-list {
  display: grid;
  gap: 6px;
}
.footer__nav-sublist {
  display: grid;
  gap: 6px;
  padding-left: 20px;
  margin-top: 6px;
  margin-bottom: 15px;
}
.footer__nav-subitem {
  position: relative;
}
.footer__nav-subitem:before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -8px;
  width: 4px;
  height: 2px;
  background: #6A6A6A;
}
.footer__nav-item a {
  color: #969696;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  transition: all 0.3s ease;
}
.footer__nav-item a:hover {
  color: #fff;
}
.footer__info {
  margin-top: 80px;
  display: flex;
  align-items: flex-end;
  gap: 20px;
}
@media (max-width: 767.98px) {
  .footer__info {
    flex-direction: column;
    align-items: center;
    gap: 30px;
    margin-top: 40px;
  }
}
.footer__logo {
  width: 200px;
}
.footer__address {
  color: #969696;
  font-size: 14px;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .footer__address {
    font-size: 12px;
  }
}
.footer__bottom {
  border-top: solid 1px #6A6A6A;
  margin-top: 35px;
  padding-top: 25px;
}
.footer__bottom-inner {
  display: flex;
  justify-content: space-between;
  align-self: center;
}
@media (max-width: 767.98px) {
  .footer__bottom-inner {
    flex-direction: column;
    justify-content: center;
    gap: 30px;
  }
}
.footer__bottom-list {
  display: flex;
  gap: 20px;
}
@media (max-width: 575.98px) {
  .footer__bottom-list {
    flex-direction: column;
    align-items: center;
  }
}
.footer__bottom-item a {
  color: #969696;
  font-size: 12px;
  transition: all 0.3s ease;
  line-height: 1;
  display: block;
}
.footer__bottom-item a:hover {
  color: #fff;
}
.footer__copyright {
  font-size: 13px;
  color: #969696;
  font-family: "Poppins", sans-serif;
  font-weight: 400;
}
@media (max-width: 575.98px) {
  .footer__copyright {
    text-align: center;
  }
}

.container {
  max-width: 1246px;
  margin: 0 auto;
  padding: 0 20px;
}

.nav {
  position: fixed;
  z-index: 1001;
  inset: 0;
  background: #50A4A1;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
@media (max-width: 767.98px) {
  .nav {
    padding: 10px;
  }
}
.nav-toggle {
  width: 60px;
  height: 60px;
  background: #fff;
  border-radius: 100px;
  position: relative;
}
.nav-toggle span {
  position: absolute;
  height: 2px;
  width: 24px;
  top: 29px;
  left: 18px;
  background: #347989;
}
.nav-toggle span:first-child {
  transform: translateY(-6px);
}
.nav-toggle span:last-child {
  transform: translateY(6px);
}
.nav__inner {
  background: #fff;
  border-radius: 20px;
  padding: 80px 20px;
  height: 100%;
  overflow-y: auto;
}
.nav__inner::-webkit-scrollbar {
  display: none;
}
.nav__container {
  max-width: 1216px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.nav__section {
  padding: 40px 0;
}
@media (max-width: 575.98px) {
  .nav__section {
    padding: 25px 0;
  }
}
.nav__section.--primary {
  border-bottom: solid 1px #EDEDED;
  grid-column: 1/3;
  padding-top: 10px;
}
@media (max-width: 1023.98px) {
  .nav__section.--secondary {
    grid-column: 1/3;
  }
}
.nav__section.--secondary.--left {
  padding-right: 50px;
  position: relative;
}
@media (max-width: 1023.98px) {
  .nav__section.--secondary.--left {
    padding-right: 0;
    border-bottom: 1px solid #EDEDED;
  }
}
.nav__section.--secondary.--left:after {
  content: "";
  position: absolute;
  width: 1px;
  height: calc(100% - 80px);
  background: #EDEDED;
  right: 0;
  top: 40px;
  bottom: 40px;
}
@media (max-width: 1023.98px) {
  .nav__section.--secondary.--left:after {
    display: none;
  }
}
.nav__section.--secondary.--right {
  padding-left: 50px;
}
@media (max-width: 1023.98px) {
  .nav__section.--secondary.--right {
    padding-left: 0;
  }
}
.nav__section.--tertiary {
  border-top: solid 1px #EDEDED;
  grid-column: 1/3;
  display: grid;
  grid-template-columns: 120px 1fr;
  align-items: center;
  padding-bottom: 0;
  gap: 40px;
}
@media (max-width: 1023.98px) {
  .nav__section.--tertiary {
    grid-template-columns: 1fr;
  }
}
.nav__title {
  font-size: 21px;
  font-weight: 600;
  line-height: 1.4;
}
.nav__title.--tertiary {
  margin-bottom: 0;
}
.nav__title.--tertiary small {
  display: block;
  margin-left: 0;
  margin-top: 8px;
}
@media (max-width: 1023.98px) {
  .nav__title.--tertiary small {
    margin-top: 0;
    margin-left: 1em;
    display: inline;
  }
}
.nav__title small {
  font-size: 15px;
  line-height: 1.4;
  margin-left: 1em;
  font-weight: 300;
  color: #50A4A1;
}
.nav__header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 25px;
}
.nav__header.--tertiary {
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 0;
}
@media (max-width: 1023.98px) {
  .nav__header.--tertiary {
    flex-direction: row;
  }
}
.nav__link {
  font-size: 14px;
  line-height: 1;
  font-weight: 300;
  color: #50A4A1;
  font-family: "Poppins", sans-serif;
  display: block;
  border: solid 1px #50A4A1;
  padding: 5px 35px 5px 10px;
  position: relative;
  transition: color 0.3s, background-color 0.3s;
}
.nav__link:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  width: 5px;
  height: 5px;
  border-top: 1px solid #50A4A1;
  border-right: 1px solid #50A4A1;
  transform: translateY(-50%) rotate(45deg);
  transition: border-color 0.3s;
}
.nav__link:hover {
  color: #fff;
  background: #50A4A1;
}
.nav__link:hover:after {
  border-color: #fff;
}
.nav__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media (max-width: 1023.98px) {
  .nav__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575.98px) {
  .nav__list {
    grid-template-columns: 1fr;
  }
}
.nav__list.--secondary {
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 575.98px) {
  .nav__list.--secondary {
    grid-template-columns: 1fr;
  }
}
.nav__list.--tertiary {
  gap: 20px 32px;
}
.nav__item-link:hover .nav__item-img img {
  transform: scale(1.05);
}
.nav__item-link:hover .nav__item-text {
  color: #50A4A1;
}
.nav__item-link.--tertiary {
  display: block;
  border-bottom: solid 1px #EDEDED;
  padding: 13px 40px 13px 0;
  position: relative;
}
.nav__item-link.--tertiary:after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  width: 30px;
  height: 16px;
  background: url("../images/arrow-right.svg") no-repeat center;
  background-size: contain;
  transition: all 0.3s ease;
}
.nav__item-link.--tertiary:hover:after {
  transform: translateY(-50%) translateX(5px);
}
.nav__item-img {
  margin-bottom: 10px;
  overflow: hidden;
  border-radius: 6px;
}
.nav__item-img img {
  transition: all 0.3s ease;
}
.nav__item-text {
  font-size: 13px;
  transition: all 0.3s ease;
}

.menu-open .nav {
  opacity: 1;
  visibility: visible;
}
.menu-open .nav-toggle {
  background: #50A4A1;
}
.menu-open .nav-toggle span {
  background-color: #fff;
}
.menu-open .nav-toggle span:first-child {
  transform: translateY(0) rotate(45deg);
}
.menu-open .nav-toggle span:nth-child(2) {
  opacity: 0;
  visibility: hidden;
}
.menu-open .nav-toggle span:last-child {
  transform: translateY(0) rotate(-45deg);
}

.tab-menu {
  margin-bottom: 55px;
}
.tab-menu__list {
  display: flex;
  border-bottom: solid 2px #CBCBCB;
}
.tab-menu__item {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.4;
}
@media (max-width: 767.98px) {
  .tab-menu__item {
    font-size: 14px;
    text-align: center;
    flex-grow: 1;
  }
}
.tab-menu__item a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 30px;
  position: relative;
  transition: color 0.3s;
  height: 100%;
}
@media (max-width: 767.98px) {
  .tab-menu__item a {
    padding: 10px 15px;
  }
}
.tab-menu__item a:hover {
  color: #50A4A1;
}
.tab-menu__item a:hover:before {
  opacity: 1;
}
.tab-menu__item a.--active {
  color: #50A4A1;
}
@media (max-width: 767.98px) {
  .tab-menu__item a.--active {
    padding: 10px;
  }
}
.tab-menu__item a.--active:before {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: #50A4A1;
}
.tab-menu__item a.--active:after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  width: 0;
  height: 0;
  margin-left: -8px;
  border-style: solid;
  border-color: #50A4A1 transparent transparent transparent;
  border-width: 14px 8px;
}

.archive-title {
  font-size: 36px;
  font-weight: 600;
  text-align: center;
  color: #50A4A1;
  padding-bottom: 20px;
  margin-bottom: 60px;
  position: relative;
}
@media (max-width: 767.98px) {
  .archive-title {
    font-size: 28px;
    margin-bottom: 40px;
  }
}
.archive-title:before {
  content: "";
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  position: absolute;
  width: 56px;
  height: 4px;
  background: #50A4A1;
}

.heading1 {
  font-size: 40px;
  font-weight: 700;
  padding-bottom: 0.5em;
  position: relative;
  margin-bottom: 2.4rem;
}
@media (max-width: 767.98px) {
  .heading1 {
    font-size: 28px;
  }
}
.heading1.--sm {
  font-size: 28px;
}
@media (max-width: 767.98px) {
  .heading1.--sm {
    font-size: 20px;
  }
}
.heading1:before {
  content: "";
  width: 56px;
  height: 4px;
  background: #50A4A1;
  position: absolute;
  bottom: 0;
  left: 0;
}

.heading2 {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.4;
  padding-left: 0.7em;
  padding-top: 0.2em;
  padding-bottom: 0.2em;
  margin-bottom: 2rem;
  border-left: 6px solid #50A4A1;
}
@media (max-width: 767.98px) {
  .heading2 {
    font-size: 20px;
  }
}

.heading3 {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.4;
  padding-bottom: 0.2em;
  margin-bottom: 1.8rem;
  border-bottom: 2px solid #50A4A1;
}
@media (max-width: 767.98px) {
  .heading3 {
    font-size: 18px;
  }
}

.heading4 {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 1.4rem;
}
@media (max-width: 767.98px) {
  .heading4 {
    font-size: 17px;
  }
}

.heading5, .heading6 {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 1rem;
}
@media (max-width: 767.98px) {
  .heading5, .heading6 {
    font-size: 16px;
  }
}

.text {
  line-height: 1.8;
  margin-bottom: 1.75em;
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -13px;
}
.row > [class*=col-] {
  padding-right: 13px;
  padding-left: 13px;
}

.col-1 {
  flex: 0 0 8.3333333333%;
  max-width: 8.3333333333%;
}

.col-2 {
  flex: 0 0 16.6666666667%;
  max-width: 16.6666666667%;
}

.col-3 {
  flex: 0 0 25%;
  max-width: 25%;
}

.col-4 {
  flex: 0 0 33.3333333333%;
  max-width: 33.3333333333%;
}

.col-5 {
  flex: 0 0 41.6666666667%;
  max-width: 41.6666666667%;
}

.col-6 {
  flex: 0 0 50%;
  max-width: 50%;
}

.col-7 {
  flex: 0 0 58.3333333333%;
  max-width: 58.3333333333%;
}

.col-8 {
  flex: 0 0 66.6666666667%;
  max-width: 66.6666666667%;
}

.col-9 {
  flex: 0 0 75%;
  max-width: 75%;
}

.col-10 {
  flex: 0 0 83.3333333333%;
  max-width: 83.3333333333%;
}

.col-11 {
  flex: 0 0 91.6666666667%;
  max-width: 91.6666666667%;
}

.col-12 {
  flex: 0 0 100%;
  max-width: 100%;
}

@media (min-width: 375px) {
  .col-xs-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-xs-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-xs-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-xs-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-xs-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-xs-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-xs-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-xs-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-xs-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-xs-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-xs-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-xs-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 576px) {
  .col-sm-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-sm-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-sm-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-sm-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-sm-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-sm-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-sm-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-sm-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-sm-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-sm-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 768px) {
  .col-md-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-md-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-md-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-md-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-md-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-md-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-md-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-md-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 1024px) {
  .col-lg-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-lg-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-lg-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-lg-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-lg-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-lg-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-lg-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-lg-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-lg-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-lg-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 1280px) {
  .col-xl-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-xl-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-xl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-xl-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-xl-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-xl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-xl-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-xl-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-xl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-xl-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-xl-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-xl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
@media (min-width: 1400px) {
  .col-xxl-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
  .col-xxl-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
  .col-xxl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-xxl-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
  .col-xxl-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
  .col-xxl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .col-xxl-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
  .col-xxl-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
  .col-xxl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
  .col-xxl-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
  .col-xxl-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
  .col-xxl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
.table1 {
  margin-bottom: 2rem;
  width: 100%;
}
.table1 th {
  font-weight: 700;
  padding: 10px 35px;
  background: #CBCBCB;
  border-top: solid 1px #CBCBCB;
  border-bottom: solid 1px #CBCBCB;
}
.table1 td {
  padding: 10px 35px;
  border-top: solid 1px #CBCBCB;
  border-bottom: solid 1px #CBCBCB;
}

.table2 {
  margin-bottom: 2rem;
  width: 100%;
}
.table2 th, .table2 td {
  padding: 20px 35px;
  border-top: solid 1px #CBCBCB;
  border-bottom: solid 1px #CBCBCB;
}

.textbox {
  font-size: 22px;
  color: #fff;
  font-weight: bold;
  text-align: center;
  background: #50A4A1;
  padding: 1em;
}

.btn {
  font-size: 15px;
  font-weight: 500;
  color: #fff;
  display: block;
  width: 160px;
  padding: 1em;
  background: #50A4A1;
  border: solid 1px #50A4A1;
  border-radius: 100px;
  text-align: center;
  transition: all 0.3s ease;
  max-width: 100%;
}
@media (max-width: 767.98px) {
  .btn {
    font-size: 13px;
  }
}
.btn:hover {
  border: solid 1px #50A4A1;
  background: #fff;
  color: #50A4A1;
}
.btn.--white {
  background: #fff;
  color: #50A4A1;
  border: solid 1px #fff;
}
.btn.--white:hover {
  background: #50A4A1;
  color: #fff;
}
.btn.--lg {
  font-size: 20px;
  width: 300px;
}
@media (max-width: 767.98px) {
  .btn.--lg {
    font-size: 17px;
  }
}
.btn.--wide {
  width: 100%;
}
.btn.--border {
  border: solid 1px #50A4A1;
}
.btn.--center {
  margin-left: auto;
  margin-right: auto;
}

.ul {
  line-height: 1.8;
  margin-bottom: 1.75em;
}
.ul li {
  position: relative;
  padding-left: 1em;
}
.ul li:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}

.ol {
  line-height: 1.8;
  margin-bottom: 1.75em;
  counter-reset: ol;
}
.ol li {
  position: relative;
  padding-left: 1em;
  counter-increment: ol;
}
.ol li:before {
  content: counter(ol) ".";
  position: absolute;
  top: 0;
  left: 0;
}

.card {
  background: #fff;
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.card:hover .card__img img {
  transform: scale(1.05);
}
.card:hover .card__body::after {
  transform: translateX(5px);
}
.card__img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
}
.card__img img {
  transition: all 0.3s ease;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card__category {
  position: absolute;
  top: 0;
  right: 0;
  color: #fff;
  background: #3B3B3B;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  padding: 4px 10px;
  text-align: center;
  min-width: 140px;
}
.card__body {
  padding: 20px 24px 50px;
  position: relative;
  background: #F9F7F7;
  flex-grow: 1;
}
.card__body.--bg-white {
  background: #fff;
}
.card__body:after {
  position: absolute;
  content: "";
  bottom: 20px;
  right: 12px;
  width: 30px;
  height: 16px;
  background: url("../images/arrow-right.svg") no-repeat center;
  background-size: contain;
  transition: all 0.3s ease;
}
.card__title {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.8;
  margin-bottom: 0.5em;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card__text {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.8;
  margin-bottom: 1em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card__tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.card__tag {
  color: #50A4A1;
  font-size: 12px;
  font-weight: 500;
}

.wp-pagenavi {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 40px;
}
.wp-pagenavi .page {
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4rem;
  height: 4rem;
  background: #F9F7F7;
  color: #50A4A1;
  border-radius: 6px;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.wp-pagenavi .page:hover {
  background: #50A4A1;
  color: #fff;
}
.wp-pagenavi .current {
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4rem;
  height: 4rem;
  border: solid 2px #50A4A1;
  background: #50A4A1;
  border-radius: 6px;
  color: #fff;
}
.wp-pagenavi .extend {
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4rem;
  height: 4rem;
  color: #50A4A1;
}
.wp-pagenavi .first, .wp-pagenavi .previouspostslink, .wp-pagenavi .nextpostslink, .wp-pagenavi .last {
  font-size: 1rem;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4rem;
  height: 4rem;
  background: #F9F7F7;
  transition: background-color 0.3s ease, color 0.3s ease;
  border-radius: 6px;
}
.wp-pagenavi .first:hover, .wp-pagenavi .previouspostslink:hover, .wp-pagenavi .nextpostslink:hover, .wp-pagenavi .last:hover {
  background: #50A4A1;
}
.wp-pagenavi .first:hover:before, .wp-pagenavi .first:hover:after, .wp-pagenavi .previouspostslink:hover:before, .wp-pagenavi .previouspostslink:hover:after, .wp-pagenavi .nextpostslink:hover:before, .wp-pagenavi .nextpostslink:hover:after, .wp-pagenavi .last:hover:before, .wp-pagenavi .last:hover:after {
  border-color: #fff;
}
.wp-pagenavi .first {
  color: transparent;
  position: relative;
}
.wp-pagenavi .first:before {
  content: "";
  position: absolute;
  width: 7px;
  height: 7px;
  border-top: solid 2px #50A4A1;
  border-left: solid 2px #50A4A1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
  margin-left: -1px;
}
.wp-pagenavi .first:after {
  content: "";
  position: absolute;
  width: 7px;
  height: 7px;
  border-top: solid 2px #50A4A1;
  border-left: solid 2px #50A4A1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
  margin-left: 3px;
}
.wp-pagenavi .previouspostslink {
  color: transparent;
  position: relative;
}
.wp-pagenavi .previouspostslink:before {
  content: "";
  position: absolute;
  width: 7px;
  height: 7px;
  border-top: solid 2px #50A4A1;
  border-left: solid 2px #50A4A1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
  margin-left: 1px;
}
.wp-pagenavi .nextpostslink {
  color: transparent;
  position: relative;
}
.wp-pagenavi .nextpostslink:before {
  content: "";
  position: absolute;
  width: 7px;
  height: 7px;
  border-top: solid 2px #50A4A1;
  border-right: solid 2px #50A4A1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  margin-left: -1px;
}
.wp-pagenavi .last {
  color: transparent;
  position: relative;
}
.wp-pagenavi .last:before {
  content: "";
  position: absolute;
  width: 7px;
  height: 7px;
  border-top: solid 2px #50A4A1;
  border-right: solid 2px #50A4A1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  margin-left: -3px;
}
.wp-pagenavi .last:after {
  content: "";
  position: absolute;
  width: 7px;
  height: 7px;
  border-top: solid 2px #50A4A1;
  border-right: solid 2px #50A4A1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  margin-left: 1px;
}

.coming-soon {
  text-align: center;
  font-family: "Poppins", sans-serif;
  font-size: 40px;
  font-weight: 600;
  margin-top: 200px;
  margin-bottom: 200px;
}
@media (max-width: 767.98px) {
  .coming-soon {
    font-size: 24px;
    margin-top: 100px;
    margin-bottom: 100px;
  }
}

.home-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 30px;
}
@media (max-width: 1023.98px) {
  .home-section-header {
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (max-width: 1023.98px) {
  .home-section-header__btn {
    margin-left: auto;
    margin-right: auto;
  }
}

.home-heading1 {
  font-family: "Poppins", sans-serif;
  font-size: 60px;
  font-weight: 400;
  line-height: 1.3;
}
@media (max-width: 1023.98px) {
  .home-heading1 {
    font-size: 50px;
  }
}
@media (max-width: 767.98px) {
  .home-heading1 {
    font-size: 40px;
  }
}
.home-heading1.--white {
  color: #fff;
}
.home-heading1.--green {
  color: #50A4A1;
}
.home-heading1.--center {
  text-align: center;
}
.home-heading1 small {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  display: block;
  font-size: 17px;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 8px;
}
@media (max-width: 767.98px) {
  .home-heading1 small {
    font-size: 14px;
  }
}
.home-heading1 small.--poppins {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
}

.home-visual {
  position: relative;
  z-index: 1;
}
.home-visual::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  background: rgba(0, 0, 0, 0.7);
  pointer-events: none;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}
.home-visual__media {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}
.home-visual.--inactive::before,
.home-visual.--inactive .home-visual__media {
  opacity: 0;
  visibility: hidden;
}
.home-visual__body {
  position: relative;
  z-index: 1;
}
.home-visual__media-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-visual__media-img--message {
  clip-path: inset(100% 0 0 0);
  will-change: clip-path;
}

.home-infinite-lights {
  position: fixed;
  inset: 0;
  z-index: 2;
  overflow: hidden;
  pointer-events: none;
  mix-blend-mode: color-dodge;
  opacity: 0.7;
  visibility: visible;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}
.home-infinite-lights.--dimmed {
  opacity: 0.1;
}
.home-infinite-lights.--released {
  position: absolute;
  inset: auto 0 0;
  height: 100svh;
}
.home-visual.--inactive .home-infinite-lights {
  opacity: 0;
  visibility: hidden;
}
.home-infinite-lights canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
  background: transparent;
  pointer-events: none;
}
@media (max-width: 767.98px) {
  .home-infinite-lights {
    opacity: 0.78;
  }
  .home-infinite-lights.--dimmed {
    opacity: 0.2;
  }
}

.home-mv {
  position: relative;
  z-index: 0;
}
.home-mv.--front {
  z-index: 2;
}
.home-mv__logo {
  position: absolute;
  top: 45px;
  left: 20px;
  z-index: 1;
}
@media (max-width: 767.98px) {
  .home-mv__logo {
    width: 143px;
    top: 35px;
  }
}
.home-mv__intro {
  height: 100svh;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 1;
}
.home-mv__intro-text {
  font-size: 90px;
  font-weight: 400;
  font-family: "Poppins", sans-serif;
  color: #fff;
}
@media (max-width: 1023.98px) {
  .home-mv__intro-text {
    font-size: 60px;
  }
}
@media (max-width: 767.98px) {
  .home-mv__intro-text {
    font-size: 16vw;
    line-height: 1.3;
  }
}
.home-mv__intro-text br {
  display: none;
}
@media (max-width: 767.98px) {
  .home-mv__intro-text br {
    display: block;
  }
}
.home-mv__scroll-down {
  --_size: 200px;
  --_offset-x: 40px;
  --_offset-y: 40px;
  position: fixed;
  top: calc(100svh - var(--_size) - var(--_offset-y));
  right: var(--_offset-x);
  z-index: 0;
  text-align: center;
  width: var(--_size);
  height: var(--_size);
}
@media (max-width: 1399.98px) {
  .home-mv__scroll-down {
    --_size: 160px;
    --_offset-x: 20px;
    --_offset-y: 20px;
  }
}
@media (max-width: 1023.98px) {
  .home-mv__scroll-down {
    --_size: 150px;
  }
}
@media (max-width: 575.98px) {
  .home-mv__scroll-down {
    --_size: 100px;
    --_offset-x: 15px;
    --_offset-y: 15px;
  }
}
.home-mv__scroll-down-circle {
  animation: rotate 4s linear infinite;
}
@keyframes rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.home-mv__scroll-down-arrow {
  position: absolute;
  inset: 0;
}
.home-mv__missions {
  position: relative;
  height: calc(var(--home-mission-scroll-count, 3) * 100svh);
  z-index: 1;
}
.home-mv__missions-pin {
  position: relative;
  width: 100%;
  height: 100svh;
  will-change: transform;
}
.home-mv__missions-stage {
  position: relative;
  width: 100%;
  height: 100%;
  will-change: transform;
}
.home-mv__missions-slides {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.home-mv__missions-nav {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  z-index: 10;
  pointer-events: none;
  font-family: "Poppins", sans-serif;
  font-size: 13px;
  font-weight: 400;
  color: #fff;
  line-height: 1;
}
.home-mv__missions-nav-track {
  position: relative;
  width: 1px;
  height: 120px;
  background: rgba(255, 255, 255, 0.25);
}
@media (max-width: 767.98px) {
  .home-mv__missions-nav-track {
    height: 80px;
  }
}
.home-mv__missions-nav-progress {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #50A4A1;
  transform: scaleY(0);
  transform-origin: top;
  will-change: transform;
}
.home-mv__mission {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  backface-visibility: hidden;
  will-change: opacity;
}
.home-mv__mission-inner {
  display: grid;
  grid-template-columns: 37.3% 1fr;
  align-items: center;
  width: 100%;
}
@media (max-width: 767.98px) {
  .home-mv__mission-inner {
    grid-template-columns: 1fr;
    gap: 10px;
    text-align: center;
    padding-top: 40px;
  }
}
.home-mv__mission-img-wrap {
  position: relative;
  padding-left: 65px;
  overflow: hidden;
  will-change: opacity;
}
@media (max-width: 1023.98px) {
  .home-mv__mission-img-wrap {
    padding-left: 40px;
  }
}
@media (max-width: 767.98px) {
  .home-mv__mission-img-wrap {
    --home-mission-img-height: max(0px, calc(100svh - var(--home-mission-content-height, 0px) - 5svh));
    --home-mission-img-width: calc(var(--home-mission-img-height) * 385 / 516);
    width: min(100%, var(--home-mission-img-width));
    margin-inline: auto;
    padding-inline: 30px;
  }
}
.home-mv__mission-img {
  display: block;
  border-radius: 12px;
  max-width: 100%;
  height: auto;
  will-change: transform, opacity;
}
.home-mv__mission-img ~ .home-mv__mission-img {
  position: absolute;
  top: 0;
  left: 65px;
  width: calc(100% - 65px);
}
@media (max-width: 1023.98px) {
  .home-mv__mission-img {
    margin-inline: auto;
  }
  .home-mv__mission-img ~ .home-mv__mission-img {
    left: 30px;
    right: 30px;
    width: calc(100% - 60px);
  }
}
@media (max-width: 767.98px) {
  .home-mv__mission-img {
    width: 100%;
  }
  .home-mv__mission-img ~ .home-mv__mission-img {
    left: 30px;
    right: 30px;
  }
}
.home-mv__mission-content {
  padding-inline: 75px;
  will-change: transform, opacity;
}
@media (max-width: 1023.98px) {
  .home-mv__mission-content {
    padding-inline: 30px;
  }
}
@media (max-width: 767.98px) {
  .home-mv__mission-content {
    padding-inline: 0;
  }
}
.home-mv__mission-title {
  font-size: 50px;
  font-weight: 400;
  font-family: "Poppins", sans-serif;
  color: #50A4A1;
  margin-bottom: 0.25em;
}
@media (max-width: 767.98px) {
  .home-mv__mission-title {
    font-size: 40px;
  }
}
.home-mv__mission-text {
  color: #fff;
  font-size: 15px;
  line-height: 2.26;
}
@media (max-width: 767.98px) {
  .home-mv__mission-text {
    text-align: left;
    line-height: 2;
  }
}

.home-message {
  position: relative;
  height: 200svh;
  z-index: 1;
  box-sizing: border-box;
  padding-top: 100svh;
}
.home-message::before {
  content: "";
  position: absolute;
  height: 100svh;
  background: #000;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 0;
  opacity: 0.5;
}
.home-message__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100svh;
  width: 100%;
  z-index: 1;
  text-align: center;
  padding-top: calc(var(--infinity-shape-height, 34vmin) + var(--infinity-text-gap, 0px));
}
.home-message__title {
  font-size: 30px;
  font-weight: 400;
  color: #50A4A1;
  margin-bottom: 0.25em;
}
@media (max-width: 767.98px) {
  .home-message__title {
    font-size: 24px;
  }
}
.home-message__text {
  color: #fff;
  font-size: 15px;
  line-height: 2.26;
  margin-block: 20px;
}
.home-message__btn {
  margin-top: 20px;
  width: 300px;
  margin-inline: auto;
}

.home-casestudy {
  padding: 20px;
  background: #fff;
  position: relative;
  z-index: 1;
}
@media (max-width: 767.98px) {
  .home-casestudy {
    padding: 0;
  }
}
.home-casestudy__inner {
  background: linear-gradient(to bottom, #53C1B7 0%, #4C9E97 100%);
  border-radius: 16px;
  padding: 100px 0 150px;
}
@media (max-width: 1023.98px) {
  .home-casestudy__inner {
    padding: 50px 0 75px;
  }
}
@media (max-width: 767.98px) {
  .home-casestudy__inner {
    padding: 40px 0;
    border-radius: 0;
  }
}
.home-casestudy__text {
  font-size: 15px;
  line-height: 2;
  color: #fff;
  max-width: 600px;
}
.home-casestudy__middle {
  margin-top: 80px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 1023.98px) {
  .home-casestudy__middle {
    margin-top: 40px;
    flex-direction: column-reverse;
    gap: 40px;
  }
}
.home-casestudy__nav-list {
  background: #fff;
  padding: 10px;
  border-radius: 100px;
  display: grid;
  grid-template-columns: repeat(3, 200px);
  gap: 10px;
}
@media (max-width: 767.98px) {
  .home-casestudy__nav-list {
    grid-template-columns: repeat(3, 1fr);
    padding: 5px;
    gap: 5px;
  }
}
.home-casestudy__nav-link {
  font-size: 16px;
  font-weight: 600;
  color: #707070;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1em;
  border-radius: 100px;
  line-height: 1.5;
  transition: all 0.3s ease;
  text-align: center;
  height: 100%;
}
@media (max-width: 767.98px) {
  .home-casestudy__nav-link {
    font-size: 12px;
    padding: 0.5em 0.8em;
    line-height: 1.3;
  }
}
.home-casestudy__nav-link:hover {
  background: #50A4A1;
  color: #fff;
}
.home-casestudy__nav-link.--active {
  background: #50A4A1;
  color: #fff;
}
.home-casestudy__nav-link br {
  display: none;
}
@media (max-width: 767.98px) {
  .home-casestudy__nav-link br {
    display: block;
  }
}
.home-casestudy__list {
  display: none;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-top: 45px;
}
@media (max-width: 1023.98px) {
  .home-casestudy__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767.98px) {
  .home-casestudy__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575.98px) {
  .home-casestudy__list {
    grid-template-columns: 1fr;
  }
}
.home-casestudy__list.--active {
  display: grid;
  animation: fadeIn 0.3s ease forwards;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.home-casestudy__item {
  background: #fff;
}
.home-casestudy__item-link {
  position: relative;
  display: block;
}
.home-casestudy__item-link:after {
  content: "";
}
.home-casestudy__item-link:hover .home-casestudy__item-img img {
  transform: scale(1.05);
}
.home-casestudy__item-link:hover .home-casestudy__item-body::after {
  transform: translateX(5px);
}
.home-casestudy__item-img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
}
.home-casestudy__item-img img {
  transition: all 0.3s ease;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-casestudy__item-category {
  position: absolute;
  top: 0;
  right: 0;
  background: #3B3B3B;
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  padding: 4px 10px;
  text-align: center;
  min-width: 140px;
}
.home-casestudy__item-body {
  padding: 20px 24px 37px;
  position: relative;
}
.home-casestudy__item-body:after {
  position: absolute;
  content: "";
  bottom: 20px;
  right: 12px;
  width: 30px;
  height: 16px;
  background: url("../images/arrow-right.svg") no-repeat center;
  background-size: contain;
  transition: all 0.3s ease;
}
.home-casestudy__item-date {
  font-family: "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 1em;
}
.home-casestudy__item-title {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.8;
  margin-bottom: 0.5em;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.home-casestudy__item-text {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.8;
  margin-bottom: 1em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.home-casestudy__item-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.home-casestudy__item-tag {
  color: #50A4A1;
  font-size: 12px;
  font-weight: 500;
}

.home-blog {
  overflow: hidden;
  padding: 120px 0;
  background: #fff;
  position: relative;
  z-index: 1;
}
@media (max-width: 1023.98px) {
  .home-blog {
    padding: 60px 0 80px;
  }
}
@media (max-width: 767.98px) {
  .home-blog {
    padding: 40px 0 60px;
  }
}
.home-blog__slider {
  max-width: 360px;
  margin-left: 0;
  margin-top: 60px;
}
@media (max-width: 767.98px) {
  .home-blog__slider {
    max-width: 80%;
    margin-top: 40px;
  }
}
.home-blog__slider.swiper {
  overflow: visible;
}
.home-blog__item-link {
  position: relative;
  display: block;
}
.home-blog__item-link:hover .home-blog__item-img img {
  transform: scale(1.05);
}
.home-blog__item-link:hover .home-blog__item-body::after {
  transform: translateX(5px);
}
.home-blog__item-img {
  margin-left: 30px;
  border-radius: 6px;
  overflow: hidden;
  aspect-ratio: 407/290;
}
@media (max-width: 767.98px) {
  .home-blog__item-img {
    margin-left: 30px;
  }
}
.home-blog__item-img img {
  transition: all 0.3s ease;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-blog__item-date {
  font-family: "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 500;
  writing-mode: vertical-rl;
  position: absolute;
  line-height: 1;
  top: 3px;
  left: 0;
}
@media (max-width: 767.98px) {
  .home-blog__item-date {
    font-size: 14px;
  }
}
.home-blog__item-body {
  position: relative;
  margin-right: 30px;
  background: #F2F2F2;
  border-radius: 10px;
  padding: 20px 60px 25px 25px;
  margin-top: -53px;
}
@media (max-width: 767.98px) {
  .home-blog__item-body {
    margin-top: -30px;
    padding: 20px 50px 30px 25px;
    margin-right: 30px;
  }
}
.home-blog__item-body:after {
  position: absolute;
  content: "";
  top: 50%;
  right: 20px;
  width: 30px;
  height: 16px;
  background: url("../images/arrow-right.svg") no-repeat center;
  background-size: contain;
  margin-top: -8px;
  transition: all 0.3s ease;
}
@media (max-width: 767.98px) {
  .home-blog__item-body:after {
    right: 10px;
  }
}
.home-blog__item-title {
  font-size: 16px;
  font-weight: 500;
  line-height: 2;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 0.5em;
}
@media (max-width: 767.98px) {
  .home-blog__item-title {
    font-size: 15px;
  }
}
.home-blog__item-tags {
  display: flex;
  gap: 8px;
  margin-top: 10px;
  font-size: 12px;
  font-weight: 500;
  color: #50A4A1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.home-blog__slider-controls {
  padding-left: 150px;
  margin-top: 70px;
  position: relative;
}
@media (max-width: 767.98px) {
  .home-blog__slider-controls {
    padding-left: 120px;
    margin-top: 50px;
  }
}
.home-blog__slider-controls .swiper-button-prev {
  left: 75px;
  top: 23px;
  width: 50px;
  height: 50px;
  margin-left: -50px;
}
@media (max-width: 767.98px) {
  .home-blog__slider-controls .swiper-button-prev {
    left: 50px;
  }
}
.home-blog__slider-controls .swiper-button-prev:after {
  display: block;
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  width: 26px;
  height: 26px;
  border-top: 3px solid #50A4A1;
  border-left: 3px solid #50A4A1;
  transform: translate(-50%, -50%) rotate(-45deg);
  margin-left: 5px;
}
.home-blog__slider-controls .swiper-button-next {
  left: 75px;
  top: 23px;
  width: 50px;
  height: 50px;
}
@media (max-width: 767.98px) {
  .home-blog__slider-controls .swiper-button-next {
    left: 50px;
  }
}
.home-blog__slider-controls .swiper-button-next:after {
  display: block;
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  width: 26px;
  height: 26px;
  border-top: 3px solid #50A4A1;
  border-right: 3px solid #50A4A1;
  transform: translate(-50%, -50%) rotate(45deg);
  margin-left: -5px;
}
.home-blog__slider-controls .swiper-pagination-progressbar {
  margin-top: 0;
  height: 3px;
}
.home-blog__slider-controls .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: #50A4A1;
}

.home-business-partners {
  padding: 120px 0 0;
  background: #EDEDED;
  position: relative;
  z-index: 1;
}
@media (max-width: 1023.98px) {
  .home-business-partners {
    padding: 60px 0 0;
  }
}
@media (max-width: 767.98px) {
  .home-business-partners {
    padding: 40px 0 0;
  }
}
.home-business-partners__list {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 28px;
  margin-top: 80px;
}
@media (max-width: 767.98px) {
  .home-business-partners__list {
    margin-top: 40px;
    flex-direction: column;
    align-items: center;
  }
}
.home-business-partners__item a img {
  width: auto;
}

.home-news {
  padding: 120px 0 150px;
  background: #EDEDED;
  position: relative;
  z-index: 1;
}
@media (max-width: 1023.98px) {
  .home-news {
    padding: 60px 0 80px;
  }
}
@media (max-width: 767.98px) {
  .home-news {
    padding: 40px 0 40px;
  }
}
.home-news__middle {
  display: flex;
  align-items: center;
  gap: 30px;
}
@media (max-width: 1023.98px) {
  .home-news__middle {
    flex-direction: column-reverse;
    align-items: center;
    gap: 40px;
    width: 100%;
  }
}
.home-news__list {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 28px;
  margin-top: 80px;
}
@media (max-width: 1023.98px) {
  .home-news__list {
    margin-top: 40px;
  }
}
.home-news__nav-list {
  display: flex;
  align-items: center;
  gap: 40px;
}
@media (max-width: 1023.98px) {
  .home-news__nav-list {
    gap: 20px;
  }
}
.home-news__nav-item:not(:last-child) {
  position: relative;
}
.home-news__nav-item:not(:last-child):after {
  content: "";
  position: absolute;
  width: 1px;
  height: 25px;
  background: #50A4A1;
  right: -20px;
  top: 0;
  transform: rotate(25deg);
}
@media (max-width: 1023.98px) {
  .home-news__nav-item:not(:last-child):after {
    height: 18px;
    top: 4px;
    right: -11px;
  }
}
.home-news__nav-link {
  font-size: 16px;
  font-weight: 600;
  color: #707070;
  transition: all 0.3s ease;
}
@media (max-width: 767.98px) {
  .home-news__nav-link {
    margin-top: 14px;
  }
}
.home-news__nav-link:hover {
  color: #50A4A1;
}
.home-news__nav-link.--active {
  color: #50A4A1;
}
.home-news__list {
  display: none;
  gap: 12px;
}
.home-news__list.--active {
  display: grid;
  animation: fadeIn 0.3s ease forwards;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.home-news__item-link {
  display: grid;
  grid-template-columns: 120px 140px 1fr;
  align-items: center;
  background: #fff;
  padding: 30px 45px;
  border-radius: 12px;
  transition: all 0.3s ease;
}
@media (max-width: 767.98px) {
  .home-news__item-link {
    grid-template-columns: 100px 120px 1fr;
    padding: 20px;
  }
}
.home-news__item-link:hover .home-news__item-title {
  color: #50A4A1;
}
.home-news__item-date {
  font-size: 16px;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .home-news__item-date {
    font-size: 14px;
  }
}
.home-news__item-category {
  font-size: 14px;
  background-color: #50A4A1;
  font-weight: 500;
  color: #fff;
  border-radius: 4px;
  text-align: center;
  padding: 5px;
}
@media (max-width: 767.98px) {
  .home-news__item-category {
    font-size: 12px;
    padding: 3px;
  }
}
.home-news__item-title {
  font-size: 16px;
  margin-left: 30px;
  transition: all 0.3s ease;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 1023.98px) {
  .home-news__item-title {
    font-size: 14px;
    grid-column: 1/4;
    margin-left: 0;
    margin-top: 15px;
  }
}

.home-recruit {
  background-image: url("../images/home/recruit-bg.jpg");
  background-position: center;
  background-size: cover;
  padding: 150px 0 200px;
  position: relative;
  z-index: 1;
}
@media (max-width: 1023.98px) {
  .home-recruit {
    padding: 80px 0;
  }
}
@media (max-width: 767.98px) {
  .home-recruit {
    padding: 40px 0;
  }
}
.home-recruit__text {
  font-size: 15px;
  font-weight: 500;
  line-height: 2;
  margin-top: 40px;
  color: #fff;
  text-align: center;
  margin-bottom: 45px;
}
@media (max-width: 1023.98px) {
  .home-recruit__text {
    text-align: left;
  }
}

.page-header {
  margin: 15px 15px 65px;
  padding: 150px 15px;
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  background-image: url(../images/header-bg.jpg);
  background-position: center;
}
@media (max-width: 767.98px) {
  .page-header {
    margin: 10px 10px 45px;
    border-radius: 10px;
    padding: 90px 0 40px;
  }
}
.page-header.--company {
  background-image: url(../images/company/header-bg.jpg);
}
.page-header.--business {
  background-image: url(../images/business/header-bg.jpg);
}
.page-header.--case-study {
  background-image: url(../images/case-study/header-bg.jpg);
}
.page-header.--tech-blog {
  background-image: url(../images/tech-blog/header-bg.jpg);
}
.page-header.--recruit {
  background-image: url(../images/recruit/header-bg.jpg);
}
.page-header__logo {
  position: absolute;
  top: 30px;
  left: 30px;
}
@media (max-width: 767.98px) {
  .page-header__logo {
    width: 143px;
    top: 25px;
    left: 10px;
  }
}
.page-header__inner {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (max-width: 767.98px) {
  .page-header__inner {
    gap: 30px;
    flex-direction: column-reverse;
  }
}
.page-header__title {
  color: #fff;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-size: 56px;
}
@media (max-width: 767.98px) {
  .page-header__title {
    font-size: 32px;
  }
}
.page-header__title small {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  line-height: 1.2;
  display: block;
}
@media (max-width: 767.98px) {
  .page-header__title small {
    font-size: 16px;
  }
}

.page-content {
  margin-bottom: 80px;
}
@media (max-width: 767.98px) {
  .page-content {
    margin-bottom: 50px;
  }
}

.page-section {
  margin-bottom: 70px;
}

.breadcrumb {
  font-size: 14px;
  color: #fff;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.5em 2em;
}
@media (max-width: 767.98px) {
  .breadcrumb {
    justify-content: flex-start;
    font-size: 12px;
  }
}
.breadcrumb li:not(:last-child) {
  position: relative;
}
.breadcrumb li:not(:last-child):after {
  content: "/";
  position: absolute;
  top: 0;
  right: -1.2em;
}
.breadcrumb li a {
  text-decoration: underline;
}

:root:has(.products__items) {
  scroll-behavior: smooth;
}

.products .page-content {
  padding-bottom: 90px;
}
@media (max-width: 767.98px) {
  .products .page-content {
    padding-bottom: 50px;
  }
}
.products__familia-energy #toc-target_2 .row .row:not(:last-child) {
  margin-bottom: 20px;
}
@media (max-width: 767.98px) {
  .products__familia-energy #toc-target_2 .row .row:not(:last-child) {
    margin-bottom: 0;
  }
}
@media (max-width: 767.98px) {
  .products__familia-energy #toc-target_2 .row .row .col-md-6 {
    margin-bottom: 10px;
  }
}
.products__familia-energy #toc-target_2 .products__items__check-list {
  margin-bottom: 0;
}
@media (max-width: 767.98px) {
  .products__familia-energy #toc-target_5 .row .col-md-6 {
    margin-bottom: 30px;
  }
}
.products__familia-energy #toc-target_5 .row .col-md-6:first-child, .products__familia-energy #toc-target_5 .row .col-md-6:nth-child(2) {
  margin-bottom: 30px;
}
.products__familia-energy__aggregate img {
  width: 100%;
}
.products__familia-energy__aggregate__content__title {
  font-size: 17px;
  font-weight: 700;
  margin-top: 0.5em;
}
.products__familia-energy__aggregate__content__text {
  font-size: 13px;
  text-align: justify;
  margin-top: 0.25em;
}
.products__familia-vision #toc-target_1 .products__items__lead {
  text-align: center;
}
.products__familia-vision__card {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 0;
  background: #F3F4F5;
  border-radius: 10px;
  padding: 30px;
}
@media (max-width: 767.98px) {
  .products__familia-vision__card {
    padding: 20px;
  }
}
.products__familia-vision__card__icon {
  text-align: center;
  margin-bottom: 20px;
}
.products__familia-vision__card__icon img {
  width: 100px;
}
.products__familia-vision__card__title {
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 1em;
}
.products__familia-vision__card__list {
  font-size: 14px;
}
.products__familia-vision__card__list__item {
  padding-left: 1em;
  text-indent: -1em;
}
.products__familia-vision__card__list__item:not(:last-child) {
  margin-bottom: 0.5em;
}
.products__familia-vision__card__list__item::before {
  content: "・";
  font-size: 1em;
  font-weight: 700;
  color: #50A4A1;
}
.products__familia-vision__card__wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 25px;
  margin-bottom: 50px;
}
@media (max-width: 767.98px) {
  .products__familia-vision__card__wrap {
    gap: 15px;
  }
}
@media (max-width: 575.98px) {
  .products__familia-vision__card__wrap {
    grid-template-columns: 1fr;
  }
}
.products__familia-vision__card__wrap + p {
  font-size: 24px;
  font-weight: 700;
  text-align: center;
}
.products__familia-vision__card__wrap + p span {
  display: inline-block;
}
.products__familia-vision__table {
  width: 100%;
  font-size: 16px;
}
.products__familia-vision__table tr:first-child {
  border-bottom: 1px solid #FFFFFF;
}
.products__familia-vision__table tr:first-child th {
  background: #A3CECB;
}
.products__familia-vision__table tr:first-child th:nth-child(even) {
  background: #99C8C5;
}
.products__familia-vision__table tr:last-child td {
  border-bottom: none;
}
.products__familia-vision__table tr th,
.products__familia-vision__table tr td {
  padding: 1em;
}
.products__familia-vision__table tr th {
  background: #F3F4F5;
}
.products__familia-vision__table tr th + td {
  background: rgba(71, 150, 145, 0.0509803922);
}
.products__familia-vision__table tr td {
  border-bottom: 1px solid #EDEEEF;
}
.products__familia-vision__table__wrap {
  border: 1px solid #EDEEEF;
  border-radius: 3px;
  overflow: hidden;
}
.products__familia-vision__model {
  border: 1px solid #EDEEEF;
  border-radius: 3px;
  overflow: hidden;
}
.products__familia-vision__model__title {
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  color: #FFFFFF;
  background-image: linear-gradient(90deg, #53C1B7 0%, #4C9E97 100%);
  padding: 0.625em 1em;
}
.products__familia-vision__model__list {
  display: grid;
  grid-template-columns: repeat(2, auto) 1fr;
}
.products__familia-vision__model__list__item {
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 3;
  gap: 0.5em 3em;
  font-size: 16px;
  padding: 1em 1em;
}
.products__familia-vision__model__list__item:not(:last-child) {
  border-bottom: 1px solid #EDEEEF;
}
@media (max-width: 767.98px) {
  .products__familia-vision__model__list__item__num {
    grid-row: 1/3;
    grid-column: 1/2;
  }
}
.products__familia-vision__model__list__item__name {
  font-weight: 700;
}
@media (max-width: 767.98px) {
  .products__familia-vision__model__list__item__name {
    grid-row: 1/2;
    grid-column: 2/3;
  }
}
@media (max-width: 767.98px) {
  .products__familia-vision__model__list__item__detail {
    grid-row: 2/3;
    grid-column: 2/3;
  }
}
.products__rxt #toc-target_1 .products__items__ph {
  margin-bottom: 50px;
}
.products__rxt__facility__title {
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  color: #FFFFFF;
  padding: 0.5em 1em;
  background: #334155;
  margin-bottom: 1em;
}
.products__rxt__facility__content {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
@media (max-width: 767.98px) {
  .products__rxt__facility__content {
    grid-template-columns: repeat(2, 1fr);
  }
}
.products__rxt__facility__content {
  margin-bottom: 30px;
}
.products__rxt__facility__content__card {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0;
}
.products__rxt__facility__content__card__title {
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  color: #FFFFFF;
  padding: 0.75em 0.5em;
  background: #50A4A1;
  border-radius: 2px 2px 0 0;
}
.products__rxt__facility__content__list__item li {
  padding-left: 1em;
}
.products__rxt__facility__content2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 767.98px) {
  .products__rxt__facility__content2 {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.products__rxt__facility__content2 {
  margin-bottom: 30px;
}
.products__rxt__facility__content2__list__item {
  text-indent: -1em;
  padding-left: 1em;
}
.products__title {
  font-size: 20px;
  font-weight: 600;
  color: #50A4A1;
  margin-bottom: 1.375em;
}
.products__header {
  display: block;
  color: #FFFFFF;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  aspect-ratio: 1216/450;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
}
@media (max-width: 1279.98px) {
  .products__header {
    aspect-ratio: 1216/500;
  }
}
@media (max-width: 767.98px) {
  .products__header {
    aspect-ratio: auto;
  }
}
.products__header.--familia-energy {
  background-image: url(../images/business/products/header-bg_familia-energy.jpg);
  --logo-size: 376px;
  --item-width_left: 376fr;
  --item-width_right: 615fr;
  --item-gap: 80px;
  padding: 30px 60px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 1023.98px) {
  .products__header.--familia-energy {
    --item-gap: 30px;
    padding: 30px;
  }
}
@media (max-width: 767.98px) {
  .products__header.--familia-energy {
    padding: 50px 60px;
  }
}
@media (max-width: 575.98px) {
  .products__header.--familia-energy {
    --logo-size: 221px;
    padding: 40px 30px;
  }
}
@media (max-width: 1023.98px) {
  .products__header.--familia-energy br {
    display: none;
  }
}
.products__header.--familia-vision {
  background-image: url(../images/business/products/header-bg_familia-vision.jpg);
  --logo-size: 513.5px;
  --text-width: 556px;
  --logo-mb: 40px;
  padding-left: 6.578947368%;
  display: flex;
  align-items: center;
}
@media (max-width: 1279.98px) {
  .products__header.--familia-vision {
    background-image: url(../images/business/products/header-bg_familia-vision_tb.jpg);
  }
}
@media (max-width: 1023.98px) {
  .products__header.--familia-vision {
    --logo-mb: 15px;
  }
}
@media (max-width: 767.98px) {
  .products__header.--familia-vision {
    --text-width: 100%;
    padding: 50px 60px;
  }
}
@media (max-width: 575.98px) {
  .products__header.--familia-vision {
    --logo-size: 305px;
    padding: 40px 30px;
    background-position: 70% center;
  }
}
@media (max-width: 767.98px) {
  .products__header.--familia-vision p.products__header__title br {
    display: none;
  }
}
.products__header.--rxt {
  background-image: url(../images/business/products/header-bg_rxt.jpg);
  --logo-size: 230.57px;
  --item-width_left: 230.57fr;
  --item-width_right: 556fr;
  --item-gap: 130px;
  padding: 0 150px;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 1279.98px) {
  .products__header.--rxt {
    --item-gap: 100px;
    padding: 0 40px;
  }
}
@media (max-width: 1023.98px) {
  .products__header.--rxt {
    --item-gap: 40px;
    padding: 0 40px;
  }
}
@media (max-width: 767.98px) {
  .products__header.--rxt {
    padding: 50px 60px;
  }
}
@media (max-width: 575.98px) {
  .products__header.--rxt {
    --logo-size: 151px;
    padding: 40px 30px;
  }
}
@media (max-width: 1023.98px) {
  .products__header.--rxt br {
    display: none;
  }
}
.products__header__inner {
  display: grid;
  grid-template-columns: var(--item-width_left) var(--item-width_right);
  justify-content: center;
  align-items: center;
  gap: var(--item-gap);
}
@media (max-width: 767.98px) {
  .products__header__inner {
    display: block;
  }
}
.products__header__inner span {
  display: inline-block;
}
@media (max-width: 1023.98px) {
  .products__header__inner span {
    display: inline;
  }
}
.products__header__logo {
  margin-bottom: var(--logo-mb);
}
@media (max-width: 767.98px) {
  .products__header__logo {
    text-align: center;
    margin-bottom: 30px;
  }
}
.products__header__logo img {
  width: var(--logo-size);
}
.products__header__title {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 1.5em;
}
@media (max-width: 1279.98px) {
  .products__header__title {
    font-size: 20px;
  }
}
@media (max-width: 1023.98px) {
  .products__header__title {
    font-size: 18px;
    margin-bottom: 0.5em;
  }
}
@media (max-width: 767.98px) {
  .products__header__title {
    text-align: justify;
    margin-bottom: 1em;
  }
}
.products__header__text {
  width: var(--text-width);
  line-height: 1.9;
}
@media (max-width: 1279.98px) {
  .products__header__text {
    font-size: 15px;
  }
}
@media (max-width: 1279.98px) {
  .products__header__text {
    font-size: 14px;
  }
}
@media (max-width: 767.98px) {
  .products__header__text {
    text-align: justify;
  }
}
.products__header__wrap {
  display: grid;
  gap: 30px;
  margin-top: 3.5rem;
}
.products__items {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 40px;
  margin-top: 3rem;
}
@media (max-width: 1023.98px) {
  .products__items {
    grid-template-columns: 100%;
  }
}
.products__items__content {
  order: 1;
}
.products__items__content section:not(:last-child) {
  margin-bottom: 50px;
}
.products__items__side {
  width: 360px;
  order: 0;
}
@media (max-width: 1023.98px) {
  .products__items__side {
    position: sticky;
    top: 120px;
    left: 0;
    right: 0;
    width: 100%;
  }
}
@media (max-width: 767.98px) {
  .products__items__side {
    display: none;
  }
}
.products__items__side__inner {
  position: sticky;
  top: 120px;
  left: 0;
  max-height: calc(100vh - 120px);
  overflow-y: auto;
}
@media (max-width: 1023.98px) {
  .products__items__side__inner {
    position: static;
  }
}
@media (max-width: 1023.98px) {
  .products__items__side__hidden {
    display: none;
  }
}
.products__items__side .heading2 {
  font-size: 18px;
}
.products__items__lead {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 1.5em;
}
.products__items__lead span {
  color: #50A4A1;
}
.products__items__list__item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 20px;
}
.products__items__list__item:not(:first-child) {
  margin-top: 30px;
}
.products__items__list__number {
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  color: #FFFFFF;
  background-color: #50A4A1;
  aspect-ratio: 1/1;
  width: 2.25em;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 16px;
}
.products__items__detail__title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 0.5em;
}
.products__items__text {
  margin-bottom: 1.5em;
}
.products__items__text:has(b) {
  margin-bottom: 0.25em;
}
.products__items__ph {
  margin-bottom: 20px;
}
.products__items__ph.--scrollable {
  overflow-x: auto;
}
.products__items__ph.--scrollable img {
  min-width: 584px;
}
.products__items__fig__cap {
  font-size: 12px;
  font-weight: 700;
  text-align: center;
}
.products__items__fig img {
  width: 100%;
}
.products__items__check-list {
  margin-bottom: 30px;
}
.products__items__check-list__item {
  font-weight: 500;
  position: relative;
  padding-left: 1.75em;
  margin-top: 1em;
}
.products__items__check-list__item::before {
  position: absolute;
  top: 0;
  left: 0;
  translate: 0 0.25em;
  content: "";
  aspect-ratio: 1/1;
  width: 1em;
  display: block;
  background-image: url(../images/business/products/icon_check.svg);
  background-repeat: no-repeat;
  background-size: cover;
}
.products__items__table {
  width: 100%;
  border: 1px solid #4C9E97;
}
.products__items__table:has(.--bg-gray) {
  border-color: #CBCBCB;
}
.products__items__table:has(.--bg-gray) tr:last-child th {
  border-bottom: solid 1px #CBCBCB;
}
.products__items__table:has(.--bg-gray) td {
  border-color: #CBCBCB;
}
@media (max-width: 767.98px) {
  .products__items__table th,
  .products__items__table td {
    display: block;
  }
}
.products__items__table tr:last-child th {
  border-bottom: solid 1px #4C9E97;
}
.products__items__table th {
  color: #FFFFFF;
  background: #4C9E97;
  padding: 1.5em;
  min-width: 11em;
  text-align: center;
  vertical-align: middle;
}
.products__items__table th.--bg-gray {
  background: #CBCBCB;
}
.products__items__table th:not(:last-child) {
  border-bottom: 1px solid #FFFFFF;
}
.products__items__table th span {
  display: inline-block;
}
.products__items__table td {
  padding: 1.5em;
  border: solid 1px #4C9E97;
}
@media (max-width: 767.98px) {
  .products__items__table td {
    border: none;
  }
}
.products__items__table__cap {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 0.25em;
}
.products__items__note {
  font-size: 12px;
  margin-bottom: 1em;
}
.products__items__toc {
  margin-bottom: 30px;
}
@media (max-width: 1023.98px) {
  .products__items__toc {
    display: flex;
  }
}
@media (max-width: 1023.98px) {
  .products__items__toc__item {
    flex-grow: 1;
  }
}
.products__items__toc__link {
  display: block;
  font-size: 14px;
  font-weight: 700;
  background: #F3F4F5;
  padding: 1em;
  padding-left: 2em;
  position: relative;
  transition: ease-in-out 0.3s;
}
.products__items__toc__link::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  width: 4px;
  height: 100%;
  background-color: #50A4A1;
  border-radius: 3px 0 0 0;
  opacity: 0;
  transition: ease-in-out 0.3s;
}
.products__items__toc__link.--active {
  color: #50A4A1;
  background: #FFFFFF;
}
.products__items__toc__link.--active::before {
  opacity: 1;
}
.products__items .toc-target {
  scroll-margin-top: 120px;
}
@media (max-width: 1023.98px) {
  .products__items .toc-target {
    scroll-margin-top: 200px;
  }
}

.company-origin__text {
  text-align: center;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 40px;
  margin-top: 1em;
}
.company-origin__text small {
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 500;
  color: #50A4A1;
}

.company-map {
  position: relative;
  padding-top: 400px;
  margin-bottom: 2rem;
}
.company-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.company-business-main {
  background: #F0FDFA;
  padding: 40px 20px;
  margin-bottom: 80px;
}
.company-business-main__logo {
  text-align: center;
  margin-bottom: 40px;
}
.company-business-main__logo img {
  width: 268px;
}
.company-business-main__card {
  background: #fff;
  height: 100%;
  border: solid 1px #E5E7EB;
}
.company-business-main__card-title {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  background: #50A4A1;
  padding: 0.5em;
}
.company-business-main__card-body {
  padding: 20px 24px;
  height: 100%;
}
.company-business-main__card-text {
  margin-bottom: 20px;
}
.company-business-main__card-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.company-business-main__card-gallery.--col4 {
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.company-business-main__card-gallery figure figcaption {
  font-size: 12px;
  margin-top: 10px;
  text-align: center;
}

.company-business-item__logo {
  text-align: center;
  margin-bottom: 30px;
  min-height: 48px;
}
.company-business-item__logo.--logo1 img {
  width: 117px;
}
.company-business-item__logo.--logo2 img {
  width: 267px;
}
.company-business-item__logo.--logo3 img {
  width: 320px;
}
.company-business-item__card {
  border: solid 1px #E5E7EB;
}
.company-business-item__card-title {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  background: #50A4A1;
  padding: 1em 0.5em;
}
.company-business-item__card-title.--title1 {
  background: #FED7AA;
}
.company-business-item__card-title.--title2 {
  background: #E5E7EB;
}
.company-business-item__card-title.--title3 {
  background: #BFDBFE;
}
.company-business-item__card-body {
  padding: 20px 24px;
}
.company-business-item__card-text {
  font-size: 14px;
  margin-bottom: 20px;
}
.company-business-item__card-gallery {
  margin-bottom: 20px;
}
.company-business-item__card-gallery.--col2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.company-business-item__card-gallery figure figcaption {
  font-size: 12px;
  margin-top: 10px;
  text-align: center;
}

.company-management {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
}
@media (max-width: 1023.98px) {
  .company-management {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
}
.company-management__title {
  font-size: 18px;
  color: #fff;
  font-weight: bold;
  background: #50A4A1;
  padding: 0.3em 1em;
  border-radius: 5px;
  margin-bottom: 2rem;
}
.company-management__ceo-img {
  text-align: center;
  margin-bottom: 20px;
}
.company-management__ceo-img img {
  width: 300px;
}
.company-management__ceo-title {
  font-size: 14px;
  font-weight: bold;
  color: #50A4A1;
  text-align: center;
}
.company-management__ceo-name {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 2rem;
}
.company-management__ceo-name small {
  font-size: 20px;
  color: #3B3B3B;
  font-weight: normal;
  margin-left: 1em;
}
.company-management__ceo-message {
  margin-bottom: 2rem;
}
.company-management__ceo-message h4 {
  font-size: 20px;
  font-weight: bold;
  color: #50A4A1;
  margin-bottom: 10px;
}
.company-management__ceo-message p {
  font-size: 15px;
}
.company-management__ceo-profile {
  background: #F9F7F7;
  padding: 15px 20px;
}
.company-management__ceo-profile h4 {
  font-size: 20px;
  font-weight: bold;
  color: #50A4A1;
  margin-bottom: 10px;
}
.company-management__ceo-profile p {
  font-size: 15px;
}
.company-management__member {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 20px;
  margin-bottom: 2rem;
}
@media (max-width: 575.98px) {
  .company-management__member {
    grid-template-columns: 1fr;
  }
}
.company-management__member-img {
  text-align: center;
}
.company-management__member-img img {
  max-width: 300px;
}
.company-management__member-title {
  font-size: 14px;
  font-weight: bold;
  color: #50A4A1;
}
.company-management__member-name {
  font-size: 22px;
  font-weight: bold;
  margin-bottom: 10px;
}
.company-management__member-name small {
  font-size: 14px;
  color: #3B3B3B;
  font-weight: normal;
  margin-left: 1em;
}
.company-management__member-text {
  font-size: 14px;
}
.company-management__stockholder {
  margin-top: 60px;
}
@media (max-width: 1023.98px) {
  .company-management__stockholder {
    margin-top: 3rem;
  }
}
.company-management__stockholder-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 575.98px) {
  .company-management__stockholder-list {
    grid-template-columns: 1fr;
  }
}
.company-management__stockholder-list li {
  font-size: 16px;
  font-weight: bold;
}
.company-management__stockholder-list li span {
  color: #666;
  display: block;
  font-size: 14px;
  font-weight: normal;
}
.company-management__stockholder-list li span:before {
  content: "-";
}

.company-mission-concept {
  background: url(../images/company/mission/concept-bg.jpg);
  background-size: cover;
  background-position: center;
  color: #fff;
  padding: 60px 20px;
}
.company-mission-concept__title {
  font-family: "Poppins", sans-serif;
  font-size: 60px;
  text-align: center;
  margin-bottom: 60px;
}
@media (max-width: 1023.98px) {
  .company-mission-concept__title {
    font-size: 40px;
  }
}
.company-mission-concept__title small {
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.35em;
}
.company-mission-concept__text {
  text-align: center;
  line-height: 2;
}
@media (max-width: 1023.98px) {
  .company-mission-concept__text {
    font-size: 14px;
  }
}
@media (max-width: 767.98px) {
  .company-mission-concept__text {
    text-align: left;
  }
}

.company-mission-update__text {
  text-align: center;
  font-size: 20px;
  line-height: 2;
  font-weight: bold;
  margin-bottom: 40px;
}
@media (max-width: 767.98px) {
  .company-mission-update__text {
    font-size: 16px;
  }
}
.company-mission-update__text em {
  font-style: normal;
  color: #50A4A1;
}
.company-mission-update__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 30px;
}
@media (max-width: 1023.98px) {
  .company-mission-update__list {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (max-width: 767.98px) {
  .company-mission-update__list {
    grid-template-columns: repeat(3, 1fr);
    font-size: 14px;
  }
}
@media (max-width: 575.98px) {
  .company-mission-update__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
.company-mission-update__list li {
  text-align: center;
}
.company-mission-update__list li img {
  margin-bottom: 10px;
}

.company-mission-example-list {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 40px;
  line-height: 2;
}
@media (max-width: 767.98px) {
  .company-mission-example-list {
    font-size: 16px;
  }
}

.company-mission-example-card {
  border: solid 1px #E5E7EB;
  height: 100%;
}
.company-mission-example-card__title {
  font-size: 20px;
  color: #fff;
  text-align: center;
  font-weight: bold;
  background: #50A4A1;
  padding: 0.5em;
}
@media (max-width: 767.98px) {
  .company-mission-example-card__title {
    font-size: 16px;
  }
}
.company-mission-example-card__img {
  padding: 10px;
}
.company-mission-example-card__body {
  padding: 20px 24px;
}
.company-mission-example-card__subtitle {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 15px;
  text-align: center;
}
@media (max-width: 767.98px) {
  .company-mission-example-card__subtitle {
    font-size: 15px;
  }
}
@media (max-width: 767.98px) {
  .company-mission-example-card__text {
    font-size: 14px;
  }
}

.company-mission-hardware-text {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  line-height: 2;
  margin-bottom: 40px;
}
@media (max-width: 767.98px) {
  .company-mission-hardware-text {
    font-size: 16px;
  }
}

.company-mission-hardware-img {
  margin-bottom: 40px;
}

.company-mission-hardware-card {
  border: solid 1px #E5E7EB;
  padding: 24px 20px;
  height: 100%;
}
.company-mission-hardware-card__title {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 15px;
  text-align: center;
}
@media (max-width: 767.98px) {
  .company-mission-hardware-card__title {
    font-size: 15px;
  }
}
@media (max-width: 767.98px) {
  .company-mission-hardware-card__text {
    font-size: 14px;
  }
}

.company-mission-dx-text {
  font-size: 20px;
  font-weight: bold;
  line-height: 2;
  margin-bottom: 40px;
}
@media (max-width: 767.98px) {
  .company-mission-dx-text {
    font-size: 16px;
  }
}
.company-mission-dx-text em {
  color: #50A4A1;
  font-style: normal;
}

.company-mission-dx-card {
  background: #F9F7F7;
  padding: 20px;
  height: 100%;
}
.company-mission-dx-card__title {
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
}
@media (max-width: 767.98px) {
  .company-mission-dx-card__title {
    font-size: 15px;
  }
}
.company-mission-dx-card__title span {
  font-size: 20px;
  font-weight: bold;
  color: #fff;
  background: #50A4A1;
  width: 60px;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 8px;
}
@media (max-width: 767.98px) {
  .company-mission-dx-card__title span {
    font-size: 16px;
    width: 40px;
    height: 40px;
  }
}
.company-mission-dx-card__text {
  padding-bottom: 20px;
  border-bottom: solid 1px #CBCBCB;
  margin-bottom: 20px;
}
.company-mission-dx-card__result {
  font-weight: bold;
  color: #50A4A1;
  padding-left: 2em;
  position: relative;
}
@media (max-width: 767.98px) {
  .company-mission-dx-card__result {
    font-size: 14px;
  }
}
.company-mission-dx-card__result:before {
  content: "→";
  position: absolute;
  top: 0;
  left: 0;
}

.case-study-nav__list {
  background: #F9F7F7;
  padding: 10px;
  border-radius: 100px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  max-width: 820px;
  margin: 0 auto 60px;
}
@media (max-width: 767.98px) {
  .case-study-nav__list {
    padding: 5px;
    gap: 5px;
  }
}
.case-study-nav__link {
  font-size: 16px;
  font-weight: 600;
  color: #707070;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1em;
  border-radius: 100px;
  line-height: 1.5;
  transition: all 0.3s ease;
  text-align: center;
  height: 100%;
}
@media (max-width: 767.98px) {
  .case-study-nav__link {
    font-size: 12px;
    padding: 0.5em 0.8em;
    line-height: 1.3;
  }
}
.case-study-nav__link:hover {
  background: #50A4A1;
  color: #fff;
}
.case-study-nav__link.--active {
  background: #50A4A1;
  color: #fff;
}
.case-study-nav__link br {
  display: none;
}
@media (max-width: 767.98px) {
  .case-study-nav__link br {
    display: block;
  }
}

.case-study-pagination {
  margin-top: 60px;
  margin-bottom: 100px;
}

.case-study-article-header {
  margin-bottom: 40px;
}
.case-study-article-header__date {
  font-size: 14px;
  color: #3B3B3B;
  margin-bottom: 10px;
}
.case-study-article-header__inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 30px;
  margin-bottom: 20px;
}
.case-study-article-header__categories {
  display: flex;
  gap: 10px;
}
.case-study-article-header__category {
  color: #50A4A1;
  font-weight: 600;
  border: 1px solid #50A4A1;
  padding: 2px 12px;
}
@media (max-width: 767.98px) {
  .case-study-article-header__category {
    font-size: 14px;
    padding: 2px 10px;
  }
}
.case-study-article-header__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: #50A4A1;
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .case-study-article-header__tag {
    font-size: 14px;
  }
}

.case-study-article-info {
  background: #F9F7F7;
  padding: 25px 0;
  margin-bottom: 100px;
}
@media (max-width: 767.98px) {
  .case-study-article-info {
    margin-bottom: 60px;
  }
}
.case-study-article-info__inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 34px;
}
@media (max-width: 1023.98px) {
  .case-study-article-info__inner {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.case-study-article-info__item {
  background: #fff;
  border: solid 1px #CBCBCB;
  border-radius: 6px;
  display: grid;
  grid-template-columns: 160px 1fr;
}
@media (max-width: 575.98px) {
  .case-study-article-info__item {
    grid-template-columns: 1fr;
  }
}
.case-study-article-info__item-title {
  border-right: 1px solid #CBCBCB;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: #50A4A1;
  font-weight: 600;
}
@media (max-width: 575.98px) {
  .case-study-article-info__item-title {
    border-right: none;
    border-bottom: 1px solid #CBCBCB;
    padding: 10px;
    font-size: 14px;
  }
  .case-study-article-info__item-title br {
    display: none;
  }
}
.case-study-article-info__item-content {
  padding: 30px 25px;
}
@media (max-width: 575.98px) {
  .case-study-article-info__item-content {
    padding: 20px 15px;
  }
}
.case-study-article-info__dl {
  display: grid;
  grid-template-columns: 88px 1fr;
}
.case-study-article-info__dl:first-child {
  margin-bottom: 15px;
}
.case-study-article-info__dl dt {
  border: solid 1px #CBCBCB;
  border-radius: 6px 0 0 6px;
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  padding: 5px;
}
.case-study-article-info__dl dd {
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  background: #50A4A1;
  border-radius: 0 6px 6px 0;
  text-align: center;
  padding: 5px;
}
.case-study-article-info__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
}
.case-study-article-info__list li {
  text-align: center;
  font-size: 14px;
  font-weight: 500;
  color: #50A4A1;
  border: solid 1px #50A4A1;
  border-radius: 6px;
  padding: 5px;
}
.case-study-article-info__list li.--active {
  background: #50A4A1;
  color: #fff;
}

.case-study-article-posts {
  background: #F9F7F7;
  padding: 100px 0;
  margin-top: 80px;
}
@media (max-width: 767.98px) {
  .case-study-article-posts {
    margin-top: 50px;
  }
}
.case-study-article-posts__title {
  font-size: 30px;
  font-weight: 600;
  text-align: center;
  max-width: 210px;
  margin: 0 auto 60px;
  border-top: solid 1px #A5A5A5;
  border-bottom: solid 1px #A5A5A5;
  padding: 0.4em 0;
}

.entry {
  margin-bottom: 60px;
}
.entry h1 {
  font-size: 40px;
  font-weight: 700;
  padding-bottom: 0.5em;
  position: relative;
  margin-top: 3.4rem;
  margin-bottom: 2.4rem;
}
@media (max-width: 767.98px) {
  .entry h1 {
    font-size: 28px;
  }
}
.entry h1:before {
  content: "";
  width: 56px;
  height: 4px;
  background: #50A4A1;
  position: absolute;
  bottom: 0;
  left: 0;
}
.entry h2 {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.4;
  padding-left: 0.7em;
  padding-top: 0.2em;
  padding-bottom: 0.2em;
  margin-top: 3rem;
  margin-bottom: 2rem;
  border-left: 6px solid #50A4A1;
}
@media (max-width: 767.98px) {
  .entry h2 {
    font-size: 20px;
  }
}
.entry h3 {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.4;
  padding-bottom: 0.2em;
  margin-top: 2.6rem;
  margin-bottom: 1.8rem;
  border-bottom: 2px solid #50A4A1;
}
@media (max-width: 767.98px) {
  .entry h3 {
    font-size: 18px;
  }
}
.entry h4 {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  margin-top: 2rem;
  margin-bottom: 1.6rem;
}
@media (max-width: 767.98px) {
  .entry h4 {
    font-size: 17px;
  }
}
.entry h5, .entry h6 {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  margin-top: 1.6rem;
  margin-bottom: 1.6rem;
}
@media (max-width: 767.98px) {
  .entry h5, .entry h6 {
    font-size: 16px;
  }
}
.entry p {
  line-height: 1.8;
  margin-top: 1.6rem;
  margin-bottom: 1.6rem;
}
@media (max-width: 767.98px) {
  .entry p {
    font-size: 14px;
  }
}
.entry a {
  color: #50A4A1;
  text-decoration: underline;
}
.entry ul {
  line-height: 1.8;
  margin-top: 1.6rem;
  margin-bottom: 1.6rem;
}
.entry ul li {
  position: relative;
  padding-left: 1em;
}
.entry ul li:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
.entry ol {
  line-height: 1.8;
  margin-top: 1.6rem;
  margin-bottom: 1.6rem;
  counter-reset: ol;
}
.entry ol li {
  position: relative;
  padding-left: 1em;
  counter-increment: ol;
}
.entry ol li:before {
  content: counter(ol) ".";
  position: absolute;
  top: 0;
  left: 0;
}
.entry .wp-block-columns, .entry .wp-block-image {
  margin-top: 2rem;
  margin-bottom: 2rem;
}
.entry .wp-block-quote {
  background: #F9F7F7;
  margin-top: 2rem;
  margin-bottom: 2rem;
  border-left: 4px solid #50A4A1;
  padding: 1rem 1.5rem;
}
.entry .wp-block-quote p {
  margin: 0;
}
.entry .wp-block-embed {
  margin-top: 2rem;
  margin-bottom: 2rem;
}
.entry .wp-block-embed__wrapper {
  padding-top: 56.25%;
}
.entry .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.entry .wp-block-flexible-table-block-table {
  margin-top: 2rem;
  margin-bottom: 2rem;
}
.entry .wp-block-flexible-table-block-table > table tr th {
  background: #F9F7F7;
}

.business__ph {
  margin-bottom: 30px;
}
@media (max-width: 767.98px) {
  .business__ph {
    margin-bottom: 20px;
  }
}
.business__ph__scrollable {
  overflow-x: auto;
}
.business__ph__scrollable img {
  min-width: 800px;
}
.business__ph img {
  width: 100%;
}
.business__intro {
  background-color: #50A4A1;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 30px;
  padding: 40px 70px;
  margin-bottom: 40px;
}
@media (max-width: 1023.98px) {
  .business__intro {
    padding: 30px;
  }
}
@media (max-width: 767.98px) {
  .business__intro {
    padding: 30px 20px;
    flex-direction: column;
    margin-bottom: 30px;
  }
}
@media (max-width: 767.98px) {
  .business__intro__logo img {
    width: 200px;
  }
}
.business__intro__text {
  font-size: 24px;
  font-weight: 600;
  color: #FFFFFF;
}
@media (max-width: 1023.98px) {
  .business__intro__text {
    font-size: 20px;
  }
}
@media (max-width: 767.98px) {
  .business__intro__text {
    font-size: 17px;
    text-align: center;
  }
}
.business__intro__text small {
  display: block;
  font-size: 16px;
  margin-top: 0.5rem;
}
@media (max-width: 1023.98px) {
  .business__intro__text small {
    font-size: 15px;
  }
}
@media (max-width: 767.98px) {
  .business__intro__text small {
    font-size: 13px;
    margin-top: 0.2rem;
  }
}
.business__service__inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
}
@media (max-width: 767.98px) {
  .business__service__inner {
    grid-template-columns: 100%;
    gap: 30px;
  }
}
.business__service__inner__item {
  border: solid 1px #50A4A1;
  border-radius: 10px;
  padding: 30px;
  display: flex;
  flex-direction: column;
}
@media (max-width: 767.98px) {
  .business__service__inner__item {
    padding: 20px;
  }
}
.business__service__title {
  margin-bottom: 30px;
}
.business__service__title__main {
  font-size: 28px;
  font-weight: 700;
  color: #50A4A1;
  text-align: center;
  padding-bottom: 0.5em;
  border-bottom: 1px solid #50A4A1;
  margin-bottom: 30px;
}
@media (max-width: 767.98px) {
  .business__service__title__main {
    font-size: 20px;
  }
}
.business__service__title__sub {
  font-weight: 700;
  font-size: 18px;
  text-align: center;
}
@media (max-width: 767.98px) {
  .business__service__title__sub {
    font-size: 15px;
  }
}
.business__service__title__detail-btn {
  font-size: 14px;
  font-weight: 700;
  color: #50A4A1;
  text-align: center;
  padding: 3px 17px 4px;
  border-radius: 4px;
  border: 1px solid #50A4A1;
  grid-row: 1/2;
  grid-column: 2/3;
}
@media (max-width: 767.98px) {
  .business__service__title__detail-btn {
    font-size: 13px;
  }
}
.business__service__ph {
  overflow: hidden;
  margin-bottom: 30px;
}
.business__service__list__title {
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 0.25em;
}
@media (max-width: 767.98px) {
  .business__service__list__title {
    font-size: 14px;
  }
}
.business__service__list__text {
  font-size: 14px;
  margin-bottom: 2em;
}
@media (max-width: 767.98px) {
  .business__service__list__text {
    font-size: 13px;
  }
}
.business__service__btn {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.business__lead {
  font-size: 18px;
  font-weight: 700;
  text-align: justify;
  margin-bottom: 1em;
}
@media (max-width: 767.98px) {
  .business__lead {
    font-size: 16px;
  }
}
.business__lead span {
  color: #50A4A1;
}
.business__application__inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 767.98px) {
  .business__application__inner {
    grid-template-columns: 100%;
    margin-bottom: 30px;
  }
}
.business__application__inner__item:first-child {
  padding-right: 30px;
}
@media (max-width: 767.98px) {
  .business__application__inner__item:first-child {
    padding-right: 0;
  }
}
.business__application__title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 0.75em;
}
@media (max-width: 767.98px) {
  .business__application__title {
    font-size: 16px;
  }
}
.business__application__list {
  font-size: 16px;
  margin-bottom: 1.25em;
}
@media (max-width: 767.98px) {
  .business__application__list {
    font-size: 14px;
  }
}
.business__application__list__item {
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 0.25em;
}
.business__application__note {
  font-size: 12px;
  color: #666666;
}
.business__application__function {
  text-align: center;
  border-radius: 20px;
  padding: 40px;
  background-color: #F8FAFC;
}
@media (max-width: 767.98px) {
  .business__application__function {
    padding: 20px;
  }
}

.solutions__title {
  font-weight: 700;
  font-size: 24px;
  padding-bottom: 0.5em;
  border-bottom: 2px solid #036763;
  margin-bottom: 0.75em;
}
.solutions__lead {
  font-size: 18px;
  font-weight: 700;
  text-align: justify;
  margin-bottom: 1em;
}
@media (max-width: 767.98px) {
  .solutions__lead {
    font-size: 16px;
  }
}
.solutions__lead span {
  color: #50A4A1;
}
.solutions__assignment__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 30px;
}
@media (max-width: 767.98px) {
  .solutions__assignment__list {
    grid-template-columns: 100%;
  }
}
.solutions__assignment__card {
  padding: 24px;
  background-color: #F9F7F7;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
@media (max-width: 767.98px) {
  .solutions__assignment__card {
    padding: 16px;
  }
}
.solutions__assignment__card__title {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}
@media (max-width: 767.98px) {
  .solutions__assignment__card__title {
    margin-bottom: 10px;
  }
}
.solutions__assignment__card__title__num {
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  color: #FFFFFF;
  background-color: #4C9E97;
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 1/1;
  width: 3em;
  border-radius: 8px;
}
@media (max-width: 767.98px) {
  .solutions__assignment__card__title__num {
    font-size: 16px;
  }
}
.solutions__assignment__card__title__text {
  font-size: 18px;
  font-weight: 700;
  margin-left: 1em;
}
@media (max-width: 767.98px) {
  .solutions__assignment__card__title__text {
    font-size: 16px;
  }
}
.solutions__assignment__card__text {
  font-size: 16px;
  font-weight: 500;
  padding-bottom: 1.5em;
  border-bottom: 1px solid #CBCBCB;
  margin-bottom: 1em;
  flex-grow: 1;
}
@media (max-width: 767.98px) {
  .solutions__assignment__card__text {
    font-size: 14px;
  }
}
.solutions__assignment__card__link {
  font-size: 16px;
  font-weight: 500;
  color: #50A4A1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1em;
}
@media (max-width: 767.98px) {
  .solutions__assignment__card__link {
    font-size: 14px;
  }
}
.solutions__assignment__card__link::after {
  content: "";
  aspect-ratio: 30/16;
  height: 1em;
  background-image: url(../images/business/solutions/icon_arrow.svg);
  background-repeat: no-repeat;
  background-size: cover;
}
.solutions__assignment__copy {
  font-weight: 700;
  font-size: 18px;
  text-align: center;
  color: #FFFFFF;
  padding: 0.75em 1em;
  border-radius: 4px;
  background-image: linear-gradient(90deg, #53C1B7 0%, #4C9E97 100%);
}
@media (max-width: 767.98px) {
  .solutions__assignment__copy {
    font-size: 16px;
  }
}
.solutions__assignment__copy span {
  display: inline-block;
}
.solutions__partner__inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px;
}
@media (max-width: 767.98px) {
  .solutions__partner__inner {
    grid-template-columns: 100%;
    gap: 20px;
  }
}
.solutions__partner__card {
  border-radius: 4px;
  border: 1px solid #E5E7EB;
  overflow: hidden;
}
.solutions__partner__card__title {
  font-weight: 700;
  font-size: 18px;
  text-align: center;
  color: #FFFFFF;
  padding: 0.75em 1em;
  background-image: linear-gradient(90deg, #53C1B7 0%, #4C9E97 100%);
}
@media (max-width: 767.98px) {
  .solutions__partner__card__title {
    font-size: 16px;
  }
}
.solutions__partner__card__contents {
  padding: 30px;
}
@media (max-width: 767.98px) {
  .solutions__partner__card__contents {
    padding: 15px;
  }
}
.solutions__partner__card__contents__title {
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 0.5em;
}
@media (max-width: 767.98px) {
  .solutions__partner__card__contents__title {
    font-size: 14px;
  }
}
.solutions__partner__card__contents__detail {
  margin-bottom: 30px;
}
@media (max-width: 767.98px) {
  .solutions__partner__card__contents__detail {
    margin-bottom: 20px;
  }
}
.solutions__partner__card__list {
  font-size: 14px;
  color: #374151;
}
@media (max-width: 767.98px) {
  .solutions__partner__card__list {
    font-size: 13px;
  }
}
.solutions__partner__card__list__item {
  text-indent: -1em;
  padding-left: 1em;
}
.solutions__partner__card__list__item::before {
  content: "・";
  color: #50A4A1;
}
.solutions__partner__card__offer {
  font-size: 12px;
  display: grid;
  grid-template-columns: 12em 1fr;
}
.solutions__partner__card__offer__phase, .solutions__partner__card__offer__content {
  padding: 0.5em 0;
  border-bottom: 1px solid #E5E7EB;
}
.solutions__partner__card__offer__phase {
  font-weight: 700;
}
.solutions__partner__card__offer__phase:not(:first-child) {
  color: #50A4A1;
}
.solutions__partner__card__offer__phase:first-child {
  padding-top: 0;
}
.solutions__partner__card__offer__phase:first-child + dd {
  padding-top: 0;
}
.solutions__partner__card__offer__phase:has(+ dd:last-child) {
  border-bottom: none;
}
.solutions__partner__card__offer__content:last-child {
  border-bottom: none;
}
.solutions__partner__card__image {
  font-weight: 700;
  font-size: 14px;
}
@media (max-width: 767.98px) {
  .solutions__partner__card__image {
    font-size: 13px;
  }
}
.solutions__partner__card__image__item:not(:last-child) {
  margin-bottom: 0.25em;
}
.solutions__partner__card__image__item span {
  display: inline-block;
}
.solutions__sub-title {
  font-weight: 700;
  font-size: 22px;
  text-align: center;
  margin-bottom: 1em;
}
@media (max-width: 767.98px) {
  .solutions__sub-title {
    font-size: 18px;
  }
}
.solutions__range__card {
  position: relative;
}
.solutions__range__card:not(:last-child)::before {
  position: absolute;
  top: 50%;
  left: calc(100% + 20px);
  translate: -50% -50%;
  content: "";
  aspect-ratio: 20/18;
  width: 20px;
  background-image: url(../images/business/solutions/icon_arrow_2.svg);
  background-repeat: no-repeat;
  background-size: cover;
  z-index: 2;
}
@media (max-width: 767.98px) {
  .solutions__range__card:not(:last-child)::before {
    top: calc(100% + 20px);
    left: 50%;
    rotate: 90deg;
  }
}
.solutions__range__card__inner {
  height: 100%;
  padding: 16px;
  overflow: hidden;
  border-radius: 4px;
  border: 1px solid #E5E7EB;
}
.solutions__range__card__title {
  font-weight: 700;
  font-size: 16px;
  text-align: center;
  padding: 0.5em 1em;
  background-color: #C2E2E0;
  margin: -16px -16px 16px;
}
@media (max-width: 767.98px) {
  .solutions__range__card__title {
    font-size: 14px;
  }
}
.solutions__range__card__ph {
  margin-bottom: 20px;
}
.solutions__range__card__ph img {
  width: 100%;
}
.solutions__range__card__list {
  list-style: none;
  font-size: 13px;
}
.solutions__range__card__list__item:not(:last-child) {
  margin-bottom: 0.25em;
}
.solutions__range__card__wrap {
  list-style-type: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;
  gap: 40px;
}
@media (max-width: 767.98px) {
  .solutions__range__card__wrap {
    grid-template-columns: 100%;
  }
}
.solutions__development__items__wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
@media (max-width: 767.98px) {
  .solutions__development__items__wrap {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575.98px) {
  .solutions__development__items__wrap {
    grid-template-columns: 100%;
  }
}
.solutions__development__items__title {
  font-weight: 700;
  font-size: 14px;
  color: #FFFFFF;
  background-color: #4C9E97;
  text-align: center;
  padding: 0.25em 0.75em;
  border-radius: 4px;
  margin-bottom: 1.25em;
}
@media (max-width: 767.98px) {
  .solutions__development__items__title {
    font-size: 13px;
  }
}
.solutions__development__items__ph {
  margin-bottom: 20px;
}
.solutions__development__items__ph img {
  width: 100%;
}
.solutions__development__items__text {
  font-size: 14px;
}
@media (max-width: 767.98px) {
  .solutions__development__items__text {
    font-size: 13px;
  }
}

.tech-blog-content {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 60px;
}
@media (max-width: 1023.98px) {
  .tech-blog-content {
    grid-template-columns: 1fr;
    gap: 40px;
  }
}

.tech-blog-side {
  margin-bottom: 60px;
}
.tech-blog-side__categories li {
  border-bottom: 1px dashed #CBCBCB;
}
.tech-blog-side__categories li a {
  display: block;
  font-weight: 500;
  transition: color 0.3s;
  font-size: 18px;
  padding: 1em 50px 1em 0;
  position: relative;
}
@media (max-width: 767.98px) {
  .tech-blog-side__categories li a {
    font-size: 16px;
  }
}
.tech-blog-side__categories li a:after {
  position: absolute;
  content: "";
  top: 50%;
  margin-top: -8px;
  right: 12px;
  width: 30px;
  height: 16px;
  background: url("../images/arrow-right.svg") no-repeat center;
  background-size: contain;
  transition: all 0.3s ease;
}
.tech-blog-side__categories li a:hover {
  color: #50A4A1;
}
.tech-blog-side__categories li a:hover:after {
  transform: translateX(5px);
}
.tech-blog-side__posts {
  margin-top: 30px;
}
.tech-blog-side__post {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dashed #CBCBCB;
  margin-bottom: 10px;
  transition: color 0.3s;
}
.tech-blog-side__post:hover {
  color: #50A4A1;
}
.tech-blog-side__post:hover .tech-blog-side__post__body:after {
  transform: translateX(5px);
}
.tech-blog-side__post:hover .tech-blog-side__post__img img {
  transform: scale(1.05);
}
.tech-blog-side__post__img {
  width: 80px;
  height: 80px;
  overflow: hidden;
}
.tech-blog-side__post__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s;
}
.tech-blog-side__post__body {
  position: relative;
  padding-right: 50px;
}
.tech-blog-side__post__body:after {
  position: absolute;
  content: "";
  top: 50%;
  margin-top: -8px;
  right: 12px;
  width: 30px;
  height: 16px;
  background: url("../images/arrow-right.svg") no-repeat center;
  background-size: contain;
  transition: all 0.3s ease;
}
.tech-blog-side__post__date {
  font-size: 14px;
  color: #3B3B3B;
  margin-bottom: 0;
}
.tech-blog-side__post__title {
  font-size: 15px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.tech-blog-article-header {
  margin-bottom: 40px;
}
.tech-blog-article-header__date {
  font-size: 16px;
  color: #3B3B3B;
}
.tech-blog-article-header__inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 30px;
  margin-bottom: 10px;
}
.tech-blog-article-header__title {
  font-size: 28px;
  margin-bottom: 20px;
}
@media (max-width: 767.98px) {
  .tech-blog-article-header__title {
    font-size: 20px;
  }
}
.tech-blog-article-header__categories {
  display: flex;
  gap: 10px;
}
.tech-blog-article-header__category {
  color: #50A4A1;
  font-weight: 600;
  border: 1px solid #50A4A1;
  padding: 2px 12px;
}
@media (max-width: 767.98px) {
  .tech-blog-article-header__category {
    font-size: 14px;
    padding: 2px 10px;
  }
}
.tech-blog-article-header__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: #50A4A1;
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .tech-blog-article-header__tag {
    font-size: 14px;
  }
}

.news-container {
  max-width: 990px;
}

.news-nav {
  text-align: center;
  margin-bottom: 60px;
}
.news-nav__list {
  display: inline-flex;
  align-items: center;
  gap: 40px;
}
@media (max-width: 1023.98px) {
  .news-nav__list {
    gap: 20px;
  }
}
.news-nav__item:not(:last-child) {
  position: relative;
}
.news-nav__item:not(:last-child):after {
  content: "";
  position: absolute;
  width: 1px;
  height: 25px;
  background: #50A4A1;
  right: -20px;
  top: 0;
  transform: rotate(25deg);
}
@media (max-width: 1023.98px) {
  .news-nav__item:not(:last-child):after {
    height: 18px;
    top: 4px;
    right: -11px;
  }
}
.news-nav__link {
  font-size: 16px;
  font-weight: 600;
  color: #707070;
  transition: all 0.3s ease;
}
@media (max-width: 767.98px) {
  .news-nav__link {
    margin-top: 14px;
  }
}
.news-nav__link:hover {
  color: #50A4A1;
}
.news-nav__link.--active {
  color: #50A4A1;
}

.news-article-header {
  margin-bottom: 40px;
}
.news-article-header__date {
  font-size: 16px;
  color: #3B3B3B;
}
.news-article-header__inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 30px;
  margin-bottom: 10px;
}
.news-article-header__title {
  font-size: 28px;
  margin-bottom: 20px;
}
@media (max-width: 767.98px) {
  .news-article-header__title {
    font-size: 20px;
  }
}
.news-article-header__categories {
  display: flex;
  gap: 10px;
}
.news-article-header__category {
  color: #50A4A1;
  font-weight: 600;
  border: 1px solid #50A4A1;
  padding: 2px 12px;
}
@media (max-width: 767.98px) {
  .news-article-header__category {
    font-size: 14px;
    padding: 2px 10px;
  }
}
.news-article-header__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  color: #50A4A1;
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .news-article-header__tag {
    font-size: 14px;
  }
}

.contact {
  max-width: 800px;
  margin: 0 auto;
}

.contact-form-block {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 40px;
  margin-bottom: 40px;
}
@media (max-width: 767.98px) {
  .contact-form-block {
    grid-template-columns: 1fr;
    gap: 5px;
    margin-bottom: 30px;
  }
}
.contact-form-block dt {
  font-weight: 500;
  padding: 0.5em;
}
.contact-form-block dt span {
  color: #dc3232;
  font-size: 14px;
  border: 1px solid #dc3232;
  padding: 0 0.5em;
  border-radius: 5px;
  margin-left: 1em;
  display: inline-block;
}
.contact-form-block dd input[type=text],
.contact-form-block dd input[type=email],
.contact-form-block dd input[type=tel],
.contact-form-block dd textarea {
  border: 1px solid #CBCBCB;
  border-radius: 5px;
  padding: 0.5em;
  width: 100%;
}
.contact-form-block dd input[type=radio] {
  appearance: auto;
  margin-right: 5px;
  margin-top: -2px;
}
.contact-form-block dd .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
  padding: 0.5em;
}

.contact-form-concent {
  text-align: center;
}
.contact-form-concent input[type=checkbox] {
  appearance: auto;
  margin-right: 5px;
  margin-top: -2px;
}

input[type=submit] {
  font-size: 15px;
  font-weight: 500;
  color: #fff;
  display: block;
  width: 160px;
  padding: 1em;
  background: #50A4A1;
  border: solid 1px #50A4A1;
  border-radius: 100px;
  text-align: center;
  transition: all 0.3s ease;
  max-width: 100%;
  margin: 40px auto 0;
}
@media (max-width: 767.98px) {
  input[type=submit] {
    font-size: 13px;
  }
}
input[type=submit]:hover {
  border: solid 1px #50A4A1;
  background: #fff;
  color: #50A4A1;
}

.wpcf7-list-item {
  margin-left: 0;
}

.privacy-policy p {
  margin-bottom: 1em;
}
.privacy-policy ol li {
  margin-bottom: 1em;
}
.privacy-policy ol li ol li {
  margin-bottom: 0;
}

@media (max-width: 767.98px) {
  .hidden-sp {
    display: none;
  }
}

@media (min-width: 768px) {
  .hidden-pc {
    display: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.mt-35 {
  margin-top: 35px !important;
}

.mb-35 {
  margin-bottom: 35px !important;
}

.ml-35 {
  margin-left: 35px !important;
}

.mr-35 {
  margin-right: 35px !important;
}

.pt-35 {
  padding-top: 35px !important;
}

.pb-35 {
  padding-bottom: 35px !important;
}

.pl-35 {
  padding-left: 35px !important;
}

.pr-35 {
  padding-right: 35px !important;
}

.mt-40 {
  margin-top: 40px !important;
}

.mb-40 {
  margin-bottom: 40px !important;
}

.ml-40 {
  margin-left: 40px !important;
}

.mr-40 {
  margin-right: 40px !important;
}

.pt-40 {
  padding-top: 40px !important;
}

.pb-40 {
  padding-bottom: 40px !important;
}

.pl-40 {
  padding-left: 40px !important;
}

.pr-40 {
  padding-right: 40px !important;
}

.mt-45 {
  margin-top: 45px !important;
}

.mb-45 {
  margin-bottom: 45px !important;
}

.ml-45 {
  margin-left: 45px !important;
}

.mr-45 {
  margin-right: 45px !important;
}

.pt-45 {
  padding-top: 45px !important;
}

.pb-45 {
  padding-bottom: 45px !important;
}

.pl-45 {
  padding-left: 45px !important;
}

.pr-45 {
  padding-right: 45px !important;
}

.mt-50 {
  margin-top: 50px !important;
}

.mb-50 {
  margin-bottom: 50px !important;
}

.ml-50 {
  margin-left: 50px !important;
}

.mr-50 {
  margin-right: 50px !important;
}

.pt-50 {
  padding-top: 50px !important;
}

.pb-50 {
  padding-bottom: 50px !important;
}

.pl-50 {
  padding-left: 50px !important;
}

.pr-50 {
  padding-right: 50px !important;
}

@media (max-width: 374.98px) {
  .mt-xs-0 {
    margin-top: 0px !important;
  }
  .mb-xs-0 {
    margin-bottom: 0px !important;
  }
  .ml-xs-0 {
    margin-left: 0px !important;
  }
  .mr-xs-0 {
    margin-right: 0px !important;
  }
  .pt-xs-0 {
    padding-top: 0px !important;
  }
  .pb-xs-0 {
    padding-bottom: 0px !important;
  }
  .pl-xs-0 {
    padding-left: 0px !important;
  }
  .pr-xs-0 {
    padding-right: 0px !important;
  }
  .mt-xs-5 {
    margin-top: 5px !important;
  }
  .mb-xs-5 {
    margin-bottom: 5px !important;
  }
  .ml-xs-5 {
    margin-left: 5px !important;
  }
  .mr-xs-5 {
    margin-right: 5px !important;
  }
  .pt-xs-5 {
    padding-top: 5px !important;
  }
  .pb-xs-5 {
    padding-bottom: 5px !important;
  }
  .pl-xs-5 {
    padding-left: 5px !important;
  }
  .pr-xs-5 {
    padding-right: 5px !important;
  }
  .mt-xs-10 {
    margin-top: 10px !important;
  }
  .mb-xs-10 {
    margin-bottom: 10px !important;
  }
  .ml-xs-10 {
    margin-left: 10px !important;
  }
  .mr-xs-10 {
    margin-right: 10px !important;
  }
  .pt-xs-10 {
    padding-top: 10px !important;
  }
  .pb-xs-10 {
    padding-bottom: 10px !important;
  }
  .pl-xs-10 {
    padding-left: 10px !important;
  }
  .pr-xs-10 {
    padding-right: 10px !important;
  }
  .mt-xs-15 {
    margin-top: 15px !important;
  }
  .mb-xs-15 {
    margin-bottom: 15px !important;
  }
  .ml-xs-15 {
    margin-left: 15px !important;
  }
  .mr-xs-15 {
    margin-right: 15px !important;
  }
  .pt-xs-15 {
    padding-top: 15px !important;
  }
  .pb-xs-15 {
    padding-bottom: 15px !important;
  }
  .pl-xs-15 {
    padding-left: 15px !important;
  }
  .pr-xs-15 {
    padding-right: 15px !important;
  }
  .mt-xs-20 {
    margin-top: 20px !important;
  }
  .mb-xs-20 {
    margin-bottom: 20px !important;
  }
  .ml-xs-20 {
    margin-left: 20px !important;
  }
  .mr-xs-20 {
    margin-right: 20px !important;
  }
  .pt-xs-20 {
    padding-top: 20px !important;
  }
  .pb-xs-20 {
    padding-bottom: 20px !important;
  }
  .pl-xs-20 {
    padding-left: 20px !important;
  }
  .pr-xs-20 {
    padding-right: 20px !important;
  }
  .mt-xs-25 {
    margin-top: 25px !important;
  }
  .mb-xs-25 {
    margin-bottom: 25px !important;
  }
  .ml-xs-25 {
    margin-left: 25px !important;
  }
  .mr-xs-25 {
    margin-right: 25px !important;
  }
  .pt-xs-25 {
    padding-top: 25px !important;
  }
  .pb-xs-25 {
    padding-bottom: 25px !important;
  }
  .pl-xs-25 {
    padding-left: 25px !important;
  }
  .pr-xs-25 {
    padding-right: 25px !important;
  }
  .mt-xs-30 {
    margin-top: 30px !important;
  }
  .mb-xs-30 {
    margin-bottom: 30px !important;
  }
  .ml-xs-30 {
    margin-left: 30px !important;
  }
  .mr-xs-30 {
    margin-right: 30px !important;
  }
  .pt-xs-30 {
    padding-top: 30px !important;
  }
  .pb-xs-30 {
    padding-bottom: 30px !important;
  }
  .pl-xs-30 {
    padding-left: 30px !important;
  }
  .pr-xs-30 {
    padding-right: 30px !important;
  }
  .mt-xs-35 {
    margin-top: 35px !important;
  }
  .mb-xs-35 {
    margin-bottom: 35px !important;
  }
  .ml-xs-35 {
    margin-left: 35px !important;
  }
  .mr-xs-35 {
    margin-right: 35px !important;
  }
  .pt-xs-35 {
    padding-top: 35px !important;
  }
  .pb-xs-35 {
    padding-bottom: 35px !important;
  }
  .pl-xs-35 {
    padding-left: 35px !important;
  }
  .pr-xs-35 {
    padding-right: 35px !important;
  }
  .mt-xs-40 {
    margin-top: 40px !important;
  }
  .mb-xs-40 {
    margin-bottom: 40px !important;
  }
  .ml-xs-40 {
    margin-left: 40px !important;
  }
  .mr-xs-40 {
    margin-right: 40px !important;
  }
  .pt-xs-40 {
    padding-top: 40px !important;
  }
  .pb-xs-40 {
    padding-bottom: 40px !important;
  }
  .pl-xs-40 {
    padding-left: 40px !important;
  }
  .pr-xs-40 {
    padding-right: 40px !important;
  }
  .mt-xs-45 {
    margin-top: 45px !important;
  }
  .mb-xs-45 {
    margin-bottom: 45px !important;
  }
  .ml-xs-45 {
    margin-left: 45px !important;
  }
  .mr-xs-45 {
    margin-right: 45px !important;
  }
  .pt-xs-45 {
    padding-top: 45px !important;
  }
  .pb-xs-45 {
    padding-bottom: 45px !important;
  }
  .pl-xs-45 {
    padding-left: 45px !important;
  }
  .pr-xs-45 {
    padding-right: 45px !important;
  }
  .mt-xs-50 {
    margin-top: 50px !important;
  }
  .mb-xs-50 {
    margin-bottom: 50px !important;
  }
  .ml-xs-50 {
    margin-left: 50px !important;
  }
  .mr-xs-50 {
    margin-right: 50px !important;
  }
  .pt-xs-50 {
    padding-top: 50px !important;
  }
  .pb-xs-50 {
    padding-bottom: 50px !important;
  }
  .pl-xs-50 {
    padding-left: 50px !important;
  }
  .pr-xs-50 {
    padding-right: 50px !important;
  }
}
@media (max-width: 575.98px) {
  .mt-sm-0 {
    margin-top: 0px !important;
  }
  .mb-sm-0 {
    margin-bottom: 0px !important;
  }
  .ml-sm-0 {
    margin-left: 0px !important;
  }
  .mr-sm-0 {
    margin-right: 0px !important;
  }
  .pt-sm-0 {
    padding-top: 0px !important;
  }
  .pb-sm-0 {
    padding-bottom: 0px !important;
  }
  .pl-sm-0 {
    padding-left: 0px !important;
  }
  .pr-sm-0 {
    padding-right: 0px !important;
  }
  .mt-sm-5 {
    margin-top: 5px !important;
  }
  .mb-sm-5 {
    margin-bottom: 5px !important;
  }
  .ml-sm-5 {
    margin-left: 5px !important;
  }
  .mr-sm-5 {
    margin-right: 5px !important;
  }
  .pt-sm-5 {
    padding-top: 5px !important;
  }
  .pb-sm-5 {
    padding-bottom: 5px !important;
  }
  .pl-sm-5 {
    padding-left: 5px !important;
  }
  .pr-sm-5 {
    padding-right: 5px !important;
  }
  .mt-sm-10 {
    margin-top: 10px !important;
  }
  .mb-sm-10 {
    margin-bottom: 10px !important;
  }
  .ml-sm-10 {
    margin-left: 10px !important;
  }
  .mr-sm-10 {
    margin-right: 10px !important;
  }
  .pt-sm-10 {
    padding-top: 10px !important;
  }
  .pb-sm-10 {
    padding-bottom: 10px !important;
  }
  .pl-sm-10 {
    padding-left: 10px !important;
  }
  .pr-sm-10 {
    padding-right: 10px !important;
  }
  .mt-sm-15 {
    margin-top: 15px !important;
  }
  .mb-sm-15 {
    margin-bottom: 15px !important;
  }
  .ml-sm-15 {
    margin-left: 15px !important;
  }
  .mr-sm-15 {
    margin-right: 15px !important;
  }
  .pt-sm-15 {
    padding-top: 15px !important;
  }
  .pb-sm-15 {
    padding-bottom: 15px !important;
  }
  .pl-sm-15 {
    padding-left: 15px !important;
  }
  .pr-sm-15 {
    padding-right: 15px !important;
  }
  .mt-sm-20 {
    margin-top: 20px !important;
  }
  .mb-sm-20 {
    margin-bottom: 20px !important;
  }
  .ml-sm-20 {
    margin-left: 20px !important;
  }
  .mr-sm-20 {
    margin-right: 20px !important;
  }
  .pt-sm-20 {
    padding-top: 20px !important;
  }
  .pb-sm-20 {
    padding-bottom: 20px !important;
  }
  .pl-sm-20 {
    padding-left: 20px !important;
  }
  .pr-sm-20 {
    padding-right: 20px !important;
  }
  .mt-sm-25 {
    margin-top: 25px !important;
  }
  .mb-sm-25 {
    margin-bottom: 25px !important;
  }
  .ml-sm-25 {
    margin-left: 25px !important;
  }
  .mr-sm-25 {
    margin-right: 25px !important;
  }
  .pt-sm-25 {
    padding-top: 25px !important;
  }
  .pb-sm-25 {
    padding-bottom: 25px !important;
  }
  .pl-sm-25 {
    padding-left: 25px !important;
  }
  .pr-sm-25 {
    padding-right: 25px !important;
  }
  .mt-sm-30 {
    margin-top: 30px !important;
  }
  .mb-sm-30 {
    margin-bottom: 30px !important;
  }
  .ml-sm-30 {
    margin-left: 30px !important;
  }
  .mr-sm-30 {
    margin-right: 30px !important;
  }
  .pt-sm-30 {
    padding-top: 30px !important;
  }
  .pb-sm-30 {
    padding-bottom: 30px !important;
  }
  .pl-sm-30 {
    padding-left: 30px !important;
  }
  .pr-sm-30 {
    padding-right: 30px !important;
  }
  .mt-sm-35 {
    margin-top: 35px !important;
  }
  .mb-sm-35 {
    margin-bottom: 35px !important;
  }
  .ml-sm-35 {
    margin-left: 35px !important;
  }
  .mr-sm-35 {
    margin-right: 35px !important;
  }
  .pt-sm-35 {
    padding-top: 35px !important;
  }
  .pb-sm-35 {
    padding-bottom: 35px !important;
  }
  .pl-sm-35 {
    padding-left: 35px !important;
  }
  .pr-sm-35 {
    padding-right: 35px !important;
  }
  .mt-sm-40 {
    margin-top: 40px !important;
  }
  .mb-sm-40 {
    margin-bottom: 40px !important;
  }
  .ml-sm-40 {
    margin-left: 40px !important;
  }
  .mr-sm-40 {
    margin-right: 40px !important;
  }
  .pt-sm-40 {
    padding-top: 40px !important;
  }
  .pb-sm-40 {
    padding-bottom: 40px !important;
  }
  .pl-sm-40 {
    padding-left: 40px !important;
  }
  .pr-sm-40 {
    padding-right: 40px !important;
  }
  .mt-sm-45 {
    margin-top: 45px !important;
  }
  .mb-sm-45 {
    margin-bottom: 45px !important;
  }
  .ml-sm-45 {
    margin-left: 45px !important;
  }
  .mr-sm-45 {
    margin-right: 45px !important;
  }
  .pt-sm-45 {
    padding-top: 45px !important;
  }
  .pb-sm-45 {
    padding-bottom: 45px !important;
  }
  .pl-sm-45 {
    padding-left: 45px !important;
  }
  .pr-sm-45 {
    padding-right: 45px !important;
  }
  .mt-sm-50 {
    margin-top: 50px !important;
  }
  .mb-sm-50 {
    margin-bottom: 50px !important;
  }
  .ml-sm-50 {
    margin-left: 50px !important;
  }
  .mr-sm-50 {
    margin-right: 50px !important;
  }
  .pt-sm-50 {
    padding-top: 50px !important;
  }
  .pb-sm-50 {
    padding-bottom: 50px !important;
  }
  .pl-sm-50 {
    padding-left: 50px !important;
  }
  .pr-sm-50 {
    padding-right: 50px !important;
  }
}
@media (max-width: 767.98px) {
  .mt-md-0 {
    margin-top: 0px !important;
  }
  .mb-md-0 {
    margin-bottom: 0px !important;
  }
  .ml-md-0 {
    margin-left: 0px !important;
  }
  .mr-md-0 {
    margin-right: 0px !important;
  }
  .pt-md-0 {
    padding-top: 0px !important;
  }
  .pb-md-0 {
    padding-bottom: 0px !important;
  }
  .pl-md-0 {
    padding-left: 0px !important;
  }
  .pr-md-0 {
    padding-right: 0px !important;
  }
  .mt-md-5 {
    margin-top: 5px !important;
  }
  .mb-md-5 {
    margin-bottom: 5px !important;
  }
  .ml-md-5 {
    margin-left: 5px !important;
  }
  .mr-md-5 {
    margin-right: 5px !important;
  }
  .pt-md-5 {
    padding-top: 5px !important;
  }
  .pb-md-5 {
    padding-bottom: 5px !important;
  }
  .pl-md-5 {
    padding-left: 5px !important;
  }
  .pr-md-5 {
    padding-right: 5px !important;
  }
  .mt-md-10 {
    margin-top: 10px !important;
  }
  .mb-md-10 {
    margin-bottom: 10px !important;
  }
  .ml-md-10 {
    margin-left: 10px !important;
  }
  .mr-md-10 {
    margin-right: 10px !important;
  }
  .pt-md-10 {
    padding-top: 10px !important;
  }
  .pb-md-10 {
    padding-bottom: 10px !important;
  }
  .pl-md-10 {
    padding-left: 10px !important;
  }
  .pr-md-10 {
    padding-right: 10px !important;
  }
  .mt-md-15 {
    margin-top: 15px !important;
  }
  .mb-md-15 {
    margin-bottom: 15px !important;
  }
  .ml-md-15 {
    margin-left: 15px !important;
  }
  .mr-md-15 {
    margin-right: 15px !important;
  }
  .pt-md-15 {
    padding-top: 15px !important;
  }
  .pb-md-15 {
    padding-bottom: 15px !important;
  }
  .pl-md-15 {
    padding-left: 15px !important;
  }
  .pr-md-15 {
    padding-right: 15px !important;
  }
  .mt-md-20 {
    margin-top: 20px !important;
  }
  .mb-md-20 {
    margin-bottom: 20px !important;
  }
  .ml-md-20 {
    margin-left: 20px !important;
  }
  .mr-md-20 {
    margin-right: 20px !important;
  }
  .pt-md-20 {
    padding-top: 20px !important;
  }
  .pb-md-20 {
    padding-bottom: 20px !important;
  }
  .pl-md-20 {
    padding-left: 20px !important;
  }
  .pr-md-20 {
    padding-right: 20px !important;
  }
  .mt-md-25 {
    margin-top: 25px !important;
  }
  .mb-md-25 {
    margin-bottom: 25px !important;
  }
  .ml-md-25 {
    margin-left: 25px !important;
  }
  .mr-md-25 {
    margin-right: 25px !important;
  }
  .pt-md-25 {
    padding-top: 25px !important;
  }
  .pb-md-25 {
    padding-bottom: 25px !important;
  }
  .pl-md-25 {
    padding-left: 25px !important;
  }
  .pr-md-25 {
    padding-right: 25px !important;
  }
  .mt-md-30 {
    margin-top: 30px !important;
  }
  .mb-md-30 {
    margin-bottom: 30px !important;
  }
  .ml-md-30 {
    margin-left: 30px !important;
  }
  .mr-md-30 {
    margin-right: 30px !important;
  }
  .pt-md-30 {
    padding-top: 30px !important;
  }
  .pb-md-30 {
    padding-bottom: 30px !important;
  }
  .pl-md-30 {
    padding-left: 30px !important;
  }
  .pr-md-30 {
    padding-right: 30px !important;
  }
  .mt-md-35 {
    margin-top: 35px !important;
  }
  .mb-md-35 {
    margin-bottom: 35px !important;
  }
  .ml-md-35 {
    margin-left: 35px !important;
  }
  .mr-md-35 {
    margin-right: 35px !important;
  }
  .pt-md-35 {
    padding-top: 35px !important;
  }
  .pb-md-35 {
    padding-bottom: 35px !important;
  }
  .pl-md-35 {
    padding-left: 35px !important;
  }
  .pr-md-35 {
    padding-right: 35px !important;
  }
  .mt-md-40 {
    margin-top: 40px !important;
  }
  .mb-md-40 {
    margin-bottom: 40px !important;
  }
  .ml-md-40 {
    margin-left: 40px !important;
  }
  .mr-md-40 {
    margin-right: 40px !important;
  }
  .pt-md-40 {
    padding-top: 40px !important;
  }
  .pb-md-40 {
    padding-bottom: 40px !important;
  }
  .pl-md-40 {
    padding-left: 40px !important;
  }
  .pr-md-40 {
    padding-right: 40px !important;
  }
  .mt-md-45 {
    margin-top: 45px !important;
  }
  .mb-md-45 {
    margin-bottom: 45px !important;
  }
  .ml-md-45 {
    margin-left: 45px !important;
  }
  .mr-md-45 {
    margin-right: 45px !important;
  }
  .pt-md-45 {
    padding-top: 45px !important;
  }
  .pb-md-45 {
    padding-bottom: 45px !important;
  }
  .pl-md-45 {
    padding-left: 45px !important;
  }
  .pr-md-45 {
    padding-right: 45px !important;
  }
  .mt-md-50 {
    margin-top: 50px !important;
  }
  .mb-md-50 {
    margin-bottom: 50px !important;
  }
  .ml-md-50 {
    margin-left: 50px !important;
  }
  .mr-md-50 {
    margin-right: 50px !important;
  }
  .pt-md-50 {
    padding-top: 50px !important;
  }
  .pb-md-50 {
    padding-bottom: 50px !important;
  }
  .pl-md-50 {
    padding-left: 50px !important;
  }
  .pr-md-50 {
    padding-right: 50px !important;
  }
}
@media (max-width: 1023.98px) {
  .mt-lg-0 {
    margin-top: 0px !important;
  }
  .mb-lg-0 {
    margin-bottom: 0px !important;
  }
  .ml-lg-0 {
    margin-left: 0px !important;
  }
  .mr-lg-0 {
    margin-right: 0px !important;
  }
  .pt-lg-0 {
    padding-top: 0px !important;
  }
  .pb-lg-0 {
    padding-bottom: 0px !important;
  }
  .pl-lg-0 {
    padding-left: 0px !important;
  }
  .pr-lg-0 {
    padding-right: 0px !important;
  }
  .mt-lg-5 {
    margin-top: 5px !important;
  }
  .mb-lg-5 {
    margin-bottom: 5px !important;
  }
  .ml-lg-5 {
    margin-left: 5px !important;
  }
  .mr-lg-5 {
    margin-right: 5px !important;
  }
  .pt-lg-5 {
    padding-top: 5px !important;
  }
  .pb-lg-5 {
    padding-bottom: 5px !important;
  }
  .pl-lg-5 {
    padding-left: 5px !important;
  }
  .pr-lg-5 {
    padding-right: 5px !important;
  }
  .mt-lg-10 {
    margin-top: 10px !important;
  }
  .mb-lg-10 {
    margin-bottom: 10px !important;
  }
  .ml-lg-10 {
    margin-left: 10px !important;
  }
  .mr-lg-10 {
    margin-right: 10px !important;
  }
  .pt-lg-10 {
    padding-top: 10px !important;
  }
  .pb-lg-10 {
    padding-bottom: 10px !important;
  }
  .pl-lg-10 {
    padding-left: 10px !important;
  }
  .pr-lg-10 {
    padding-right: 10px !important;
  }
  .mt-lg-15 {
    margin-top: 15px !important;
  }
  .mb-lg-15 {
    margin-bottom: 15px !important;
  }
  .ml-lg-15 {
    margin-left: 15px !important;
  }
  .mr-lg-15 {
    margin-right: 15px !important;
  }
  .pt-lg-15 {
    padding-top: 15px !important;
  }
  .pb-lg-15 {
    padding-bottom: 15px !important;
  }
  .pl-lg-15 {
    padding-left: 15px !important;
  }
  .pr-lg-15 {
    padding-right: 15px !important;
  }
  .mt-lg-20 {
    margin-top: 20px !important;
  }
  .mb-lg-20 {
    margin-bottom: 20px !important;
  }
  .ml-lg-20 {
    margin-left: 20px !important;
  }
  .mr-lg-20 {
    margin-right: 20px !important;
  }
  .pt-lg-20 {
    padding-top: 20px !important;
  }
  .pb-lg-20 {
    padding-bottom: 20px !important;
  }
  .pl-lg-20 {
    padding-left: 20px !important;
  }
  .pr-lg-20 {
    padding-right: 20px !important;
  }
  .mt-lg-25 {
    margin-top: 25px !important;
  }
  .mb-lg-25 {
    margin-bottom: 25px !important;
  }
  .ml-lg-25 {
    margin-left: 25px !important;
  }
  .mr-lg-25 {
    margin-right: 25px !important;
  }
  .pt-lg-25 {
    padding-top: 25px !important;
  }
  .pb-lg-25 {
    padding-bottom: 25px !important;
  }
  .pl-lg-25 {
    padding-left: 25px !important;
  }
  .pr-lg-25 {
    padding-right: 25px !important;
  }
  .mt-lg-30 {
    margin-top: 30px !important;
  }
  .mb-lg-30 {
    margin-bottom: 30px !important;
  }
  .ml-lg-30 {
    margin-left: 30px !important;
  }
  .mr-lg-30 {
    margin-right: 30px !important;
  }
  .pt-lg-30 {
    padding-top: 30px !important;
  }
  .pb-lg-30 {
    padding-bottom: 30px !important;
  }
  .pl-lg-30 {
    padding-left: 30px !important;
  }
  .pr-lg-30 {
    padding-right: 30px !important;
  }
  .mt-lg-35 {
    margin-top: 35px !important;
  }
  .mb-lg-35 {
    margin-bottom: 35px !important;
  }
  .ml-lg-35 {
    margin-left: 35px !important;
  }
  .mr-lg-35 {
    margin-right: 35px !important;
  }
  .pt-lg-35 {
    padding-top: 35px !important;
  }
  .pb-lg-35 {
    padding-bottom: 35px !important;
  }
  .pl-lg-35 {
    padding-left: 35px !important;
  }
  .pr-lg-35 {
    padding-right: 35px !important;
  }
  .mt-lg-40 {
    margin-top: 40px !important;
  }
  .mb-lg-40 {
    margin-bottom: 40px !important;
  }
  .ml-lg-40 {
    margin-left: 40px !important;
  }
  .mr-lg-40 {
    margin-right: 40px !important;
  }
  .pt-lg-40 {
    padding-top: 40px !important;
  }
  .pb-lg-40 {
    padding-bottom: 40px !important;
  }
  .pl-lg-40 {
    padding-left: 40px !important;
  }
  .pr-lg-40 {
    padding-right: 40px !important;
  }
  .mt-lg-45 {
    margin-top: 45px !important;
  }
  .mb-lg-45 {
    margin-bottom: 45px !important;
  }
  .ml-lg-45 {
    margin-left: 45px !important;
  }
  .mr-lg-45 {
    margin-right: 45px !important;
  }
  .pt-lg-45 {
    padding-top: 45px !important;
  }
  .pb-lg-45 {
    padding-bottom: 45px !important;
  }
  .pl-lg-45 {
    padding-left: 45px !important;
  }
  .pr-lg-45 {
    padding-right: 45px !important;
  }
  .mt-lg-50 {
    margin-top: 50px !important;
  }
  .mb-lg-50 {
    margin-bottom: 50px !important;
  }
  .ml-lg-50 {
    margin-left: 50px !important;
  }
  .mr-lg-50 {
    margin-right: 50px !important;
  }
  .pt-lg-50 {
    padding-top: 50px !important;
  }
  .pb-lg-50 {
    padding-bottom: 50px !important;
  }
  .pl-lg-50 {
    padding-left: 50px !important;
  }
  .pr-lg-50 {
    padding-right: 50px !important;
  }
}
@media (max-width: 1279.98px) {
  .mt-xl-0 {
    margin-top: 0px !important;
  }
  .mb-xl-0 {
    margin-bottom: 0px !important;
  }
  .ml-xl-0 {
    margin-left: 0px !important;
  }
  .mr-xl-0 {
    margin-right: 0px !important;
  }
  .pt-xl-0 {
    padding-top: 0px !important;
  }
  .pb-xl-0 {
    padding-bottom: 0px !important;
  }
  .pl-xl-0 {
    padding-left: 0px !important;
  }
  .pr-xl-0 {
    padding-right: 0px !important;
  }
  .mt-xl-5 {
    margin-top: 5px !important;
  }
  .mb-xl-5 {
    margin-bottom: 5px !important;
  }
  .ml-xl-5 {
    margin-left: 5px !important;
  }
  .mr-xl-5 {
    margin-right: 5px !important;
  }
  .pt-xl-5 {
    padding-top: 5px !important;
  }
  .pb-xl-5 {
    padding-bottom: 5px !important;
  }
  .pl-xl-5 {
    padding-left: 5px !important;
  }
  .pr-xl-5 {
    padding-right: 5px !important;
  }
  .mt-xl-10 {
    margin-top: 10px !important;
  }
  .mb-xl-10 {
    margin-bottom: 10px !important;
  }
  .ml-xl-10 {
    margin-left: 10px !important;
  }
  .mr-xl-10 {
    margin-right: 10px !important;
  }
  .pt-xl-10 {
    padding-top: 10px !important;
  }
  .pb-xl-10 {
    padding-bottom: 10px !important;
  }
  .pl-xl-10 {
    padding-left: 10px !important;
  }
  .pr-xl-10 {
    padding-right: 10px !important;
  }
  .mt-xl-15 {
    margin-top: 15px !important;
  }
  .mb-xl-15 {
    margin-bottom: 15px !important;
  }
  .ml-xl-15 {
    margin-left: 15px !important;
  }
  .mr-xl-15 {
    margin-right: 15px !important;
  }
  .pt-xl-15 {
    padding-top: 15px !important;
  }
  .pb-xl-15 {
    padding-bottom: 15px !important;
  }
  .pl-xl-15 {
    padding-left: 15px !important;
  }
  .pr-xl-15 {
    padding-right: 15px !important;
  }
  .mt-xl-20 {
    margin-top: 20px !important;
  }
  .mb-xl-20 {
    margin-bottom: 20px !important;
  }
  .ml-xl-20 {
    margin-left: 20px !important;
  }
  .mr-xl-20 {
    margin-right: 20px !important;
  }
  .pt-xl-20 {
    padding-top: 20px !important;
  }
  .pb-xl-20 {
    padding-bottom: 20px !important;
  }
  .pl-xl-20 {
    padding-left: 20px !important;
  }
  .pr-xl-20 {
    padding-right: 20px !important;
  }
  .mt-xl-25 {
    margin-top: 25px !important;
  }
  .mb-xl-25 {
    margin-bottom: 25px !important;
  }
  .ml-xl-25 {
    margin-left: 25px !important;
  }
  .mr-xl-25 {
    margin-right: 25px !important;
  }
  .pt-xl-25 {
    padding-top: 25px !important;
  }
  .pb-xl-25 {
    padding-bottom: 25px !important;
  }
  .pl-xl-25 {
    padding-left: 25px !important;
  }
  .pr-xl-25 {
    padding-right: 25px !important;
  }
  .mt-xl-30 {
    margin-top: 30px !important;
  }
  .mb-xl-30 {
    margin-bottom: 30px !important;
  }
  .ml-xl-30 {
    margin-left: 30px !important;
  }
  .mr-xl-30 {
    margin-right: 30px !important;
  }
  .pt-xl-30 {
    padding-top: 30px !important;
  }
  .pb-xl-30 {
    padding-bottom: 30px !important;
  }
  .pl-xl-30 {
    padding-left: 30px !important;
  }
  .pr-xl-30 {
    padding-right: 30px !important;
  }
  .mt-xl-35 {
    margin-top: 35px !important;
  }
  .mb-xl-35 {
    margin-bottom: 35px !important;
  }
  .ml-xl-35 {
    margin-left: 35px !important;
  }
  .mr-xl-35 {
    margin-right: 35px !important;
  }
  .pt-xl-35 {
    padding-top: 35px !important;
  }
  .pb-xl-35 {
    padding-bottom: 35px !important;
  }
  .pl-xl-35 {
    padding-left: 35px !important;
  }
  .pr-xl-35 {
    padding-right: 35px !important;
  }
  .mt-xl-40 {
    margin-top: 40px !important;
  }
  .mb-xl-40 {
    margin-bottom: 40px !important;
  }
  .ml-xl-40 {
    margin-left: 40px !important;
  }
  .mr-xl-40 {
    margin-right: 40px !important;
  }
  .pt-xl-40 {
    padding-top: 40px !important;
  }
  .pb-xl-40 {
    padding-bottom: 40px !important;
  }
  .pl-xl-40 {
    padding-left: 40px !important;
  }
  .pr-xl-40 {
    padding-right: 40px !important;
  }
  .mt-xl-45 {
    margin-top: 45px !important;
  }
  .mb-xl-45 {
    margin-bottom: 45px !important;
  }
  .ml-xl-45 {
    margin-left: 45px !important;
  }
  .mr-xl-45 {
    margin-right: 45px !important;
  }
  .pt-xl-45 {
    padding-top: 45px !important;
  }
  .pb-xl-45 {
    padding-bottom: 45px !important;
  }
  .pl-xl-45 {
    padding-left: 45px !important;
  }
  .pr-xl-45 {
    padding-right: 45px !important;
  }
  .mt-xl-50 {
    margin-top: 50px !important;
  }
  .mb-xl-50 {
    margin-bottom: 50px !important;
  }
  .ml-xl-50 {
    margin-left: 50px !important;
  }
  .mr-xl-50 {
    margin-right: 50px !important;
  }
  .pt-xl-50 {
    padding-top: 50px !important;
  }
  .pb-xl-50 {
    padding-bottom: 50px !important;
  }
  .pl-xl-50 {
    padding-left: 50px !important;
  }
  .pr-xl-50 {
    padding-right: 50px !important;
  }
}
@media (max-width: 1399.98px) {
  .mt-xxl-0 {
    margin-top: 0px !important;
  }
  .mb-xxl-0 {
    margin-bottom: 0px !important;
  }
  .ml-xxl-0 {
    margin-left: 0px !important;
  }
  .mr-xxl-0 {
    margin-right: 0px !important;
  }
  .pt-xxl-0 {
    padding-top: 0px !important;
  }
  .pb-xxl-0 {
    padding-bottom: 0px !important;
  }
  .pl-xxl-0 {
    padding-left: 0px !important;
  }
  .pr-xxl-0 {
    padding-right: 0px !important;
  }
  .mt-xxl-5 {
    margin-top: 5px !important;
  }
  .mb-xxl-5 {
    margin-bottom: 5px !important;
  }
  .ml-xxl-5 {
    margin-left: 5px !important;
  }
  .mr-xxl-5 {
    margin-right: 5px !important;
  }
  .pt-xxl-5 {
    padding-top: 5px !important;
  }
  .pb-xxl-5 {
    padding-bottom: 5px !important;
  }
  .pl-xxl-5 {
    padding-left: 5px !important;
  }
  .pr-xxl-5 {
    padding-right: 5px !important;
  }
  .mt-xxl-10 {
    margin-top: 10px !important;
  }
  .mb-xxl-10 {
    margin-bottom: 10px !important;
  }
  .ml-xxl-10 {
    margin-left: 10px !important;
  }
  .mr-xxl-10 {
    margin-right: 10px !important;
  }
  .pt-xxl-10 {
    padding-top: 10px !important;
  }
  .pb-xxl-10 {
    padding-bottom: 10px !important;
  }
  .pl-xxl-10 {
    padding-left: 10px !important;
  }
  .pr-xxl-10 {
    padding-right: 10px !important;
  }
  .mt-xxl-15 {
    margin-top: 15px !important;
  }
  .mb-xxl-15 {
    margin-bottom: 15px !important;
  }
  .ml-xxl-15 {
    margin-left: 15px !important;
  }
  .mr-xxl-15 {
    margin-right: 15px !important;
  }
  .pt-xxl-15 {
    padding-top: 15px !important;
  }
  .pb-xxl-15 {
    padding-bottom: 15px !important;
  }
  .pl-xxl-15 {
    padding-left: 15px !important;
  }
  .pr-xxl-15 {
    padding-right: 15px !important;
  }
  .mt-xxl-20 {
    margin-top: 20px !important;
  }
  .mb-xxl-20 {
    margin-bottom: 20px !important;
  }
  .ml-xxl-20 {
    margin-left: 20px !important;
  }
  .mr-xxl-20 {
    margin-right: 20px !important;
  }
  .pt-xxl-20 {
    padding-top: 20px !important;
  }
  .pb-xxl-20 {
    padding-bottom: 20px !important;
  }
  .pl-xxl-20 {
    padding-left: 20px !important;
  }
  .pr-xxl-20 {
    padding-right: 20px !important;
  }
  .mt-xxl-25 {
    margin-top: 25px !important;
  }
  .mb-xxl-25 {
    margin-bottom: 25px !important;
  }
  .ml-xxl-25 {
    margin-left: 25px !important;
  }
  .mr-xxl-25 {
    margin-right: 25px !important;
  }
  .pt-xxl-25 {
    padding-top: 25px !important;
  }
  .pb-xxl-25 {
    padding-bottom: 25px !important;
  }
  .pl-xxl-25 {
    padding-left: 25px !important;
  }
  .pr-xxl-25 {
    padding-right: 25px !important;
  }
  .mt-xxl-30 {
    margin-top: 30px !important;
  }
  .mb-xxl-30 {
    margin-bottom: 30px !important;
  }
  .ml-xxl-30 {
    margin-left: 30px !important;
  }
  .mr-xxl-30 {
    margin-right: 30px !important;
  }
  .pt-xxl-30 {
    padding-top: 30px !important;
  }
  .pb-xxl-30 {
    padding-bottom: 30px !important;
  }
  .pl-xxl-30 {
    padding-left: 30px !important;
  }
  .pr-xxl-30 {
    padding-right: 30px !important;
  }
  .mt-xxl-35 {
    margin-top: 35px !important;
  }
  .mb-xxl-35 {
    margin-bottom: 35px !important;
  }
  .ml-xxl-35 {
    margin-left: 35px !important;
  }
  .mr-xxl-35 {
    margin-right: 35px !important;
  }
  .pt-xxl-35 {
    padding-top: 35px !important;
  }
  .pb-xxl-35 {
    padding-bottom: 35px !important;
  }
  .pl-xxl-35 {
    padding-left: 35px !important;
  }
  .pr-xxl-35 {
    padding-right: 35px !important;
  }
  .mt-xxl-40 {
    margin-top: 40px !important;
  }
  .mb-xxl-40 {
    margin-bottom: 40px !important;
  }
  .ml-xxl-40 {
    margin-left: 40px !important;
  }
  .mr-xxl-40 {
    margin-right: 40px !important;
  }
  .pt-xxl-40 {
    padding-top: 40px !important;
  }
  .pb-xxl-40 {
    padding-bottom: 40px !important;
  }
  .pl-xxl-40 {
    padding-left: 40px !important;
  }
  .pr-xxl-40 {
    padding-right: 40px !important;
  }
  .mt-xxl-45 {
    margin-top: 45px !important;
  }
  .mb-xxl-45 {
    margin-bottom: 45px !important;
  }
  .ml-xxl-45 {
    margin-left: 45px !important;
  }
  .mr-xxl-45 {
    margin-right: 45px !important;
  }
  .pt-xxl-45 {
    padding-top: 45px !important;
  }
  .pb-xxl-45 {
    padding-bottom: 45px !important;
  }
  .pl-xxl-45 {
    padding-left: 45px !important;
  }
  .pr-xxl-45 {
    padding-right: 45px !important;
  }
  .mt-xxl-50 {
    margin-top: 50px !important;
  }
  .mb-xxl-50 {
    margin-bottom: 50px !important;
  }
  .ml-xxl-50 {
    margin-left: 50px !important;
  }
  .mr-xxl-50 {
    margin-right: 50px !important;
  }
  .pt-xxl-50 {
    padding-top: 50px !important;
  }
  .pb-xxl-50 {
    padding-bottom: 50px !important;
  }
  .pl-xxl-50 {
    padding-left: 50px !important;
  }
  .pr-xxl-50 {
    padding-right: 50px !important;
  }
}
.text-center {
  text-align: center !important;
}

/*# sourceMappingURL=style.css.map */
