@media (max-width: 576px) {
  html {
    font-size: 0.2666666667vw;
  }
}
@media (min-width: 576.1px) and (max-width: 959px) {
  html {
    font-size: 1.5px;
  }
}
@media (min-width: 959.1px) and (max-width: 1600px) {
  html {
    font-size: 0.0694444444vw;
  }
}
@media (min-width: 1600.1px) {
  html {
    font-size: 1.25px;
  }
}

html {
  overflow-x: hidden;
}

body {
  background: #F5F5F5;
  font-size: 14rem;
  font-family: "noto-sans-cjk-jp", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.8;
  letter-spacing: 0.05em;
  color: #444444;
  text-align: justify;
  text-justify: inter-ideograph;
  -webkit-text-size-adjust: 100%;
  word-break: break-word;
  font-feature-settings: "palt";
  margin: 0;
  padding: 0;
  width: 100%;
  overflow-x: hidden;
  opacity: 0;
  animation: fadeIn 0.4s ease-in forwards;
}
@media (min-width: 959.1px) {
  body {
    font-size: 16rem;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
body.no-scroll {
  overflow: hidden;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
}

a,
input[type=button],
input[type=submit],
button {
  color: #444444;
  text-decoration: underline;
}
@media (min-width: 959.1px) {
  a,
  input[type=button],
  input[type=submit],
  button {
    transition: 0.2s;
  }
  a:hover,
  input[type=button]:hover,
  input[type=submit]:hover,
  button:hover {
    text-decoration: none;
    opacity: 0.8;
  }
}
a:visited,
input[type=button]:visited,
input[type=submit]:visited,
button:visited {
  color: #444444;
}

.sp-only {
  display: block !important;
}
@media (min-width: 959.1px) {
  .sp-only {
    display: none !important;
  }
}

.pc-only {
  display: none !important;
}
@media (min-width: 959.1px) {
  .pc-only {
    display: block !important;
  }
}

section,
nav,
header,
footer,
article,
p,
h1,
h2,
h3,
h4,
h5 {
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5 {
  font-weight: 700;
  color: #222222;
}

img {
  width: 100%;
  height: auto;
  display: block;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
ul li {
  margin: 0;
  padding: 0;
}

dl,
dt,
dd {
  margin: 0;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

input,
textarea {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

button {
  background: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

.marker-text.simple .marker.red {
  background: linear-gradient(transparent 85%, rgb(221, 0, 17) 85%) no-repeat;
  display: inline;
  background-size: 0% 100%;
  background-position: 0px -2rem;
  transition: background-size 1.5s;
}
.marker-text.simple .marker.yellow {
  background: linear-gradient(transparent 85%, rgb(255, 222, 0) 85%) no-repeat;
  display: inline;
  background-size: 0% 100%;
  background-position: 0px -2rem;
  transition: background-size 1.5s;
}
.marker-text.simple .marker.green {
  background: linear-gradient(transparent 85%, rgb(20, 168, 59) 85%) no-repeat;
  display: inline;
  background-size: 0% 100%;
  background-position: 0px -2rem;
  transition: background-size 1.5s;
}
.marker-text.simple .marker.blue {
  background: linear-gradient(transparent 85%, rgb(0, 160, 233) 85%) no-repeat;
  display: inline;
  background-size: 0% 100%;
  background-position: 0px -2rem;
  transition: background-size 1.5s;
}
.marker-text.simple .marker.pink {
  background: linear-gradient(transparent 85%, rgb(228, 0, 127) 85%) no-repeat;
  display: inline;
  background-size: 0% 100%;
  background-position: 0px -2rem;
  transition: background-size 1.5s;
}
.marker-text.simple .marker.active {
  background-size: 100% 100%;
}

/*------------------------------------------*/
header {
  position: relative;
  z-index: 999;
}
@media (min-width: 959.1px) {
  header {
    position: fixed;
    width: 100%;
  }
}
@media (min-width: 959.1px) {
  header.is-animation .inner {
    height: 80rem;
    background: #fff;
  }
}
@media (min-width: 959.1px) {
  header.is-animation .inner .logo {
    width: 150rem;
  }
}
header .inner {
  height: 80rem;
  padding: 0 0 0 20rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: 0.3s;
}
@media (min-width: 959.1px) {
  header .inner {
    height: 100rem;
    padding: 0 40rem 0;
  }
}
header .inner .logo {
  width: 133rem;
  line-height: 1;
  position: relative;
  transition: 0.3s;
}
@media (min-width: 959.1px) {
  header .inner .logo {
    width: 170rem;
  }
}
header .inner .menu-container {
  position: fixed;
  top: 0;
  right: 0;
  overflow: hidden;
}
@media (min-width: 959.1px) {
  header .inner .menu-container {
    position: static;
    overflow: inherit;
  }
}
header .inner .menu-container .menu-button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8rem;
  position: relative;
  top: 0;
  right: 0;
  height: 80rem;
  width: 80rem;
  cursor: pointer;
  z-index: 2;
}
@media (min-width: 959.1px) {
  header .inner .menu-container .menu-button {
    display: none;
  }
}
header .inner .menu-container .menu-button .bar {
  display: block;
  width: 30rem;
  height: 4rem;
  border-radius: 2rem;
  background: #222222;
  transition: 0.4s;
}
header .inner .menu-container #menu-toggle:checked ~ .menu-button .bar:nth-child(1) {
  transform-origin: center;
  transform: rotate(45deg) translate(8rem, 9rem);
}
header .inner .menu-container #menu-toggle:checked ~ .menu-button .bar:nth-child(2) {
  opacity: 0;
}
header .inner .menu-container #menu-toggle:checked ~ .menu-button .bar:nth-child(3) {
  transform-origin: center;
  transform: rotate(-45deg) translate(8rem, -9rem);
}
header .inner .menu-container #menu-toggle {
  display: none;
}
header .inner .menu-container #menu-toggle:checked ~ .menu {
  opacity: 1;
  visibility: visible;
}
header .inner .menu-container .menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s, visibility 0.4s;
  z-index: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media (min-width: 959.1px) {
  header .inner .menu-container .menu {
    background: none;
    position: static;
    flex-direction: row;
    width: inherit;
    height: inherit;
    opacity: 1;
    overflow: inherit;
    transition: inherit;
    visibility: inherit;
    align-items: flex-end;
    flex-direction: column-reverse;
  }
}
header .inner .menu-container .menu ul {
  list-style: none;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 30rem;
}
@media (min-width: 959.1px) {
  header .inner .menu-container .menu ul {
    flex-direction: row;
  }
}
header .inner .menu-container .menu ul li.menu-logo {
  width: 100rem;
  margin: 0 auto;
}
@media (min-width: 959.1px) {
  header .inner .menu-container .menu ul li.menu-logo {
    display: none;
  }
}
header .inner .menu-container .menu ul li a {
  text-decoration: none;
  font-size: 20rem;
  font-weight: 700;
  color: #222222;
}
@media (min-width: 959.1px) {
  header .inner .menu-container .menu ul li a {
    font-size: 16rem;
    font-weight: 400;
  }
}

/*------------------------------------------*/
footer {
  background: #fff;
}
footer .inner {
  padding: 0 20rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  footer .inner {
    padding: 0 40rem;
    margin: 0 auto;
  }
}
footer .inner .bana-area {
  display: flex;
  flex-direction: column;
  margin: 0 -20rem;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area {
    flex-direction: row;
    justify-content: space-between;
    margin: 0 -40rem;
  }
}
footer .inner .bana-area .bana {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 260rem;
  display: flex;
  text-decoration: none;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana {
    height: 500rem;
  }
}
footer .inner .bana-area .bana.recruit::after {
  background: url(../images/bana5.webp) center center/cover no-repeat;
}
footer .inner .bana-area .bana.recruit .filter::before {
  background: rgba(255, 222, 0, 0.5);
}
footer .inner .bana-area .bana.recruit .filter::after {
  background: linear-gradient(90deg, rgb(255, 222, 0) 0%, rgba(255, 222, 0, 0) 100%);
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana.recruit:hover .arrow::before {
    color: #FFDE00;
  }
}
footer .inner .bana-area .bana.product::after {
  background: url(../images/bana6.webp) center center/cover no-repeat;
}
footer .inner .bana-area .bana.product .filter::before {
  background: rgba(228, 0, 127, 0.5);
}
footer .inner .bana-area .bana.product .filter::after {
  background: linear-gradient(90deg, rgb(228, 0, 127) 0%, rgba(228, 0, 127, 0) 100%);
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana.product:hover .arrow::before {
    color: #E4007F;
  }
}
footer .inner .bana-area .bana::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease-in-out;
}
footer .inner .bana-area .bana .filter {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
}
footer .inner .bana-area .bana .filter::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
footer .inner .bana-area .bana .filter::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
footer .inner .bana-area .bana .frame {
  position: relative;
  z-index: 3;
  padding: 30rem 20rem;
  width: 100%;
  height: 100%;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana .frame {
    padding: 60rem 50rem;
  }
}
footer .inner .bana-area .bana .frame h4 {
  color: #fff;
  display: flex;
  flex-direction: column;
  line-height: 1;
}
footer .inner .bana-area .bana .frame h4 .en {
  font-family: "poppins", sans-serif;
  font-size: 30rem;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana .frame h4 .en {
    font-size: 50rem;
  }
}
footer .inner .bana-area .bana .frame h4 .jp {
  font-size: 16rem;
  margin-top: 5rem;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana .frame h4 .jp {
    font-size: 20rem;
    margin-top: 10rem;
  }
}
footer .inner .bana-area .bana .frame p {
  margin-top: 20rem;
  color: #fff;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana .frame p {
    margin-top: 30rem;
  }
}
footer .inner .bana-area .bana .frame .arrow {
  position: absolute;
  right: 20rem;
  bottom: 20rem;
  width: 25rem;
  height: 25rem;
  border-radius: 50%;
  border: 2px solid #fff;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana .frame .arrow {
    right: 50rem;
    bottom: 60rem;
    width: 50rem;
    height: 50rem;
  }
}
footer .inner .bana-area .bana .frame .arrow::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Material Symbols Outlined";
  content: "\e5c8";
  color: #fff;
  font-size: 12rem;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana .frame .arrow::before {
    font-size: 20rem;
  }
}
footer .inner .bana-area .bana:hover {
  opacity: 1;
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana:hover::after {
    transform: scale(1.1);
  }
}
@media (min-width: 959.1px) {
  footer .inner .bana-area .bana:hover .arrow {
    background: #fff;
  }
  footer .inner .bana-area .bana:hover .arrow::before {
    color: #00A0E9;
  }
}
footer .inner .f-sitemap {
  padding: 50rem 0;
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap {
    padding: 60rem 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
}
footer .inner .f-sitemap .block .logo {
  width: 170rem;
}
footer .inner .f-sitemap .block .menu {
  margin-top: 40rem;
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block .menu {
    margin-top: 20rem;
    display: flex;
  }
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block .menu ul {
    display: flex;
  }
}
footer .inner .f-sitemap .block .menu ul li {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block .menu ul li {
    margin-top: 0;
    margin-right: 10rem;
  }
}
footer .inner .f-sitemap .block .menu ul li a[target=_blank]::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  background-color: #fff;
  display: inline-block;
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block .menu .associate {
    display: flex;
  }
}
footer .inner .f-sitemap .block .menu .associate .sub {
  font-size: 12rem;
  margin-top: 15rem;
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block .menu .associate .sub {
    font-size: 16rem;
    margin-top: 0;
    margin-left: 40rem;
  }
}
footer .inner .f-sitemap .block .sns {
  margin-top: 30rem;
  width: 40rem;
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block .sns {
    margin-top: 0;
  }
}
footer .inner .f-sitemap .block .copyright {
  margin-top: 40rem;
  font-size: 10rem;
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block .copyright {
    margin-top: 20rem;
    font-size: 16rem;
  }
}
@media (min-width: 959.1px) {
  footer .inner .f-sitemap .block:last-child {
    align-items: flex-end;
    display: flex;
    flex-direction: column;
  }
}

