@charset "UTF-8";
html, body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: 500;
  color: #222;
  font-size: 16px;
  line-height: 1.75;
  background: #fdfdfd;
}
@media (max-width: 575.98px) {
  html, body {
    font-size: 14px;
  }
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 100px;
}

body.fixed {
  overflow: hidden;
}

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

p {
  text-align: justify;
  word-break: break-all;
}

.sans {
  font-family: "Open Sans", sans-serif;
}

.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2em;
}

.sticky-wrap {
  position: sticky;
  top: 120px;
}

.title-area {
  display: flex;
  justify-content: center;
  flex-direction: column;
  gap: 2em;
}
.title-area .title {
  font-size: 96px;
  font-weight: bold;
  text-align: center;
  line-height: 1;
}
@media (max-width: 991.98px) {
  .title-area .title {
    font-size: 9.68vw;
  }
}
@media (max-width: 575.98px) {
  .title-area .title {
    font-size: 11.5vw;
  }
}
.title-area p {
  font-size: 16px;
  text-align: center;
}
@media (max-width: 991.98px) {
  .title-area p {
    font-size: 1.81vw;
  }
}
@media (max-width: 575.98px) {
  .title-area p {
    font-size: 3.5vw;
  }
}

.btn-wh {
  width: 100%;
  padding: 1em;
  border: 1px solid #fdfdfd;
  color: #fdfdfd;
  font-size: 18px;
  font-weight: 700;
  background: #222;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
@media (max-width: 991.98px) {
  .btn-wh {
    font-size: 1.81vw;
  }
}
@media (max-width: 575.98px) {
  .btn-wh {
    font-size: 4vw;
  }
}
.btn-wh span {
  position: relative;
  z-index: 3;
}
.btn-wh:hover span {
  color: #222;
}
.btn-wh.bgleft:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background: #fdfdfd;
  width: 100%;
  height: 100%;
  transition: transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}
.btn-wh.bgleft:hover:before {
  transform-origin: left top;
  transform: scale(1, 1);
}

.btn-bk {
  width: 100%;
  padding: 1em;
  border: 1px solid #222;
  color: #222;
  font-size: 18px;
  font-weight: 700;
  background: #fdfdfd;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
@media (max-width: 991.98px) {
  .btn-bk {
    font-size: 1.81vw;
  }
}
@media (max-width: 575.98px) {
  .btn-bk {
    font-size: 4vw;
  }
}
.btn-bk span {
  position: relative;
  z-index: 3;
}
.btn-bk:hover span {
  color: #fdfdfd;
}
.btn-bk.bgleft:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background: #222;
  width: 100%;
  height: 100%;
  transition: transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}
.btn-bk.bgleft:hover:before {
  transform-origin: left top;
  transform: scale(1, 1);
}

.btn-wh2 {
  width: 100%;
  padding: 1em;
  border: 1px solid #fdfdfd;
  color: #fdfdfd;
  font-size: 18px;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
@media (max-width: 991.98px) {
  .btn-wh2 {
    font-size: 1.81vw;
  }
}
@media (max-width: 575.98px) {
  .btn-wh2 {
    font-size: 4vw;
  }
}
.btn-wh2 span {
  position: relative;
  z-index: 3;
  transition: 0.4s;
}
.btn-wh2:hover span {
  color: #222;
}
.btn-wh2.bgleft:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background: #fdfdfd;
  width: 100%;
  height: 100%;
  transition: transform 0.6s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  transform: scale(0, 1);
  transform-origin: right top;
}
.btn-wh2.bgleft:hover:before {
  transform-origin: left top;
  transform: scale(1, 1);
}

table th {
  text-align: left;
  padding: 0.5em 1em 0.5em 0;
  vertical-align: top;
}
table td {
  padding: 0.5em 1em;
}

hr {
  display: block;
  height: 1px;
  border: none;
  border-bottom: 1px solid #b5b5b6;
  margin-bottom: 5em;
}

