@charset "UTF-8";
footer a {
  color: #fff;
  text-decoration: none;
}
footer a:hover {
  text-decoration: underline;
}
footer .inner-w {
  margin: 0 auto;
}
footer .footer-main {
  margin: 0 auto;
  background-color: #aacf53;
  color: #fff;
  padding: 8em 1em;
  font-size: 0.95rem;
  max-width: 100%;
  max-height: auto;
}
footer .footer-main .footer-nav-group {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6em;
}
footer .footer-main .footer-nav-group .company_head .company_name {
  font-size: 2.4rem;
  font-weight: 700;
  text-align: center;
  white-space: nowrap;
}
footer .footer-main .footer-nav-group .company_head .company_name::before {
  content: "";
  display: block;
  width: 100%;
  height: 42px;
  background-image: url("../img/logo-footer.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-bottom: 0.5em;
}
footer .footer-main .footer-nav-group .company_head .company_name small {
  display: block;
  font-size: 1rem;
  margin-top: 0.2em;
}
footer .footer-main .footer-nav-group .company_head .company_grouplogo img {
  height: 25px;
  width: auto;
  margin-top: 1em;
}
footer .footer-main .footer-nav-group .company_head .company_instagram {
  margin-top: 1em;
  display: flex;
  justify-content: center;
  align-items: center;
}
footer .footer-main .footer-nav-group .company_head .company_instagram a {
  display: inline-block;
  width: 34px;
  height: 34px;
}
footer .footer-main .footer-nav-group .company_head .company_instagram a img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
footer .footer-main .footer-nav-group .company_head .company_instagram a:hover img {
  transform: scale(1.05);
  opacity: 0.7;
}
footer .footer-main .footer-nav-group .footer-col .menu {
  list-style: none;
  padding: 0;
}
footer .footer-main .footer-nav-group .footer-col .menu li {
  margin-bottom: 0.4em;
  font-size: 1.4rem;
}
footer .footer-main .footer-nav-group .footer-col .menu li.main {
  font-weight: bold;
  margin-bottom: 1em;
  font-size: 1.7rem;
}
footer .footer-main .footer-nav-group .footer-col .menu li.border {
  border-top: 1px solid #ffffff;
  margin-top: 8px;
  padding-top: 8px;
}
footer .footer-main .footer-nav-group .policy {
  display: block;
  margin-top: 1.5em;
  font-size: 1rem;
}
footer .footer-main .footer-nav-group .copyright {
  margin-top: 1em;
  font-size: 1rem;
  opacity: 0.8;
}

.recruit-hero {
  position: relative;
  width: 100%;
  height: 600px;
  background-image: linear-gradient(90deg, #ff4e50 0%, #ffa155 25%, #f9d423 50%, #ffa155 75%, #ff4e50 100%);
  background-size: 200% 100%;
  background-repeat: repeat-x;
  animation: moveGradient 10s linear infinite;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: white;
  overflow: hidden;
  padding-top: 100px;
  border: none;
}
.recruit-hero__overlay {
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: 150px;
  background: rgb(255, 255, 255);
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  z-index: 1;
}
.recruit-hero__content {
  z-index: 2;
}
.recruit-hero__content > h2 {
  font-size: 4rem;
  margin: 0;
}
.recruit-hero__content > p {
  font-size: 2rem;
  margin: 0.5rem 0 1.5rem;
  color: #000000;
  font-weight: 700;
}
.recruit-hero .hero-top-btn {
  position: absolute;
  right: 20px;
  bottom: 20px;
  scroll-behavior: smooth;
  z-index: 3;
}
.recruit-hero .hero-top-btn a {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: #000;
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
}
.recruit-hero .hero-top-btn a .arrow-up {
  width: 0;
  height: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-bottom: 20px solid #000;
  transition: border-bottom-color 0.3s;
}
.recruit-hero .hero-top-btn a .arrow-line {
  width: 6px;
  height: 30px;
  background-color: #000;
  margin-top: -6px;
  transition: background-color 0.3s;
}
.recruit-hero .hero-top-btn a .text {
  font-size: 1.8rem;
  line-height: 1;
  margin-top: 5px;
}
.recruit-hero .hero-top-btn a:hover {
  color: #6e6e6e;
}
.recruit-hero .hero-top-btn a:hover .arrow-up {
  border-bottom-color: #6e6e6e;
}
.recruit-hero .hero-top-btn a:hover .arrow-line {
  background-color: #6e6e6e;
}

.recruit-options {
  display: flex;
  gap: 2rem;
  justify-content: center;
  margin-top: 1rem;
}

.recruit-option {
  background: rgb(255, 255, 255);
  border: 2px solid white;
  padding: 1.5rem 5rem;
  border-radius: 8px;
  font-weight: bold;
  cursor: pointer;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
.recruit-option:hover {
  transform: scale(1.05);
  opacity: 0.7;
}
.recruit-option--new {
  color: #000000;
  font-size: 1.5rem;
}
.recruit-option--mid {
  color: #000000;
  font-size: 1.5rem;
}

.entry-icon {
  height: 1.2em;
  width: auto;
  display: inline-block;
  margin-left: 20px;
}

@media (max-width: 480px) {
  .recruit-hero {
    height: 400px;
    padding-top: 80px;
  }
  .recruit-hero__content > h2 {
    font-size: 2.5rem;
  }
  .recruit-hero__content > p {
    font-size: 1.4rem;
    margin: 0.5rem 0 1rem;
  }
  .recruit-hero .hero-top-btn {
    right: 10px;
    bottom: 10px;
  }
  .recruit-hero .hero-top-btn a .arrow-up {
    border-left: 12px solid transparent;
    border-right: 12px solid transparent;
    border-bottom: 12px solid #000;
  }
  .recruit-hero .hero-top-btn a .arrow-line {
    width: 4px;
    height: 20px;
    margin-top: -4px;
  }
  .recruit-hero .hero-top-btn a .text {
    font-size: 1.2rem;
    margin-top: 3px;
  }
  .recruit-hero__overlay {
    height: 45px;
  }
  .recruit-options {
    flex-direction: column;
    gap: 1.5rem;
    margin-top: 1rem;
    align-items: center;
  }
  .recruit-option {
    width: 90%;
    padding: 1rem 2rem;
    font-size: 1.3rem;
    text-align: center;
  }
  .recruit-option--new, .recruit-option--mid {
    font-size: 1.3rem;
  }
  .entry-icon {
    height: 1em;
    margin-left: 10px;
  }
}
@keyframes moveGradient {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: -200% 0%;
  }
}
/* ヘッダー固定 */
.header {
  -webkit-backdrop-filter: blur(2px);
          backdrop-filter: blur(2px);
  position: fixed;
  top: 0 !important;
  left: 0;
  width: 100%;
  z-index: 10000;
  background-color: transparent;
  transition: background-color 0.3s ease;
}
.header .header-inner {
  width: 100%;
  display: flex;
  align-items: center;
  padding-right: 0;
  justify-content: flex-start;
}
.header .header-inner .logo-flex {
  display: flex;
  align-items: center;
}
.header .header-inner .logo-flex .logo img {
  height: 100px;
  width: auto;
  display: block;
}
.header .header-inner .logo-flex .recruit img {
  height: 60px;
  width: auto;
  display: block;
  margin-left: 35px;
}
.header .header-inner .global-nav {
  margin-left: auto;
  margin-right: 20px;
}
.header .header-inner .global-nav ul.nav-list {
  display: flex;
  gap: 4em;
  list-style: none;
  flex-wrap: nowrap;
  align-items: center;
}
.header .header-inner .global-nav ul.nav-list li a {
  color: #ffffff;
  text-decoration: none;
  padding: 0.5em 0;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  background-image: linear-gradient(90deg, #ff5377, #ffa500);
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: 0 6px;
  transition: background-size 0.5s;
  border-radius: 2px;
  text-shadow: #000 1px 1px 4px;
}
.header .header-inner .global-nav ul.nav-list li a:hover {
  background-size: 100% 6px;
}
.header .header-inner .global-nav ul.nav-list li a.btn-entry {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.5em 1em;
  border: 2px solid #fff;
  border-radius: 999px 999px 999px 999px;
  color: #fff;
  text-decoration: none;
  font-family: "Montserrat", sans-serif;
  width: 12em;
  height: 3.5em;
  box-sizing: border-box;
  margin-right: 20px;
  background-image: linear-gradient(90deg, #ff5377, #ffa500);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: 0% 100%;
  transition: background-size 0.5s ease, background-color 0.3s ease;
}
.header .header-inner .global-nav ul.nav-list li a.btn-entry:hover {
  background-size: 100% 100%;
  color: #ffffff;
}
.header .header-inner .global-nav ul.nav-list li a.btn-entry .text-break {
  display: inline-block;
  text-align: left;
  transition: all 0.4s ease-in-out;
  white-space: normal;
}
.header .header-inner .global-nav ul.nav-list li a.btn-entry .text-break--applied.text-break--centered {
  text-align: center;
  line-height: 1.6;
  font-size: 1.6rem;
}
.header .header-inner .global-nav ul.nav-list li a.btn-entry .entry-icon {
  margin-left: 40px;
  height: 1.2em;
  width: auto;
  display: inline-block;
}
.header .header-inner .global-nav ul.nav-list li a.btn-entry .entry-icon:hover {
  opacity: 0.8;
}
.header .header-inner .global-nav .hamburger-menu {
  display: none;
}

.header.bg-colored .global-nav ul.nav-list li a {
  text-shadow: none !important;
}

/* ダークテーマ用クラス */
.header.black .global-nav ul.nav-list li a {
  color: #000 !important;
  text-shadow: none !important;
}
.header.black .global-nav ul.nav-list li a.btn-entry {
  border: 2px solid #000;
  color: #000;
}
.header.black .global-nav ul.nav-list li a.btn-entry:hover {
  background-size: 100% 100%;
  color: #ffffff;
}
.header.black .hamburger-menu span {
  background-color: #000000;
}

@media (max-width: 1366px) {
  .header .header-inner .logo-flex .recruit img {
    height: 45px;
  }
  .header .global-nav ul.nav-list {
    gap: 3em;
  }
  .header .global-nav ul.nav-list li a {
    font-size: 1.5rem;
  }
}
@media (max-width: 1130px) {
  .header .header-inner .logo-flex .logo img {
    height: 65px;
  }
  .header .header-inner .logo-flex .recruit img {
    height: 50px;
    margin-left: 15px;
  }
  .header .header-inner .global-nav ul.nav-list {
    gap: 2em;
  }
  .header .header-inner .global-nav ul.nav-list li a {
    font-size: 1.4rem;
    padding: 0.5em 0;
  }
  .header .header-inner .global-nav ul.nav-list li a.btn-entry {
    width: 12em;
    height: 3em;
    margin-right: 10px;
    font-size: 1.2rem;
  }
}
@media (max-width: 1024px) {
  .header .header-inner .global-nav {
    display: none;
  }
  .header .header-inner .global-nav.active {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(118, 207, 83, 0.9);
    padding-top: 80px;
    z-index: 15000;
    overflow-y: auto;
  }
  .header .header-inner .global-nav.active ul.nav-list {
    flex-direction: column;
    gap: 1em;
    list-style: none;
    padding: 0;
    margin: 0;
  }
  .header .header-inner .global-nav.active ul.nav-list li a {
    color: #ffffff;
    display: block;
    padding: 0.8em 1em;
    border-radius: 4px;
    font-size: 2.5rem;
    margin-top: 10px;
  }
  .header .header-inner .global-nav.active ul.nav-list li a:hover {
    background: linear-gradient(90deg, #ff5377, #ffa500);
    color: #ffffff;
  }
  .header .header-inner .global-nav.active ul.nav-list li a.btn-entry:hover {
    background-size: 100% 100%;
    color: #ffffff;
  }
  .header .header-inner .hamburger-menu {
    display: block;
    position: absolute;
    top: 70%;
    right: 10px;
    transform: translateY(-50%);
    width: 60px;
    height: 60px;
    cursor: pointer;
    z-index: 16000;
  }
  .header .header-inner .hamburger-menu span {
    display: block;
    width: 30px;
    height: 4px;
    background: #ffffff;
    border-radius: 2px;
    margin: 6px auto;
    position: relative;
    transition: 0.3s;
    transform-origin: center center;
  }
  .header .header-inner .hamburger-menu.active span:nth-child(1) {
    position: absolute;
    top: 13px;
    left: 50%;
    width: 40px;
    transform: translateX(-50%) rotate(45deg);
  }
  .header .header-inner .hamburger-menu.active span:nth-child(2) {
    opacity: 0;
  }
  .header .header-inner .hamburger-menu.active span:nth-child(3) {
    position: absolute;
    top: 13px;
    left: 50%;
    width: 40px;
    transform: translateX(-50%) rotate(-45deg);
  }
  .header .header-inner .hamburger-menu.black span {
    background: #000000;
  }
}
@media (max-width: 768px) {
  .header .header-inner {
    position: relative;
  }
  .header .header-inner .logo-flex .logo img {
    height: 65px;
  }
  .header .header-inner .logo-flex .recruit img {
    height: 30px;
    margin-left: 10px;
  }
  .header .header-inner .global-nav {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgb(118, 207, 83);
    padding-top: 80px;
    z-index: 15000;
    overflow-y: auto;
  }
  .header .header-inner .global-nav.active {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 2em 1em;
  }
  .header .header-inner .global-nav ul.nav-list {
    flex-direction: column;
    gap: 1em;
    list-style: none;
    padding: 0;
    margin: 0;
  }
  .header .header-inner .global-nav ul.nav-list li a {
    color: #ffffff;
    display: block;
    padding: 0.8em 1em;
    border-radius: 4px;
    font-size: 2.5rem;
    margin-top: 10px;
  }
  .header .header-inner .global-nav ul.nav-list li a:hover {
    background: linear-gradient(90deg, #ff5377, #ffa500);
    color: #ffffff;
  }
  .header .header-inner .global-nav ul.nav-list li a.btn-entry:hover {
    background-size: 100% 100%;
    color: #ffffff;
  }
  .header .header-inner .hamburger-menu {
    display: block;
    position: absolute;
    top: 72%;
    right: 0;
    transform: translateY(-50%);
    width: 60px;
    height: 60px;
    cursor: pointer;
    z-index: 16000;
  }
  .header .header-inner .hamburger-menu span {
    display: block;
    width: 30px;
    height: 4px;
    background: #ffffff;
    border-radius: 2px;
    margin: 6px auto;
    position: relative;
    transition: 0.3s;
    transform-origin: center center;
  }
  .header .header-inner .hamburger-menu.active span:nth-child(1) {
    position: absolute;
    top: 13px;
    left: 50%;
    width: 40px;
    transform: translateX(-50%) rotate(45deg);
  }
  .header .header-inner .hamburger-menu.active span:nth-child(2) {
    opacity: 0;
  }
  .header .header-inner .hamburger-menu.active span:nth-child(3) {
    position: absolute;
    top: 13px;
    left: 50%;
    width: 40px;
    transform: translateX(-50%) rotate(-45deg);
  }
  .header .header-inner .hamburger-menu.black span {
    background: #000000;
  }
}
@media (max-width: 768px) {
  .header .header-inner .logo-flex .logo img {
    height: 50px;
  }
}
.l-max {
  max-width: 1500px;
  width: 100%;
  margin: auto;
  position: relative;
  z-index: 20;
}

.l-large {
  max-width: 1280px;
  width: 100%;
  margin: auto;
  position: relative;
  z-index: 20;
}

.l-medium {
  max-width: 1024px;
  width: 100%;
  margin: auto;
  position: relative;
  z-index: 20;
}

.l-mini {
  max-width: 768px;
  width: 100%;
  margin: auto;
  position: relative;
  z-index: 20;
}

.l-small {
  max-width: 680px;
  width: 100%;
  margin: auto;
  position: relative;
  z-index: 20;
}

.l-tiny {
  max-width: 320px;
  width: 100%;
  margin: auto;
  position: relative;
  z-index: 20;
}

.u-pt0 {
  padding-top: 0px;
}
@media screen and (max-width: 600px) {
  .u-pt0 {
    padding-top: 0px;
  }
}

.u-pb0 {
  padding-bottom: 0px;
}
@media screen and (max-width: 600px) {
  .u-pb0 {
    padding-bottom: 0px;
  }
}

.u-mt0 {
  margin-top: 0px !important;
}
@media screen and (max-width: 600px) {
  .u-mt0 {
    margin-top: 0px !important;
  }
}

.u-mb0 {
  margin-bottom: 0px !important;
}
@media screen and (max-width: 600px) {
  .u-mb0 {
    margin-bottom: 0px !important;
  }
}

.u-pt1 {
  padding-top: 1px;
}
@media screen and (max-width: 600px) {
  .u-pt1 {
    padding-top: 0.5px;
  }
}

.u-pb1 {
  padding-bottom: 1px;
}
@media screen and (max-width: 600px) {
  .u-pb1 {
    padding-bottom: 0.5px;
  }
}

.u-mt1 {
  margin-top: 1px !important;
}
@media screen and (max-width: 600px) {
  .u-mt1 {
    margin-top: 0.5px !important;
  }
}

.u-mb1 {
  margin-bottom: 1px !important;
}
@media screen and (max-width: 600px) {
  .u-mb1 {
    margin-bottom: 0.5px !important;
  }
}

.u-pt2 {
  padding-top: 2px;
}
@media screen and (max-width: 600px) {
  .u-pt2 {
    padding-top: 1px;
  }
}

.u-pb2 {
  padding-bottom: 2px;
}
@media screen and (max-width: 600px) {
  .u-pb2 {
    padding-bottom: 1px;
  }
}

.u-mt2 {
  margin-top: 2px !important;
}
@media screen and (max-width: 600px) {
  .u-mt2 {
    margin-top: 1px !important;
  }
}

.u-mb2 {
  margin-bottom: 2px !important;
}
@media screen and (max-width: 600px) {
  .u-mb2 {
    margin-bottom: 1px !important;
  }
}

.u-pt3 {
  padding-top: 3px;
}
@media screen and (max-width: 600px) {
  .u-pt3 {
    padding-top: 1.5px;
  }
}

.u-pb3 {
  padding-bottom: 3px;
}
@media screen and (max-width: 600px) {
  .u-pb3 {
    padding-bottom: 1.5px;
  }
}

.u-mt3 {
  margin-top: 3px !important;
}
@media screen and (max-width: 600px) {
  .u-mt3 {
    margin-top: 1.5px !important;
  }
}

.u-mb3 {
  margin-bottom: 3px !important;
}
@media screen and (max-width: 600px) {
  .u-mb3 {
    margin-bottom: 1.5px !important;
  }
}

.u-pt4 {
  padding-top: 4px;
}
@media screen and (max-width: 600px) {
  .u-pt4 {
    padding-top: 2px;
  }
}

.u-pb4 {
  padding-bottom: 4px;
}
@media screen and (max-width: 600px) {
  .u-pb4 {
    padding-bottom: 2px;
  }
}

.u-mt4 {
  margin-top: 4px !important;
}
@media screen and (max-width: 600px) {
  .u-mt4 {
    margin-top: 2px !important;
  }
}

.u-mb4 {
  margin-bottom: 4px !important;
}
@media screen and (max-width: 600px) {
  .u-mb4 {
    margin-bottom: 2px !important;
  }
}

.u-pt5 {
  padding-top: 5px;
}
@media screen and (max-width: 600px) {
  .u-pt5 {
    padding-top: 2.5px;
  }
}

.u-pb5 {
  padding-bottom: 5px;
}
@media screen and (max-width: 600px) {
  .u-pb5 {
    padding-bottom: 2.5px;
  }
}

.u-mt5 {
  margin-top: 5px !important;
}
@media screen and (max-width: 600px) {
  .u-mt5 {
    margin-top: 2.5px !important;
  }
}

.u-mb5 {
  margin-bottom: 5px !important;
}
@media screen and (max-width: 600px) {
  .u-mb5 {
    margin-bottom: 2.5px !important;
  }
}

.u-pt6 {
  padding-top: 6px;
}
@media screen and (max-width: 600px) {
  .u-pt6 {
    padding-top: 3px;
  }
}

.u-pb6 {
  padding-bottom: 6px;
}
@media screen and (max-width: 600px) {
  .u-pb6 {
    padding-bottom: 3px;
  }
}

.u-mt6 {
  margin-top: 6px !important;
}
@media screen and (max-width: 600px) {
  .u-mt6 {
    margin-top: 3px !important;
  }
}

.u-mb6 {
  margin-bottom: 6px !important;
}
@media screen and (max-width: 600px) {
  .u-mb6 {
    margin-bottom: 3px !important;
  }
}

.u-pt7 {
  padding-top: 7px;
}
@media screen and (max-width: 600px) {
  .u-pt7 {
    padding-top: 3.5px;
  }
}

.u-pb7 {
  padding-bottom: 7px;
}
@media screen and (max-width: 600px) {
  .u-pb7 {
    padding-bottom: 3.5px;
  }
}

.u-mt7 {
  margin-top: 7px !important;
}
@media screen and (max-width: 600px) {
  .u-mt7 {
    margin-top: 3.5px !important;
  }
}

.u-mb7 {
  margin-bottom: 7px !important;
}
@media screen and (max-width: 600px) {
  .u-mb7 {
    margin-bottom: 3.5px !important;
  }
}

.u-pt8 {
  padding-top: 8px;
}
@media screen and (max-width: 600px) {
  .u-pt8 {
    padding-top: 4px;
  }
}

.u-pb8 {
  padding-bottom: 8px;
}
@media screen and (max-width: 600px) {
  .u-pb8 {
    padding-bottom: 4px;
  }
}

.u-mt8 {
  margin-top: 8px !important;
}
@media screen and (max-width: 600px) {
  .u-mt8 {
    margin-top: 4px !important;
  }
}

.u-mb8 {
  margin-bottom: 8px !important;
}
@media screen and (max-width: 600px) {
  .u-mb8 {
    margin-bottom: 4px !important;
  }
}

.u-pt9 {
  padding-top: 9px;
}
@media screen and (max-width: 600px) {
  .u-pt9 {
    padding-top: 4.5px;
  }
}

.u-pb9 {
  padding-bottom: 9px;
}
@media screen and (max-width: 600px) {
  .u-pb9 {
    padding-bottom: 4.5px;
  }
}

.u-mt9 {
  margin-top: 9px !important;
}
@media screen and (max-width: 600px) {
  .u-mt9 {
    margin-top: 4.5px !important;
  }
}

.u-mb9 {
  margin-bottom: 9px !important;
}
@media screen and (max-width: 600px) {
  .u-mb9 {
    margin-bottom: 4.5px !important;
  }
}

.u-pt10 {
  padding-top: 10px;
}
@media screen and (max-width: 600px) {
  .u-pt10 {
    padding-top: 5px;
  }
}

.u-pb10 {
  padding-bottom: 10px;
}
@media screen and (max-width: 600px) {
  .u-pb10 {
    padding-bottom: 5px;
  }
}

.u-mt10 {
  margin-top: 10px !important;
}
@media screen and (max-width: 600px) {
  .u-mt10 {
    margin-top: 5px !important;
  }
}

.u-mb10 {
  margin-bottom: 10px !important;
}
@media screen and (max-width: 600px) {
  .u-mb10 {
    margin-bottom: 5px !important;
  }
}

.u-pt11 {
  padding-top: 11px;
}
@media screen and (max-width: 600px) {
  .u-pt11 {
    padding-top: 5.5px;
  }
}

.u-pb11 {
  padding-bottom: 11px;
}
@media screen and (max-width: 600px) {
  .u-pb11 {
    padding-bottom: 5.5px;
  }
}

.u-mt11 {
  margin-top: 11px !important;
}
@media screen and (max-width: 600px) {
  .u-mt11 {
    margin-top: 5.5px !important;
  }
}

.u-mb11 {
  margin-bottom: 11px !important;
}
@media screen and (max-width: 600px) {
  .u-mb11 {
    margin-bottom: 5.5px !important;
  }
}

.u-pt12 {
  padding-top: 12px;
}
@media screen and (max-width: 600px) {
  .u-pt12 {
    padding-top: 6px;
  }
}

.u-pb12 {
  padding-bottom: 12px;
}
@media screen and (max-width: 600px) {
  .u-pb12 {
    padding-bottom: 6px;
  }
}

.u-mt12 {
  margin-top: 12px !important;
}
@media screen and (max-width: 600px) {
  .u-mt12 {
    margin-top: 6px !important;
  }
}

.u-mb12 {
  margin-bottom: 12px !important;
}
@media screen and (max-width: 600px) {
  .u-mb12 {
    margin-bottom: 6px !important;
  }
}

.u-pt13 {
  padding-top: 13px;
}
@media screen and (max-width: 600px) {
  .u-pt13 {
    padding-top: 6.5px;
  }
}

.u-pb13 {
  padding-bottom: 13px;
}
@media screen and (max-width: 600px) {
  .u-pb13 {
    padding-bottom: 6.5px;
  }
}

.u-mt13 {
  margin-top: 13px !important;
}
@media screen and (max-width: 600px) {
  .u-mt13 {
    margin-top: 6.5px !important;
  }
}

.u-mb13 {
  margin-bottom: 13px !important;
}
@media screen and (max-width: 600px) {
  .u-mb13 {
    margin-bottom: 6.5px !important;
  }
}

.u-pt14 {
  padding-top: 14px;
}
@media screen and (max-width: 600px) {
  .u-pt14 {
    padding-top: 7px;
  }
}

.u-pb14 {
  padding-bottom: 14px;
}
@media screen and (max-width: 600px) {
  .u-pb14 {
    padding-bottom: 7px;
  }
}

.u-mt14 {
  margin-top: 14px !important;
}
@media screen and (max-width: 600px) {
  .u-mt14 {
    margin-top: 7px !important;
  }
}

.u-mb14 {
  margin-bottom: 14px !important;
}
@media screen and (max-width: 600px) {
  .u-mb14 {
    margin-bottom: 7px !important;
  }
}

.u-pt15 {
  padding-top: 15px;
}
@media screen and (max-width: 600px) {
  .u-pt15 {
    padding-top: 7.5px;
  }
}

.u-pb15 {
  padding-bottom: 15px;
}
@media screen and (max-width: 600px) {
  .u-pb15 {
    padding-bottom: 7.5px;
  }
}

.u-mt15 {
  margin-top: 15px !important;
}
@media screen and (max-width: 600px) {
  .u-mt15 {
    margin-top: 7.5px !important;
  }
}

.u-mb15 {
  margin-bottom: 15px !important;
}
@media screen and (max-width: 600px) {
  .u-mb15 {
    margin-bottom: 7.5px !important;
  }
}

.u-pt16 {
  padding-top: 16px;
}
@media screen and (max-width: 600px) {
  .u-pt16 {
    padding-top: 8px;
  }
}

.u-pb16 {
  padding-bottom: 16px;
}
@media screen and (max-width: 600px) {
  .u-pb16 {
    padding-bottom: 8px;
  }
}

.u-mt16 {
  margin-top: 16px !important;
}
@media screen and (max-width: 600px) {
  .u-mt16 {
    margin-top: 8px !important;
  }
}

.u-mb16 {
  margin-bottom: 16px !important;
}
@media screen and (max-width: 600px) {
  .u-mb16 {
    margin-bottom: 8px !important;
  }
}

.u-pt17 {
  padding-top: 17px;
}
@media screen and (max-width: 600px) {
  .u-pt17 {
    padding-top: 8.5px;
  }
}

.u-pb17 {
  padding-bottom: 17px;
}
@media screen and (max-width: 600px) {
  .u-pb17 {
    padding-bottom: 8.5px;
  }
}

.u-mt17 {
  margin-top: 17px !important;
}
@media screen and (max-width: 600px) {
  .u-mt17 {
    margin-top: 8.5px !important;
  }
}

.u-mb17 {
  margin-bottom: 17px !important;
}
@media screen and (max-width: 600px) {
  .u-mb17 {
    margin-bottom: 8.5px !important;
  }
}

.u-pt18 {
  padding-top: 18px;
}
@media screen and (max-width: 600px) {
  .u-pt18 {
    padding-top: 9px;
  }
}

.u-pb18 {
  padding-bottom: 18px;
}
@media screen and (max-width: 600px) {
  .u-pb18 {
    padding-bottom: 9px;
  }
}

.u-mt18 {
  margin-top: 18px !important;
}
@media screen and (max-width: 600px) {
  .u-mt18 {
    margin-top: 9px !important;
  }
}

.u-mb18 {
  margin-bottom: 18px !important;
}
@media screen and (max-width: 600px) {
  .u-mb18 {
    margin-bottom: 9px !important;
  }
}

.u-pt19 {
  padding-top: 19px;
}
@media screen and (max-width: 600px) {
  .u-pt19 {
    padding-top: 9.5px;
  }
}

.u-pb19 {
  padding-bottom: 19px;
}
@media screen and (max-width: 600px) {
  .u-pb19 {
    padding-bottom: 9.5px;
  }
}

.u-mt19 {
  margin-top: 19px !important;
}
@media screen and (max-width: 600px) {
  .u-mt19 {
    margin-top: 9.5px !important;
  }
}

.u-mb19 {
  margin-bottom: 19px !important;
}
@media screen and (max-width: 600px) {
  .u-mb19 {
    margin-bottom: 9.5px !important;
  }
}

.u-pt20 {
  padding-top: 20px;
}
@media screen and (max-width: 600px) {
  .u-pt20 {
    padding-top: 10px;
  }
}

.u-pb20 {
  padding-bottom: 20px;
}
@media screen and (max-width: 600px) {
  .u-pb20 {
    padding-bottom: 10px;
  }
}

.u-mt20 {
  margin-top: 20px !important;
}
@media screen and (max-width: 600px) {
  .u-mt20 {
    margin-top: 10px !important;
  }
}

.u-mb20 {
  margin-bottom: 20px !important;
}
@media screen and (max-width: 600px) {
  .u-mb20 {
    margin-bottom: 10px !important;
  }
}

.u-pt21 {
  padding-top: 21px;
}
@media screen and (max-width: 600px) {
  .u-pt21 {
    padding-top: 10.5px;
  }
}

.u-pb21 {
  padding-bottom: 21px;
}
@media screen and (max-width: 600px) {
  .u-pb21 {
    padding-bottom: 10.5px;
  }
}

.u-mt21 {
  margin-top: 21px !important;
}
@media screen and (max-width: 600px) {
  .u-mt21 {
    margin-top: 10.5px !important;
  }
}

.u-mb21 {
  margin-bottom: 21px !important;
}
@media screen and (max-width: 600px) {
  .u-mb21 {
    margin-bottom: 10.5px !important;
  }
}

.u-pt22 {
  padding-top: 22px;
}
@media screen and (max-width: 600px) {
  .u-pt22 {
    padding-top: 11px;
  }
}

.u-pb22 {
  padding-bottom: 22px;
}
@media screen and (max-width: 600px) {
  .u-pb22 {
    padding-bottom: 11px;
  }
}

.u-mt22 {
  margin-top: 22px !important;
}
@media screen and (max-width: 600px) {
  .u-mt22 {
    margin-top: 11px !important;
  }
}

.u-mb22 {
  margin-bottom: 22px !important;
}
@media screen and (max-width: 600px) {
  .u-mb22 {
    margin-bottom: 11px !important;
  }
}

.u-pt23 {
  padding-top: 23px;
}
@media screen and (max-width: 600px) {
  .u-pt23 {
    padding-top: 11.5px;
  }
}

.u-pb23 {
  padding-bottom: 23px;
}
@media screen and (max-width: 600px) {
  .u-pb23 {
    padding-bottom: 11.5px;
  }
}

.u-mt23 {
  margin-top: 23px !important;
}
@media screen and (max-width: 600px) {
  .u-mt23 {
    margin-top: 11.5px !important;
  }
}

.u-mb23 {
  margin-bottom: 23px !important;
}
@media screen and (max-width: 600px) {
  .u-mb23 {
    margin-bottom: 11.5px !important;
  }
}

.u-pt24 {
  padding-top: 24px;
}
@media screen and (max-width: 600px) {
  .u-pt24 {
    padding-top: 12px;
  }
}

.u-pb24 {
  padding-bottom: 24px;
}
@media screen and (max-width: 600px) {
  .u-pb24 {
    padding-bottom: 12px;
  }
}

.u-mt24 {
  margin-top: 24px !important;
}
@media screen and (max-width: 600px) {
  .u-mt24 {
    margin-top: 12px !important;
  }
}

.u-mb24 {
  margin-bottom: 24px !important;
}
@media screen and (max-width: 600px) {
  .u-mb24 {
    margin-bottom: 12px !important;
  }
}

.u-pt25 {
  padding-top: 25px;
}
@media screen and (max-width: 600px) {
  .u-pt25 {
    padding-top: 12.5px;
  }
}

.u-pb25 {
  padding-bottom: 25px;
}
@media screen and (max-width: 600px) {
  .u-pb25 {
    padding-bottom: 12.5px;
  }
}

.u-mt25 {
  margin-top: 25px !important;
}
@media screen and (max-width: 600px) {
  .u-mt25 {
    margin-top: 12.5px !important;
  }
}

.u-mb25 {
  margin-bottom: 25px !important;
}
@media screen and (max-width: 600px) {
  .u-mb25 {
    margin-bottom: 12.5px !important;
  }
}

.u-pt26 {
  padding-top: 26px;
}
@media screen and (max-width: 600px) {
  .u-pt26 {
    padding-top: 13px;
  }
}

.u-pb26 {
  padding-bottom: 26px;
}
@media screen and (max-width: 600px) {
  .u-pb26 {
    padding-bottom: 13px;
  }
}

.u-mt26 {
  margin-top: 26px !important;
}
@media screen and (max-width: 600px) {
  .u-mt26 {
    margin-top: 13px !important;
  }
}

.u-mb26 {
  margin-bottom: 26px !important;
}
@media screen and (max-width: 600px) {
  .u-mb26 {
    margin-bottom: 13px !important;
  }
}

.u-pt27 {
  padding-top: 27px;
}
@media screen and (max-width: 600px) {
  .u-pt27 {
    padding-top: 13.5px;
  }
}

.u-pb27 {
  padding-bottom: 27px;
}
@media screen and (max-width: 600px) {
  .u-pb27 {
    padding-bottom: 13.5px;
  }
}

.u-mt27 {
  margin-top: 27px !important;
}
@media screen and (max-width: 600px) {
  .u-mt27 {
    margin-top: 13.5px !important;
  }
}

.u-mb27 {
  margin-bottom: 27px !important;
}
@media screen and (max-width: 600px) {
  .u-mb27 {
    margin-bottom: 13.5px !important;
  }
}

.u-pt28 {
  padding-top: 28px;
}
@media screen and (max-width: 600px) {
  .u-pt28 {
    padding-top: 14px;
  }
}

.u-pb28 {
  padding-bottom: 28px;
}
@media screen and (max-width: 600px) {
  .u-pb28 {
    padding-bottom: 14px;
  }
}

.u-mt28 {
  margin-top: 28px !important;
}
@media screen and (max-width: 600px) {
  .u-mt28 {
    margin-top: 14px !important;
  }
}

.u-mb28 {
  margin-bottom: 28px !important;
}
@media screen and (max-width: 600px) {
  .u-mb28 {
    margin-bottom: 14px !important;
  }
}

.u-pt29 {
  padding-top: 29px;
}
@media screen and (max-width: 600px) {
  .u-pt29 {
    padding-top: 14.5px;
  }
}

.u-pb29 {
  padding-bottom: 29px;
}
@media screen and (max-width: 600px) {
  .u-pb29 {
    padding-bottom: 14.5px;
  }
}

.u-mt29 {
  margin-top: 29px !important;
}
@media screen and (max-width: 600px) {
  .u-mt29 {
    margin-top: 14.5px !important;
  }
}

.u-mb29 {
  margin-bottom: 29px !important;
}
@media screen and (max-width: 600px) {
  .u-mb29 {
    margin-bottom: 14.5px !important;
  }
}

.u-pt30 {
  padding-top: 30px;
}
@media screen and (max-width: 600px) {
  .u-pt30 {
    padding-top: 15px;
  }
}

.u-pb30 {
  padding-bottom: 30px;
}
@media screen and (max-width: 600px) {
  .u-pb30 {
    padding-bottom: 15px;
  }
}

.u-mt30 {
  margin-top: 30px !important;
}
@media screen and (max-width: 600px) {
  .u-mt30 {
    margin-top: 15px !important;
  }
}

.u-mb30 {
  margin-bottom: 30px !important;
}
@media screen and (max-width: 600px) {
  .u-mb30 {
    margin-bottom: 15px !important;
  }
}

.u-pt31 {
  padding-top: 31px;
}
@media screen and (max-width: 600px) {
  .u-pt31 {
    padding-top: 15.5px;
  }
}

.u-pb31 {
  padding-bottom: 31px;
}
@media screen and (max-width: 600px) {
  .u-pb31 {
    padding-bottom: 15.5px;
  }
}

.u-mt31 {
  margin-top: 31px !important;
}
@media screen and (max-width: 600px) {
  .u-mt31 {
    margin-top: 15.5px !important;
  }
}

.u-mb31 {
  margin-bottom: 31px !important;
}
@media screen and (max-width: 600px) {
  .u-mb31 {
    margin-bottom: 15.5px !important;
  }
}

.u-pt32 {
  padding-top: 32px;
}
@media screen and (max-width: 600px) {
  .u-pt32 {
    padding-top: 16px;
  }
}

.u-pb32 {
  padding-bottom: 32px;
}
@media screen and (max-width: 600px) {
  .u-pb32 {
    padding-bottom: 16px;
  }
}

.u-mt32 {
  margin-top: 32px !important;
}
@media screen and (max-width: 600px) {
  .u-mt32 {
    margin-top: 16px !important;
  }
}

.u-mb32 {
  margin-bottom: 32px !important;
}
@media screen and (max-width: 600px) {
  .u-mb32 {
    margin-bottom: 16px !important;
  }
}

.u-pt33 {
  padding-top: 33px;
}
@media screen and (max-width: 600px) {
  .u-pt33 {
    padding-top: 16.5px;
  }
}

.u-pb33 {
  padding-bottom: 33px;
}
@media screen and (max-width: 600px) {
  .u-pb33 {
    padding-bottom: 16.5px;
  }
}

.u-mt33 {
  margin-top: 33px !important;
}
@media screen and (max-width: 600px) {
  .u-mt33 {
    margin-top: 16.5px !important;
  }
}

.u-mb33 {
  margin-bottom: 33px !important;
}
@media screen and (max-width: 600px) {
  .u-mb33 {
    margin-bottom: 16.5px !important;
  }
}

.u-pt34 {
  padding-top: 34px;
}
@media screen and (max-width: 600px) {
  .u-pt34 {
    padding-top: 17px;
  }
}

.u-pb34 {
  padding-bottom: 34px;
}
@media screen and (max-width: 600px) {
  .u-pb34 {
    padding-bottom: 17px;
  }
}

.u-mt34 {
  margin-top: 34px !important;
}
@media screen and (max-width: 600px) {
  .u-mt34 {
    margin-top: 17px !important;
  }
}

.u-mb34 {
  margin-bottom: 34px !important;
}
@media screen and (max-width: 600px) {
  .u-mb34 {
    margin-bottom: 17px !important;
  }
}

.u-pt35 {
  padding-top: 35px;
}
@media screen and (max-width: 600px) {
  .u-pt35 {
    padding-top: 17.5px;
  }
}

.u-pb35 {
  padding-bottom: 35px;
}
@media screen and (max-width: 600px) {
  .u-pb35 {
    padding-bottom: 17.5px;
  }
}

.u-mt35 {
  margin-top: 35px !important;
}
@media screen and (max-width: 600px) {
  .u-mt35 {
    margin-top: 17.5px !important;
  }
}

.u-mb35 {
  margin-bottom: 35px !important;
}
@media screen and (max-width: 600px) {
  .u-mb35 {
    margin-bottom: 17.5px !important;
  }
}

.u-pt36 {
  padding-top: 36px;
}
@media screen and (max-width: 600px) {
  .u-pt36 {
    padding-top: 18px;
  }
}

.u-pb36 {
  padding-bottom: 36px;
}
@media screen and (max-width: 600px) {
  .u-pb36 {
    padding-bottom: 18px;
  }
}

.u-mt36 {
  margin-top: 36px !important;
}
@media screen and (max-width: 600px) {
  .u-mt36 {
    margin-top: 18px !important;
  }
}

.u-mb36 {
  margin-bottom: 36px !important;
}
@media screen and (max-width: 600px) {
  .u-mb36 {
    margin-bottom: 18px !important;
  }
}

.u-pt37 {
  padding-top: 37px;
}
@media screen and (max-width: 600px) {
  .u-pt37 {
    padding-top: 18.5px;
  }
}

.u-pb37 {
  padding-bottom: 37px;
}
@media screen and (max-width: 600px) {
  .u-pb37 {
    padding-bottom: 18.5px;
  }
}

.u-mt37 {
  margin-top: 37px !important;
}
@media screen and (max-width: 600px) {
  .u-mt37 {
    margin-top: 18.5px !important;
  }
}

.u-mb37 {
  margin-bottom: 37px !important;
}
@media screen and (max-width: 600px) {
  .u-mb37 {
    margin-bottom: 18.5px !important;
  }
}

.u-pt38 {
  padding-top: 38px;
}
@media screen and (max-width: 600px) {
  .u-pt38 {
    padding-top: 19px;
  }
}

.u-pb38 {
  padding-bottom: 38px;
}
@media screen and (max-width: 600px) {
  .u-pb38 {
    padding-bottom: 19px;
  }
}

.u-mt38 {
  margin-top: 38px !important;
}
@media screen and (max-width: 600px) {
  .u-mt38 {
    margin-top: 19px !important;
  }
}

.u-mb38 {
  margin-bottom: 38px !important;
}
@media screen and (max-width: 600px) {
  .u-mb38 {
    margin-bottom: 19px !important;
  }
}

.u-pt39 {
  padding-top: 39px;
}
@media screen and (max-width: 600px) {
  .u-pt39 {
    padding-top: 19.5px;
  }
}

.u-pb39 {
  padding-bottom: 39px;
}
@media screen and (max-width: 600px) {
  .u-pb39 {
    padding-bottom: 19.5px;
  }
}

.u-mt39 {
  margin-top: 39px !important;
}
@media screen and (max-width: 600px) {
  .u-mt39 {
    margin-top: 19.5px !important;
  }
}

.u-mb39 {
  margin-bottom: 39px !important;
}
@media screen and (max-width: 600px) {
  .u-mb39 {
    margin-bottom: 19.5px !important;
  }
}

.u-pt40 {
  padding-top: 40px;
}
@media screen and (max-width: 600px) {
  .u-pt40 {
    padding-top: 20px;
  }
}

.u-pb40 {
  padding-bottom: 40px;
}
@media screen and (max-width: 600px) {
  .u-pb40 {
    padding-bottom: 20px;
  }
}

.u-mt40 {
  margin-top: 40px !important;
}
@media screen and (max-width: 600px) {
  .u-mt40 {
    margin-top: 20px !important;
  }
}

.u-mb40 {
  margin-bottom: 40px !important;
}
@media screen and (max-width: 600px) {
  .u-mb40 {
    margin-bottom: 20px !important;
  }
}

.u-pt41 {
  padding-top: 41px;
}
@media screen and (max-width: 600px) {
  .u-pt41 {
    padding-top: 20.5px;
  }
}

.u-pb41 {
  padding-bottom: 41px;
}
@media screen and (max-width: 600px) {
  .u-pb41 {
    padding-bottom: 20.5px;
  }
}

.u-mt41 {
  margin-top: 41px !important;
}
@media screen and (max-width: 600px) {
  .u-mt41 {
    margin-top: 20.5px !important;
  }
}

.u-mb41 {
  margin-bottom: 41px !important;
}
@media screen and (max-width: 600px) {
  .u-mb41 {
    margin-bottom: 20.5px !important;
  }
}

.u-pt42 {
  padding-top: 42px;
}
@media screen and (max-width: 600px) {
  .u-pt42 {
    padding-top: 21px;
  }
}

.u-pb42 {
  padding-bottom: 42px;
}
@media screen and (max-width: 600px) {
  .u-pb42 {
    padding-bottom: 21px;
  }
}

.u-mt42 {
  margin-top: 42px !important;
}
@media screen and (max-width: 600px) {
  .u-mt42 {
    margin-top: 21px !important;
  }
}

.u-mb42 {
  margin-bottom: 42px !important;
}
@media screen and (max-width: 600px) {
  .u-mb42 {
    margin-bottom: 21px !important;
  }
}

.u-pt43 {
  padding-top: 43px;
}
@media screen and (max-width: 600px) {
  .u-pt43 {
    padding-top: 21.5px;
  }
}

.u-pb43 {
  padding-bottom: 43px;
}
@media screen and (max-width: 600px) {
  .u-pb43 {
    padding-bottom: 21.5px;
  }
}

.u-mt43 {
  margin-top: 43px !important;
}
@media screen and (max-width: 600px) {
  .u-mt43 {
    margin-top: 21.5px !important;
  }
}

.u-mb43 {
  margin-bottom: 43px !important;
}
@media screen and (max-width: 600px) {
  .u-mb43 {
    margin-bottom: 21.5px !important;
  }
}

.u-pt44 {
  padding-top: 44px;
}
@media screen and (max-width: 600px) {
  .u-pt44 {
    padding-top: 22px;
  }
}

.u-pb44 {
  padding-bottom: 44px;
}
@media screen and (max-width: 600px) {
  .u-pb44 {
    padding-bottom: 22px;
  }
}

.u-mt44 {
  margin-top: 44px !important;
}
@media screen and (max-width: 600px) {
  .u-mt44 {
    margin-top: 22px !important;
  }
}

.u-mb44 {
  margin-bottom: 44px !important;
}
@media screen and (max-width: 600px) {
  .u-mb44 {
    margin-bottom: 22px !important;
  }
}

.u-pt45 {
  padding-top: 45px;
}
@media screen and (max-width: 600px) {
  .u-pt45 {
    padding-top: 22.5px;
  }
}

.u-pb45 {
  padding-bottom: 45px;
}
@media screen and (max-width: 600px) {
  .u-pb45 {
    padding-bottom: 22.5px;
  }
}

.u-mt45 {
  margin-top: 45px !important;
}
@media screen and (max-width: 600px) {
  .u-mt45 {
    margin-top: 22.5px !important;
  }
}

.u-mb45 {
  margin-bottom: 45px !important;
}
@media screen and (max-width: 600px) {
  .u-mb45 {
    margin-bottom: 22.5px !important;
  }
}

.u-pt46 {
  padding-top: 46px;
}
@media screen and (max-width: 600px) {
  .u-pt46 {
    padding-top: 23px;
  }
}

.u-pb46 {
  padding-bottom: 46px;
}
@media screen and (max-width: 600px) {
  .u-pb46 {
    padding-bottom: 23px;
  }
}

.u-mt46 {
  margin-top: 46px !important;
}
@media screen and (max-width: 600px) {
  .u-mt46 {
    margin-top: 23px !important;
  }
}

.u-mb46 {
  margin-bottom: 46px !important;
}
@media screen and (max-width: 600px) {
  .u-mb46 {
    margin-bottom: 23px !important;
  }
}

.u-pt47 {
  padding-top: 47px;
}
@media screen and (max-width: 600px) {
  .u-pt47 {
    padding-top: 23.5px;
  }
}

.u-pb47 {
  padding-bottom: 47px;
}
@media screen and (max-width: 600px) {
  .u-pb47 {
    padding-bottom: 23.5px;
  }
}

.u-mt47 {
  margin-top: 47px !important;
}
@media screen and (max-width: 600px) {
  .u-mt47 {
    margin-top: 23.5px !important;
  }
}

.u-mb47 {
  margin-bottom: 47px !important;
}
@media screen and (max-width: 600px) {
  .u-mb47 {
    margin-bottom: 23.5px !important;
  }
}

.u-pt48 {
  padding-top: 48px;
}
@media screen and (max-width: 600px) {
  .u-pt48 {
    padding-top: 24px;
  }
}

.u-pb48 {
  padding-bottom: 48px;
}
@media screen and (max-width: 600px) {
  .u-pb48 {
    padding-bottom: 24px;
  }
}

.u-mt48 {
  margin-top: 48px !important;
}
@media screen and (max-width: 600px) {
  .u-mt48 {
    margin-top: 24px !important;
  }
}

.u-mb48 {
  margin-bottom: 48px !important;
}
@media screen and (max-width: 600px) {
  .u-mb48 {
    margin-bottom: 24px !important;
  }
}

.u-pt49 {
  padding-top: 49px;
}
@media screen and (max-width: 600px) {
  .u-pt49 {
    padding-top: 24.5px;
  }
}

.u-pb49 {
  padding-bottom: 49px;
}
@media screen and (max-width: 600px) {
  .u-pb49 {
    padding-bottom: 24.5px;
  }
}

.u-mt49 {
  margin-top: 49px !important;
}
@media screen and (max-width: 600px) {
  .u-mt49 {
    margin-top: 24.5px !important;
  }
}

.u-mb49 {
  margin-bottom: 49px !important;
}
@media screen and (max-width: 600px) {
  .u-mb49 {
    margin-bottom: 24.5px !important;
  }
}

.u-pt50 {
  padding-top: 50px;
}
@media screen and (max-width: 600px) {
  .u-pt50 {
    padding-top: 25px;
  }
}

.u-pb50 {
  padding-bottom: 50px;
}
@media screen and (max-width: 600px) {
  .u-pb50 {
    padding-bottom: 25px;
  }
}

.u-mt50 {
  margin-top: 50px !important;
}
@media screen and (max-width: 600px) {
  .u-mt50 {
    margin-top: 25px !important;
  }
}

.u-mb50 {
  margin-bottom: 50px !important;
}
@media screen and (max-width: 600px) {
  .u-mb50 {
    margin-bottom: 25px !important;
  }
}

.u-pt51 {
  padding-top: 51px;
}
@media screen and (max-width: 600px) {
  .u-pt51 {
    padding-top: 25.5px;
  }
}

.u-pb51 {
  padding-bottom: 51px;
}
@media screen and (max-width: 600px) {
  .u-pb51 {
    padding-bottom: 25.5px;
  }
}

.u-mt51 {
  margin-top: 51px !important;
}
@media screen and (max-width: 600px) {
  .u-mt51 {
    margin-top: 25.5px !important;
  }
}

.u-mb51 {
  margin-bottom: 51px !important;
}
@media screen and (max-width: 600px) {
  .u-mb51 {
    margin-bottom: 25.5px !important;
  }
}

.u-pt52 {
  padding-top: 52px;
}
@media screen and (max-width: 600px) {
  .u-pt52 {
    padding-top: 26px;
  }
}

.u-pb52 {
  padding-bottom: 52px;
}
@media screen and (max-width: 600px) {
  .u-pb52 {
    padding-bottom: 26px;
  }
}

.u-mt52 {
  margin-top: 52px !important;
}
@media screen and (max-width: 600px) {
  .u-mt52 {
    margin-top: 26px !important;
  }
}

.u-mb52 {
  margin-bottom: 52px !important;
}
@media screen and (max-width: 600px) {
  .u-mb52 {
    margin-bottom: 26px !important;
  }
}

.u-pt53 {
  padding-top: 53px;
}
@media screen and (max-width: 600px) {
  .u-pt53 {
    padding-top: 26.5px;
  }
}

.u-pb53 {
  padding-bottom: 53px;
}
@media screen and (max-width: 600px) {
  .u-pb53 {
    padding-bottom: 26.5px;
  }
}

.u-mt53 {
  margin-top: 53px !important;
}
@media screen and (max-width: 600px) {
  .u-mt53 {
    margin-top: 26.5px !important;
  }
}

.u-mb53 {
  margin-bottom: 53px !important;
}
@media screen and (max-width: 600px) {
  .u-mb53 {
    margin-bottom: 26.5px !important;
  }
}

.u-pt54 {
  padding-top: 54px;
}
@media screen and (max-width: 600px) {
  .u-pt54 {
    padding-top: 27px;
  }
}

.u-pb54 {
  padding-bottom: 54px;
}
@media screen and (max-width: 600px) {
  .u-pb54 {
    padding-bottom: 27px;
  }
}

.u-mt54 {
  margin-top: 54px !important;
}
@media screen and (max-width: 600px) {
  .u-mt54 {
    margin-top: 27px !important;
  }
}

.u-mb54 {
  margin-bottom: 54px !important;
}
@media screen and (max-width: 600px) {
  .u-mb54 {
    margin-bottom: 27px !important;
  }
}

.u-pt55 {
  padding-top: 55px;
}
@media screen and (max-width: 600px) {
  .u-pt55 {
    padding-top: 27.5px;
  }
}

.u-pb55 {
  padding-bottom: 55px;
}
@media screen and (max-width: 600px) {
  .u-pb55 {
    padding-bottom: 27.5px;
  }
}

.u-mt55 {
  margin-top: 55px !important;
}
@media screen and (max-width: 600px) {
  .u-mt55 {
    margin-top: 27.5px !important;
  }
}

.u-mb55 {
  margin-bottom: 55px !important;
}
@media screen and (max-width: 600px) {
  .u-mb55 {
    margin-bottom: 27.5px !important;
  }
}

.u-pt56 {
  padding-top: 56px;
}
@media screen and (max-width: 600px) {
  .u-pt56 {
    padding-top: 28px;
  }
}

.u-pb56 {
  padding-bottom: 56px;
}
@media screen and (max-width: 600px) {
  .u-pb56 {
    padding-bottom: 28px;
  }
}

.u-mt56 {
  margin-top: 56px !important;
}
@media screen and (max-width: 600px) {
  .u-mt56 {
    margin-top: 28px !important;
  }
}

.u-mb56 {
  margin-bottom: 56px !important;
}
@media screen and (max-width: 600px) {
  .u-mb56 {
    margin-bottom: 28px !important;
  }
}

.u-pt57 {
  padding-top: 57px;
}
@media screen and (max-width: 600px) {
  .u-pt57 {
    padding-top: 28.5px;
  }
}

.u-pb57 {
  padding-bottom: 57px;
}
@media screen and (max-width: 600px) {
  .u-pb57 {
    padding-bottom: 28.5px;
  }
}

.u-mt57 {
  margin-top: 57px !important;
}
@media screen and (max-width: 600px) {
  .u-mt57 {
    margin-top: 28.5px !important;
  }
}

.u-mb57 {
  margin-bottom: 57px !important;
}
@media screen and (max-width: 600px) {
  .u-mb57 {
    margin-bottom: 28.5px !important;
  }
}

.u-pt58 {
  padding-top: 58px;
}
@media screen and (max-width: 600px) {
  .u-pt58 {
    padding-top: 29px;
  }
}

.u-pb58 {
  padding-bottom: 58px;
}
@media screen and (max-width: 600px) {
  .u-pb58 {
    padding-bottom: 29px;
  }
}

.u-mt58 {
  margin-top: 58px !important;
}
@media screen and (max-width: 600px) {
  .u-mt58 {
    margin-top: 29px !important;
  }
}

.u-mb58 {
  margin-bottom: 58px !important;
}
@media screen and (max-width: 600px) {
  .u-mb58 {
    margin-bottom: 29px !important;
  }
}

.u-pt59 {
  padding-top: 59px;
}
@media screen and (max-width: 600px) {
  .u-pt59 {
    padding-top: 29.5px;
  }
}

.u-pb59 {
  padding-bottom: 59px;
}
@media screen and (max-width: 600px) {
  .u-pb59 {
    padding-bottom: 29.5px;
  }
}

.u-mt59 {
  margin-top: 59px !important;
}
@media screen and (max-width: 600px) {
  .u-mt59 {
    margin-top: 29.5px !important;
  }
}

.u-mb59 {
  margin-bottom: 59px !important;
}
@media screen and (max-width: 600px) {
  .u-mb59 {
    margin-bottom: 29.5px !important;
  }
}

.u-pt60 {
  padding-top: 60px;
}
@media screen and (max-width: 600px) {
  .u-pt60 {
    padding-top: 30px;
  }
}

.u-pb60 {
  padding-bottom: 60px;
}
@media screen and (max-width: 600px) {
  .u-pb60 {
    padding-bottom: 30px;
  }
}

.u-mt60 {
  margin-top: 60px !important;
}
@media screen and (max-width: 600px) {
  .u-mt60 {
    margin-top: 30px !important;
  }
}

.u-mb60 {
  margin-bottom: 60px !important;
}
@media screen and (max-width: 600px) {
  .u-mb60 {
    margin-bottom: 30px !important;
  }
}

.u-pt61 {
  padding-top: 61px;
}
@media screen and (max-width: 600px) {
  .u-pt61 {
    padding-top: 30.5px;
  }
}

.u-pb61 {
  padding-bottom: 61px;
}
@media screen and (max-width: 600px) {
  .u-pb61 {
    padding-bottom: 30.5px;
  }
}

.u-mt61 {
  margin-top: 61px !important;
}
@media screen and (max-width: 600px) {
  .u-mt61 {
    margin-top: 30.5px !important;
  }
}

.u-mb61 {
  margin-bottom: 61px !important;
}
@media screen and (max-width: 600px) {
  .u-mb61 {
    margin-bottom: 30.5px !important;
  }
}

.u-pt62 {
  padding-top: 62px;
}
@media screen and (max-width: 600px) {
  .u-pt62 {
    padding-top: 31px;
  }
}

.u-pb62 {
  padding-bottom: 62px;
}
@media screen and (max-width: 600px) {
  .u-pb62 {
    padding-bottom: 31px;
  }
}

.u-mt62 {
  margin-top: 62px !important;
}
@media screen and (max-width: 600px) {
  .u-mt62 {
    margin-top: 31px !important;
  }
}

.u-mb62 {
  margin-bottom: 62px !important;
}
@media screen and (max-width: 600px) {
  .u-mb62 {
    margin-bottom: 31px !important;
  }
}

.u-pt63 {
  padding-top: 63px;
}
@media screen and (max-width: 600px) {
  .u-pt63 {
    padding-top: 31.5px;
  }
}

.u-pb63 {
  padding-bottom: 63px;
}
@media screen and (max-width: 600px) {
  .u-pb63 {
    padding-bottom: 31.5px;
  }
}

.u-mt63 {
  margin-top: 63px !important;
}
@media screen and (max-width: 600px) {
  .u-mt63 {
    margin-top: 31.5px !important;
  }
}

.u-mb63 {
  margin-bottom: 63px !important;
}
@media screen and (max-width: 600px) {
  .u-mb63 {
    margin-bottom: 31.5px !important;
  }
}

.u-pt64 {
  padding-top: 64px;
}
@media screen and (max-width: 600px) {
  .u-pt64 {
    padding-top: 32px;
  }
}

.u-pb64 {
  padding-bottom: 64px;
}
@media screen and (max-width: 600px) {
  .u-pb64 {
    padding-bottom: 32px;
  }
}

.u-mt64 {
  margin-top: 64px !important;
}
@media screen and (max-width: 600px) {
  .u-mt64 {
    margin-top: 32px !important;
  }
}

.u-mb64 {
  margin-bottom: 64px !important;
}
@media screen and (max-width: 600px) {
  .u-mb64 {
    margin-bottom: 32px !important;
  }
}

.u-pt65 {
  padding-top: 65px;
}
@media screen and (max-width: 600px) {
  .u-pt65 {
    padding-top: 32.5px;
  }
}

.u-pb65 {
  padding-bottom: 65px;
}
@media screen and (max-width: 600px) {
  .u-pb65 {
    padding-bottom: 32.5px;
  }
}

.u-mt65 {
  margin-top: 65px !important;
}
@media screen and (max-width: 600px) {
  .u-mt65 {
    margin-top: 32.5px !important;
  }
}

.u-mb65 {
  margin-bottom: 65px !important;
}
@media screen and (max-width: 600px) {
  .u-mb65 {
    margin-bottom: 32.5px !important;
  }
}

.u-pt66 {
  padding-top: 66px;
}
@media screen and (max-width: 600px) {
  .u-pt66 {
    padding-top: 33px;
  }
}

.u-pb66 {
  padding-bottom: 66px;
}
@media screen and (max-width: 600px) {
  .u-pb66 {
    padding-bottom: 33px;
  }
}

.u-mt66 {
  margin-top: 66px !important;
}
@media screen and (max-width: 600px) {
  .u-mt66 {
    margin-top: 33px !important;
  }
}

.u-mb66 {
  margin-bottom: 66px !important;
}
@media screen and (max-width: 600px) {
  .u-mb66 {
    margin-bottom: 33px !important;
  }
}

.u-pt67 {
  padding-top: 67px;
}
@media screen and (max-width: 600px) {
  .u-pt67 {
    padding-top: 33.5px;
  }
}

.u-pb67 {
  padding-bottom: 67px;
}
@media screen and (max-width: 600px) {
  .u-pb67 {
    padding-bottom: 33.5px;
  }
}

.u-mt67 {
  margin-top: 67px !important;
}
@media screen and (max-width: 600px) {
  .u-mt67 {
    margin-top: 33.5px !important;
  }
}

.u-mb67 {
  margin-bottom: 67px !important;
}
@media screen and (max-width: 600px) {
  .u-mb67 {
    margin-bottom: 33.5px !important;
  }
}

.u-pt68 {
  padding-top: 68px;
}
@media screen and (max-width: 600px) {
  .u-pt68 {
    padding-top: 34px;
  }
}

.u-pb68 {
  padding-bottom: 68px;
}
@media screen and (max-width: 600px) {
  .u-pb68 {
    padding-bottom: 34px;
  }
}

.u-mt68 {
  margin-top: 68px !important;
}
@media screen and (max-width: 600px) {
  .u-mt68 {
    margin-top: 34px !important;
  }
}

.u-mb68 {
  margin-bottom: 68px !important;
}
@media screen and (max-width: 600px) {
  .u-mb68 {
    margin-bottom: 34px !important;
  }
}

.u-pt69 {
  padding-top: 69px;
}
@media screen and (max-width: 600px) {
  .u-pt69 {
    padding-top: 34.5px;
  }
}

.u-pb69 {
  padding-bottom: 69px;
}
@media screen and (max-width: 600px) {
  .u-pb69 {
    padding-bottom: 34.5px;
  }
}

.u-mt69 {
  margin-top: 69px !important;
}
@media screen and (max-width: 600px) {
  .u-mt69 {
    margin-top: 34.5px !important;
  }
}

.u-mb69 {
  margin-bottom: 69px !important;
}
@media screen and (max-width: 600px) {
  .u-mb69 {
    margin-bottom: 34.5px !important;
  }
}

.u-pt70 {
  padding-top: 70px;
}
@media screen and (max-width: 600px) {
  .u-pt70 {
    padding-top: 35px;
  }
}

.u-pb70 {
  padding-bottom: 70px;
}
@media screen and (max-width: 600px) {
  .u-pb70 {
    padding-bottom: 35px;
  }
}

.u-mt70 {
  margin-top: 70px !important;
}
@media screen and (max-width: 600px) {
  .u-mt70 {
    margin-top: 35px !important;
  }
}

.u-mb70 {
  margin-bottom: 70px !important;
}
@media screen and (max-width: 600px) {
  .u-mb70 {
    margin-bottom: 35px !important;
  }
}

.u-pt71 {
  padding-top: 71px;
}
@media screen and (max-width: 600px) {
  .u-pt71 {
    padding-top: 35.5px;
  }
}

.u-pb71 {
  padding-bottom: 71px;
}
@media screen and (max-width: 600px) {
  .u-pb71 {
    padding-bottom: 35.5px;
  }
}

.u-mt71 {
  margin-top: 71px !important;
}
@media screen and (max-width: 600px) {
  .u-mt71 {
    margin-top: 35.5px !important;
  }
}

.u-mb71 {
  margin-bottom: 71px !important;
}
@media screen and (max-width: 600px) {
  .u-mb71 {
    margin-bottom: 35.5px !important;
  }
}

.u-pt72 {
  padding-top: 72px;
}
@media screen and (max-width: 600px) {
  .u-pt72 {
    padding-top: 36px;
  }
}

.u-pb72 {
  padding-bottom: 72px;
}
@media screen and (max-width: 600px) {
  .u-pb72 {
    padding-bottom: 36px;
  }
}

.u-mt72 {
  margin-top: 72px !important;
}
@media screen and (max-width: 600px) {
  .u-mt72 {
    margin-top: 36px !important;
  }
}

.u-mb72 {
  margin-bottom: 72px !important;
}
@media screen and (max-width: 600px) {
  .u-mb72 {
    margin-bottom: 36px !important;
  }
}

.u-pt73 {
  padding-top: 73px;
}
@media screen and (max-width: 600px) {
  .u-pt73 {
    padding-top: 36.5px;
  }
}

.u-pb73 {
  padding-bottom: 73px;
}
@media screen and (max-width: 600px) {
  .u-pb73 {
    padding-bottom: 36.5px;
  }
}

.u-mt73 {
  margin-top: 73px !important;
}
@media screen and (max-width: 600px) {
  .u-mt73 {
    margin-top: 36.5px !important;
  }
}

.u-mb73 {
  margin-bottom: 73px !important;
}
@media screen and (max-width: 600px) {
  .u-mb73 {
    margin-bottom: 36.5px !important;
  }
}

.u-pt74 {
  padding-top: 74px;
}
@media screen and (max-width: 600px) {
  .u-pt74 {
    padding-top: 37px;
  }
}

.u-pb74 {
  padding-bottom: 74px;
}
@media screen and (max-width: 600px) {
  .u-pb74 {
    padding-bottom: 37px;
  }
}

.u-mt74 {
  margin-top: 74px !important;
}
@media screen and (max-width: 600px) {
  .u-mt74 {
    margin-top: 37px !important;
  }
}

.u-mb74 {
  margin-bottom: 74px !important;
}
@media screen and (max-width: 600px) {
  .u-mb74 {
    margin-bottom: 37px !important;
  }
}

.u-pt75 {
  padding-top: 75px;
}
@media screen and (max-width: 600px) {
  .u-pt75 {
    padding-top: 37.5px;
  }
}

.u-pb75 {
  padding-bottom: 75px;
}
@media screen and (max-width: 600px) {
  .u-pb75 {
    padding-bottom: 37.5px;
  }
}

.u-mt75 {
  margin-top: 75px !important;
}
@media screen and (max-width: 600px) {
  .u-mt75 {
    margin-top: 37.5px !important;
  }
}

.u-mb75 {
  margin-bottom: 75px !important;
}
@media screen and (max-width: 600px) {
  .u-mb75 {
    margin-bottom: 37.5px !important;
  }
}

.u-pt76 {
  padding-top: 76px;
}
@media screen and (max-width: 600px) {
  .u-pt76 {
    padding-top: 38px;
  }
}

.u-pb76 {
  padding-bottom: 76px;
}
@media screen and (max-width: 600px) {
  .u-pb76 {
    padding-bottom: 38px;
  }
}

.u-mt76 {
  margin-top: 76px !important;
}
@media screen and (max-width: 600px) {
  .u-mt76 {
    margin-top: 38px !important;
  }
}

.u-mb76 {
  margin-bottom: 76px !important;
}
@media screen and (max-width: 600px) {
  .u-mb76 {
    margin-bottom: 38px !important;
  }
}

.u-pt77 {
  padding-top: 77px;
}
@media screen and (max-width: 600px) {
  .u-pt77 {
    padding-top: 38.5px;
  }
}

.u-pb77 {
  padding-bottom: 77px;
}
@media screen and (max-width: 600px) {
  .u-pb77 {
    padding-bottom: 38.5px;
  }
}

.u-mt77 {
  margin-top: 77px !important;
}
@media screen and (max-width: 600px) {
  .u-mt77 {
    margin-top: 38.5px !important;
  }
}

.u-mb77 {
  margin-bottom: 77px !important;
}
@media screen and (max-width: 600px) {
  .u-mb77 {
    margin-bottom: 38.5px !important;
  }
}

.u-pt78 {
  padding-top: 78px;
}
@media screen and (max-width: 600px) {
  .u-pt78 {
    padding-top: 39px;
  }
}

.u-pb78 {
  padding-bottom: 78px;
}
@media screen and (max-width: 600px) {
  .u-pb78 {
    padding-bottom: 39px;
  }
}

.u-mt78 {
  margin-top: 78px !important;
}
@media screen and (max-width: 600px) {
  .u-mt78 {
    margin-top: 39px !important;
  }
}

.u-mb78 {
  margin-bottom: 78px !important;
}
@media screen and (max-width: 600px) {
  .u-mb78 {
    margin-bottom: 39px !important;
  }
}

.u-pt79 {
  padding-top: 79px;
}
@media screen and (max-width: 600px) {
  .u-pt79 {
    padding-top: 39.5px;
  }
}

.u-pb79 {
  padding-bottom: 79px;
}
@media screen and (max-width: 600px) {
  .u-pb79 {
    padding-bottom: 39.5px;
  }
}

.u-mt79 {
  margin-top: 79px !important;
}
@media screen and (max-width: 600px) {
  .u-mt79 {
    margin-top: 39.5px !important;
  }
}

.u-mb79 {
  margin-bottom: 79px !important;
}
@media screen and (max-width: 600px) {
  .u-mb79 {
    margin-bottom: 39.5px !important;
  }
}

.u-pt80 {
  padding-top: 80px;
}
@media screen and (max-width: 600px) {
  .u-pt80 {
    padding-top: 40px;
  }
}

.u-pb80 {
  padding-bottom: 80px;
}
@media screen and (max-width: 600px) {
  .u-pb80 {
    padding-bottom: 40px;
  }
}

.u-mt80 {
  margin-top: 80px !important;
}
@media screen and (max-width: 600px) {
  .u-mt80 {
    margin-top: 40px !important;
  }
}

.u-mb80 {
  margin-bottom: 80px !important;
}
@media screen and (max-width: 600px) {
  .u-mb80 {
    margin-bottom: 40px !important;
  }
}

.u-pt81 {
  padding-top: 81px;
}
@media screen and (max-width: 600px) {
  .u-pt81 {
    padding-top: 40.5px;
  }
}

.u-pb81 {
  padding-bottom: 81px;
}
@media screen and (max-width: 600px) {
  .u-pb81 {
    padding-bottom: 40.5px;
  }
}

.u-mt81 {
  margin-top: 81px !important;
}
@media screen and (max-width: 600px) {
  .u-mt81 {
    margin-top: 40.5px !important;
  }
}

.u-mb81 {
  margin-bottom: 81px !important;
}
@media screen and (max-width: 600px) {
  .u-mb81 {
    margin-bottom: 40.5px !important;
  }
}

.u-pt82 {
  padding-top: 82px;
}
@media screen and (max-width: 600px) {
  .u-pt82 {
    padding-top: 41px;
  }
}

.u-pb82 {
  padding-bottom: 82px;
}
@media screen and (max-width: 600px) {
  .u-pb82 {
    padding-bottom: 41px;
  }
}

.u-mt82 {
  margin-top: 82px !important;
}
@media screen and (max-width: 600px) {
  .u-mt82 {
    margin-top: 41px !important;
  }
}

.u-mb82 {
  margin-bottom: 82px !important;
}
@media screen and (max-width: 600px) {
  .u-mb82 {
    margin-bottom: 41px !important;
  }
}

.u-pt83 {
  padding-top: 83px;
}
@media screen and (max-width: 600px) {
  .u-pt83 {
    padding-top: 41.5px;
  }
}

.u-pb83 {
  padding-bottom: 83px;
}
@media screen and (max-width: 600px) {
  .u-pb83 {
    padding-bottom: 41.5px;
  }
}

.u-mt83 {
  margin-top: 83px !important;
}
@media screen and (max-width: 600px) {
  .u-mt83 {
    margin-top: 41.5px !important;
  }
}

.u-mb83 {
  margin-bottom: 83px !important;
}
@media screen and (max-width: 600px) {
  .u-mb83 {
    margin-bottom: 41.5px !important;
  }
}

.u-pt84 {
  padding-top: 84px;
}
@media screen and (max-width: 600px) {
  .u-pt84 {
    padding-top: 42px;
  }
}

.u-pb84 {
  padding-bottom: 84px;
}
@media screen and (max-width: 600px) {
  .u-pb84 {
    padding-bottom: 42px;
  }
}

.u-mt84 {
  margin-top: 84px !important;
}
@media screen and (max-width: 600px) {
  .u-mt84 {
    margin-top: 42px !important;
  }
}

.u-mb84 {
  margin-bottom: 84px !important;
}
@media screen and (max-width: 600px) {
  .u-mb84 {
    margin-bottom: 42px !important;
  }
}

.u-pt85 {
  padding-top: 85px;
}
@media screen and (max-width: 600px) {
  .u-pt85 {
    padding-top: 42.5px;
  }
}

.u-pb85 {
  padding-bottom: 85px;
}
@media screen and (max-width: 600px) {
  .u-pb85 {
    padding-bottom: 42.5px;
  }
}

.u-mt85 {
  margin-top: 85px !important;
}
@media screen and (max-width: 600px) {
  .u-mt85 {
    margin-top: 42.5px !important;
  }
}

.u-mb85 {
  margin-bottom: 85px !important;
}
@media screen and (max-width: 600px) {
  .u-mb85 {
    margin-bottom: 42.5px !important;
  }
}

.u-pt86 {
  padding-top: 86px;
}
@media screen and (max-width: 600px) {
  .u-pt86 {
    padding-top: 43px;
  }
}

.u-pb86 {
  padding-bottom: 86px;
}
@media screen and (max-width: 600px) {
  .u-pb86 {
    padding-bottom: 43px;
  }
}

.u-mt86 {
  margin-top: 86px !important;
}
@media screen and (max-width: 600px) {
  .u-mt86 {
    margin-top: 43px !important;
  }
}

.u-mb86 {
  margin-bottom: 86px !important;
}
@media screen and (max-width: 600px) {
  .u-mb86 {
    margin-bottom: 43px !important;
  }
}

.u-pt87 {
  padding-top: 87px;
}
@media screen and (max-width: 600px) {
  .u-pt87 {
    padding-top: 43.5px;
  }
}

.u-pb87 {
  padding-bottom: 87px;
}
@media screen and (max-width: 600px) {
  .u-pb87 {
    padding-bottom: 43.5px;
  }
}

.u-mt87 {
  margin-top: 87px !important;
}
@media screen and (max-width: 600px) {
  .u-mt87 {
    margin-top: 43.5px !important;
  }
}

.u-mb87 {
  margin-bottom: 87px !important;
}
@media screen and (max-width: 600px) {
  .u-mb87 {
    margin-bottom: 43.5px !important;
  }
}

.u-pt88 {
  padding-top: 88px;
}
@media screen and (max-width: 600px) {
  .u-pt88 {
    padding-top: 44px;
  }
}

.u-pb88 {
  padding-bottom: 88px;
}
@media screen and (max-width: 600px) {
  .u-pb88 {
    padding-bottom: 44px;
  }
}

.u-mt88 {
  margin-top: 88px !important;
}
@media screen and (max-width: 600px) {
  .u-mt88 {
    margin-top: 44px !important;
  }
}

.u-mb88 {
  margin-bottom: 88px !important;
}
@media screen and (max-width: 600px) {
  .u-mb88 {
    margin-bottom: 44px !important;
  }
}

.u-pt89 {
  padding-top: 89px;
}
@media screen and (max-width: 600px) {
  .u-pt89 {
    padding-top: 44.5px;
  }
}

.u-pb89 {
  padding-bottom: 89px;
}
@media screen and (max-width: 600px) {
  .u-pb89 {
    padding-bottom: 44.5px;
  }
}

.u-mt89 {
  margin-top: 89px !important;
}
@media screen and (max-width: 600px) {
  .u-mt89 {
    margin-top: 44.5px !important;
  }
}

.u-mb89 {
  margin-bottom: 89px !important;
}
@media screen and (max-width: 600px) {
  .u-mb89 {
    margin-bottom: 44.5px !important;
  }
}

.u-pt90 {
  padding-top: 90px;
}
@media screen and (max-width: 600px) {
  .u-pt90 {
    padding-top: 45px;
  }
}

.u-pb90 {
  padding-bottom: 90px;
}
@media screen and (max-width: 600px) {
  .u-pb90 {
    padding-bottom: 45px;
  }
}

.u-mt90 {
  margin-top: 90px !important;
}
@media screen and (max-width: 600px) {
  .u-mt90 {
    margin-top: 45px !important;
  }
}

.u-mb90 {
  margin-bottom: 90px !important;
}
@media screen and (max-width: 600px) {
  .u-mb90 {
    margin-bottom: 45px !important;
  }
}

.u-pt91 {
  padding-top: 91px;
}
@media screen and (max-width: 600px) {
  .u-pt91 {
    padding-top: 45.5px;
  }
}

.u-pb91 {
  padding-bottom: 91px;
}
@media screen and (max-width: 600px) {
  .u-pb91 {
    padding-bottom: 45.5px;
  }
}

.u-mt91 {
  margin-top: 91px !important;
}
@media screen and (max-width: 600px) {
  .u-mt91 {
    margin-top: 45.5px !important;
  }
}

.u-mb91 {
  margin-bottom: 91px !important;
}
@media screen and (max-width: 600px) {
  .u-mb91 {
    margin-bottom: 45.5px !important;
  }
}

.u-pt92 {
  padding-top: 92px;
}
@media screen and (max-width: 600px) {
  .u-pt92 {
    padding-top: 46px;
  }
}

.u-pb92 {
  padding-bottom: 92px;
}
@media screen and (max-width: 600px) {
  .u-pb92 {
    padding-bottom: 46px;
  }
}

.u-mt92 {
  margin-top: 92px !important;
}
@media screen and (max-width: 600px) {
  .u-mt92 {
    margin-top: 46px !important;
  }
}

.u-mb92 {
  margin-bottom: 92px !important;
}
@media screen and (max-width: 600px) {
  .u-mb92 {
    margin-bottom: 46px !important;
  }
}

.u-pt93 {
  padding-top: 93px;
}
@media screen and (max-width: 600px) {
  .u-pt93 {
    padding-top: 46.5px;
  }
}

.u-pb93 {
  padding-bottom: 93px;
}
@media screen and (max-width: 600px) {
  .u-pb93 {
    padding-bottom: 46.5px;
  }
}

.u-mt93 {
  margin-top: 93px !important;
}
@media screen and (max-width: 600px) {
  .u-mt93 {
    margin-top: 46.5px !important;
  }
}

.u-mb93 {
  margin-bottom: 93px !important;
}
@media screen and (max-width: 600px) {
  .u-mb93 {
    margin-bottom: 46.5px !important;
  }
}

.u-pt94 {
  padding-top: 94px;
}
@media screen and (max-width: 600px) {
  .u-pt94 {
    padding-top: 47px;
  }
}

.u-pb94 {
  padding-bottom: 94px;
}
@media screen and (max-width: 600px) {
  .u-pb94 {
    padding-bottom: 47px;
  }
}

.u-mt94 {
  margin-top: 94px !important;
}
@media screen and (max-width: 600px) {
  .u-mt94 {
    margin-top: 47px !important;
  }
}

.u-mb94 {
  margin-bottom: 94px !important;
}
@media screen and (max-width: 600px) {
  .u-mb94 {
    margin-bottom: 47px !important;
  }
}

.u-pt95 {
  padding-top: 95px;
}
@media screen and (max-width: 600px) {
  .u-pt95 {
    padding-top: 47.5px;
  }
}

.u-pb95 {
  padding-bottom: 95px;
}
@media screen and (max-width: 600px) {
  .u-pb95 {
    padding-bottom: 47.5px;
  }
}

.u-mt95 {
  margin-top: 95px !important;
}
@media screen and (max-width: 600px) {
  .u-mt95 {
    margin-top: 47.5px !important;
  }
}

.u-mb95 {
  margin-bottom: 95px !important;
}
@media screen and (max-width: 600px) {
  .u-mb95 {
    margin-bottom: 47.5px !important;
  }
}

.u-pt96 {
  padding-top: 96px;
}
@media screen and (max-width: 600px) {
  .u-pt96 {
    padding-top: 48px;
  }
}

.u-pb96 {
  padding-bottom: 96px;
}
@media screen and (max-width: 600px) {
  .u-pb96 {
    padding-bottom: 48px;
  }
}

.u-mt96 {
  margin-top: 96px !important;
}
@media screen and (max-width: 600px) {
  .u-mt96 {
    margin-top: 48px !important;
  }
}

.u-mb96 {
  margin-bottom: 96px !important;
}
@media screen and (max-width: 600px) {
  .u-mb96 {
    margin-bottom: 48px !important;
  }
}

.u-pt97 {
  padding-top: 97px;
}
@media screen and (max-width: 600px) {
  .u-pt97 {
    padding-top: 48.5px;
  }
}

.u-pb97 {
  padding-bottom: 97px;
}
@media screen and (max-width: 600px) {
  .u-pb97 {
    padding-bottom: 48.5px;
  }
}

.u-mt97 {
  margin-top: 97px !important;
}
@media screen and (max-width: 600px) {
  .u-mt97 {
    margin-top: 48.5px !important;
  }
}

.u-mb97 {
  margin-bottom: 97px !important;
}
@media screen and (max-width: 600px) {
  .u-mb97 {
    margin-bottom: 48.5px !important;
  }
}

.u-pt98 {
  padding-top: 98px;
}
@media screen and (max-width: 600px) {
  .u-pt98 {
    padding-top: 49px;
  }
}

.u-pb98 {
  padding-bottom: 98px;
}
@media screen and (max-width: 600px) {
  .u-pb98 {
    padding-bottom: 49px;
  }
}

.u-mt98 {
  margin-top: 98px !important;
}
@media screen and (max-width: 600px) {
  .u-mt98 {
    margin-top: 49px !important;
  }
}

.u-mb98 {
  margin-bottom: 98px !important;
}
@media screen and (max-width: 600px) {
  .u-mb98 {
    margin-bottom: 49px !important;
  }
}

.u-pt99 {
  padding-top: 99px;
}
@media screen and (max-width: 600px) {
  .u-pt99 {
    padding-top: 49.5px;
  }
}

.u-pb99 {
  padding-bottom: 99px;
}
@media screen and (max-width: 600px) {
  .u-pb99 {
    padding-bottom: 49.5px;
  }
}

.u-mt99 {
  margin-top: 99px !important;
}
@media screen and (max-width: 600px) {
  .u-mt99 {
    margin-top: 49.5px !important;
  }
}

.u-mb99 {
  margin-bottom: 99px !important;
}
@media screen and (max-width: 600px) {
  .u-mb99 {
    margin-bottom: 49.5px !important;
  }
}

.u-pt100 {
  padding-top: 100px;
}
@media screen and (max-width: 600px) {
  .u-pt100 {
    padding-top: 50px;
  }
}

.u-pb100 {
  padding-bottom: 100px;
}
@media screen and (max-width: 600px) {
  .u-pb100 {
    padding-bottom: 50px;
  }
}

.u-mt100 {
  margin-top: 100px !important;
}
@media screen and (max-width: 600px) {
  .u-mt100 {
    margin-top: 50px !important;
  }
}

.u-mb100 {
  margin-bottom: 100px !important;
}
@media screen and (max-width: 600px) {
  .u-mb100 {
    margin-bottom: 50px !important;
  }
}

/*------------------------------------*\
    RESET
\*------------------------------------*/
/* global box-sizing */
* {
  box-sizing: border-box;
}

*,
*:after,
*:before {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* clear */
.clear {
  zoom: 1;
}
.clear:before {
  content: " ";
  display: block;
}
.clear:after {
  content: " ";
  display: block;
  clear: both;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}
img[src$=".svg"] {
  width: 100%;
}

a {
  color: #311703;
  text-decoration: none;
}

button {
  background: transparent;
  font-size: min(5.4vw, 1.8rem);
  display: block;
  border: none;
  box-shadow: none;
  color: #311703;
  cursor: pointer;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック", "Hiragino Sans", "Helvetica Neue", "Helvetica", "Arial", "sans-serif";
}

input:focus {
  outline: 0;
  border: 1px solid #04A4CC;
}

h1, h2, h3, h4, h5,
p, table, ul, ol, dl, dd, dt {
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
  font-size: 1.8rem;
}

html {
  position: relative;
  font-size: 62.5%;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}
@media screen and (max-width: 834px) {
  html {
    font-size: 52.5%;
  }
}

p {
  font-size: min(5.4vw, 1.8rem);
  line-height: 1.5;
}

h2 {
  font-size: min(5.4vw, 2.2rem);
  font-weight: bold;
  letter-spacing: 5px;
}

h4 {
  font-size: min(5.4vw, 2rem);
  font-weight: bold;
  line-height: 1.5;
}

body {
  position: relative;
  font-family: "ヒラギノ角ゴシック", "Hiragino Sans", "Helvetica Neue", "Helvetica", "Arial", "sans-serif", "Noto Sans JP";
  font-weight: 400;
  line-height: 1.5;
  color: #311703;
  width: 100%;
  max-width: 100%;
  display: block;
  margin: 0;
  overflow-x: hidden;
}

main {
  display: block;
  width: 100%;
  max-width: 100%;
  padding-bottom: 5rem;
}
@media screen and (max-width: 600px) {
  main {
    padding-bottom: 15rem;
  }
}

address {
  font-style: normal;
  font-size: min(5.4vw, 1.6rem);
}

html {
  scroll-behavior: smooth;
}

/* index.html TOP */
.main-visual {
  position: relative;
  background-size: cover;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  height: 920px;
}
.main-visual__slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.main-visual__content {
  position: relative;
  z-index: 2;
  padding: 0 1rem;
}
.main-visual-img {
  position: absolute;
  width: 90%;
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center bottom;
  opacity: 0;
  transition: opacity 1.5s ease;
  transform: translateY(0);
  z-index: 1;
  top: 0;
  right: 0;
}
.main-visual-img:nth-child(1) {
  background-image: url("../img/main-01.png");
}
.main-visual-img:nth-child(2) {
  background-image: url("../img/main-02.png");
}
.main-visual-img:nth-child(3) {
  background-image: url("../img/main-03.png");
}
@media (max-width: 1024px) {
  .main-visual-img:nth-child(1) {
    background-image: url("../img/main-01-tb.jpg");
  }
  .main-visual-img:nth-child(2) {
    background-image: url("../img/main-02-tb.jpg");
  }
  .main-visual-img:nth-child(3) {
    background-image: url("../img/main-03-tb.jpg");
  }
}
@media (max-width: 600px) {
  .main-visual-img:nth-child(1) {
    background-image: url("../img/main-01-sp.jpg");
  }
  .main-visual-img:nth-child(2) {
    background-image: url("../img/main-02-sp.jpg");
  }
  .main-visual-img:nth-child(3) {
    background-image: url("../img/main-03-sp.jpg");
  }
}
.main-visual-img.active {
  opacity: 1;
  z-index: 2;
}
.main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
  position: relative;
  color: transparent;
  overflow: hidden;
  font-size: 5.2rem;
  font-weight: 700;
  text-align: left;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  background-color: #ffffff;
  z-index: 5;
  padding: 10px;
  box-sizing: content-box;
}
.main-visual-title-1::before, .main-visual-title-2::before, .main-visual-title-3::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  display: inline-block;
  width: 0;
  height: 100%;
  background-color: #30a520;
}
.main-visual .active .catch-copy {
  animation: textAnime forwards 1.5s 1 ease 0.5s normal;
}
.main-visual .active .catch-copy::before {
  animation: titleAnime forwards 1.5s 1 ease 0.1s normal;
}
.main-visual-title-1 {
  right: 130%;
  margin-top: -30%;
  margin-bottom: 20px;
}
.main-visual-title-2 {
  right: 95%;
  display: inline;
  padding: 13px;
}
.main-visual-title-3 {
  right: 100%;
  margin-top: 20px;
}
.main-visual .dots {
  position: absolute;
  left: 12%;
  bottom: 15%;
  z-index: 5;
}
.main-visual .dots .dot {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 12px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  position: relative;
}
.main-visual .dots .dot::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid rgb(180, 180, 180);
  background-color: transparent;
  box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
}
.main-visual .dots .dot.active::before {
  background-color: rgb(80, 80, 80);
  border-color: rgb(80, 80, 80);
}
@media (max-width: 1750px) {
  .main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
    font-size: 4rem;
  }
  .main-visual-title-1 {
    right: 100%;
  }
  .main-visual-title-2 {
    right: 70%;
  }
  .main-visual-title-3 {
    right: 80%;
  }
  .main-visual .main-visual-img {
    width: 92%;
    height: 95%;
  }
}
@media (max-width: 1680px) {
  .main-visual .main-visual-img {
    width: 100%;
    height: 100%;
  }
  .main-visual .dots {
    bottom: 8%;
  }
}
@media (max-width: 1680px) {
  .main-visual .main-visual-img {
    height: 80%;
  }
  .main-visual .dots {
    bottom: 22%;
  }
  .main-visual .scroll {
    top: 76vh;
  }
}
@media (max-width: 1200px) {
  .main-visual .dots {
    bottom: 3%;
    left: 9%;
  }
  .main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
    font-size: 4rem;
  }
  .main-visual-title-1 {
    right: 85%;
    margin-top: -45%;
  }
  .main-visual-title-2 {
    right: 55%;
  }
  .main-visual-title-3 {
    right: 65%;
  }
}
@media (max-width: 1111px) {
  .main-visual-title-1 {
    right: 80%;
    margin-top: -45%;
  }
  .main-visual-title-2 {
    right: 60%;
  }
  .main-visual-title-3 {
    right: 75%;
  }
}
@media (max-width: 1024px) {
  .main-visual .dots {
    display: none;
  }
  .main-visual .main-visual {
    height: calc(var(--vh, 1vh) * 100);
    background-size: cover;
  }
  .main-visual .main-visual-img {
    height: 120%;
    background-size: cover;
  }
  .main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
    font-size: 5rem;
  }
  .main-visual-title-1 {
    margin-top: 50dvh;
    right: 0;
  }
  .main-visual-title-2 {
    right: 0;
  }
  .main-visual-title-3 {
    right: 0;
  }
}
@media (max-width: 834px) {
  .main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
    font-size: 6rem;
  }
}
@media (max-width: 768px) {
  .main-visual .main-visual-img {
    height: 100%;
  }
}
@media (max-width: 700px) {
  .main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
    font-size: 4.5rem;
  }
}
@media (max-width: 600px) {
  .main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
    font-size: 3.5rem;
  }
}
@media (max-width: 440px) {
  .main-visual .main-visual-img {
    height: 90%;
    top: -40px;
  }
  .main-visual .main-visual-title-1 {
    margin-top: 15dvh;
  }
  .main-visual-title-1, .main-visual-title-2, .main-visual-title-3 {
    font-size: 3.5rem;
  }
}
@media (max-width: 360px) {
  .main-visual .main-visual-title-1 {
    margin-top: 12dvh;
  }
}