/*------------------------------------------*/
#top #top-main .inner {
  padding: 90rem 10rem 20rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #top #top-main .inner {
    padding: 200rem 40rem 50rem;
    max-width: 990rem;
    margin: 0 auto;
  }
}
#top #top-main .inner .bg {
  background: url(../images/mv.webp) no-repeat center center/contain;
  width: 355rem;
  height: 299rem;
  position: relative;
  z-index: -1;
  display: block;
  margin: 0 auto;
}
@media (min-width: 959.1px) {
  #top #top-main .inner .bg {
    width: 990rem;
    height: 796rem;
  }
}
#top #top-main .inner .bg h1 {
  padding-top: 20rem;
  font-size: 28rem;
  letter-spacing: 0;
  line-height: 52rem;
  text-align: center;
}
@media (min-width: 959.1px) {
  #top #top-main .inner .bg h1 {
    padding-top: 50rem;
    font-size: 74rem;
    line-height: 130rem;
  }
}
#top #top-main .inner .bg h1 .marker {
  position: relative;
  display: inline-block;
  font-size: 38rem;
  padding-bottom: 0;
  z-index: 1;
}
@media (min-width: 959.1px) {
  #top #top-main .inner .bg h1 .marker {
    font-size: 98rem;
  }
}
#top #top-main .inner .bg h1 .marker::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 2rem;
  width: 100%;
  height: 20rem;
  z-index: -1;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.5s ease;
  background-repeat: no-repeat;
  background-position: left bottom;
  background-size: contain;
}
#top #top-main .inner .bg h1 .marker.red::before {
  background-image: url("../images/main-red.svg");
}
#top #top-main .inner .bg h1 .marker.green::before {
  background-image: url("../images/main-green.svg");
}
#top #top-main .inner .bg h1 .marker.blue::before {
  background-image: url("../images/main-blue.svg");
}
#top #top-main .inner .bg h1 .marker.yellow::before {
  background-image: url("../images/main-yellow.svg");
}
#top #top-main .inner .bg h1 .marker.active::before {
  clip-path: inset(0 0% 0 0);
}
#top #top-about .inner {
  padding: 100rem 20rem 75rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #top #top-about .inner {
    padding: 200rem 40rem 150rem;
    margin: 0 auto;
  }
}
#top #top-about .inner h2 {
  margin: 0;
  padding: 0;
  line-height: 1;
  text-align: center;
}
#top #top-about .inner h2 .txt {
  font-size: 20rem;
  line-height: 1.5;
  display: block;
  margin-bottom: 5rem;
}
@media (min-width: 959.1px) {
  #top #top-about .inner h2 .txt {
    font-size: 40rem;
  }
}
#top #top-about .inner h2 .marker {
  font-size: 40rem;
  display: inline;
  background: linear-gradient(transparent 85%, rgb(221, 0, 17) 85%) no-repeat;
  background-size: 0% 100%;
  background-position: 0px -5rem;
  transition: background-size 1.5s;
}
@media (min-width: 959.1px) {
  #top #top-about .inner h2 .marker {
    font-size: 70rem;
    background-position: 0px -10rem;
  }
}
#top #top-about .inner h2 .marker.active {
  background-size: 100% 100%;
}
#top #top-about .inner .slider-wrap {
  overflow: hidden;
  width: calc(100% + 40rem);
  margin: 50rem -20rem 0;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .slider-wrap {
    width: calc(100% + 80rem);
    margin: 100rem -40rem 0;
  }
}
#top #top-about .inner .slider-wrap .slider-track {
  display: flex;
  transform: translateX(0);
  will-change: transform;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout {
  display: grid;
  grid-template: "slide1 slide1 slide4 slide5 slide6 slide8" 115rem "slide2 slide3 slide4 slide7 slide7 slide8" 115rem/115rem 115rem 200rem 115rem 115rem 250rem;
  align-items: center;
  gap: 20rem;
  margin-right: 20rem;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .slider-wrap .slider-track .slide-layout {
    grid-template: "slide1 slide1 slide4 slide5 slide6 slide8" 230rem "slide2 slide3 slide4 slide7 slide7 slide8" 230rem/230rem 230rem 400rem 230rem 230rem 500rem;
    gap: 40rem;
    margin-right: 40rem;
  }
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide {
  display: flex;
  align-items: center;
  height: 100%;
  width: 100%;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide img {
  border-radius: 12rem;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .slider-wrap .slider-track .slide-layout .slide img {
    border-radius: 25rem;
  }
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide1 {
  grid-area: slide1;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide2 {
  grid-area: slide2;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide3 {
  grid-area: slide3;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide4 {
  grid-area: slide4;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide5 {
  grid-area: slide5;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide6 {
  grid-area: slide6;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide7 {
  grid-area: slide7;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide.slide8 {
  grid-area: slide8;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide .flip {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 1s;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide .flip .flip-front,
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide .flip .flip-back {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  overflow: hidden;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide .flip .flip-front img,
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide .flip .flip-back img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
#top #top-about .inner .slider-wrap .slider-track .slide-layout .slide .flip .flip-back {
  transform: rotateY(180deg);
}
#top #top-about .inner p {
  margin-top: 40px;
  font-size: 18rem;
  font-weight: 700;
  line-height: 2;
  color: #222222;
}
@media (min-width: 959.1px) {
  #top #top-about .inner p {
    margin-top: 120px;
    font-size: 25rem;
    text-align: center;
  }
}
#top #top-about .inner .bana-area {
  margin-top: 50rem;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area {
    margin-top: 100rem;
    flex-direction: row;
    justify-content: space-between;
    gap: 0;
  }
}
#top #top-about .inner .bana-area .bana {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 150rem;
  display: flex;
  text-decoration: none;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana {
    height: 300rem;
  }
}
#top #top-about .inner .bana-area .bana.message::after {
  background: url(../images/bana1.webp) center center/cover no-repeat;
}
#top #top-about .inner .bana-area .bana.overview::after {
  background: url(../images/bana2.webp) center center/cover no-repeat;
}
#top #top-about .inner .bana-area .bana::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease-in-out;
}
#top #top-about .inner .bana-area .bana .filter {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#top #top-about .inner .bana-area .bana .filter::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(230, 0, 18, 0.5);
}
#top #top-about .inner .bana-area .bana .filter::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, rgb(230, 0, 18) 0%, rgba(230, 0, 18, 0) 100%);
}
#top #top-about .inner .bana-area .bana .frame {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20rem;
  width: 100%;
  height: 100%;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana .frame {
    padding: 40rem;
  }
}
#top #top-about .inner .bana-area .bana .frame h4 {
  color: #fff;
  display: flex;
  flex-direction: column;
  line-height: 1;
}
#top #top-about .inner .bana-area .bana .frame h4 .en {
  font-family: "poppins", sans-serif;
  font-size: 25rem;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana .frame h4 .en {
    font-size: 50rem;
  }
}
#top #top-about .inner .bana-area .bana .frame h4 .jp {
  font-size: 12rem;
  margin-top: 5rem;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana .frame h4 .jp {
    font-size: 20rem;
    margin-top: 10rem;
  }
}
#top #top-about .inner .bana-area .bana .frame .arrow {
  width: 25rem;
  height: 25rem;
  border-radius: 50%;
  border: 2px solid #fff;
  position: relative;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana .frame .arrow {
    width: 50rem;
    height: 50rem;
  }
}
#top #top-about .inner .bana-area .bana .frame .arrow::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Material Symbols Outlined";
  content: "\e5c8";
  color: #fff;
  font-size: 12rem;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana .frame .arrow::before {
    font-size: 20rem;
  }
}
#top #top-about .inner .bana-area .bana:hover {
  opacity: 1;
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana:hover::after {
    transform: scale(1.1);
  }
}
@media (min-width: 959.1px) {
  #top #top-about .inner .bana-area .bana:hover .arrow {
    background: #fff;
  }
  #top #top-about .inner .bana-area .bana:hover .arrow::before {
    color: #E60012;
  }
}
#top #top-business .inner {
  padding: 70rem 20rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #top #top-business .inner {
    padding: 150rem 40rem;
    margin: 0 auto;
  }
}
#top #top-business .inner h2 {
  line-height: 1;
  display: flex;
  flex-direction: column;
  position: relative;
}
#top #top-business .inner h2::after {
  content: "BUSINESS";
  line-height: 1;
  font-family: "poppins", sans-serif;
  font-size: 100rem;
  color: #eee;
  position: absolute;
  top: 50%;
  left: 100rem;
  transform: translateY(-50%);
  overflow: hidden;
  white-space: nowrap;
  z-index: -1;
}
@media (min-width: 959.1px) {
  #top #top-business .inner h2::after {
    font-size: 300rem;
    left: 360rem;
  }
}
#top #top-business .inner h2 .en {
  font-family: "poppins", sans-serif;
  font-size: 30rem;
  color: #00A0E9;
}
@media (min-width: 959.1px) {
  #top #top-business .inner h2 .en {
    font-size: 60rem;
  }
}
#top #top-business .inner h2 .jp {
  margin-top: 5rem;
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner h2 .jp {
    font-size: 20rem;
    margin-top: 10rem;
  }
}
#top #top-business .inner .wrap {
  margin-top: 70rem;
  display: flex;
  flex-direction: column;
  gap: 40rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap {
    margin-top: 140rem;
    gap: 80rem;
  }
}
#top #top-business .inner .wrap .block {
  background: #fff;
  border-radius: 0 20rem 20rem 0;
  width: calc(100% + 20rem);
  margin: 0 0 0 -20rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block {
    border-radius: 0 25rem 25rem 0;
    width: calc(100% + 40rem);
    margin: 0 0 0 -40rem;
  }
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame {
    display: flex;
    align-items: center;
  }
}
#top #top-business .inner .wrap .block .frame .img img {
  border-radius: 0 20rem 0 0;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .img img {
    border-radius: 0;
  }
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .img {
    width: 55%;
  }
}
#top #top-business .inner .wrap .block .frame .txt {
  padding: 30rem 20rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .txt {
    padding: 0 70rem;
    width: 45%;
  }
}
#top #top-business .inner .wrap .block .frame .txt h3 {
  font-size: 20rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .txt h3 {
    font-size: 40rem;
  }
}
#top #top-business .inner .wrap .block .frame .txt p {
  margin-top: 20rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .txt p {
    margin-top: 30rem;
  }
}
#top #top-business .inner .wrap .block .frame .txt .btn {
  margin-top: 20rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .txt .btn {
    margin-top: 30rem;
  }
}
#top #top-business .inner .wrap .block .frame .txt .btn a {
  width: fit-content;
  height: 40rem;
  padding: 0 30rem;
  color: #00A0E9;
  border: 2px solid #00A0E9;
  border-radius: 20rem;
  line-height: 1;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .txt .btn a {
    height: 60rem;
    padding: 0 50rem;
    border-radius: 30rem;
  }
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block .frame .txt .btn a:hover {
    background: #00A0E9;
    color: #fff;
  }
}
#top #top-business .inner .wrap .block:nth-child(2n) {
  border-radius: 20rem 0 0 20rem;
  width: calc(100% + 20rem);
  margin: 0 -20rem 0 0;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block:nth-child(2n) {
    border-radius: 25rem 0 0 25rem;
    width: calc(100% + 40rem);
    margin: 0 -40rem 0 0;
  }
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block:nth-child(2n) .frame {
    flex-direction: row-reverse;
  }
}
#top #top-business .inner .wrap .block:nth-child(2n) .frame .img img {
  border-radius: 20rem 0 0 0;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .wrap .block:nth-child(2n) .frame .img img {
    border-radius: 0;
  }
}
#top #top-business .inner .bana-area {
  margin-top: 50rem;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area {
    margin-top: 100rem;
    flex-direction: row;
    justify-content: space-between;
    gap: 0;
  }
}
#top #top-business .inner .bana-area .bana {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 150rem;
  display: flex;
  text-decoration: none;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana {
    height: 300rem;
  }
}
#top #top-business .inner .bana-area .bana.consulting::after {
  background: url(../images/bana3.webp) center center/cover no-repeat;
}
#top #top-business .inner .bana-area .bana.event::after {
  background: url(../images/bana4.webp) center center/cover no-repeat;
}
#top #top-business .inner .bana-area .bana::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease-in-out;
}
#top #top-business .inner .bana-area .bana .filter {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#top #top-business .inner .bana-area .bana .filter::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 160, 233, 0.5);
}
#top #top-business .inner .bana-area .bana .filter::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, rgb(0, 160, 233) 0%, rgba(0, 160, 233, 0) 100%);
}
#top #top-business .inner .bana-area .bana .frame {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20rem;
  width: 100%;
  height: 100%;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana .frame {
    padding: 40rem;
  }
}
#top #top-business .inner .bana-area .bana .frame h4 {
  color: #fff;
  display: flex;
  flex-direction: column;
  line-height: 1;
}
#top #top-business .inner .bana-area .bana .frame h4 .en {
  font-family: "poppins", sans-serif;
  font-size: 25rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana .frame h4 .en {
    font-size: 50rem;
  }
}
#top #top-business .inner .bana-area .bana .frame h4 .jp {
  font-size: 12rem;
  margin-top: 5rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana .frame h4 .jp {
    font-size: 20rem;
    margin-top: 10rem;
  }
}
#top #top-business .inner .bana-area .bana .frame .arrow {
  width: 25rem;
  height: 25rem;
  border-radius: 50%;
  border: 2px solid #fff;
  position: relative;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana .frame .arrow {
    width: 50rem;
    height: 50rem;
  }
}
#top #top-business .inner .bana-area .bana .frame .arrow::before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: "Material Symbols Outlined";
  content: "\e5c8";
  color: #fff;
  font-size: 12rem;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana .frame .arrow::before {
    font-size: 20rem;
  }
}
#top #top-business .inner .bana-area .bana:hover {
  opacity: 1;
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana:hover::after {
    transform: scale(1.1);
  }
}
@media (min-width: 959.1px) {
  #top #top-business .inner .bana-area .bana:hover .arrow {
    background: #fff;
  }
  #top #top-business .inner .bana-area .bana:hover .arrow::before {
    color: #00A0E9;
  }
}
#top #top-achievements {
  background: #fff;
  position: relative;
  z-index: 1;
}
#top #top-achievements .inner {
  padding: 100rem 20rem 70rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner {
    padding: 250rem 40rem 150rem;
    margin: 0 auto;
  }
}
#top #top-achievements .inner h2 {
  line-height: 1;
  display: flex;
  flex-direction: column;
  position: relative;
}
#top #top-achievements .inner h2::after {
  content: "ACHIEVEMENTS";
  line-height: 1;
  font-family: "poppins", sans-serif;
  font-size: 100rem;
  color: #F5F5F5;
  position: absolute;
  top: 50%;
  left: 100rem;
  transform: translateY(-50%);
  overflow: hidden;
  white-space: nowrap;
  z-index: -1;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner h2::after {
    font-size: 300rem;
    left: 360rem;
  }
}
#top #top-achievements .inner h2 .en {
  font-family: "poppins", sans-serif;
  font-size: 30rem;
  color: #14A83B;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner h2 .en {
    font-size: 60rem;
  }
}
#top #top-achievements .inner h2 .jp {
  margin-top: 5rem;
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner h2 .jp {
    font-size: 20rem;
    margin-top: 10rem;
  }
}
#top #top-achievements .inner .wrap {
  margin-top: 70rem;
  display: flex;
  flex-direction: column;
  gap: 40rem;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .wrap {
    margin-top: 140rem;
    gap: 50rem;
    flex-direction: row;
    flex-wrap: nowrap;
  }
}
#top #top-achievements .inner .wrap .block {
  width: 100%;
}
#top #top-achievements .inner .wrap .block .frame .img img {
  border-radius: 20rem;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .wrap .block .frame .img img {
    border-radius: 25rem;
  }
}
#top #top-achievements .inner .wrap .block .frame .txt {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .wrap .block .frame .txt {
    margin-top: 20rem;
  }
}
#top #top-achievements .inner .wrap .block .frame .txt h3 {
  font-size: 20rem;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .wrap .block .frame .txt h3 {
    font-size: 25rem;
  }
}
#top #top-achievements .inner .wrap .block .frame .txt p {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .wrap .block .frame .txt p {
    margin-top: 20rem;
  }
}
#top #top-achievements .inner .btn {
  margin-top: 50rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .btn {
    margin-top: 100rem;
  }
}
#top #top-achievements .inner .btn a {
  border: 2px solid #14A83B;
  height: 60rem;
  padding: 0 60rem;
  border-radius: 30rem;
  color: #14A83B;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .btn a {
    height: 80rem;
    padding: 0 90rem;
    border-radius: 40rem;
  }
}
@media (min-width: 959.1px) {
  #top #top-achievements .inner .btn a:hover {
    background: #14A83B;
    color: #fff;
  }
}