.single-content {
  width: 66.67%;
}
@media (max-width: 767.98px) {
  .single-content {
    width: 100%;
  }
}
.single-content .eyecatch {
  width: 100%;
  margin-bottom: 1em;
  aspect-ratio: 16/9;
  object-fit: cover;
}
.single-content .blogtitle {
  font-size: 24px;
  margin-bottom: 1em;
}
@media (max-width: 767.98px) {
  .single-content .blogtitle {
    font-size: 5vw;
  }
}
.single-content img {
  display: block;
  margin: 0 auto 1.5em;
}
.single-content p {
  margin-bottom: 1em;
}
.single-content iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: auto;
  margin-bottom: 1em;
}
.single-content a {
  color: #595757;
  text-decoration: underline;
}
.single-content a:hover {
  opacity: 0.7;
  transition: 0.3s;
}

header {
  width: 100%;
  height: 56px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(255, 255, 255, 0.8);
  padding: 0 2em;
  position: fixed;
  top: 0;
  z-index: 100;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
header .logo {
  width: 224px;
  height: 36px;
}
header nav {
  display: flex;
  justify-content: space-between;
  gap: 1.5em;
}
@media (max-width: 991.98px) {
  header nav {
    display: none;
  }
}
header nav a {
  font-size: 16px;
  font-weight: 700;
}

#menu-btn {
  width: 30px;
  height: 30px;
  display: none;
  gap: 6px;
  cursor: pointer;
  position: relative;
}
@media (max-width: 991.98px) {
  #menu-btn {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}
#menu-btn span {
  display: block;
  width: 100%;
  height: 2px;
  background: #222;
  transition: 0.3s;
  position: relative;
}
#menu-btn.open span:first-child {
  transform: rotate(45deg);
  position: absolute;
  top: 14px;
}
#menu-btn.open span:nth-child(2) {
  display: none;
}
#menu-btn.open span:last-child {
  transform: rotate(-45deg);
  position: absolute;
  top: 14px;
}

#sp-menu {
  width: 100%;
  height: 100vh;
  background: #222;
  position: fixed;
  top: 0;
  left: 100%;
  z-index: 98;
  color: #fdfdfd;
  padding: 56px;
  transition: 0.3s;
}
#sp-menu.active {
  left: 0;
}
#sp-menu nav {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.5em;
}
#sp-menu nav a {
  font-size: 24px;
  font-weight: bold;
  color: #fdfdfd;
}

#home .main-v {
  width: 100%;
  height: 100vh;
  position: relative;
  z-index: 1;
  overflow: hidden;
}
#home .main-v video {
  position: relative;
  z-index: 1;
  top: 50%;
  left: 50%;
  display: block;
  width: auto;
  height: auto;
  max-width: none;
  min-width: 100%;
  min-height: 100%;
  transform: translate(-50%, -50%);
  aspect-ratio: 16/9;
}
#home .main-v .logo-area {
  width: 800px;
  height: 184px;
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.5em;
}
@media (max-width: 991.98px) {
  #home .main-v .logo-area {
    width: 80.65vw;
    height: 18.55vw;
  }
}
#home .main-v .logo-area img {
  margin-top: 56px;
}
@media (max-width: 991.98px) {
  #home .main-v .logo-area img {
    margin-top: 5.65vw;
  }
}
#home .main-v .logo-area p {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
@media (max-width: 991.98px) {
  #home .main-v .logo-area p {
    font-size: 2.42vw;
  }
}
#home .service {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4em;
  padding: 11em 0;
}
@media (max-width: 575.98px) {
  #home .service {
    padding: 7em 0;
    flex-direction: column;
  }
}
#home .service .title-area {
  width: calc(50% - 2em);
}
@media (max-width: 575.98px) {
  #home .service .title-area {
    width: 100%;
  }
}
#home .service .btn-area {
  width: calc(50% - 2em);
}
@media (max-width: 575.98px) {
  #home .service .btn-area {
    width: 100%;
  }
}
@media (max-width: 991.98px) {
  #home .service br {
    display: none;
  }
}
#home .works {
  display: block;
  width: 100%;
  background: url(../img/chuttersnap-hqVGQ4-D0NI-unsplash.jpg) center center/cover no-repeat;
  aspect-ratio: 4/3;
}
@media (max-width: 575.98px) {
  #home .works {
    aspect-ratio: unset;
  }
}
#home .works .works-inner {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
}
#home .works .works-inner .container {
  height: 100%;
  display: flex;
  justify-content: flex-end;
}
#home .works .works-inner .works-contents {
  width: calc(50% - 2em);
  height: 100%;
  color: #fdfdfd;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 575.98px) {
  #home .works .works-inner .works-contents {
    width: 100%;
    margin: 7em 0;
  }
}
#home .works .works-inner .works-contents .title-area {
  width: 100%;
}
#home .news {
  padding: 10em 0;
  display: flex;
  gap: 4em;
}
@media (max-width: 575.98px) {
  #home .news {
    padding: 7em 0;
    flex-direction: column;
    gap: 2em;
  }
}
#home .news .title-area, #home .news .news-list {
  width: calc(50% - 2em);
}
@media (max-width: 575.98px) {
  #home .news .title-area, #home .news .news-list {
    width: 100%;
  }
}
#home .news ul.news-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid #222;
}
#home .news ul.news-list li {
  display: block;
}
#home .news ul.news-list li a {
  display: flex;
  align-items: flex-start;
  gap: 2em;
  border-bottom: 1px solid #222;
  padding: 1em 0;
  font-size: 16px;
  font-weight: 700;
  transition: 0.3s;
}
@media (max-width: 991.98px) {
  #home .news ul.news-list li a {
    font-size: 16px;
  }
}
@media (max-width: 575.98px) {
  #home .news ul.news-list li a {
    font-size: 3.5vw;
  }
}
#home .news ul.news-list li a:hover {
  opacity: 0.7;
}