@keyframes titleAnime {
  0% {
    left: 0;
    width: 0;
  }
  50% {
    left: 0;
    width: 100%;
  }
  51% {
    left: 0;
    width: 100%;
  }
  60% {
    left: 0;
    width: 100%;
  }
  100% {
    left: 100%;
    width: 0;
  }
}
@keyframes textAnime {
  0% {
    color: transparent;
  }
  40% {
    color: transparent;
  }
  100% {
    color: #000000;
  }
}
.scroll {
  position: absolute;
  left: 5%;
  top: 70%;
  font-family: "Montserrat", sans-serif;
  font-size: 1.5rem;
  color: #000;
  letter-spacing: 0.2em;
  z-index: 100;
  display: flex;
  align-items: center;
  writing-mode: vertical-rl;
  gap: 5px;
}
.scroll .scroll-text {
  font-size: 1.5rem;
  letter-spacing: 0.2em;
  font-weight: 500;
  color: #000;
  margin: 0;
}
.scroll .scroll-arrow {
  transform-origin: center;
  position: relative;
  width: 1px;
  height: 30px;
  background-color: #000;
  top: 20px;
  animation: scrollMove 2s ease-in-out infinite;
  opacity: 0;
  position: relative;
}
.scroll .scroll-arrow::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid #000;
}
.scroll .scroll-bar {
  display: block;
  width: 20px;
  height: 40px;
  background-color: transparent;
  border: 1px solid #000;
  border-radius: 9999px;
}