/*------------------------------------------*/
#lower-main .inner {
  padding: 70rem 20rem 70rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #lower-main .inner {
    padding: 300rem 40rem 170rem;
    margin: 0 auto;
  }
}
#lower-main .inner .breadcrumb {
  overflow-x: auto;
  width: 100%;
}
#lower-main .inner .breadcrumb ul {
  display: flex;
  flex-wrap: nowrap;
  font-size: 10rem;
}
@media (min-width: 959.1px) {
  #lower-main .inner .breadcrumb ul {
    font-size: 12rem;
  }
}
#lower-main .inner .breadcrumb ul li {
  white-space: nowrap;
  display: flex;
  align-items: center;
}
#lower-main .inner .breadcrumb ul li:not(:last-child)::after {
  content: "";
  background: #aaa;
  height: 1px;
  width: 10rem;
  margin: 0 5rem;
}
#lower-main .inner .breadcrumb ul li a {
  text-decoration: none;
}
#lower-main .inner h1 {
  margin-top: 10rem;
  line-height: 1;
  display: flex;
  flex-direction: column;
  position: relative;
}
@media (min-width: 959.1px) {
  #lower-main .inner h1 {
    margin-top: 20rem;
  }
}
#lower-main .inner h1::after {
  line-height: 1;
  font-family: "poppins", sans-serif;
  font-size: 100rem;
  color: #eee;
  position: absolute;
  top: 50%;
  left: 100rem;
  transform: translateY(-50%);
  overflow: hidden;
  white-space: nowrap;
  z-index: -1;
}
@media (min-width: 959.1px) {
  #lower-main .inner h1::after {
    font-size: 300rem;
    left: 360rem;
  }
}
#lower-main .inner h1 .en {
  font-family: "poppins", sans-serif;
  font-size: 30rem;
}
@media (min-width: 959.1px) {
  #lower-main .inner h1 .en {
    font-size: 60rem;
  }
}
#lower-main .inner h1 .en.red {
  color: #E60012;
}
#lower-main .inner h1 .en.yellow {
  color: #FFDE00;
}
#lower-main .inner h1 .en.green {
  color: #14A83B;
}
#lower-main .inner h1 .en.blue {
  color: #00A0E9;
}
#lower-main .inner h1 .en.pink {
  color: #E4007F;
}
#lower-main .inner h1 .jp {
  margin-top: 5rem;
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #lower-main .inner h1 .jp {
    font-size: 20rem;
    margin-top: 10rem;
  }
}