#opening {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 101;
  overflow: hidden;
  animation: fadeout 3.5s forwards;
}
#opening video {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: auto;
  height: auto;
  max-width: none;
  min-width: 100%;
  min-height: 100%;
  transform: translate(-50%, -50%);
  aspect-ratio: 16/9;
}
@media (max-width: 767.98px) {
  #opening {
    display: none;
  }
}

@keyframes fadeout {
  0% {
    opacity: 1;
    z-index: 101;
  }
  50% {
    opacity: 1;
  }
  99.9% {
    z-index: 101;
  }
  100% {
    opacity: 0;
    z-index: -1;
    display: none !important;
  }
}
#index {
  padding-top: 120px;
}
#index .title-area {
  margin-bottom: 5em;
}
#index .news-items {
  display: flex;
  flex-direction: column;
  gap: 9em;
  margin-bottom: 9em;
}
#index .news-items .news-item {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 767.98px) {
  #index .news-items .news-item {
    flex-direction: column;
  }
}
#index .news-items .news-item .update {
  font-size: 18px;
  font-weight: bold;
}
@media (max-width: 767.98px) {
  #index .news-items .news-item .update {
    font-size: 4vw;
  }
}
#index .works-items {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 9em;
  gap: 2em;
}
#index .works-items .works-item {
  width: calc(33% - 1.2em);
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.1);
  margin-bottom: 2em;
}
@media (max-width: 991.98px) {
  #index .works-items .works-item {
    width: calc(50% - 1em);
  }
}
@media (max-width: 767.98px) {
  #index .works-items .works-item {
    width: 100%;
  }
}
#index .works-items .works-item img {
  width: 100%;
}
#index .works-items .works-item .text-area {
  padding: 1em;
  display: flex;
  flex-direction: column;
}
#index .works-items .works-item .text-area h2 {
  font-size: 18px;
  line-height: 1.3;
  margin-bottom: 0.5em;
}
@media (max-width: 767.98px) {
  #index .works-items .works-item .text-area h2 {
    font-size: 4.25vw;
  }
}
#index .works-items .works-item .text-area .client {
  font-size: 13px;
  color: #898989;
  margin-bottom: 1em;
}
@media (max-width: 767.98px) {
  #index .works-items .works-item .text-area .client {
    font-size: 3vw;
  }
}
#index .works-items .works-item .text-area .cats {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
#index .works-items .works-item .text-area .cat {
  display: inline-block;
  font-size: 12px;
  color: #b5b5b6;
  border: 1px solid #b5b5b6;
  padding: 0 1em;
  margin: 0;
}
@media (max-width: 767.98px) {
  #index .works-items .works-item .text-area .cat {
    font-size: 2.75vw;
  }
}
#index .select {
  display: block;
  margin-bottom: 2em;
  color: #898989;
}
#index .select select {
  padding: 0.5em;
}
#index .pagenav {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5em;
  margin-bottom: 5em;
}
#index a.page-numbers, #index .pagenav .current {
  color: #898989;
  width: 30px;
  height: 30px;
  border: 1px solid #898989;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: 0.3s;
}
#index a.page-numbers:hover {
  color: #fdfdfd;
  background: #898989;
}
#index .pagenav .current {
  color: #fdfdfd;
  background: #898989;
}