@keyframes scrollMove {
  0% {
    transform: translateY(-20px);
    opacity: 0;
  }
  30% {
    opacity: 1;
  }
  70% {
    opacity: 1;
  }
  100% {
    transform: translateY(10px);
    opacity: 0;
  }
}
@media (max-width: 1680px) {
  .scroll {
    top: 80vh;
  }
}
@media (max-width: 1024px) {
  .scroll {
    color: #ffffff;
    top: 70vh;
  }
  .scroll .scroll-text {
    color: #ffffff;
  }
  .scroll .scroll-arrow {
    background-color: #ffffff;
  }
  .scroll .scroll-arrow::after {
    border-top: 5px solid #ffffff;
  }
  .scroll .scroll-bar {
    border: 1px solid #ffffff;
  }
}
/* concept */
.concept-background {
  display: flex;
  width: 100%;
  height: auto;
}
.concept-background-left-background, .concept-background-right-background {
  flex: 1;
  position: relative;
  min-height: 350px;
  overflow: visible;
}
.concept-background .background-circle {
  position: absolute;
  width: 350px;
  height: 350px;
  border-radius: 50%;
  background-image: linear-gradient(90deg, #ff5377, #ffa500);
  z-index: 0;
  opacity: 0.8;
}
.concept-background-left-background .background-circle {
  top: 4%;
  left: -54px;
}
.concept-background-right-background .background-circle {
  top: 116%;
  right: -30px;
}
.concept-background .left-image,
.concept-background .right-image {
  position: absolute;
  top: 0;
  height: 100%;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
  z-index: 1;
  opacity: 0;
}
.concept-background .left-image {
  left: -50px;
}
.concept-background .right-image {
  right: -30px;
  top: 120%;
}

.concept-center-area {
  position: relative;
  width: -moz-max-content;
  width: max-content;
  margin: 0 auto;
  opacity: 0;
  /* 右下 */
}
.concept-center-area .concept-center-message {
  font-size: 4rem;
  color: #000000;
  text-align: center;
  position: relative;
  z-index: 3;
  opacity: 0;
  margin-top: -15%;
}
@keyframes stretch-horizontal {
  0% {
    transform: scaleX(0);
  }
  100% {
    transform: scaleX(1);
  }
}
@keyframes stretch-vertical {
  0% {
    transform: scaleY(0);
  }
  100% {
    transform: scaleY(1);
  }
}
.concept-center-area .corner-top-left,
.concept-center-area .corner-top-right,
.concept-center-area .corner-bottom-left,
.concept-center-area .corner-bottom-right {
  position: absolute;
  width: 5em;
  height: 5em;
  z-index: 1;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  color: #8fcd00;
}
.concept-center-area .corner-top-left {
  top: -50%;
  left: -20%;
}
.concept-center-area .corner-top-left::before, .concept-center-area .corner-top-left::after {
  content: "";
  position: absolute;
  background-color: currentColor;
}
.concept-center-area .corner-top-left::before {
  top: 0;
  left: 0;
  width: 6em;
  height: 0.5em;
  transform-origin: left;
}
.concept-center-area .corner-top-left::after {
  top: 0;
  left: 0;
  width: 0.5em;
  height: 6em;
  transform-origin: top;
}
.concept-center-area .corner-top-right {
  top: -50%;
  right: -20%;
}
.concept-center-area .corner-top-right::before, .concept-center-area .corner-top-right::after {
  content: "";
  position: absolute;
  background-color: currentColor;
}
.concept-center-area .corner-top-right::before {
  top: 0;
  right: 0;
  width: 6em;
  height: 0.5em;
  transform-origin: right;
}
.concept-center-area .corner-top-right::after {
  top: 0;
  right: 0;
  width: 0.5em;
  height: 6em;
  transform-origin: top;
}
.concept-center-area .corner-bottom-left {
  bottom: -50%;
  left: -20%;
}
.concept-center-area .corner-bottom-left::before, .concept-center-area .corner-bottom-left::after {
  content: "";
  position: absolute;
  background-color: currentColor;
}
.concept-center-area .corner-bottom-left::before {
  bottom: 0;
  left: 0;
  width: 6em;
  height: 0.5em;
  transform-origin: left;
}
.concept-center-area .corner-bottom-left::after {
  bottom: 0;
  left: 0;
  width: 0.5em;
  height: 6em;
  transform-origin: bottom;
}
.concept-center-area .corner-bottom-right {
  bottom: -50%;
  right: -20%;
}
.concept-center-area .corner-bottom-right::before, .concept-center-area .corner-bottom-right::after {
  content: "";
  position: absolute;
  background-color: currentColor;
}
.concept-center-area .corner-bottom-right::before {
  bottom: 0;
  right: 0;
  width: 6em;
  height: 0.5em;
  transform-origin: right;
}
.concept-center-area .corner-bottom-right::after {
  bottom: 0;
  right: 0;
  width: 0.5em;
  height: 6em;
  transform-origin: bottom;
}
.concept-center-area.is-visible {
  opacity: 1;
}
.concept-center-area.is-visible .corner-top-left::before {
  animation: stretch-horizontal 2s 0s ease-out forwards;
}
.concept-center-area.is-visible .corner-top-left::after {
  animation: stretch-vertical 2s 0s ease-out forwards;
}
.concept-center-area.is-visible .corner-top-right::before {
  animation: stretch-horizontal 2s 0s ease-out forwards;
}
.concept-center-area.is-visible .corner-top-right::after {
  animation: stretch-vertical 2s 0s ease-out forwards;
}
.concept-center-area.is-visible .corner-bottom-left::before {
  animation: stretch-horizontal 2s 0s ease-out forwards;
}
.concept-center-area.is-visible .corner-bottom-left::after {
  animation: stretch-vertical 2s 0s ease-out forwards;
}
.concept-center-area.is-visible .corner-bottom-right::before {
  animation: stretch-horizontal 2s 0s ease-out forwards;
}
.concept-center-area.is-visible .corner-bottom-right::after {
  animation: stretch-vertical 2s 0s ease-out forwards;
}

.concept-subtext {
  opacity: 0;
  position: relative;
  z-index: 4;
  text-align: center;
  font-size: 2.5rem;
  font-weight: bold;
  color: #333;
  margin-top: 10%;
}

@media (max-width: 1440px) {
  .concept-background .concept-background-left-background .background-circle {
    top: 5%;
    left: -50px;
  }
  .concept-background .concept-background-right-background .background-circle {
    top: 105%;
    right: -28px;
  }
  .concept-background .left-image {
    left: -45px;
  }
  .concept-background .right-image {
    right: -25px;
    top: 110%;
  }
  .concept-center-area .concept-center-message {
    font-size: 3.2rem;
    top: 18%;
  }
  .concept-center-area .corner-top-left,
  .concept-center-area .corner-top-right,
  .concept-center-area .corner-bottom-left,
  .concept-center-area .corner-bottom-right {
    width: 4em;
    height: 4em;
  }
  .concept-center-area .corner-top-left::before,
  .concept-center-area .corner-top-right::before,
  .concept-center-area .corner-bottom-left::before,
  .concept-center-area .corner-bottom-right::before {
    width: 4.8em;
    height: 0.4em;
  }
  .concept-center-area .corner-top-left::after,
  .concept-center-area .corner-top-right::after,
  .concept-center-area .corner-bottom-left::after,
  .concept-center-area .corner-bottom-right::after {
    width: 0.4em;
    height: 4.8em;
  }
  .concept-subtext {
    font-size: 2rem;
    margin-top: 12%;
  }
}
@media (max-width: 1024px) {
  .concept-background .concept-background-left-background {
    margin-top: 300px;
  }
  .concept-background .concept-background-left-background .background-circle {
    top: 5%;
    left: -50px;
  }
  .concept-background .concept-background-right-background {
    margin-top: 300px;
  }
  .concept-background .concept-background-right-background .background-circle {
    top: 105%;
    right: -28px;
  }
  .concept-background .left-image {
    left: -45px;
    height: 70%;
  }
  .concept-background .right-image {
    right: -25px;
    top: 110%;
    height: 70%;
  }
  .concept-background .background-circle {
    width: 245px;
    height: 245px;
  }
  .concept-center-area .concept-center-message {
    font-size: 2.6rem;
    top: 16%;
  }
  .concept-center-area .corner-top-left,
  .concept-center-area .corner-top-right,
  .concept-center-area .corner-bottom-left,
  .concept-center-area .corner-bottom-right {
    width: 3.6em;
    height: 3.6em;
  }
  .concept-center-area .corner-top-left::before,
  .concept-center-area .corner-top-right::before,
  .concept-center-area .corner-bottom-left::before,
  .concept-center-area .corner-bottom-right::before {
    width: 4.3em;
    height: 0.45em;
  }
  .concept-center-area .corner-top-left::after,
  .concept-center-area .corner-top-right::after,
  .concept-center-area .corner-bottom-left::after,
  .concept-center-area .corner-bottom-right::after {
    width: 0.45em;
    height: 4.3em;
  }
  .concept-subtext {
    font-size: 1.8rem;
    margin-top: 15%;
    margin-bottom: 20%;
  }
}
@media (max-width: 767px) {
  .concept-background .background-circle {
    width: 193px;
    height: 193px;
  }
  .concept-background .concept-background-left-background .background-circle {
    top: -4%;
    left: -49px;
  }
  .concept-background .concept-background-right-background .background-circle {
    top: 168%;
    right: -32px;
  }
  .concept-background .left-image {
    left: -50px;
    top: 0;
    height: 55%;
  }
  .concept-background .right-image {
    right: -30px;
    top: 165%;
    height: 55%;
    z-index: 1;
  }
  .concept-center-area .concept-center-message {
    font-size: 2.5rem;
    margin-top: -30%;
    text-shadow: 0 0 3px #fff, 0 0 6px #fff;
  }
  .concept-center-area .corner-top-left,
  .concept-center-area .corner-top-right,
  .concept-center-area .corner-bottom-left,
  .concept-center-area .corner-bottom-right {
    width: 3em;
    height: 3em;
  }
  .concept-center-area .corner-top-left.corner-top-left,
  .concept-center-area .corner-top-right.corner-top-left,
  .concept-center-area .corner-bottom-left.corner-top-left,
  .concept-center-area .corner-bottom-right.corner-top-left {
    top: -50px;
    left: -50px;
  }
  .concept-center-area .corner-top-left.corner-top-right,
  .concept-center-area .corner-top-right.corner-top-right,
  .concept-center-area .corner-bottom-left.corner-top-right,
  .concept-center-area .corner-bottom-right.corner-top-right {
    top: -50px;
    right: -50px;
  }
  .concept-center-area .corner-top-left.corner-bottom-left,
  .concept-center-area .corner-top-right.corner-bottom-left,
  .concept-center-area .corner-bottom-left.corner-bottom-left,
  .concept-center-area .corner-bottom-right.corner-bottom-left {
    bottom: -50px;
    left: -50px;
  }
  .concept-center-area .corner-top-left.corner-bottom-right,
  .concept-center-area .corner-top-right.corner-bottom-right,
  .concept-center-area .corner-bottom-left.corner-bottom-right,
  .concept-center-area .corner-bottom-right.corner-bottom-right {
    bottom: -50px;
    right: -50px;
  }
  .concept-center-area .corner-top-left::before,
  .concept-center-area .corner-top-right::before,
  .concept-center-area .corner-bottom-left::before,
  .concept-center-area .corner-bottom-right::before {
    width: 3.6em;
    height: 0.6em;
  }
  .concept-center-area .corner-top-left::after,
  .concept-center-area .corner-top-right::after,
  .concept-center-area .corner-bottom-left::after,
  .concept-center-area .corner-bottom-right::after {
    width: 0.6em;
    height: 3.6em;
  }
  .concept-subtext {
    font-size: 1.6rem;
    margin-top: 20%;
    margin-bottom: 40%;
    position: relative;
    z-index: 3;
    text-shadow: 0 0 3px #fff, 0 0 6px #fff;
  }
}
@media (max-width: 460px) {
  .concept-background {
    margin-top: -260px;
  }
  .concept-background .concept-background-left-background .background-circle {
    top: -20%;
    left: -50px;
  }
  .concept-background .concept-background-right-background .background-circle {
    top: 145%;
    right: -33px;
  }
  .concept-background .background-circle {
    width: 193px;
    height: 193px;
  }
  .concept-background .left-image {
    top: -60px;
  }
  .concept-background .right-image {
    top: 500px;
    z-index: 1;
  }
  .concept-center-area .concept-center-message {
    font-size: 1.5rem;
    margin-top: -60%;
    word-break: keep-all;
    padding: 5px;
    text-shadow: 0 0 3px #fff, 0 0 6px #fff;
  }
  .concept-center-area .corner-top-left,
  .concept-center-area .corner-top-right,
  .concept-center-area .corner-bottom-left,
  .concept-center-area .corner-bottom-right {
    width: 3em;
    height: 3em;
  }
  .concept-center-area .corner-top-left.corner-top-left,
  .concept-center-area .corner-top-right.corner-top-left,
  .concept-center-area .corner-bottom-left.corner-top-left,
  .concept-center-area .corner-bottom-right.corner-top-left {
    top: -25px;
    left: -30px;
  }
  .concept-center-area .corner-top-left.corner-top-right,
  .concept-center-area .corner-top-right.corner-top-right,
  .concept-center-area .corner-bottom-left.corner-top-right,
  .concept-center-area .corner-bottom-right.corner-top-right {
    top: -25px;
    right: -30px;
  }
  .concept-center-area .corner-top-left.corner-bottom-left,
  .concept-center-area .corner-top-right.corner-bottom-left,
  .concept-center-area .corner-bottom-left.corner-bottom-left,
  .concept-center-area .corner-bottom-right.corner-bottom-left {
    bottom: -25px;
    left: -30px;
  }
  .concept-center-area .corner-top-left.corner-bottom-right,
  .concept-center-area .corner-top-right.corner-bottom-right,
  .concept-center-area .corner-bottom-left.corner-bottom-right,
  .concept-center-area .corner-bottom-right.corner-bottom-right {
    bottom: -25px;
    right: -30px;
  }
  .concept-center-area .corner-top-left::before,
  .concept-center-area .corner-top-right::before,
  .concept-center-area .corner-bottom-left::before,
  .concept-center-area .corner-bottom-right::before {
    width: 3.6em;
    height: 0.6em;
  }
  .concept-center-area .corner-top-left::after,
  .concept-center-area .corner-top-right::after,
  .concept-center-area .corner-bottom-left::after,
  .concept-center-area .corner-bottom-right::after {
    width: 0.6em;
    height: 3.6em;
  }
  .concept-subtext {
    font-size: 1.6rem;
    margin-top: 20%;
    margin-bottom: 60%;
    position: relative;
    z-index: 3;
    padding: 0 20px;
    text-shadow: 0 0 3px #fff, 0 0 6px #fff;
  }
  .concept-subtext br {
    display: none;
  }
}
@media (max-width: 350px) {
  .concept-background {
    margin-top: 50px;
  }
  .concept-background .concept-background-left-background .background-circle {
    top: -16%;
    left: -44px;
  }
  .concept-background .concept-background-right-background .background-circle {
    top: 137%;
    right: -26px;
  }
  .concept-background .background-circle {
    width: 170px;
    height: 170px;
  }
}
/* Message */
.message-background {
  position: relative;
  width: 100%;
  background-image: url("../img/message-background.jpeg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  box-sizing: border-box;
  margin-top: 8%;
}
.message-background .message-top {
  position: absolute;
  top: 70px;
  left: 200px;
  font-size: 5rem;
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
  color: #000;
  z-index: 5;
}
.message-background .message-top .message-sub {
  font-size: 2rem;
  font-weight: normal;
}
.message-background .message-content {
  padding-top: 280px;
}

.message-title {
  display: flex;
  gap: 0.3em;
}
.message-title span {
  display: inline-block;
  transform: translateY(100px);
  opacity: 0;
  transition: transform 0.6s ease, opacity 1.5s ease;
}
.message-title.active span {
  transform: translateY(0);
  opacity: 1;
}
.message-title .char {
  display: inline-block;
  transform: translateY(-100px);
  opacity: 0;
}
.message-title.active .char {
  animation: dropIn 0.6s ease forwards;
}

@keyframes dropIn {
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
.message-background-arch {
  position: absolute;
  pointer-events: none;
  bottom: 0%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 500px;
  background: white;
  clip-path: ellipse(60% 100% at 50% 100%);
  z-index: 1;
}

.message-content {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 20% 0 20%;
  flex-wrap: wrap;
  z-index: 2;
}
.message-content .message-image {
  flex: 0 0 40%;
  text-align: center;
}
.message-content .message-image .circle-outline {
  position: absolute;
  top: 72%;
  left: 62%;
  transform: translate(20%, -50%);
  width: 220px;
  height: 220px;
  border-radius: 50%;
  border: 8px solid transparent;
  background-image: linear-gradient(90deg, #ff5377, #ffa500);
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 8px), black calc(100% - 8px));
  mask: radial-gradient(farthest-side, transparent calc(100% - 8px), black calc(100% - 8px));
  z-index: -1;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.message-content .message-text {
  flex: 0 0 30%;
  color: #000;
  padding-top: 50px;
  padding-left: 30px;
  opacity: 0;
  font-family: "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "游明朝体", "Yu Mincho", serif;
}
.message-content .message-text p {
  line-height: 1.8;
  font-size: 1.8rem;
}
.message-content .circle-label {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-end;
  padding-right: 20px;
  font-size: 1.8rem;
  font-weight: bold;
  color: #000;
  top: 65%;
  left: 68%;
}
.message-content .circle-label .line1 {
  font-size: 1.8rem;
  color: #000;
  margin-right: 30px;
  font-family: "Shippori Mincho", serif;
  opacity: 0;
}
.message-content .circle-label .line2 {
  font-size: 2.8rem;
  margin-top: 4px;
  font-family: "Shippori Mincho", serif;
  opacity: 0;
}
.message-content .circle-label .line3 {
  font-size: 1.5rem;
  margin-top: 4px;
  margin-right: 50px;
  font-family: "Yu Mincho", "YuMincho", serif;
  font-weight: bold;
  opacity: 0;
}

@media (max-width: 1536px) {
  .message-content .message-text p {
    font-size: 1.6rem;
  }
  .message-content .circle-label {
    top: 64%;
    left: 69%;
  }
}
@media (max-width: 1440px) {
  .message-content .message-text p {
    font-size: 1.5rem;
  }
}
@media (max-width: 1280px) {
  .message-background .message-top {
    font-size: 4rem;
  }
  .message-content .message-text {
    flex: 0 0 40%;
  }
  .message-content .message-image .circle-outline {
    top: 70%;
    left: 64%;
  }
  .message-content .circle-label {
    left: 72%;
    top: 63%;
  }
  .message-background-arch {
    height: 450px;
  }
}
@media (max-width: 1280px) {
  .message-background .message-top {
    font-size: 3.5rem;
  }
  .message-content .message-text {
    flex: 0 0 50%;
  }
  .message-content .circle-label {
    left: 73%;
    top: 62%;
  }
}
@media (max-width: 1024px) {
  .message-background {
    height: auto;
    margin-top: 5%;
  }
  .message-background .message-top {
    left: 38%;
  }
  .message-background .message-header {
    position: relative;
    top: 0;
    left: 0;
    text-align: center;
    font-size: 4rem;
  }
  .message-background .message-header .message-sub {
    font-size: 1.8rem;
  }
  .message-background .message-content {
    flex-direction: column;
    align-items: center;
    padding: 0 5%;
    margin-top: 80px;
  }
  .message-background .message-content .message-image {
    flex: 0 0 auto;
    position: relative;
    width: 100%;
    text-align: center;
  }
  .message-background .message-content .message-image img {
    width: 40%;
    height: auto;
  }
  .message-background .message-content .message-image .circle-outline {
    top: 70%;
    left: 56%;
    width: 180px;
    height: 180px;
  }
  .message-background .message-content .message-text {
    flex: 0 0 auto;
    margin-top: 160px;
    margin-left: 0;
    text-align: center;
  }
  .message-background .message-content .message-text p {
    font-size: 1.6rem;
  }
  .message-background .message-content .circle-label {
    top: 58%;
    left: 71%;
    transform: translateX(-50%);
    flex-direction: column;
    align-items: center;
    padding: 0;
  }
  .message-background .message-content .circle-label .line1 {
    font-size: 1.5rem;
    margin-right: 0;
  }
  .message-background .message-content .circle-label .line2 {
    font-size: 2.3rem;
    margin-top: 4px;
  }
  .message-background .message-content .circle-label .line3 {
    font-size: 1.3rem;
    margin-top: 4px;
    margin-right: 0;
  }
  .message-background .message-background-arch {
    height: 300px;
    clip-path: ellipse(70% 100% at 50% 100%);
  }
}
@media (max-width: 850px) {
  .message-background .message-content .circle-label {
    left: 73%;
  }
}
@media (max-width: 768px) {
  .message-background {
    height: auto;
    margin-top: 10%;
  }
  .message-background .message-top {
    position: relative;
    top: 50px;
    left: 0;
    text-align: center;
    font-size: 4rem;
  }
  .message-background .message-top .message-title {
    display: block;
  }
  .message-background .message-top .message-sub {
    font-size: 1.8rem;
  }
  .message-background .message-content {
    flex-direction: column;
    padding: 0 10%;
    margin-top: 80px;
    margin-bottom: 100px;
  }
  .message-background .message-content .message-text {
    flex: 0 0 100%;
    margin: 0 0 30px 0;
  }
  .message-background .message-content .message-text p {
    font-size: 1.6rem;
    line-height: 1.7;
  }
  .message-background .message-content .message-image {
    flex: 0 0 100%;
    position: relative;
  }
  .message-background .message-content .message-image img {
    width: 70%;
    height: auto;
    margin-top: 0;
    margin-left: 40px;
  }
  .message-background .message-content .message-image .circle-outline {
    display: none;
  }
  .message-background .message-content .circle-label {
    top: 93%;
    left: 50%;
    transform: translateX(-50%);
    align-items: center;
    justify-content: center;
    padding-right: 0;
  }
  .message-background .message-content .circle-label .line1 {
    font-size: 1.6rem;
    margin-right: 0;
    text-align: center;
    margin-top: 60%;
  }
  .message-background .message-content .circle-label .line2 {
    font-size: 2.4rem;
    margin-top: 2px;
    text-align: center;
  }
  .message-background .message-content .circle-label .line3 {
    font-size: 1.4rem;
    margin-top: 2px;
    margin-right: 0;
    text-align: center;
  }
  .message-background .message-content .circle-label .line3 br {
    display: none;
  }
  .message-background .message-background-arch {
    height: 400px;
    clip-path: ellipse(70% 100% at 50% 100%);
  }
}
@media (max-width: 480px) {
  .message-background {
    height: auto;
  }
  .message-background .message-top {
    font-size: 3rem;
  }
  .message-background .message-top .message-sub {
    font-size: 1.5rem;
  }
  .message-background .message-content {
    flex-direction: column;
    padding: 0px 10% 0 10%;
    margin-top: 50px;
  }
  .message-background .message-content .message-text {
    flex: 0 0 100%;
    margin: 30px 0 30px 0;
    text-align: left;
    padding: 0 20px;
  }
  .message-background .message-content .message-text br {
    display: none;
  }
  .message-background .message-content .message-text p {
    font-size: 1.6rem;
    line-height: 1.7;
  }
  .message-background .message-content .message-image {
    flex: 0 0 100%;
    position: relative;
  }
  .message-background .message-content .message-image img {
    width: 100%;
    height: auto;
    margin-left: 25px;
  }
  .message-background .message-content .message-image .circle-outline {
    display: none;
  }
  .message-background .message-content .circle-label {
    top: 90%;
    left: 50%;
    transform: translateX(-50%);
    align-items: center;
    justify-content: center;
    padding-right: 0;
  }
  .message-background .message-content .circle-label .line1 {
    font-size: 1.4rem;
    margin-right: 0;
    text-align: center;
    margin-top: 70%;
  }
  .message-background .message-content .circle-label .line2 {
    font-size: 2rem;
    margin-top: 2px;
    text-align: center;
  }
  .message-background .message-content .circle-label .line3 {
    font-size: 1.2rem;
    margin-top: 2px;
    margin-right: 0;
    text-align: center;
  }
  .message-background .message-content .circle-label .line3 br {
    display: none;
  }
  .message-background .message-background-arch {
    height: 300px;
    clip-path: ellipse(70% 100% at 50% 100%);
  }
}
/* News */
.news-background {
  background-image: url("../img/news-background.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: 70vh;
  padding: 150px 200px 20px 60px;
}
.news-background .news-content {
  color: white;
}
.news-background .news-content .news-top {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.news-background .news-content .news-top .news-header {
  margin-left: 140px;
}
.news-background .news-content .news-top .news-header h2 {
  font-size: 7rem;
  margin-bottom: 0.5rem;
  font-family: "Montserrat", sans-serif;
}
.news-background .news-content .news-top .news-header p {
  font-size: 2rem;
  color: #000;
  margin-top: -20px;
}
.news-background .news-content .news-top .news-title {
  display: flex;
}
.news-background .news-content .news-top .news-title span {
  display: inline-block;
  transform: translateY(-100px);
  opacity: 0;
  transition: transform 0.6s ease, opacity 1s ease;
}
.news-background .news-content .news-top .news-title span:nth-child(1) {
  transition-delay: 0s;
}
.news-background .news-content .news-top .news-title span:nth-child(2) {
  transition-delay: 0.3s;
}
.news-background .news-content .news-top .news-title span:nth-child(3) {
  transition-delay: 0.6s;
}
.news-background .news-content .news-top .news-title span:nth-child(4) {
  transition-delay: 0.9s;
}
.news-background .news-content .news-top .news-title.active span {
  transform: translateY(0);
  opacity: 1;
}
.news-background .news-content .news-top .news-link {
  position: relative;
  display: inline-block;
  color: white;
  text-decoration: none;
  padding-bottom: 4px;
}
.news-background .news-content .news-top .news-lines {
  display: flex;
  flex-direction: column;
  gap: 25px;
  width: 55%;
  margin-top: 50px;
  margin-left: 70px;
  margin-right: auto;
}
.news-background .news-content .news-top .news-lines .news-item {
  font-size: 2rem;
  color: #fff;
  text-align: left;
}
.news-background .news-content .news-top .news-lines .news-item-wrapper {
  transition: transform 0.3s ease;
}
.news-background .news-content .news-top .news-lines .news-item-wrapper:hover .news-link {
  transform: scale(1.05);
}
.news-background .news-content .news-top .news-lines .news-link {
  display: inline-block;
  margin-left: 10px;
  transition: transform 0.3s ease, color 0.3s ease;
}
.news-background .news-content .news-top .news-lines .news-divider {
  position: relative;
  width: 100%;
  height: 2px;
  background-color: white;
  overflow: hidden;
}
.news-background .news-content .news-top .news-lines .news-divider::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-image: linear-gradient(90deg, #ff5377, #ffa500);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.8s ease;
}
.news-background .news-content .news-top .news-lines .news-item-wrapper:hover .news-divider::after {
  transform: scaleX(1);
}
.news-background .news-content .news-top .news-lines .news-text {
  position: relative;
  display: inline-block;
  color: white;
}
.news-background .news-content .news-top .news-lines .view-more-button-wrapper {
  display: flex;
  justify-content: flex-end;
  position: relative;
  top: 20px;
  left: 260px;
}
.news-background .news-content .news-top .news-lines .view-more-button {
  display: inline-block;
  padding: 8px 36px;
  background-color: white;
  color: black;
  font-weight: 500;
  font-size: 16px;
  text-decoration: none;
  border-radius: 0 50px 50px 0;
  letter-spacing: 0.2em;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
.news-background .news-content .news-top .news-lines .view-more-button:hover {
  transform: scale(1.05);
  opacity: 0.7;
}

@media (max-width: 1280px) {
  .news-background {
    padding: 120px 60px 20px 40px;
    height: 55vh;
  }
  .news-background .news-content .news-top {
    gap: 40px;
  }
  .news-background .news-content .news-top .news-header {
    margin-left: 0;
    text-align: center;
  }
  .news-background .news-content .news-top .news-header h2 {
    font-size: 5rem;
  }
  .news-background .news-content .news-top .news-header p {
    font-size: 1.7rem;
    margin-top: -15px;
  }
  .news-background .news-content .news-top .news-lines {
    width: 80%;
    margin: 0 auto;
  }
  .news-background .news-content .news-top .news-lines .view-more-button-wrapper {
    justify-content: center;
    top: 0;
    left: 0;
    margin-top: 30px;
  }
  .news-background .news-content .news-top .news-lines .view-more-button {
    border-radius: 50px;
    padding: 8px 28px;
    font-size: 14px;
  }
}
@media (max-width: 1024px) {
  .news-background {
    padding: 100px 40px 20px 40px;
    height: 40vh;
  }
  .news-background .news-content .news-top {
    flex-direction: column;
    gap: 30px;
  }
  .news-background .news-content .news-top .news-header {
    margin: 0 auto;
    text-align: center;
  }
  .news-background .news-content .news-top .news-header h2 {
    font-size: 4rem;
  }
  .news-background .news-content .news-top .news-header p {
    font-size: 1.5rem;
    margin-top: -10px;
  }
  .news-background .news-content .news-top .news-lines {
    width: 100%;
    margin: 0 auto;
  }
  .news-background .news-content .news-top .news-lines .news-item {
    font-size: 1.8rem;
  }
  .news-background .news-content .news-top .news-lines .view-more-button-wrapper {
    justify-content: center;
    top: 0;
    left: 0;
    margin-top: 20px;
  }
  .news-background .news-content .news-top .news-lines .view-more-button {
    border-radius: 50px;
    padding: 8px 24px;
    font-size: 14px;
  }
}
@media (max-width: 768px) {
  .news-background {
    padding: 80px 40px 20px 40px;
  }
  .news-background .news-content .news-top {
    flex-direction: column;
    gap: 30px;
  }
  .news-background .news-content .news-top .news-header {
    margin-left: auto !important;
    margin-right: auto;
    display: block;
    margin-left: 0;
    text-align: center;
  }
  .news-background .news-content .news-top .news-header h2 {
    font-size: 4rem;
  }
  .news-background .news-content .news-top .news-header p {
    font-size: 1.5rem;
    margin-top: -10px;
  }
  .news-background .news-content .news-top .news-lines {
    width: 100%;
    margin: 0 auto;
  }
  .news-background .news-content .news-top .news-lines .news-item {
    font-size: 1.8rem;
  }
  .news-background .news-content .news-top .news-lines .view-more-button-wrapper {
    justify-content: center;
    top: 0;
    left: 0;
    margin-top: 20px;
  }
  .news-background .news-content .news-top .news-lines .view-more-button {
    border-radius: 50px;
    padding: 8px 24px;
    font-size: 14px;
    letter-spacing: 0.1em;
  }
}
@media (max-width: 480px) {
  .news-background {
    padding: 60px 20px 60px 20px;
  }
  .news-background .news-content .news-top .news-header h2 {
    font-size: 3rem;
  }
  .news-background .news-content .news-top .news-header p {
    font-size: 1.2rem;
  }
  .news-background .news-content .news-top .news-lines .news-item {
    font-size: 1.4rem;
  }
  .news-background .news-content .news-top .news-lines .news-divider {
    height: 1px;
  }
  .news-background .news-content .news-top .news-lines .view-more-button {
    padding: 6px 20px;
    font-size: 12px;
  }
}
/* more-contents */
.more-contents {
  padding: 60px 5%;
  margin-top: 7%;
}
.more-contents .more-contents-row {
  display: flex;
  align-items: flex-start;
  gap: 150px;
  flex-wrap: wrap;
}
.more-contents .more-contents-row .more-contents-title {
  flex: 0 0 auto;
  width: 200px;
  margin-left: 110px;
}
.more-contents .more-contents-row .more-contents-title h2 {
  font-size: 6rem;
  font-weight: bold;
  font-family: "Montserrat", sans-serif;
  line-height: 1;
  letter-spacing: -2px;
}
.more-contents .more-contents-row .more-contents-title p {
  font-size: 2rem;
  margin-top: 10px;
}
.more-contents .more-contents-row .more-contents-items {
  display: flex;
  gap: 100px;
  flex-wrap: wrap;
}
.more-contents .more-contents-row .more-contents-items .content-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: #000;
}
.more-contents .more-contents-row .more-contents-items .content-box img {
  width: 300px;
  height: 200px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 50px;
  margin-bottom: 8px;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
.more-contents .more-contents-row .more-contents-items .content-box:hover img {
  transform: scale(1.05);
  opacity: 0.7;
}
.more-contents .more-contents-row .more-contents-items .content-box span {
  font-weight: bold;
  font-size: 2rem;
  text-align: center;
  position: relative;
}
.more-contents .more-contents-row .more-contents-items .content-box span::before {
  content: "＞";
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 25px;
  height: 25px;
  border-radius: 50%;
  border: 1px solid #000;
  font-size: 1.2rem;
  margin-right: 8px;
  vertical-align: middle;
}
.more-contents .interview-banner {
  display: flex;
  justify-content: center;
  margin-top: 10%;
}
.more-contents .interview-banner a img {
  width: 100%;
  max-width: 1100px;
  position: relative;
  left: 140px;
  height: auto;
  border-radius: 25px;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
.more-contents .interview-banner:hover a img {
  transform: scale(1.05);
  opacity: 0.7;
}

@media (max-width: 1750px) {
  .more-contents .interview-banner a img {
    max-width: 950px;
    left: 0;
  }
  .more-contents .more-contents-row {
    flex-direction: column;
    align-items: center;
    gap: 60px;
  }
  .more-contents .more-contents-row .more-contents-title {
    width: 180px;
    left: 0;
  }
  .more-contents .more-contents-row .more-contents-title h2 {
    font-size: 6rem;
  }
  .more-contents .more-contents-row .more-contents-title p {
    font-size: 1.9rem;
  }
  .more-contents .more-contents-row .more-contents-items {
    gap: 80px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box img {
    width: 260px;
    height: 180px;
    border-radius: 40px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span {
    font-size: 1.9rem;
  }
}
@media (max-width: 1440px) {
  .more-contents .more-contents-row .more-contents-title {
    width: 180px;
  }
  .more-contents .more-contents-row .more-contents-title h2 {
    font-size: 6rem;
  }
  .more-contents .more-contents-row .more-contents-title p {
    font-size: 1.9rem;
  }
  .more-contents .more-contents-row .more-contents-items {
    gap: 60px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box img {
    width: 260px;
    height: 180px;
    border-radius: 40px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span {
    font-size: 1.9rem;
  }
}
@media (max-width: 1350px) {
  .more-contents .more-contents-row {
    flex-direction: column;
    align-items: center;
    gap: 60px;
  }
  .more-contents .more-contents-row .more-contents-title {
    width: 100%;
    text-align: center;
    margin-bottom: 20px;
    margin-left: 0;
  }
  .more-contents .more-contents-row .more-contents-title h2 {
    font-size: 6rem;
    letter-spacing: -1px;
  }
  .more-contents .more-contents-row .more-contents-title p {
    font-size: 1.9rem;
    margin-top: 8px;
  }
  .more-contents .more-contents-row .more-contents-items {
    justify-content: center;
    gap: 60px;
  }
}
@media (max-width: 1280px) {
  .more-contents .interview-banner a img {
    left: 0px;
  }
}
@media (max-width: 1024px) {
  .more-contents {
    padding: 40px 5%;
    margin-top: 10%;
  }
  .more-contents .more-contents-row {
    flex-direction: row;
    align-items: center;
    gap: 60px;
  }
  .more-contents .more-contents-row .more-contents-title {
    width: 100%;
    text-align: center;
    margin-left: 0;
  }
  .more-contents .more-contents-row .more-contents-title h2 {
    font-size: 5rem;
    letter-spacing: -1px;
  }
  .more-contents .more-contents-row .more-contents-title p {
    font-size: 1.8rem;
    margin-top: 8px;
  }
  .more-contents .more-contents-row .more-contents-items {
    justify-content: center;
    flex-direction: column;
    gap: 50px;
    align-items: center;
  }
  .more-contents .more-contents-row .more-contents-items .content-box {
    width: 100%;
  }
  .more-contents .more-contents-row .more-contents-items .content-box img {
    width: 45%;
    height: auto;
    border-radius: 35px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span {
    font-size: 1.8rem;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span::before {
    width: 22px;
    height: 22px;
    font-size: 1rem;
    margin-right: 6px;
  }
}
@media (max-width: 800px) {
  .entry-fixed {
    top: 80%;
  }
  .entry-fixed img {
    height: 80%;
    width: auto;
    display: block;
    transition: transform 0.5s ease, opacity 0.5s ease;
  }
}
/* 768px以下 */
@media (max-width: 768px) {
  .more-contents {
    padding: 20px 5%;
    margin-top: 12%;
  }
  .more-contents .more-contents-row {
    gap: 40px;
  }
  .more-contents .more-contents-row .more-contents-title h2 {
    font-size: 4rem;
  }
  .more-contents .more-contents-row .more-contents-title p {
    font-size: 1.6rem;
  }
  .more-contents .more-contents-row .more-contents-items {
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box {
    width: 100%;
  }
  .more-contents .more-contents-row .more-contents-items .content-box img {
    width: 50%;
    height: auto;
    border-radius: 30px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span {
    font-size: 1.7rem;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span::before {
    width: 20px;
    height: 20px;
    font-size: 1rem;
  }
}
@media (max-width: 600px) {
  .entry-fixed {
    top: 90%;
  }
  .entry-fixed img {
    height: 70%;
    width: auto;
    display: block;
    transition: transform 0.5s ease, opacity 0.5s ease;
  }
}
@media (max-width: 480px) {
  .more-contents {
    padding: 20px 5%;
    margin-top: 10%;
  }
  .more-contents .more-contents-row {
    flex-direction: row !important;
    align-items: center;
    gap: 50px;
  }
  .more-contents .more-contents-row .more-contents-title {
    width: 100%;
    text-align: center;
    margin-left: 0;
  }
  .more-contents .more-contents-row .more-contents-title h2 {
    font-size: 4rem;
    letter-spacing: -1px;
  }
  .more-contents .more-contents-row .more-contents-title p {
    font-size: 1.6rem;
    margin-top: 8px;
  }
  .more-contents .more-contents-row .more-contents-items {
    flex-direction: column;
    gap: 40px;
    align-items: center;
  }
  .more-contents .more-contents-row .more-contents-items .content-box {
    width: 100%;
  }
  .more-contents .more-contents-row .more-contents-items .content-box img {
    width: 90%;
    height: auto;
    border-radius: 30px;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span {
    font-size: 1.8rem;
  }
  .more-contents .more-contents-row .more-contents-items .content-box span::before {
    width: 20px;
    height: 20px;
    font-size: 1rem;
    margin-right: 6px;
  }
  .more-contents .interview-banner {
    margin-top: 25%;
    padding: 0 5%;
  }
  .more-contents .interview-banner a img {
    width: 100%;
    max-width: 100%;
    border-radius: 20px;
  }
}
.concept-background-left-background, .concept-background-right-background {
  margin-top: 50px;
}

.entry-fixed {
  position: fixed;
  right: 0;
  top: 75%;
  height: 14%;
  z-index: 100;
}
.entry-fixed a {
  display: block;
  height: 100%;
}
.entry-fixed img {
  height: 100%;
  width: auto;
  display: block;
  transition: transform 0.5s ease, opacity 0.5s ease;
}
.entry-fixed:hover img {
  transform: scale(1.05);
  opacity: 0.7;
}

/* section-page */
.top {
  position: relative;
  width: 100vw;
  height: 912px;
  overflow: hidden;
}

.section-top-photo {
  position: absolute;
  top: 14%;
  right: 0;
  width: 100%;
  max-width: 1350px;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: 1;
  display: block;
  overflow-y: auto;
}

.chapter-label {
  position: absolute;
  top: 30%;
  left: 9%;
  font-family: "Libre Baskerville", serif;
  font-weight: 600;
  font-size: 2.4rem;
  color: #000000;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  z-index: 4;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.section-top {
  position: absolute;
  top: 25%;
  left: 18%;
  text-align: center;
  font-size: 6rem;
  color: #333;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  font-family: "Libre Baskerville", serif;
  z-index: 3;
}
.section-top .hash {
  color: #aacf53;
  font-size: 7rem;
  font-weight: 900;
  font-family: "League Spartan", sans-serif;
}
.section-top .number {
  font-weight: 600;
}

.section-title {
  position: absolute;
  top: calc(25% + 8rem + 4rem);
  left: 18%;
  z-index: 3;
}
.section-title .matrix {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s ease, transform 0.6s ease;
}
.section-title .matrix .bg-wrap,
.section-title .matrix .bg-wrap1,
.section-title .matrix .bg-wrap .inn,
.section-title .matrix .bg-wrap1 .inn {
  display: block;
}
.section-title .matrix .bg-wrap,
.section-title .matrix .bg-wrap1 {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  overflow: hidden;
  opacity: 0;
  background-color: #fff;
  padding: 0.5rem 1rem;
  margin: 0.5rem 0;
}
.section-title .matrix .bg-wrap + .section-title .matrix .bg-wrap,
.section-title .matrix .bg-wrap + .section-title .matrix .bg-wrap1,
.section-title .matrix .bg-wrap1 + .section-title .matrix .bg-wrap,
.section-title .matrix .bg-wrap1 + .section-title .matrix .bg-wrap1 {
  margin-top: 15px;
}
.section-title .matrix .inn.large {
  font-size: 4.5rem;
  font-weight: bold;
  line-height: 1.4;
  color: #333;
}
.section-title .matrix .inn {
  opacity: 0;
  transform: matrix(1, 0, 0, 1, 0, 100);
  transition: 3s cubic-bezier(0.22, 1, 0.36, 1);
}
.section-title .matrix.is-animated {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 1s;
}
.section-title .matrix.is-animated .bg-wrap,
.section-title .matrix.is-animated .bg-wrap1 {
  opacity: 1;
}
.section-title .matrix.is-animated .bg-wrap .inn,
.section-title .matrix.is-animated .bg-wrap1 .inn {
  opacity: 1;
  transform: matrix(1, 0, 0, 1, 0, 0);
}

.subtitle-person {
  position: absolute;
  top: calc(25% + 8rem + 4rem + 20rem);
  left: 18%;
  z-index: 3;
  text-align: left;
  width: -moz-fit-content;
  width: fit-content;
}
.subtitle-person .person-role,
.subtitle-person .person-name,
.subtitle-person .person-kana {
  margin: 0;
}
.subtitle-person .person-role {
  font-size: 3.2rem;
  font-weight: normal;
  margin-bottom: 0.5rem;
}
.subtitle-person .person-name {
  font-size: 4rem;
  font-weight: bold;
  margin-bottom: 0.3rem;
}
.subtitle-person .person-kana {
  font-size: 2rem;
  font-weight: normal;
}

@media (max-width: 1870px) {
  .subtitle-person {
    left: 13%;
  }
  .section-title {
    left: 13%;
  }
}
@media (max-width: 1750px) {
  .subtitle-person {
    left: 10%;
  }
  .section-title {
    left: 10%;
  }
  .section-top {
    top: 26%;
  }
  .chapter-label {
    left: 8%;
  }
}
@media (max-width: 1700px) {
  .section-top-photo {
    width: 75%;
    right: -30px;
  }
}
@media (max-width: 1536px) {
  .section-top-photo {
    width: 70%;
  }
  .section-title {
    left: 12%;
  }
  .chapter-label {
    left: 7%;
  }
  .section-title .matrix .inn.large {
    font-size: 4rem;
  }
}
@media (max-width: 1440px) {
  .chapter-label {
    left: 6.5%;
  }
}
@media (max-width: 1440px) and (max-width: 1536px) {
  .section-top-photo {
    width: 86%;
    right: -150px;
  }
}
@media (max-width: 1366px) {
  .chapter-label {
    left: 6%;
  }
  .section-title .matrix .inn.large {
    font-size: 3.6rem;
  }
}
@media (max-width: 1280px) {
  .chapter-label {
    left: 5%;
    top: 25%;
  }
  .subtitle-person {
    left: 10%;
    top: calc(20% + 8rem + 4rem + 20rem);
  }
  .section-title {
    left: 10%;
    top: calc(20% + 8rem + 4rem);
  }
  .section-top {
    top: 20%;
  }
  .subtitle-person {
    left: 10%;
    top: 60%;
  }
  .subtitle-person .person-role {
    font-size: 2rem;
  }
  .subtitle-person .person-name {
    font-size: 2.5rem;
  }
  .subtitle-person .person-kana {
    font-size: 1.5rem;
  }
}
@media (max-width: 1024px) {
  .subtitle-person {
    left: 6%;
    top: 65%;
  }
}
@media (max-width: 1024px) {
  .section-top-photo {
    width: 100%;
    right: 0;
    height: 730px;
    top: 7%;
  }
  .s {
    width: 110%;
  }
  .section-top {
    top: 15%;
    left: 4%;
  }
  .chapter-label {
    top: 23%;
  }
  .subtitle-person {
    left: 6%;
    top: 75%;
  }
  .section-title .matrix .bg-wrap1 {
    margin: 0 auto;
  }
  .section-title .matrix .bg-wrap {
    margin: 0 auto;
  }
  .section-title {
    top: 32%;
    left: 96%;
  }
  .section-title .matrix {
    position: relative;
  }
  .section-title .matrix .bg-wrap {
    writing-mode: vertical-rl;
    position: absolute;
    white-space: nowrap;
    top: 100px;
    right: 65px;
  }
  .section-title .matrix .bg-wrap .inn {
    font-size: 2.5rem;
  }
  .section-title .matrix .bg-wrap1 {
    writing-mode: vertical-rl;
    position: absolute;
    white-space: nowrap;
    top: 20px;
    right: 0px;
  }
  .section-title .matrix .bg-wrap1 .inn {
    font-size: 2.5rem;
  }
}
@media (max-width: 700px) {
  .chapter-label {
    left: 3%;
    top: 20%;
  }
  .section-top {
    left: 3%;
    top: 11.6%;
    font-size: 7rem;
  }
  .section-top-photo {
    width: 100%;
    right: 0;
  }
}
@media (max-width: 500px) {
  .top {
    height: 700px;
  }
  .section-title {
    top: 37%;
    left: 90%;
  }
  .section-title .matrix .bg-wrap {
    top: 35px;
    right: 20px;
  }
  .section-title .matrix .bg-wrap .inn {
    font-size: 2rem;
  }
  .section-title .matrix .bg-wrap1 {
    top: 10px;
    right: -30px;
  }
  .section-title .matrix .bg-wrap1 .inn {
    font-size: 2rem;
  }
  .section-title {
    top: 45%;
    left: 90%;
  }
  .section-top-photo {
    width: 100%;
    right: 0;
    height: 630px;
  }
  .chapter-label {
    display: none;
  }
  .section-top {
    top: 8.6%;
  }
  .subtitle-person {
    top: 80%;
    text-shadow: 0 0 4px white, 0 0 8px white, 0 0 12px white, 0 0 16px white;
  }
  .s {
    width: 125%;
  }
}
@media (max-width: 390px) {
  .section-title {
    top: 39%;
    left: 90%;
  }
  .section-title .matrix .bg-wrap {
    top: 60px;
    right: 20px;
  }
  .section-title .matrix .bg-wrap .inn {
    font-size: 2rem;
  }
  .section-title .matrix .bg-wrap1 {
    top: 10px;
    right: -30px;
  }
  .section-title .matrix .bg-wrap1 .inn {
    font-size: 2rem;
  }
  .section-top {
    font-size: 6rem;
  }
  .chapter-label {
    font-size: 2rem;
  }
}
@media (max-width: 375px) {
  .section-title {
    top: 50%;
    left: 87%;
  }
  .section-title .matrix .bg-wrap {
    right: 10px;
  }
  .section-title .matrix .bg-wrap .inn {
    font-size: 1.5rem;
  }
  .section-title .matrix .bg-wrap1 .inn {
    font-size: 1.5rem;
  }
  .section-top {
    font-size: 6rem;
    top: 7.6%;
  }
  .chapter-label {
    font-size: 2rem;
    top: 19%;
  }
  .subtitle-person {
    top: 72%;
    left: 4%;
  }
}
/* interview */
.interview01, .interview02, .interview03 {
  display: flex;
  justify-content: center;
  padding: 7rem 2rem;
}
.interview01 .interview-inner-left-img, .interview02 .interview-inner-left-img, .interview03 .interview-inner-left-img {
  display: flex;
  align-items: center;
  max-width: 1200px;
  width: 100%;
  gap: 10rem;
}
.interview01 .interview-inner-right-img, .interview02 .interview-inner-right-img, .interview03 .interview-inner-right-img {
  display: flex;
  align-items: center;
  max-width: 1200px;
  width: 100%;
  gap: 10rem;
  flex-direction: row-reverse;
}
.interview01 .interview-image, .interview02 .interview-image, .interview03 .interview-image {
  flex: 0 0 50%;
  opacity: 0;
}
.interview01 .interview-image img, .interview02 .interview-image img, .interview03 .interview-image img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  -o-object-fit: cover;
     object-fit: cover;
}
.interview01 .interview-box-img, .interview02 .interview-box-img, .interview03 .interview-box-img {
  position: relative;
  width: 100%;
  max-width: 200px;
  margin: 0 auto 30px auto;
  padding: 2rem;
}
.interview01 .interview-box-img::before, .interview02 .interview-box-img::before, .interview03 .interview-box-img::before {
  content: "";
  position: absolute;
  top: -60px;
  left: -136px;
  width: 90vh;
  height: 100%;
  background-image: url(../img/interview-question-background.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -1;
}
.interview01 .interview-box-img img, .interview02 .interview-box-img img, .interview03 .interview-box-img img {
  width: 100%;
  height: auto;
  display: block;
  position: relative;
  z-index: 1;
}
.interview01 .interview-box-img.reverse-bg::before, .interview02 .interview-box-img.reverse-bg::before, .interview03 .interview-box-img.reverse-bg::before {
  top: -40%;
  left: auto;
  right: -136px;
  transform: scaleX(-1);
}
.interview01 .interview-text, .interview02 .interview-text, .interview03 .interview-text {
  flex: 1;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #333;
  align-items: center;
  opacity: 0;
}
.interview01 .interview-text h3, .interview02 .interview-text h3, .interview03 .interview-text h3 {
  font-size: 2.5rem;
  margin-bottom: 20px;
}
.interview01 .interview-text p, .interview02 .interview-text p, .interview03 .interview-text p {
  margin: 0;
}

@media (max-width: 1024px) {
  .interview01, .interview02, .interview03 {
    padding: 4rem 2rem;
  }
  .interview01 .interview-inner-left-img,
  .interview01 .interview-inner-right-img, .interview02 .interview-inner-left-img,
  .interview02 .interview-inner-right-img, .interview03 .interview-inner-left-img,
  .interview03 .interview-inner-right-img {
    gap: 5rem;
    align-items: flex-start;
  }
  .interview01 .interview-image, .interview02 .interview-image, .interview03 .interview-image {
    flex: 0 0 auto;
  }
  .interview01 .interview-image img, .interview02 .interview-image img, .interview03 .interview-image img {
    width: 100%;
    height: auto;
    max-width: 350px;
    margin-top: 22%;
  }
  .interview01 .interview-text, .interview02 .interview-text, .interview03 .interview-text {
    flex: 1;
    font-size: 1.4rem;
    line-height: 1.7;
    padding: 0 20px 0 20px;
  }
  .interview01 .interview-text h3, .interview02 .interview-text h3, .interview03 .interview-text h3 {
    font-size: 2rem;
    margin-bottom: 16px;
  }
  .interview01 .interview-box-img, .interview02 .interview-box-img, .interview03 .interview-box-img {
    max-width: 160px;
    padding: 1.2rem;
  }
  .interview01 .interview-box-img::before, .interview02 .interview-box-img::before, .interview03 .interview-box-img::before {
    top: -60px;
    left: -90px;
    width: 55vh;
  }
  .interview01 .interview-box-img.reverse-bg::before, .interview02 .interview-box-img.reverse-bg::before, .interview03 .interview-box-img.reverse-bg::before {
    top: -60px;
    right: -90px;
    left: auto;
    width: 55vh;
  }
}
@media (max-width: 1024px) {
  .otherinterview {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    gap: 1%;
  }
  .otherinterview h2 {
    position: relative;
    font-size: 3.5rem;
    left: auto;
    text-align: center;
  }
  .otherinterview h2::before {
    content: "";
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 150px;
    height: 4px;
    background-color: #aacf53;
  }
  .otherinterview .other-interview-text {
    position: relative;
    padding: 0.8rem 1.5rem;
    text-align: center;
    max-width: 700px;
    margin-bottom: 4rem;
  }
  .otherinterview .other-interview-text::before {
    content: "";
    position: absolute;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    width: 55vh;
    height: 120%;
    background-image: url(../img/other-interview-background.png);
    background-size: cover;
    z-index: -1;
  }
  .otherinterview .otherinterview-bottom {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: center;
    gap: 2rem;
    width: 100%;
  }
  .otherinterview .otherinterview-imagebox {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .otherinterview .otherinterview-imagebox .otherinterview-icon {
    width: 240px;
    transition: transform 0.5s ease, opacity 0.5s ease;
  }
  .otherinterview .otherinterview-imagebox .otherinterview-icon:hover {
    transform: scale(1.05);
    opacity: 0.7;
  }
  .otherinterview .otherinterview-imagebox .caption-overlay {
    position: absolute;
    top: 25%;
    left: 5%;
    writing-mode: vertical-rl;
  }
  .otherinterview .otherinterview-imagebox .caption-overlay .caption-line1,
  .otherinterview .otherinterview-imagebox .caption-overlay .caption-line2 {
    padding: 0.2em 0.4em;
    background: rgb(255, 255, 255);
    margin: 2px 0;
  }
  .otherinterview .caption .caption-bottom1 {
    font-size: 1.4rem;
    display: block;
    margin-bottom: 0.3rem;
  }
  .otherinterview .caption .caption-bottom2,
  .otherinterview .caption .caption-bottom3 {
    font-size: 2.5rem;
    display: inline-block;
    margin: 0 0.3rem;
  }
  .otherinterview .caption .caption-bottom4 {
    font-size: 1.4rem;
    display: block;
    margin-top: 0.5rem;
  }
  .otherinterview .caption .caption-bottom5 {
    font-size: 1.8rem;
    display: block;
    margin-top: 0.3rem;
  }
}
@media (max-width: 767px) {
  .interview01 .interview-image img {
    margin-top: 45%;
  }
  .interview01, .interview02, .interview03 {
    padding: 3.5rem 1.5rem;
    margin-top: -130px;
  }
  .interview01 .interview-inner-left-img,
  .interview01 .interview-inner-right-img, .interview02 .interview-inner-left-img,
  .interview02 .interview-inner-right-img, .interview03 .interview-inner-left-img,
  .interview03 .interview-inner-right-img {
    flex-direction: column;
    gap: 8rem;
    align-items: center;
  }
  .interview01 .interview-image, .interview02 .interview-image, .interview03 .interview-image {
    flex: 0 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .interview01 .interview-image img, .interview02 .interview-image img, .interview03 .interview-image img {
    width: 100%;
    height: auto;
    max-width: 400px;
    display: block;
  }
  .interview01 .interview-text, .interview02 .interview-text, .interview03 .interview-text {
    width: 100%;
    font-size: 1.2rem;
    line-height: 1.5;
  }
  .interview01 .interview-text h3, .interview02 .interview-text h3, .interview03 .interview-text h3 {
    font-size: 1.6rem;
    margin-bottom: 12px;
  }
  .interview01 .interview-box-img, .interview02 .interview-box-img, .interview03 .interview-box-img {
    max-width: 140px;
    padding: 1.2rem;
  }
  .interview01 .interview-box-img::before, .interview02 .interview-box-img::before, .interview03 .interview-box-img::before {
    top: -50px;
    left: -80px;
    width: 80vw;
  }
  .interview01 .interview-box-img.reverse-bg::before, .interview02 .interview-box-img.reverse-bg::before, .interview03 .interview-box-img.reverse-bg::before {
    top: -50px;
    right: -80px;
    left: auto;
    width: 80vw;
  }
}
@media (max-width: 480px) {
  .number {
    text-shadow: 0 0 4px white, 0 0 1px white, 0 0 1px white, 0 0 1px white;
  }
  .interview01, .interview02, .interview03 {
    padding: 4rem 1rem;
  }
  .interview01 .interview-inner-left-img,
  .interview01 .interview-inner-right-img, .interview02 .interview-inner-left-img,
  .interview02 .interview-inner-right-img, .interview03 .interview-inner-left-img,
  .interview03 .interview-inner-right-img {
    flex-direction: column;
    gap: 5rem;
  }
  .interview01 .interview-image, .interview02 .interview-image, .interview03 .interview-image {
    flex: none;
    width: 100%;
  }
  .interview01 .interview-image img, .interview02 .interview-image img, .interview03 .interview-image img {
    width: 100%;
    height: auto;
  }
  .interview01 .interview-text, .interview02 .interview-text, .interview03 .interview-text {
    width: 100%;
    font-size: 1.3rem;
    line-height: 1.6;
  }
  .interview01 .interview-text h3, .interview02 .interview-text h3, .interview03 .interview-text h3 {
    font-size: 1.8rem;
    margin-bottom: 15px;
  }
  .interview01 .interview-box-img, .interview02 .interview-box-img, .interview03 .interview-box-img {
    max-width: 120px;
    padding: 1rem;
  }
  .interview01 .interview-box-img::before, .interview02 .interview-box-img::before, .interview03 .interview-box-img::before {
    top: -40px;
    left: -60px;
    width: 90vw;
  }
  .interview01 .interview-box-img.reverse-bg::before, .interview02 .interview-box-img.reverse-bg::before, .interview03 .interview-box-img.reverse-bg::before {
    top: -40px;
    right: -60px;
    left: auto;
    width: 90vw;
  }
}
/* otherinterview */
.otherinterview {
  margin: 15rem 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6%;
}
.otherinterview h2 {
  position: absolute;
  display: inline-block;
  font-size: 5.5rem;
  color: #aacf53;
  padding-top: 2rem;
  letter-spacing: 0.7rem;
  line-height: 0.8;
  left: 20%;
  margin-top: -50px;
  font-family: "Bebas Neue", sans-serif;
}
.otherinterview h2::before {
  content: "";
  position: absolute;
  top: 0;
  width: 230px;
  height: 4px;
  background-color: #aacf53;
}
.otherinterview .other-interview-text {
  position: relative;
  display: inline-block;
  padding: 1rem 2rem;
}
.otherinterview .other-interview-text::before {
  content: "";
  position: absolute;
  top: -44px;
  left: -138%;
  height: 150%;
  width: 66vh;
  background-image: url(../img/interview-question-background.png);
  z-index: -1;
}
.otherinterview .otherinterview-imagebox {
  position: relative;
  display: flex;
  align-items: center;
  flex-direction: column;
  left: 8%;
}
.otherinterview .otherinterview-imagebox .otherinterview-icon {
  width: 300px;
  height: auto;
  display: block;
  opacity: 0;
  transform: translateY(20px);
  transition: transform 0.6s ease, opacity 0.6s ease;
}
.otherinterview .otherinterview-imagebox .otherinterview-icon.show {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.otherinterview .otherinterview-imagebox .otherinterview-icon.show:hover {
  transform: translateY(0) scale(1.05);
  opacity: 0.7;
}
.otherinterview .otherinterview-imagebox .caption-overlay {
  position: absolute;
  top: 30%;
  left: 7%;
  writing-mode: vertical-rl;
  white-space: nowrap;
  background: none;
  color: #000;
  font-weight: bold;
}
.otherinterview .otherinterview-imagebox .caption-overlay .caption-line1 {
  margin-left: 10px;
  display: inline-block;
}
.otherinterview .otherinterview-imagebox .caption-overlay .caption-line1, .otherinterview .otherinterview-imagebox .caption-overlay .caption-line2 {
  background: rgb(255, 255, 255);
  white-space: nowrap;
  padding: 0.2em 0.2em;
}
.otherinterview .caption {
  font-family: "Libre Baskerville", serif;
  margin-left: 100px;
  margin-top: 20px;
}
.otherinterview .caption .caption-bottom1,
.otherinterview .caption .caption-bottom2,
.otherinterview .caption .caption-bottom3 {
  display: inline-block;
}
.otherinterview .caption .caption-bottom1 {
  font-size: 1.5rem;
}
.otherinterview .caption .caption-bottom2 {
  color: #aacf53;
  font-weight: bold;
  font-size: 3.5rem;
  margin-left: 8px;
  font-family: "League Spartan", sans-serif;
  font-weight: 900;
}
.otherinterview .caption .caption-bottom3 {
  font-weight: 1000;
  font-size: 3rem;
  margin-right: 5px;
}
.otherinterview .caption .caption-bottom4 {
  font-size: 1.5rem;
  font-family: sans-serif;
}
.otherinterview .caption .caption-bottom5 {
  font-size: 2.2rem;
  font-weight: 600;
  font-family: sans-serif;
}

@media (max-width: 1600px) {
  .otherinterview h2 {
    left: 12%;
  }
}
@media (max-width: 1366px) {
  .otherinterview h2 {
    left: 8%;
  }
}
@media (max-width: 1280px) {
  .otherinterview .otherinterview-imagebox .otherinterview-icon {
    width: 400px;
  }
  .otherinterview {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4rem;
    margin: 8rem 0;
  }
  .otherinterview h2 {
    position: relative;
    font-size: 3.5rem;
    margin-top: 0;
    left: 0;
    padding-top: 0;
  }
  .otherinterview h2::before {
    width: 150px;
    top: -5px;
    left: 50%;
    transform: translateX(-50%);
  }
  .otherinterview .other-interview-text {
    display: block;
    padding: 0.5rem 1rem;
    text-align: center;
  }
  .otherinterview .other-interview-text::before {
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 115vw;
    height: 150%;
    background-size: cover;
  }
  .otherinterview .otherinterview-imagebox {
    position: relative;
    left: 0;
  }
  .otherinterview .otherinterview-imagebox .caption-overlay {
    position: static;
    writing-mode: horizontal-tb;
    text-align: center;
    margin-top: 1rem;
  }
  .otherinterview .otherinterview-imagebox .caption-overlay .caption-line1,
  .otherinterview .otherinterview-imagebox .caption-overlay .caption-line2 {
    display: block;
    margin: 0 auto;
    background: rgb(255, 255, 255);
    padding: 0.2em 0.5em;
  }
  .otherinterview .caption {
    margin-left: 0;
    text-align: center;
    margin-top: 1rem;
  }
  .otherinterview .caption .caption-bottom1 {
    display: block;
    font-size: 1.3rem;
  }
  .otherinterview .caption .caption-bottom2,
  .otherinterview .caption .caption-bottom3 {
    display: inline-block;
    font-size: 2.2rem;
  }
  .otherinterview .caption .caption-bottom4 {
    font-size: 1.2rem;
    display: block;
    margin-top: 0.5rem;
  }
  .otherinterview .caption .caption-bottom5 {
    font-size: 1.5rem;
    display: block;
    margin-top: 0.3rem;
  }
}
@media (max-width: 480px) {
  .otherinterview {
    flex-direction: column;
    gap: 4rem;
    margin: 8rem 0;
  }
  .otherinterview h2 {
    position: relative;
    font-size: 3rem;
    margin-top: 0;
    left: 0;
    padding-top: 0;
  }
  .otherinterview h2::before {
    width: 150px;
    top: -5px;
  }
  .otherinterview .other-interview-text {
    display: block;
    padding: 0.5rem 1rem;
  }
  .otherinterview .other-interview-text::before {
    top: -20px;
    left: -50px;
    width: 300vw;
    height: 140%;
    background-size: cover;
  }
  .otherinterview .otherinterview-imagebox {
    left: 0;
  }
  .otherinterview .otherinterview-imagebox .caption-overlay {
    position: static;
    writing-mode: horizontal-tb;
    text-align: center;
    margin-top: 1rem;
  }
  .otherinterview .otherinterview-imagebox .caption-overlay .caption-line1,
  .otherinterview .otherinterview-imagebox .caption-overlay .caption-line2 {
    display: block;
    margin: 0 auto;
    background: rgb(255, 255, 255);
    padding: 0.2em 0.5em;
  }
  .otherinterview .caption {
    margin-left: 0;
    text-align: center;
    margin-top: 1rem;
  }
  .otherinterview .caption .caption-bottom1 {
    display: block;
    font-size: 1.3rem;
  }
  .otherinterview .caption .caption-bottom2,
  .otherinterview .caption .caption-bottom3 {
    display: inline-block;
    font-size: 2.2rem;
  }
  .otherinterview .caption .caption-bottom4 {
    font-size: 1.2rem;
    display: block;
    margin-top: 0.5rem;
  }
  .otherinterview .caption .caption-bottom5 {
    font-size: 1.5rem;
    display: block;
    margin-top: 0.3rem;
  }
}
/* requireページ */
.require .require-wrapper {
  position: relative;
}
.require .require-wrapper .require-top {
  margin: 150px 0;
  width: 1920px;
  height: 336px;
  max-width: none;
  overflow: visible;
}
.require .require-wrapper .require-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 4.5rem;
  font-weight: bold;
  color: rgb(0, 0, 0);
  text-align: center;
}
.require .require-wrapper .require-text::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 110%;
  height: 100%;
  background-color: #fff;
  transform: translate(-50%, -50%) skew(-12deg);
  z-index: -1;
}
.require .require-wrapper .require-text2 {
  position: absolute;
  top: 60%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: rgb(255, 255, 255);
  font-size: 2.5rem;
  font-weight: 600;
  text-align: center;
}

/* content */
.mcg-content-section {
  background-color: #ffffff;
  border: 3px solid #3c9841;
  border-radius: 24px;
  padding: 30px 20px;
  max-width: 1200px;
  margin: 40px auto;
  width: calc(100% - 50px);
}
.mcg-content-section .mcg-content-wrapper {
  max-width: 900px;
  margin: 0 auto;
  font-family: "Noto Sans JP", sans-serif;
  color: #000000;
}
.mcg-content-section .mcg-section-main-title {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 50px;
  color: #3c9841;
  text-align: center;
  padding-bottom: 50px;
  border-bottom: 1px solid #cccccc;
}
.mcg-content-section .mcg-section-block {
  margin-bottom: 50px;
  padding-bottom: 20px;
  border-bottom: 1px solid #cccccc;
}
.mcg-content-section .mcg-section-block .mcg-block-title {
  position: relative;
  font-size: 2.2rem;
  font-weight: 600;
  color: #3c9841;
  padding-left: 50px;
  margin-bottom: 20px;
}
.mcg-content-section .mcg-section-block .mcg-block-title::before {
  content: "";
  position: absolute;
  top: 55%;
  left: 22px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #3c9841;
}
.mcg-content-section .mcg-section-block .mcg-points-list-check {
  font-size: 2rem;
  font-weight: 500;
  color: #000000;
}
.mcg-content-section .mcg-section-block .mcg-points-list-check .mcg-list-item {
  position: relative;
  padding-left: 40px;
  padding-bottom: 30px;
}
.mcg-content-section .mcg-section-block .mcg-points-list-check .mcg-list-item::before {
  content: "";
  position: absolute;
  top: 27%;
  left: 0;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  background-image: url("../img/check.png");
  background-size: contain;
  background-repeat: no-repeat;
}
.mcg-content-section .mcg-section-block .mcg-points-list-check .mcg-list-item2 {
  padding-top: 10px;
  position: relative;
  padding-left: 40px;
  padding-bottom: 10px;
}
.mcg-content-section .mcg-section-block .mcg-points-list-check .mcg-list-item2::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  background-image: url("../img/check.png");
  background-size: contain;
  background-repeat: no-repeat;
}
.mcg-content-section .mcg-section-block .mcg-list-flex {
  display: flex;
  align-items: flex-start;
  margin-bottom: 30px;
}
.mcg-content-section .mcg-section-block .mcg-list-flex .number {
  color: #3c9841;
  font-weight: 600;
  margin-right: 0.6em;
  font-size: 2.5rem;
  margin-top: -6px;
}
.mcg-content-section .mcg-section-block .mcg-list-flex p {
  margin: 0;
  padding: 0;
}
.mcg-content-section .mcg-section-block .mcg-list-flex ul {
  margin-top: 1rem;
}
.mcg-content-section .mcg-section-block p.mcg-highlight-text {
  margin-top: 20px;
  font-weight: 600;
  color: #3c9841;
  white-space: pre-line;
}
.mcg-content-section .mcg-section-block ul.mcg-points-list,
.mcg-content-section .mcg-section-block ol.mcg-points-list-number {
  margin-left: 20px;
  line-height: 1.6;
  font-size: 2rem;
  font-weight: 500;
  color: #000000;
}
.mcg-content-section .mcg-section-block ul.mcg-points-list li.mcg-list-item,
.mcg-content-section .mcg-section-block ol.mcg-points-list-number li.mcg-list-item {
  margin-bottom: 12px;
}
.mcg-content-section .mcg-section-block ul.mcg-points-list li.mcg-list-item .number,
.mcg-content-section .mcg-section-block ol.mcg-points-list-number li.mcg-list-item .number {
  color: #3c9841;
  font-weight: 600;
  margin-right: 0.6em;
  font-size: 2.5rem;
}

@media (max-width: 440px) {
  .li {
    font-size: 1.6rem;
  }
  .require .require-wrapper .require-top {
    margin: 50px 0;
    width: 1500px;
    height: auto;
    margin-left: -40%;
  }
  .require .require-wrapper .require-text {
    font-size: 3.5rem;
  }
  .require .require-wrapper .require-text2 {
    top: 60%;
    font-size: 2rem;
  }
  .mcg-content-section .mcg-section-main-title {
    font-size: 1.86rem;
  }
  .mcg-content-section .mcg-section-block .mcg-points-list-check {
    margin-left: 0;
  }
  .mcg-content-section .mcg-section-block .mcg-points-list-check .mcg-list-item2 {
    font-size: 1.6rem;
  }
  .mcg-content-section .mcg-section-block p.mcg-highlight-text {
    margin-top: 10px;
    font-weight: 400;
    font-size: 1.6rem;
  }
  .mcg-content-section .mcg-section-block .mcg-block-title {
    font-size: 2rem;
  }
  .mcg-content-section .mcg-section-block .mcg-block-title::before {
    width: 15px;
    height: 15px;
  }
  .mcg-content-section .mcg-section-block .mcg-points-list-check .mcg-list-item::before {
    width: 30px;
    height: 30px;
  }
  .mcg-content-section .mcg-section-block ul.mcg-points-list,
  .mcg-content-section .mcg-section-block ol.mcg-points-list-number {
    margin-left: 20px;
    line-height: 1.6;
    font-size: 1.8rem;
    font-weight: 500;
    color: #000000;
  }
  .mcg-content-section .mcg-section-block ul.mcg-points-list li.mcg-list-item,
  .mcg-content-section .mcg-section-block ol.mcg-points-list-number li.mcg-list-item {
    margin-bottom: 12px;
  }
}
@media (max-width: 360px) {
  .require .require-wrapper .require-top {
    margin-left: -50%;
  }
}
/* recruitment */
.recruitment .recruitment-wrapper {
  position: relative;
}
.recruitment .recruitment-wrapper .recruitment-top {
  margin: 150px 0;
  width: 1920px;
  height: 336px;
  max-width: none;
  overflow: visible;
}
.recruitment .recruitment-wrapper .recruitment-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 4.5rem;
  font-weight: bold;
  color: rgb(0, 0, 0);
  text-align: center;
}
.recruitment .recruitment-wrapper .recruitment-text::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 110%;
  height: 100%;
  background-color: #fff;
  transform: translate(-50%, -50%) skew(-12deg);
  z-index: -1;
}
.recruitment .recruitment-wrapper .recruitment-text2 {
  position: absolute;
  top: 60%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: rgb(255, 255, 255);
  font-size: 2.5rem;
  font-weight: 600;
  text-align: center;
}

.recruitment-switch {
  background-color: #ffffff;
  border: 3px solid #3c9841;
  border-radius: 24px;
  padding: 30px 20px;
  max-width: 1200px;
  margin: 40px auto;
  width: calc(100% - 50px);
  font-family: "Noto Sans JP", sans-serif;
  color: #000000;
}
.recruitment-switch .entry-button {
  text-align: center;
  margin-top: 60px;
  margin-bottom: 20px;
}
.recruitment-switch .entry-button .entry-link {
  display: inline-block;
  background-color: #3c9841;
  color: #fff;
  font-size: 2.2rem;
  font-weight: bold;
  padding: 15px 70px;
  border-radius: 30px;
  text-decoration: none;
  transition: background-color 0.3s ease;
}
.recruitment-switch .entry-button .entry-link:hover {
  background-color: #2e7d35;
}
.recruitment-switch .recruitment-grad {
  font-size: 3.2rem;
  font-weight: 600;
  color: #3c9841;
  text-align: center;
  margin: 50px 0;
}
.recruitment-switch__buttons {
  margin-bottom: 30px;
  overflow: hidden;
  border: 2px solid #3c9841;
  display: flex;
  width: 100%;
  border-radius: 24px;
}
.recruitment-switch__buttons .recruitment-switch__btn:first-child {
  border-right: 2px solid #3c9841;
}
.recruitment-switch__buttons .recruitment-switch__btn {
  width: 50%;
  flex: 1;
  background-color: #ffffff;
  border: none;
  font-size: 3rem;
  font-weight: 700;
  color: #3c9841;
  padding: 30px 0;
  cursor: pointer;
  transition: all 0.3s ease;
  text-align: center;
}
.recruitment-switch__buttons .recruitment-switch__btn.active {
  background-color: #3c9841;
  color: #fff;
}
.recruitment-switch__buttons .recruitment-switch__btn:hover {
  opacity: 0.8;
}
.recruitment-switch__content {
  display: none;
  visibility: hidden;
  transition: opacity 0.5s ease, visibility 0.5s ease;
  position: absolute;
}
.recruitment-switch__content.active {
  display: block;
  visibility: visible;
  position: relative;
}
.recruitment-switch__content .recruitment-block {
  margin-bottom: 40px;
  padding-bottom: 20px;
  border-bottom: 1px solid #ccc;
}
.recruitment-switch__content .recruitment-block .block-title {
  position: relative;
  font-size: 2.2rem;
  font-weight: 600;
  color: #3c9841;
  padding-left: 50px;
  margin-bottom: 20px;
}
.recruitment-switch__content .recruitment-block .block-title::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #3c9841;
}
.recruitment-switch__content .recruitment-block .block-text {
  font-size: 2rem;
  line-height: 1.8;
  white-space: pre-line;
  padding-left: 20px;
}
.recruitment-switch__content .recruitment-block .google-map-link {
  color: #3c9841;
  text-decoration: underline;
  cursor: pointer;
}
.recruitment-switch__content .recruitment-block .google-map-link:hover {
  text-decoration: none;
}

@media (max-width: 440px) {
  .recruitment .recruitment-wrapper .recruitment-top {
    margin: 50px 0;
    margin-left: -65px;
  }
  .recruitment .recruitment-wrapper .recruitment-text {
    font-size: 3.5rem;
  }
  .recruitment .recruitment-wrapper .recruitment-text2 {
    font-size: 2rem;
  }
  .recruitment-switch {
    padding: 20px 10px;
  }
  .recruitment-switch__buttons .recruitment-switch__btn {
    font-size: 1.6rem;
    padding: 20px 0;
  }
  .recruitment-switch__buttons .recruitment-switch__btn::after {
    display: none;
  }
  .recruitment-switch__buttons .recruitment-switch__btn.active {
    border: 2px solid #3c9841;
    background-color: #3c9841;
    color: #fff;
  }
  .recruitment-switch__content .recruitment-block .block-title {
    font-size: 1.8rem;
  }
  .recruitment-switch__content .recruitment-block .block-title::before {
    width: 15px;
    height: 15px;
    left: 15px;
  }
  .recruitment-switch__content .recruitment-block .block-text {
    font-size: 1.6rem;
  }
}
/* js header color change*/
.header {
  background-color: transparent;
  transition: background-color 0.5s ease;
  z-index: 120;
}
.header.bg-colored {
  background-color: #aacf53;
}

#message {
  scroll-margin-top: 100px;
}

.up-in {
  animation: up-in 1s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}

@keyframes up-in {
  0% {
    opacity: 0;
    transform: translateY(40px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.float-in {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.chapter-label .char,
.section-top .char {
  display: inline-block;
  opacity: 0;
  transform: translateX(-30px);
  animation: slideInRight 0.5s forwards ease;
}

@keyframes slideInRight {
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@media (max-width: 1024px) {
  .entry-fixed {
    top: 88%;
    height: 12%;
  }
}
@media (max-width: 820px) {
  .entry-fixed {
    top: 90%;
    height: 10%;
  }
}
/* 記事ページ */
.recruit-news {
  background-color: #ffffff;
  color: #333;
}
.recruit-news .recruit-news-wrapper {
  position: relative;
}
.recruit-news .recruit-news-wrapper .recruit-news-top {
  margin: 150px 0;
  width: 1920px;
  height: 336px;
  max-width: none;
  overflow: visible;
}
.recruit-news .recruit-news-wrapper .recruit-news-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 4.5rem;
  font-weight: bold;
  color: rgb(0, 0, 0);
  text-align: center;
}
.recruit-news .recruit-news-wrapper .recruit-news-text::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 110%;
  height: 100%;
  background-color: #fff;
  transform: translate(-50%, -50%) skew(-12deg);
  z-index: -1;
}
.recruit-news .recruit-news-wrapper .recruit-news-text2 {
  position: absolute;
  top: 60%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: rgb(0, 0, 0);
  font-size: 2.5rem;
  font-weight: 600;
  text-align: center;
}
.recruit-news .recruit-news-box {
  padding: 40px;
}
.recruit-news .recruit-news-box__inner {
  max-width: 1200px;
  margin: 0 auto;
  background: #fff;
  border-radius: 12px;
  padding: 3rem 6rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}
.recruit-news .recruit-news-box__date {
  font-size: 2.5rem;
  color: #888;
  margin-bottom: 1rem;
  text-align: right;
  font-family: "Montserrat", sans-serif;
}
.recruit-news .recruit-news-box__title {
  font-size: 3.5em;
  font-weight: bold;
  margin-bottom: 6rem;
  border-left: 5px solid #aacd53;
  padding-left: 1rem;
  line-height: 1.4;
}
.recruit-news .recruit-news-box__body {
  line-height: 2;
}
.recruit-news .recruit-news-box__body p {
  font-size: 2.5rem;
  margin-bottom: 5rem;
}
.recruit-news .recruit-news-box__body p strong {
  background: linear-gradient(transparent 70%, #fff8b5 70%);
  font-weight: bold;
}
.recruit-news .recruit-news-box__body p a {
  display: inline-block;
  color: #0066cc;
  text-decoration: underline;
  word-break: break-word;
}
.recruit-news .recruit-news-box__body p a:hover {
  color: rgb(0, 76.5, 153);
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  .recruit-news .recruit-news-wrapper .recruit-news-top {
    margin: 50px 0;
    margin-left: -140px;
  }
  .recruit-news .recruit-news-box {
    padding: 5px;
  }
  .recruit-news .recruit-news-box__inner {
    padding: 2rem 1.5rem;
  }
  .recruit-news .recruit-news-box__title {
    font-size: 2rem;
  }
  .recruit-news .recruit-news-box__body p {
    font-size: 2rem;
    font-weight: 500;
  }
}
.transition-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: transparent;
  z-index: 9999;
  pointer-events: none; /* アニメーション中は下の要素に触れないようにする */
  /* 初期状態：右下に隠れた円 */
  clip-path: circle(0% at 100% 100%);
  transition: clip-path 1.2s cubic-bezier(0.8, 0, 0.2, 1);
}

.transition-in-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #2ecc71; /* 緑色 */
  z-index: 99999;
  pointer-events: none;
  /* 初期状態：画面全体を覆う */
  clip-path: circle(150% at 100% 100%);
  transition: clip-path 1.2s cubic-bezier(0.8, 0, 0.2, 1);
}

/* アニメーション開始時（画面から消える時） */
.transition-in-overlay.is-active {
  clip-path: circle(0% at 100% 100%);
}/*# sourceMappingURL=style.css.map */