/*------------------------------------------*/
#message #lower-main h1::after {
  content: "MESSAGE";
}
#message #sentence .inner {
  padding: 0 20rem 70rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #message #sentence .inner {
    padding: 0 40rem 150rem;
    margin: 0 auto;
  }
}
#message #sentence .inner h2 {
  text-align: center;
  font-size: 20rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #message #sentence .inner h2 {
    font-size: 40rem;
  }
}
#message #sentence .inner > .txt {
  margin-top: 30rem;
  font-size: 16rem;
  font-weight: 700;
  color: #222222;
  line-height: 2;
}
@media (min-width: 959.1px) {
  #message #sentence .inner > .txt {
    margin-top: 60rem;
    font-size: 25rem;
    text-align: center;
  }
}
#message #sentence .inner .img {
  margin: 30rem auto 0;
  width: 150rem;
}
@media (min-width: 959.1px) {
  #message #sentence .inner .img {
    margin: 60rem auto 0;
    width: 300rem;
  }
}
#message #sentence .inner .name {
  margin-top: 10rem;
  text-align: center;
}
@media (min-width: 959.1px) {
  #message #sentence .inner .name {
    margin-top: 20rem;
  }
}
#message #sentence .inner .wrap {
  margin-top: 50rem;
  display: flex;
  flex-direction: column;
  gap: 20rem;
}
@media (min-width: 959.1px) {
  #message #sentence .inner .wrap {
    margin-top: 100rem;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 40rem;
  }
}
#message #sentence .inner .wrap .block {
  background: #fff;
  padding: 30rem 20rem;
  border-radius: 20rem;
}
@media (min-width: 959.1px) {
  #message #sentence .inner .wrap .block {
    width: 48.5%;
    padding: 70rem;
    border-radius: 25rem;
  }
}
#message #sentence .inner .wrap .block h3 {
  font-size: 20rem;
}
@media (min-width: 959.1px) {
  #message #sentence .inner .wrap .block h3 {
    font-size: 40rem;
  }
}
#message #sentence .inner .wrap .block .txt {
  margin-top: 20rem;
}
@media (min-width: 959.1px) {
  #message #sentence .inner .wrap .block .txt {
    margin-top: 30rem;
  }
}
#message #sentence .inner .wrap .block .txt ul li {
  text-indent: -1em;
  padding-left: 1em;
  font-feature-settings: normal;
  letter-spacing: 0;
}

/*------------------------------------------*/
#overview #lower-main h1::after {
  content: "OVERVIEW";
}
#overview #company-info .inner,
#overview #company-access .inner {
  padding: 0 20rem 70rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #overview #company-info .inner,
  #overview #company-access .inner {
    padding: 0 40rem 150rem;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }
}
#overview #company-info .inner h2,
#overview #company-access .inner h2 {
  font-size: 20rem;
  line-height: 1.5;
  height: fit-content;
}
@media (min-width: 959.1px) {
  #overview #company-info .inner h2,
  #overview #company-access .inner h2 {
    font-size: 40rem;
  }
}
#overview #company-info .inner .wrap,
#overview #company-access .inner .wrap {
  margin-top: 20rem;
  background: #fff;
  border-radius: 20rem;
  padding: 30rem 20rem;
}
@media (min-width: 959.1px) {
  #overview #company-info .inner .wrap,
  #overview #company-access .inner .wrap {
    margin-top: 0;
    border-radius: 25rem;
    padding: 50rem 70rem;
    width: 69%;
  }
}
#overview #company-info .inner .wrap .block,
#overview #company-access .inner .wrap .block {
  border-top: 1px solid #EEEEEE;
  padding: 20rem 0;
}
@media (min-width: 959.1px) {
  #overview #company-info .inner .wrap .block,
  #overview #company-access .inner .wrap .block {
    display: flex;
    gap: 60rem;
    padding: 30rem 0;
  }
}
#overview #company-info .inner .wrap .block:last-child,
#overview #company-access .inner .wrap .block:last-child {
  border-bottom: 1px solid #EEEEEE;
}
#overview #company-info .inner .wrap .block .sub,
#overview #company-access .inner .wrap .block .sub {
  font-weight: 700;
  color: #222222;
}
@media (min-width: 959.1px) {
  #overview #company-info .inner .wrap .block .sub,
  #overview #company-access .inner .wrap .block .sub {
    width: 200rem;
  }
}
#overview #company-info .inner .wrap .block .txt,
#overview #company-access .inner .wrap .block .txt {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #overview #company-info .inner .wrap .block .txt,
  #overview #company-access .inner .wrap .block .txt {
    margin-top: 0;
    flex: 1;
  }
}
#overview #company-info .inner .wrap .block .txt a[target=_blank],
#overview #company-access .inner .wrap .block .txt a[target=_blank] {
  font-weight: 700;
  color: #222222;
}
#overview #company-info .inner .wrap .block .txt a[target=_blank]::after,
#overview #company-access .inner .wrap .block .txt a[target=_blank]::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  background-color: #fff;
  display: inline-block;
}
#overview #company-info .inner .wrap .block .txt ul li,
#overview #company-access .inner .wrap .block .txt ul li {
  text-indent: -1em;
  padding-left: 1em;
  font-feature-settings: normal;
  letter-spacing: 0;
}
#overview #company-access .inner .frame .address {
  margin-top: 20rem;
}
#overview #company-access .inner .wrap {
  background: none;
  padding: 0;
}
#overview #company-access .inner .wrap .map {
  margin-top: 20rem;
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  height: 0;
}
@media (min-width: 959.1px) {
  #overview #company-access .inner .wrap .map {
    margin-top: 0;
  }
}
#overview #company-access .inner .wrap .map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*------------------------------------------*/
#consulting #lower-main h1::after {
  content: "CONSULTING";
}
#consulting #marketing,
#consulting #production {
  position: relative;
}
#consulting #marketing::before,
#consulting #production::before {
  content: "";
  background: url(../images/consulting/marketing-bg-sp.webp) no-repeat center top/contain;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