#single {
  padding-top: 120px;
}
@media (max-width: 767.98px) {
  #single {
    padding-top: 25vw;
  }
}
#single .works-single, #single .single {
  display: flex;
  justify-content: space-between;
  gap: 4em;
}
@media (max-width: 767.98px) {
  #single .works-single, #single .single {
    flex-direction: column;
  }
}
#single .works-single .title-area, #single .single .title-area {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 1em;
  margin-bottom: 4em;
  max-width: 30%;
}
@media (max-width: 575.98px) {
  #single .works-single .title-area, #single .single .title-area {
    max-width: none;
  }
}
#single .works-single .title-area h1, #single .single .title-area h1 {
  font-size: 24px;
  line-height: 1.4;
  margin-bottom: 1em;
}
@media (max-width: 767.98px) {
  #single .works-single .title-area h1, #single .single .title-area h1 {
    font-size: 5.5vw;
  }
}
#single .works-single .title-area .details, #single .single .title-area .details {
  display: flex;
  flex-direction: column;
  gap: 1em;
}
#single .works-single .title-area .details p, #single .single .title-area .details p {
  font-size: 15px;
  text-align: left;
  font-weight: bold;
}
@media (max-width: 767.98px) {
  #single .works-single .title-area .details p, #single .single .title-area .details p {
    font-size: 3.5vw;
  }
}
#single .works-single .title-area .details p span, #single .single .title-area .details p span {
  font-size: 12px;
  display: block;
  font-weight: normal;
}
@media (max-width: 767.98px) {
  #single .works-single .title-area .details p span, #single .single .title-area .details p span {
    font-size: 2.75vw;
  }
}
#single .works-single .content, #single .single .content {
  width: 60%;
  min-height: 300px;
  margin-bottom: 8em;
}
@media (max-width: 767.98px) {
  #single .works-single .content, #single .single .content {
    width: 100%;
  }
}
#single .works-single .content img, #single .single .content img {
  margin: 0 auto 1.5em;
}
#single .works-single .content p, #single .single .content p {
  margin-bottom: 1em;
}
#single .works-single .content iframe, #single .single .content iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: auto;
  margin-bottom: 1em;
}
#single .works-single .content a, #single .single .content a {
  color: #595757;
  text-decoration: underline;
}
#single .works-single .content a:hover, #single .single .content a:hover {
  opacity: 0.7;
  transition: 0.3s;
}

#company, #recruit, #privacy {
  padding-top: 120px;
}
#company .title-area, #recruit .title-area, #privacy .title-area {
  margin-bottom: 5em;
}
#company .contents, #recruit .contents, #privacy .contents {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2em;
}
@media (max-width: 767.98px) {
  #company .contents, #recruit .contents, #privacy .contents {
    flex-direction: column;
  }
}
#company .contents .subtitle-area h2, #recruit .contents .subtitle-area h2, #privacy .contents .subtitle-area h2 {
  line-height: 1.4;
}
#company .contents .subtitle-area h2.ja, #recruit .contents .subtitle-area h2.ja, #privacy .contents .subtitle-area h2.ja {
  font-size: 18px;
}
@media (max-width: 767.98px) {
  #company .contents .subtitle-area, #recruit .contents .subtitle-area, #privacy .contents .subtitle-area {
    width: 100%;
    position: static;
    text-align: center;
  }
  #company .contents .subtitle-area p, #recruit .contents .subtitle-area p, #privacy .contents .subtitle-area p {
    text-align: center;
  }
}
#company .contents .content, #recruit .contents .content, #privacy .contents .content {
  width: 60%;
}
@media (max-width: 767.98px) {
  #company .contents .content, #recruit .contents .content, #privacy .contents .content {
    width: 100%;
  }
}
#company .contents .content table, #recruit .contents .content table, #privacy .contents .content table {
  margin-top: -1em;
}
#company .contents .content table th, #recruit .contents .content table th, #privacy .contents .content table th {
  min-width: 8em;
}
#company .contents .content p, #recruit .contents .content p, #privacy .contents .content p {
  margin-bottom: 1em;
}
#company .contents .content a, #recruit .contents .content a, #privacy .contents .content a {
  text-decoration: underline;
  transition: 0.3s;
}
#company .contents .content a .material-symbols-outlined, #recruit .contents .content a .material-symbols-outlined, #privacy .contents .content a .material-symbols-outlined {
  font-size: 16px;
}
#company .contents .content a:hover, #recruit .contents .content a:hover, #privacy .contents .content a:hover {
  opacity: 0.7;
}
#company .contents .content ul, #recruit .contents .content ul, #privacy .contents .content ul {
  margin: 0 0 1em;
  padding: 0 0 0 1em;
}