@media (min-width: 959.1px) {
  #consulting #marketing::before,
  #consulting #production::before {
    background: url(../images/consulting/marketing-bg-pc.webp) no-repeat center top/contain;
    width: 1200rem;
    height: 1050rem;
    left: inherit;
    right: 0;
  }
}
@media (min-width: 959.1px) {
  #consulting #marketing,
  #consulting #production {
    height: 1050rem;
    display: flex;
    align-items: center;
  }
}
#consulting #marketing .inner,
#consulting #production .inner {
  padding: 120rem 20rem 0;
  width: 100%;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner,
  #consulting #production .inner {
    padding: 0 40rem 0;
  }
}
#consulting #marketing .inner .wrap,
#consulting #production .inner .wrap {
  background: rgba(255, 255, 255, 0.9);
  border-radius: 20rem;
  padding: 30rem 20rem;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner .wrap,
  #consulting #production .inner .wrap {
    border-radius: 25rem;
    padding: 70rem;
    width: 69%;
  }
}
#consulting #marketing .inner .wrap h2,
#consulting #production .inner .wrap h2 {
  font-size: 20rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner .wrap h2,
  #consulting #production .inner .wrap h2 {
    font-size: 40rem;
  }
}
#consulting #marketing .inner .wrap .lead,
#consulting #production .inner .wrap .lead {
  margin-top: 20rem;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner .wrap .lead,
  #consulting #production .inner .wrap .lead {
    margin-top: 40rem;
  }
}
#consulting #marketing .inner .wrap .frame,
#consulting #production .inner .wrap .frame {
  margin-top: 20rem;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner .wrap .frame,
  #consulting #production .inner .wrap .frame {
    margin-top: 30rem;
    background: #fff;
    padding: 40rem;
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    gap: 40rem;
  }
}
#consulting #marketing .inner .wrap .frame .img,
#consulting #production .inner .wrap .frame .img {
  width: 200rem;
  margin: 0 auto;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner .wrap .frame .img,
  #consulting #production .inner .wrap .frame .img {
    width: 50%;
  }
}
#consulting #marketing .inner .wrap .frame .txt,
#consulting #production .inner .wrap .frame .txt {
  margin-top: 20rem;
  font-size: 12rem;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner .wrap .frame .txt,
  #consulting #production .inner .wrap .frame .txt {
    margin-top: 0;
    font-size: 14rem;
    width: 50%;
  }
}
#consulting #marketing .inner .wrap .frame .txt ul li:not(:first-child),
#consulting #production .inner .wrap .frame .txt ul li:not(:first-child) {
  margin-top: 10rem;
}
#consulting #marketing .inner .wrap .frame .txt ul li h3,
#consulting #production .inner .wrap .frame .txt ul li h3 {
  font-size: 12rem;
  line-height: 1;
  display: inline-block;
  padding: 5rem;
}
@media (min-width: 959.1px) {
  #consulting #marketing .inner .wrap .frame .txt ul li h3,
  #consulting #production .inner .wrap .frame .txt ul li h3 {
    font-size: 14rem;
  }
}
#consulting #marketing .inner .wrap .frame .txt ul li h3.red,
#consulting #production .inner .wrap .frame .txt ul li h3.red {
  background: rgba(221, 0, 17, 0.1);
}
#consulting #marketing .inner .wrap .frame .txt ul li h3.blue,
#consulting #production .inner .wrap .frame .txt ul li h3.blue {
  background: rgba(0, 160, 233, 0.1);
}
#consulting #marketing .inner .wrap .frame .txt ul li h3.green,
#consulting #production .inner .wrap .frame .txt ul li h3.green {
  background: rgba(20, 168, 59, 0.1);
}
#consulting #marketing .inner .wrap .frame .txt ul li h3.yellow,
#consulting #production .inner .wrap .frame .txt ul li h3.yellow {
  background: rgba(255, 222, 0, 0.1);
}
#consulting #marketing .inner .wrap .frame .txt ul li p,
#consulting #production .inner .wrap .frame .txt ul li p {
  margin-top: 5rem;
}
#consulting #production {
  margin: 70rem 0;
}
@media (min-width: 959.1px) {
  #consulting #production {
    margin: 80rem 0 150rem;
  }
}
#consulting #production::before {
  background: url(../images/consulting/production-bg-sp.webp) no-repeat center top/contain;
}
@media (min-width: 959.1px) {
  #consulting #production::before {
    background: url(../images/consulting/production-bg-pc.webp) no-repeat center top/contain;
    left: 0;
    right: inherit;
  }
}
@media (min-width: 959.1px) {
  #consulting #production .inner .wrap {
    margin-right: 0;
    margin-left: auto;
  }
}

/*------------------------------------------*/
#event #lower-main h1::after {
  content: "EVENT";
}
#event #event-flow .lead .inner {
  padding: 0 20rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #event #event-flow .lead .inner {
    padding: 0 40rem;
  }
}
#event #event-flow .lead .inner a[target=_blank]::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  background-color: #F5F5F5;
  display: inline-block;
}
#event #event-flow .container {
  position: relative;
  margin: 50rem 0 70rem;
}
@media (min-width: 959.1px) {
  #event #event-flow .container {
    height: 1120rem;
    display: flex;
    align-items: center;
    margin: 100rem 0 150rem;
  }
}
#event #event-flow .container::before {
  content: "";
  background: url(../images/event/bg-sp.webp) no-repeat center top/contain;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
@media (min-width: 959.1px) {
  #event #event-flow .container::before {
    background: url(../images/event/bg-pc.webp) no-repeat center top/contain;
    width: 1200rem;
    height: 1120rem;
    left: inherit;
    right: 0;
  }
}
#event #event-flow .container .inner {
  padding: 120rem 20rem 0;
  width: 100%;
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner {
    padding: 0 40rem 0;
  }
}
#event #event-flow .container .inner .wrap {
  background: rgba(255, 255, 255, 0.9);
  border-radius: 20rem;
  padding: 30rem 20rem;
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner .wrap {
    border-radius: 25rem;
    padding: 70rem;
    width: 69%;
  }
}
#event #event-flow .container .inner .wrap .txt {
  margin-top: 20rem;
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner .wrap .txt {
    margin-top: 40rem;
  }
}
#event #event-flow .container .inner .wrap .txt ul li:not(:first-child) {
  margin-top: 15rem;
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner .wrap .txt ul li:not(:first-child) {
    margin-top: 30rem;
  }
}
#event #event-flow .container .inner .wrap .txt ul li h3 {
  line-height: 1;
  display: flex;
  align-items: center;
  gap: 10rem;
  color: #00A0E9;
}
#event #event-flow .container .inner .wrap .txt ul li h3 .tag {
  font-size: 12rem;
  padding: 5rem;
  background: #00A0E9;
  color: #fff;
  font-weight: 700;
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner .wrap .txt ul li h3 .tag {
    font-size: 14rem;
  }
}
#event #event-flow .container .inner .wrap .txt ul li p {
  margin-top: 5rem;
}
#event #event-flow .container .inner .wrap .btn {
  margin-top: 20rem;
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner .wrap .btn {
    margin-top: 30rem;
  }
}
#event #event-flow .container .inner .wrap .btn a {
  width: fit-content;
  height: 40rem;
  padding: 0 30rem;
  color: #00A0E9;
  border: 2px solid #00A0E9;
  border-radius: 20rem;
  line-height: 1;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner .wrap .btn a {
    height: 60rem;
    padding: 0 50rem;
    border-radius: 30rem;
  }
}
@media (min-width: 959.1px) {
  #event #event-flow .container .inner .wrap .btn a:hover {
    background: #00A0E9;
    color: #fff;
  }
}

/*------------------------------------------*/
#achievements #lower-main h1::after {
  content: "ACHIEVEMENTS";
}
#achievements #list .inner {
  padding: 0 20rem 70rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #achievements #list .inner {
    padding: 0 40rem 150rem;
  }
}
#achievements #list .inner .wrap {
  display: flex;
  flex-direction: column;
  gap: 20rem;
}
@media (min-width: 959.1px) {
  #achievements #list .inner .wrap {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: stretch;
    gap: 50rem;
  }
}
@media (min-width: 959.1px) {
  #achievements #list .inner .wrap .block {
    width: calc((100% - 100rem) / 3);
  }
}
#achievements #list .inner .wrap .block a {
  background: #fff;
  border-radius: 20rem;
  padding: 20rem;
  display: flex;
  flex-direction: column;
  gap: 10rem;
  width: 100%;
  height: 100%;
}
@media (min-width: 959.1px) {
  #achievements #list .inner .wrap .block a {
    border-radius: 25rem;
    padding: 30rem;
    gap: 20rem;
  }
}
#achievements #list .inner .wrap .block a .img img {
  object-fit: cover;
  aspect-ratio: 1.44/1;
}
#achievements #list .inner .wrap .block a .tit {
  font-size: 18rem;
  line-height: 1.2;
}
@media (min-width: 959.1px) {
  #achievements #list .inner .wrap .block a .tit {
    font-size: 20rem;
  }
}
#achievements #list .inner .wrap .block a .tit::after {
  font-family: "Material Symbols Outlined";
  content: "\e5c8";
  line-height: 1;
  margin-left: 2rem;
  color: #14A83B;
  background-color: #fff;
  display: inline-block;
}
#achievements #list .inner .wrap .block a[target=_blank] .tit::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  color: #14A83B;
  background-color: #fff;
  display: inline-block;
}
#achievements #list .inner .wrap .block a[tabindex="-1"] {
  text-decoration: none;
}
#achievements #list .inner .wrap .block a[tabindex="-1"]:hover {
  opacity: 1;
}
#achievements #list .inner .wrap .block a[tabindex="-1"] .tit::after {
  content: none;
}

/*------------------------------------------*/
.pagination-wrapper {
  margin-top: 40rem;
  text-align: center;
}
@media (min-width: 959.1px) {
  .pagination-wrapper {
    margin-top: 80rem;
  }
}
.pagination-wrapper .pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  line-height: 1;
}
.pagination-wrapper .pagination__list {
  display: none;
}
@media (min-width: 959.1px) {
  .pagination-wrapper .pagination__list {
    display: flex;
    order: 3;
    list-style: none;
    margin: 0;
    padding: 0;
  }
}
.pagination-wrapper .pagination__item {
  margin: 0;
}
.pagination-wrapper .pagination__item a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60rem;
  height: 60rem;
  border-radius: 50%;
  border: 2px solid #14A83B;
  color: #14A83B;
  text-decoration: none;
  transition: 0.2s;
  margin: 0 2.5rem;
}
@media (hover: hover) {
  .pagination-wrapper .pagination__item a:hover {
    opacity: 0.8;
  }
}
.pagination-wrapper .pagination__item--current {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60rem;
  height: 60rem;
  border-radius: 50%;
  border: 2px solid #14A83B;
  background: #14A83B;
  color: #fff;
  pointer-events: none;
  margin: 0 2.5rem;
}
.pagination-wrapper .pagination__btn--prev, .pagination-wrapper .pagination__btn--next {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60rem;
  height: 60rem;
  border-radius: 50%;
  border: 2px solid #14A83B;
  color: #14A83B;
  text-decoration: none;
  transition: 0.2s;
}
@media (hover: hover) {
  .pagination-wrapper .pagination__btn--prev:hover, .pagination-wrapper .pagination__btn--next:hover {
    opacity: 0.8;
  }
}
@media (min-width: 959.1px) {
  .pagination-wrapper .pagination__btn--prev, .pagination-wrapper .pagination__btn--next {
    margin: 0 2.5rem;
  }
}
.pagination-wrapper .pagination__btn--prev::after, .pagination-wrapper .pagination__btn--next::after {
  font-family: "Material Symbols Outlined";
  color: #14A83B;
  font-weight: 400;
}
.pagination-wrapper .pagination__btn--prev {
  order: 1;
}
@media (min-width: 959.1px) {
  .pagination-wrapper .pagination__btn--prev {
    order: 2;
  }
}
.pagination-wrapper .pagination__btn--prev::after {
  content: "\e314";
  font-size: 40rem;
  font-weight: 400;
}
.pagination-wrapper .pagination__btn--next {
  order: 3;
}
@media (min-width: 959.1px) {
  .pagination-wrapper .pagination__btn--next {
    order: 4;
  }
}
.pagination-wrapper .pagination__btn--next::after {
  content: "\e315";
  font-size: 40rem;
}
.pagination-wrapper .pagination__pos {
  order: 2;
  color: #14A83B;
  font-size: 16rem;
  margin: 0 20rem;
  line-height: 1;
}
@media (min-width: 959.1px) {
  .pagination-wrapper .pagination__pos {
    display: none;
  }
}

/*------------------------------------------*/
#achievements-detail #lower-main h1::after {
  content: "ACHIEVEMENTS";
}
#achievements-detail #detail .main-img {
  width: 100%;
  aspect-ratio: 375/200;
  overflow: hidden;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .main-img {
    aspect-ratio: 1440/450;
  }
}
#achievements-detail #detail .main-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
#achievements-detail #detail .inner {
  width: 100%;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner {
    margin: 80rem auto 0;
    max-width: 940rem;
  }
}
#achievements-detail #detail .inner .wrap {
  background: #fff;
  padding: 40rem 20rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap {
    border-radius: 25rem;
    padding: 70rem;
  }
}
#achievements-detail #detail .inner .wrap h2 span {
  font-size: 20rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap h2 span {
    font-size: 40rem;
  }
}
#achievements-detail #detail .inner .wrap .info {
  margin-top: 40rem;
}
#achievements-detail #detail .inner .wrap .info h3 {
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .info h3 {
    font-size: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .info ul {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .info ul {
    margin-top: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .info ul li {
  border-top: 1px solid #EEEEEE;
  padding: 10rem 0;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .info ul li {
    padding: 15rem 0;
    display: flex;
    justify-content: space-between;
    gap: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .info ul li:last-child {
  border-bottom: 1px solid #EEEEEE;
}
#achievements-detail #detail .inner .wrap .info ul li .sub {
  line-height: 1.5;
  font-size: 12rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .info ul li .sub {
    line-height: 1.8;
    font-size: 14rem;
    width: 100rem;
  }
}
#achievements-detail #detail .inner .wrap .info ul li .txt {
  font-size: 12rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .info ul li .txt {
    font-size: 14rem;
    flex: 1;
  }
}
#achievements-detail #detail .inner .wrap .main-txt {
  margin-top: 40rem;
}
#achievements-detail #detail .inner .wrap .landscape {
  margin-top: 40rem;
}
#achievements-detail #detail .inner .wrap .landscape h3 {
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .landscape h3 {
    font-size: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .landscape .swiper {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .landscape .swiper {
    margin-top: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .landscape .swiper .swiper-pagination-frame {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .landscape .swiper .swiper-pagination-frame {
    margin-top: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .media {
  margin-top: 40rem;
}
#achievements-detail #detail .inner .wrap .media h3 {
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .media h3 {
    font-size: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .media ul {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .media ul {
    margin-top: 20rem;
  }
}
#achievements-detail #detail .inner .wrap .media ul li {
  border-top: 1px solid #EEEEEE;
  padding: 10rem 0;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .media ul li {
    padding: 15rem 0;
  }
}
#achievements-detail #detail .inner .wrap .media ul li:last-child {
  border-bottom: 1px solid #EEEEEE;
}
#achievements-detail #detail .inner .wrap .media ul li a {
  font-size: 12rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .wrap .media ul li a {
    font-size: 14rem;
  }
}
#achievements-detail #detail .inner .wrap a[target=_blank]::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  background-color: #fff;
  display: inline-block;
}
#achievements-detail #detail .inner .btn {
  margin: 40rem 0 70rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .btn {
    margin: 100rem 0 150rem;
  }
}
#achievements-detail #detail .inner .btn a {
  border: 2px solid #14A83B;
  height: 60rem;
  padding: 0 60rem;
  border-radius: 30rem;
  color: #14A83B;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .btn a {
    height: 80rem;
    padding: 0 90rem;
    border-radius: 40rem;
  }
}
@media (min-width: 959.1px) {
  #achievements-detail #detail .inner .btn a:hover {
    background: #14A83B;
    color: #fff;
  }
}