#service {
  padding-top: 120px;
}
#service .title-area {
  margin-bottom: 5em;
}
@media (max-width: 767.98px) {
  #service .title-area br {
    display: none;
  }
}
#service .cards {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 2em;
}
#service .cards .card {
  width: calc(50% - 1em);
  display: flex;
  flex-direction: column;
  border: 1px solid #b5b5b6;
}
@media (max-width: 767.98px) {
  #service .cards .card {
    width: 100%;
  }
}
#service .cards .card .main-area {
  padding: 2em;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 1.5em;
}
#service .cards .card .main-area .material-symbols-outlined {
  font-size: 70px;
}
@media (max-width: 767.98px) {
  #service .cards .card .main-area .material-symbols-outlined {
    font-size: 15vw;
  }
}
#service .cards .card .main-area h2 {
  font-size: 24px;
}
@media (max-width: 767.98px) {
  #service .cards .card .main-area h2 {
    font-size: 5.5vw;
  }
}
#service .cards .card .sub-area {
  padding: 2em;
  background: #b5b5b6;
  color: #fdfdfd;
  margin: auto 0 0;
}
#service .cards .card .sub-area p {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
}
@media (max-width: 991.98px) {
  #service .cards .card .sub-area p {
    font-size: 16px;
  }
}

#contact {
  padding-top: 120px;
}
#contact .title-area {
  margin-bottom: 5em;
}
#contact .form {
  width: 100%;
  font-size: 16px;
  margin-bottom: 2em;
}
#contact .form th {
  width: 33.3%;
  padding: 1em;
}
@media (max-width: 767.98px) {
  #contact .form th {
    display: block;
    width: 100%;
    padding: 1em 0 0.25em;
  }
}
#contact .form td {
  width: 66.6%;
  padding: 1em;
}
@media (max-width: 767.98px) {
  #contact .form td {
    display: block;
    width: 100%;
    padding: 0 0 1em;
  }
}
#contact .form input[type=text], #contact .form input[type=email], #contact .form input[type=tel], #contact .form textarea, #contact .form select {
  width: 100%;
  padding: 0.5em;
  border: none;
  border: 1px solid #b5b5b6;
}
#contact .form .btn-area {
  width: 100%;
}
#contact .form .btn-area p {
  text-align: center;
}
#contact .form input[type=submit] {
  padding: 1em 6em;
  background: #222;
  color: #fdfdfd;
  border: none;
  font-weight: bold;
  cursor: pointer;
  display: inline-block;
  margin: 0 auto;
}
@media (max-width: 767.98px) {
  #contact .form input[type=submit] {
    width: 100%;
  }
}
#contact .reCaptcha {
  margin: 9em 0 0;
  font-size: 10px;
  color: #b5b5b6;
  text-align: right;
}

footer {
  width: 100%;
  padding: 7em 0 2em;
  background: #222;
  color: #fdfdfd;
}
footer .footer-inner {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 10em;
}
footer a {
  color: #fdfdfd;
}
footer .footer-links {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 575.98px) {
  footer .footer-links {
    font-size: 3vw;
  }
}

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

.mb-1 {
  margin-bottom: 1em;
}

.mb-5 {
  margin-bottom: 5em;
}

.mb-7 {
  margin-bottom: 7em;
}

.mb-8 {
  margin-bottom: 8em;
}

.mb-9 {
  margin-bottom: 9em;
}

.video, .map {
  width: 100%;
  aspect-ratio: 16/9;
  margin: 1em 0 1.5em;
}
.video iframe, .map iframe {
  width: 100%;
  height: 100%;
}

.customize-support header {
  top: 32px;
}/*# sourceMappingURL=style.css.map */