/*------------------------------------------*/
@media (min-width: 959.1px) {
  .swiper {
    position: relative;
  }
}
.swiper .swiper-wrapper {
  width: 100%;
}
.swiper .swiper-wrapper .swiper-slide {
  width: 100%;
  aspect-ratio: 1500/1000;
  overflow: hidden;
}
.swiper .swiper-wrapper .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.swiper .swiper-pagination-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20rem;
}
.swiper .swiper-pagination-frame .swiper-pagination {
  position: inherit;
  font-size: 16rem;
  font-weight: 700;
  color: #14A83B !important;
  width: fit-content;
}
.swiper .swiper-pagination-frame .swiper-pagination.swiper-pagination-bullets {
  line-height: 1;
}
@media (min-width: 959.1px) {
  .swiper .swiper-pagination-frame .swiper-pagination.swiper-pagination-bullets span {
    background: #14A83B;
    height: 15rem;
    width: 15rem;
  }
}
.swiper .swiper-pagination-frame .swiper-button-prev,
.swiper .swiper-pagination-frame .swiper-button-next {
  position: inherit;
  margin: 0;
  top: inherit;
  left: inherit;
  right: inherit;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60rem;
  height: 60rem;
  border-radius: 50%;
  border: 2px solid #14A83B;
  color: #14A83B;
  text-decoration: none;
  transition: 0.2s;
}
@media (min-width: 959.1px) {
  .swiper .swiper-pagination-frame .swiper-button-prev,
  .swiper .swiper-pagination-frame .swiper-button-next {
    position: absolute;
    top: calc(50% - 20rem);
    transform: translateY(-50%);
  }
}
.swiper .swiper-pagination-frame .swiper-button-prev:hover,
.swiper .swiper-pagination-frame .swiper-button-next:hover {
  opacity: 1 !important;
}
@media (min-width: 959.1px) {
  .swiper .swiper-pagination-frame .swiper-button-prev:hover,
  .swiper .swiper-pagination-frame .swiper-button-next:hover {
    opacity: 0.8 !important;
  }
}
.swiper .swiper-pagination-frame .swiper-button-prev::after,
.swiper .swiper-pagination-frame .swiper-button-next::after {
  font-family: "Material Symbols Outlined";
  content: "\e314";
  font-size: 40rem;
  font-weight: 400;
}
@media (min-width: 959.1px) {
  .swiper .swiper-pagination-frame .swiper-button-prev {
    left: 0;
    border: none;
  }
}
@media (min-width: 959.1px) {
  .swiper .swiper-pagination-frame .swiper-button-prev::after {
    font-size: 80rem;
  }
}
@media (min-width: 959.1px) {
  .swiper .swiper-pagination-frame .swiper-button-next {
    right: 0;
    border: none;
  }
}
.swiper .swiper-pagination-frame .swiper-button-next::after {
  content: "\e315";
}
@media (min-width: 959.1px) {
  .swiper .swiper-pagination-frame .swiper-button-next::after {
    font-size: 80rem;
  }
}

/*------------------------------------------*/
#recruit #lower-main h1::after {
  content: "RECRUIT";
}
#recruit #recruit-overview .inner,
#recruit #recruit-detail .inner {
  padding: 0 20rem 70rem;
  width: 100%;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner,
  #recruit #recruit-detail .inner {
    padding: 0 40rem 150rem;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }
}
#recruit #recruit-overview .inner h2,
#recruit #recruit-detail .inner h2 {
  font-size: 20rem;
  line-height: 1.5;
  height: fit-content;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner h2,
  #recruit #recruit-detail .inner h2 {
    font-size: 40rem;
  }
}
#recruit #recruit-overview .inner .wrap,
#recruit #recruit-detail .inner .wrap {
  margin-top: 20rem;
  background: #fff;
  border-radius: 20rem;
  padding: 30rem 20rem;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap,
  #recruit #recruit-detail .inner .wrap {
    margin-top: 0;
    border-radius: 25rem;
    padding: 50rem 70rem;
    width: 69%;
  }
}
#recruit #recruit-overview .inner .wrap .lead,
#recruit #recruit-detail .inner .wrap .lead {
  margin-bottom: 30rem;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .lead,
  #recruit #recruit-detail .inner .wrap .lead {
    margin-bottom: 40rem;
  }
}
#recruit #recruit-overview .inner .wrap .block2:not(:first-child),
#recruit #recruit-detail .inner .wrap .block2:not(:first-child) {
  margin-top: 30rem;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .block2:not(:first-child),
  #recruit #recruit-detail .inner .wrap .block2:not(:first-child) {
    margin-top: 40rem;
  }
}
#recruit #recruit-overview .inner .wrap .block2 h3,
#recruit #recruit-detail .inner .wrap .block2 h3 {
  font-size: 16rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .block2 h3,
  #recruit #recruit-detail .inner .wrap .block2 h3 {
    font-size: 25rem;
  }
}
#recruit #recruit-overview .inner .wrap .block2 p,
#recruit #recruit-detail .inner .wrap .block2 p {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .block2 p,
  #recruit #recruit-detail .inner .wrap .block2 p {
    margin-top: 20rem;
  }
}
#recruit #recruit-overview .inner .wrap .block2 p .line,
#recruit #recruit-detail .inner .wrap .block2 p .line {
  background: rgba(255, 222, 0, 0.2);
}
#recruit #recruit-overview .inner .wrap .block,
#recruit #recruit-detail .inner .wrap .block {
  border-top: 1px solid #EEEEEE;
  padding: 20rem 0;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .block,
  #recruit #recruit-detail .inner .wrap .block {
    display: flex;
    gap: 60rem;
    padding: 30rem 0;
  }
}
#recruit #recruit-overview .inner .wrap .block:last-child,
#recruit #recruit-detail .inner .wrap .block:last-child {
  border-bottom: 1px solid #EEEEEE;
}
#recruit #recruit-overview .inner .wrap .block .sub,
#recruit #recruit-detail .inner .wrap .block .sub {
  font-weight: 700;
  color: #222222;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .block .sub,
  #recruit #recruit-detail .inner .wrap .block .sub {
    width: 200rem;
  }
}
#recruit #recruit-overview .inner .wrap .block .txt,
#recruit #recruit-detail .inner .wrap .block .txt {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .block .txt,
  #recruit #recruit-detail .inner .wrap .block .txt {
    margin-top: 0;
    flex: 1;
  }
}
#recruit #recruit-overview .inner .wrap .block .txt h4,
#recruit #recruit-detail .inner .wrap .block .txt h4 {
  font-weight: 700;
  color: #222222;
}
#recruit #recruit-overview .inner .wrap .block .txt a[target=_blank],
#recruit #recruit-detail .inner .wrap .block .txt a[target=_blank] {
  font-weight: 700;
  color: #222222;
}
#recruit #recruit-overview .inner .wrap .block .txt a[target=_blank]::after,
#recruit #recruit-detail .inner .wrap .block .txt a[target=_blank]::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  background-color: #fff;
  display: inline-block;
}
#recruit #recruit-overview .inner .wrap .block .txt ul li,
#recruit #recruit-detail .inner .wrap .block .txt ul li {
  text-indent: -1em;
  padding-left: 1em;
  font-feature-settings: normal;
  letter-spacing: 0;
}
#recruit #recruit-overview .inner .wrap .block .img,
#recruit #recruit-detail .inner .wrap .block .img {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #recruit #recruit-overview .inner .wrap .block .img,
  #recruit #recruit-detail .inner .wrap .block .img {
    width: 300rem;
  }
}

/*------------------------------------------*/
#contact #lower-main h1::after {
  content: "CONTACT";
}
#contact #detail .inner {
  width: 100%;
}
@media (min-width: 959.1px) {
  #contact #detail .inner {
    margin: 0 auto;
    max-width: 940rem;
  }
}
#contact #detail .inner .lead {
  padding: 0 20rem;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .lead {
    padding: 0;
  }
}
#contact #detail .inner .wrap {
  margin: 40rem auto 70rem;
  background: #fff;
  padding: 40rem 20rem;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap {
    margin: 80rem auto 150rem;
    border-radius: 25rem;
    padding: 70rem;
  }
}
#contact #detail .inner .wrap .form ul li {
  border-top: 1px solid #EEEEEE;
  padding: 20rem 0;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap .form ul li {
    display: flex;
    justify-content: space-between;
    gap: 20rem;
  }
}
#contact #detail .inner .wrap .form ul li:last-child {
  border-bottom: 1px solid #EEEEEE;
}
#contact #detail .inner .wrap .form ul li .sub {
  line-height: 1.5;
  font-weight: 700;
  color: #222222;
  display: flex;
  align-items: center;
  gap: 5rem;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap .form ul li .sub {
    line-height: 1;
    margin-top: 20rem;
    width: 180rem;
    align-items: flex-start;
    justify-content: space-between;
  }
}
#contact #detail .inner .wrap .form ul li .sub .required {
  font-size: 10rem;
  padding: 4rem;
  color: #fff;
  background: #E60012;
}
#contact #detail .inner .wrap .form ul li .input {
  margin-top: 5rem;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap .form ul li .input {
    flex: 1;
  }
}
#contact #detail .inner .wrap .form ul li .input input,
#contact #detail .inner .wrap .form ul li .input textarea {
  background: #eee;
  border-radius: 5rem;
  width: 100%;
  height: 50rem;
  padding: 14rem 20rem;
  line-height: 1.5;
  font-size: 14rem;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap .form ul li .input input,
  #contact #detail .inner .wrap .form ul li .input textarea {
    font-size: 16rem;
  }
}
#contact #detail .inner .wrap .form ul li .input input::placeholder,
#contact #detail .inner .wrap .form ul li .input textarea::placeholder {
  color: #aaa;
}
#contact #detail .inner .wrap .form ul li .input textarea {
  height: 200rem;
}
#contact #detail .inner .wrap .form .btn {
  margin-top: 30rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap .form .btn {
    margin-top: 60rem;
  }
}
#contact #detail .inner .wrap .form .btn input {
  cursor: pointer;
  border: 2px solid #00A0E9;
  height: 60rem;
  padding: 0 60rem;
  border-radius: 30rem;
  color: #00A0E9;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-size: 14rem;
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap .form .btn input {
    height: 80rem;
    padding: 0 90rem;
    border-radius: 40rem;
    font-size: 16rem;
  }
}
@media (min-width: 959.1px) {
  #contact #detail .inner .wrap .form .btn input:hover {
    background: #00A0E9;
    color: #fff;
  }
}

/*------------------------------------------*/
#product #lower-main h1::after {
  content: "PRODUCT";
}
#product #detail .inner {
  width: 100%;
}
@media (min-width: 959.1px) {
  #product #detail .inner {
    margin: 0 auto;
    max-width: 940rem;
  }
}
#product #detail .inner .lead1 {
  text-align: center;
  font-size: 20rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #product #detail .inner .lead1 {
    font-size: 40rem;
  }
}
#product #detail .inner .lead2 {
  margin-top: 10rem;
  text-align: center;
  font-size: 35rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #product #detail .inner .lead2 {
    margin-top: 20rem;
    font-size: 70rem;
  }
}
#product #detail .inner .wrap {
  margin: 40rem auto 70rem;
  background: #fff;
  padding: 40rem 20rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap {
    margin: 80rem auto 150rem;
    border-radius: 25rem;
    padding: 70rem;
  }
}
#product #detail .inner .wrap .img-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .img-area {
    flex-direction: row;
    justify-content: center;
    gap: 30rem;
  }
}
#product #detail .inner .wrap .img-area .img:nth-child(1) {
  max-width: 196rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .img-area .img:nth-child(1) {
    max-width: 400rem;
  }
}
#product #detail .inner .wrap .img-area .img:nth-child(2) {
  max-width: 240rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .img-area .img:nth-child(2) {
    max-width: 366rem;
  }
}
#product #detail .inner .wrap .info {
  margin-top: 30rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info {
    margin-top: 50rem;
  }
}
#product #detail .inner .wrap .info .tit {
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .tit {
    font-size: 20rem;
  }
}
#product #detail .inner .wrap .info .detail {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .detail {
    margin-top: 20rem;
  }
}
#product #detail .inner .wrap .info .detail li {
  border-top: 1px solid #EEEEEE;
  padding: 10rem 0;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .detail li {
    display: flex;
    justify-content: space-between;
    gap: 20rem;
  }
}
#product #detail .inner .wrap .info .detail li:last-child {
  border-bottom: 1px solid #EEEEEE;
}
#product #detail .inner .wrap .info .detail li .sub {
  font-size: 12rem;
  font-weight: 700;
  color: #222222;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .detail li .sub {
    font-size: 14rem;
    width: 100rem;
  }
}
#product #detail .inner .wrap .info .detail li .txt {
  font-size: 12rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .detail li .txt {
    font-size: 14rem;
    flex: 1;
  }
}
#product #detail .inner .wrap .info .note {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .note {
    margin-top: 20rem;
  }
}
#product #detail .inner .wrap .info .note li {
  font-size: 10rem;
  text-indent: -1em;
  padding-left: 1em;
  font-feature-settings: normal;
  letter-spacing: 0;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .note li {
    font-size: 12rem;
  }
}
#product #detail .inner .wrap .info .btn {
  margin-top: 30rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .btn {
    margin-top: 60rem;
  }
}
#product #detail .inner .wrap .info .btn a[target=_blank] {
  border: 2px solid #E4007F;
  height: 60rem;
  padding: 0 60rem;
  border-radius: 30rem;
  color: #E4007F;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  font-size: 14rem;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .btn a[target=_blank] {
    height: 80rem;
    padding: 0 90rem;
    border-radius: 40rem;
    font-size: 16rem;
  }
}
#product #detail .inner .wrap .info .btn a[target=_blank]::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  color: #E4007F;
  display: inline-block;
}
@media (min-width: 959.1px) {
  #product #detail .inner .wrap .info .btn a[target=_blank]:hover {
    background: #E4007F;
    color: #fff;
  }
  #product #detail .inner .wrap .info .btn a[target=_blank]:hover::after {
    color: #fff;
  }
}

/*------------------------------------------*/
#privacy-policy #lower-main h1::after {
  content: "PRIVACY POLICY";
}
#privacy-policy #detail .inner {
  width: 100%;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner {
    margin: 0 auto;
    max-width: 940rem;
  }
}
#privacy-policy #detail .inner .wrap {
  background: #fff;
  padding: 40rem 20rem;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .wrap {
    border-radius: 25rem;
    padding: 70rem;
  }
}
#privacy-policy #detail .inner .wrap .mt5 {
  margin-top: 5rem;
}
#privacy-policy #detail .inner .wrap .mt40 {
  margin-top: 30rem;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .wrap .mt40 {
    margin-top: 40rem;
  }
}
#privacy-policy #detail .inner .wrap h2 span {
  font-size: 20rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .wrap h2 span {
    font-size: 40rem;
  }
}
#privacy-policy #detail .inner .wrap h3 {
  font-size: 16rem;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .wrap h3 {
    font-size: 20rem;
  }
}
#privacy-policy #detail .inner .wrap ul {
  margin-top: 10rem;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .wrap ul {
    margin-top: 20rem;
  }
}
#privacy-policy #detail .inner .wrap ul li {
  border-top: 1px solid #EEEEEE;
  padding: 10rem 0;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .wrap ul li {
    padding: 15rem 0;
  }
}
#privacy-policy #detail .inner .wrap ul li:last-child {
  border-bottom: 1px solid #EEEEEE;
}
#privacy-policy #detail .inner .wrap ul li a {
  font-size: 12rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .wrap ul li a {
    font-size: 14rem;
  }
}
#privacy-policy #detail .inner .wrap a[target=_blank]::after {
  font-family: "Material Symbols Outlined";
  content: "\e65b";
  line-height: 1;
  margin-left: 2rem;
  background-color: #fff;
  display: inline-block;
}
#privacy-policy #detail .inner .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
#privacy-policy #detail .inner .btn.btn1 {
  margin: 30rem 0 0;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .btn.btn1 {
    margin: 60rem 0 0;
  }
}
#privacy-policy #detail .inner .btn.btn2 {
  margin: 10rem 0 70rem;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .btn.btn2 {
    margin: 20rem 0 150rem;
  }
}
#privacy-policy #detail .inner .btn a {
  border: 2px solid #E60012;
  height: 60rem;
  padding: 0 60rem;
  border-radius: 30rem;
  color: #E60012;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .btn a {
    height: 80rem;
    padding: 0 90rem;
    border-radius: 40rem;
  }
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .btn a:hover {
    background: #E60012;
    color: #fff;
  }
}
#privacy-policy #detail .inner .table-scroll {
  overflow-x: auto;
}
#privacy-policy #detail .inner .table-scroll table {
  width: 100%;
  min-width: 800rem;
  border-collapse: collapse;
  font-size: 12rem;
  line-height: 1.5;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail .inner .table-scroll table {
    font-size: 14rem;
  }
}
#privacy-policy #detail .inner .table-scroll table tr th {
  padding: 15rem;
  border: 1px solid #EEEEEE;
  background: #F5F5F5;
  text-align: center;
}
#privacy-policy #detail .inner .table-scroll table tr th:first-child {
  width: 300rem;
}
#privacy-policy #detail .inner .table-scroll table tr td {
  padding: 15rem;
  border: 1px solid #EEEEEE;
  vertical-align: top;
}
#privacy-policy #detail.child {
  margin: 0 0 70rem;
}
@media (min-width: 959.1px) {
  #privacy-policy #detail.child {
    margin: 0 0 150rem;
  }
}

/*------------------------------------------*/
/*------------------------------------------*/
/*------------------------------------------*/