@charset "UTF-8";
/*========================================================
  Break point
========================================================*/
/*========================================================
  変数
========================================================*/
:root {
  --side-space: 4vw;
}

/*========================================================
  Font
========================================================*/
/*Solid/900*/
/*Brand/400*/
/*========================================================
  color
========================================================*/
/*========================================================
  root変数
========================================================*/
:root {
  --padding-top: 80px;
  --padding-bottom: 80px;
  --margin-bottom: 80px;
  --margin-top: 80px;
}
/*========================================================
  mixin
========================================================*/
/*========================================================
  gradient
========================================================*/
/*==========================================================================
Easing
Easingの動きが一覧でわかるチートシート https://easings.net/ja
Easingジェネレーター https://easings.co/
==========================================================================*/
/* Global box-sizing */
*, *::before, *::after {
  box-sizing: border-box;
}

/* Reset margins, paddings, and other default styles */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

html {
  font-size: 87.5%;
  scroll-behavior: smooth;
}
@media screen and (min-width: 768px) {
  html {
    font-size: 93.75%;
  }
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

/* Set base styles */
body {
  line-height: 1.8;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  letter-spacing: 0.1em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "palt";
  overflow-x: clip;
  position: relative;
  background: #fbfaf6;
  transition: all 0.2s ease;
}

/* Remove list styles */
ol, ul {
  list-style: none;
}

/* Remove quotes */
blockquote, q {
  quotes: none;
}

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

/* Table reset */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

a {
  text-decoration: none;
}

img {
  object-fit: contain;
  width: 100%;
  height: 100%;
}

a {
  display: flex;
}

.inner {
  margin: 0 var(--side-space);
}
@media screen and (min-width: 1024px) {
  .inner {
    margin: 0 var(--side-space) 0 calc(var(--side-space) + 20px);
  }
}
@media screen and (min-width: 1320px) {
  .inner {
    width: 1200px;
    margin: 0 auto;
  }
}

/*========================================================
 電話番号の非リンク
========================================================*/
a[href^="tel:"] {
  color: #b7a475;
  font-weight: 600;
}

@media screen and (min-width: 1024px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
/*========================================================
 SP/TB/PCの表示・非表示
========================================================*/
.spNone {
  display: none;
}
@media screen and (min-width: 768px) {
  .spNone {
    display: block;
  }
}

.tbNone {
  display: block;
}
@media screen and (min-width: 768px) {
  .tbNone {
    display: none;
  }
}

.pcNone {
  display: block;
}
@media screen and (min-width: 1024px) {
  .pcNone {
    display: none;
  }
}

/*========================================================
 TEL
========================================================*/
.nav-tel a {
  display: block;
  color: #fff;
  text-align: center;
  padding: 4px 10px;
  border: 0.05rem solid #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  letter-spacing: 0.2rem;
}
.nav-tel a .number {
  font-size: 24px;
}

/*========================================================
 HEADER
========================================================*/
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  padding: 10px;
  z-index: 999;
}
.header .site-ci {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.header .site-ci a {
  width: 50%;
  max-width: 300px;
}
.header .site-ci a img {
  max-width: 300px;
}
.header .site-ci-txt {
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  display: flex;
  justify-content: center;
  width: 25%;
  max-width: 300px;
  font-size: 18px;
  line-height: 1.6666666667;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-size: min(3vw, 18px);
  font-family: "Noto Sans JP", sans-serif;
  margin-left: 20px;
}
@media screen and (min-width: 1024px) {
  .header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    padding: 50px 10px;
  }
  .header .site-ci {
    flex-direction: column;
    align-items: flex-start;
  }
  .header .site-ci a {
    width: 100%;
  }
  .header .site-ci-txt {
    width: 100%;
  }
}

/*========================================================
 コンテンツ部
========================================================*/
/*========================================================
 FOOTER
========================================================*/
.footer {
  position: relative;
  background: #fff;
}
.footer .section-box__bg {
  bottom: 0;
  z-index: 1 !important;
}
.footer .section-box__bg img {
  object-fit: cover;
}
.footer__menus {
  margin-bottom: 50px;
}
.footer__menus-box {
  display: grid;
  grid-template-columns: 30% 1fr;
  grid-template-rows: repeat(2, max-content);
  grid-column-gap: 20px;
  grid-row-gap: 0px;
}
.footer__menus .ci {
  grid-area: 1/1/3/1;
}
.footer__menus .ci .footer__logomark {
  width: 68px;
}
.footer__menus .nav-menu {
  grid-area: 1/2/2/3;
  margin-bottom: 20px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.footer__menus .nav-menu .menu-item {
  width: 100%;
}
.footer__menus .nav-menu a {
  display: inline-flex;
  font-size: 13px;
  line-height: 2.7692307692;
  letter-spacing: 0.32em;
  font-weight: 400;
  color: #000;
  white-space: nowrap;
}
.footer__menus .sns__box {
  grid-area: 2/2/3/3;
}
.footer__menus .sns__list {
  display: flex;
  flex-direction: row;
}
.footer__menus .sns__item {
  margin-right: 20px;
}
.footer__address {
  margin-bottom: 50px;
}
.footer__address .footer__access {
  font-size: 13px;
  line-height: 2.3076923077;
  letter-spacing: 0.04em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
}
.footer__address .footer__access div {
  display: flex;
  flex-direction: row;
}
.footer__address .footer__access div a {
  font-size: 13px;
  line-height: 2.3076923077;
  letter-spacing: 0.04em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
}
.footer__copyright {
  margin-bottom: 50px;
  font-size: 13px;
  line-height: 2.3076923077;
  letter-spacing: 0.04em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
}
.footer__meta {
  margin-bottom: 50px;
  font-size: 13px;
  line-height: 1.9230769231;
  letter-spacing: 0em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
}
.footer__links {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
}
.footer__links-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: repeat(3, 1fr);
  grid-column-gap: 30px;
  grid-row-gap: 0px;
  width: 180px;
}
.footer__links-item {
  padding: 10px 0;
}
.footer__links-item:nth-child(1) {
  grid-area: 1/1/2/3;
}
.footer__links-item:nth-child(2) {
  grid-area: 2/1/3/2;
}
.footer__links-item:nth-child(3) {
  grid-area: 2/2/3/3;
}
.footer__links-item:nth-child(4) {
  grid-area: 3/1/4/3;
}
.footer__links-item:nth-child(5) {
  grid-area: 4/1/5/3;
}
@media screen and (min-width: 480px) {
  .footer__menus-box {
    grid-template-columns: 80px 1fr;
  }
  .footer__menus .nav-menu .menu-item {
    width: calc((100% - 10px) / 2);
  }
  .footer__menus .sns__box {
    display: flex;
    justify-content: flex-end;
  }
}
@media screen and (min-width: 580px) {
  .footer__menus .nav-menu .menu-item {
    width: calc((100% - 20px) / 3);
  }
  .footer__links {
    padding-bottom: 80px;
    justify-content: flex-start;
  }
  .footer__links-list {
    display: flex;
    justify-content: flex-start;
    height: 55px;
  }
  .footer__links-item {
    padding: 0;
  }
  .footer__links-item img {
    height: 55px;
    width: auto;
  }
}
@media screen and (min-width: 768px) {
  .footer__menus .nav-menu .menu-item {
    width: auto;
  }
  .footer__menus .nav-menu .menu-item:last-child a {
    margin-right: 0px;
  }
  .footer__menus .nav-menu a {
    margin-right: 38px;
  }
  .footer__menus .sns__box {
    max-width: 600px;
  }
}
@media screen and (min-width: 1200px) {
  .footer__links-list {
    width: 1200px;
  }
}

.page footer {
  padding-top: 80px;
}

/*========================================================
 パンくず
========================================================*/
.breadcrumb {
  padding: 50px 0;
}
.breadcrumb-list {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.breadcrumb-item {
  display: flex;
  flex-direction: row;
  align-items: center;
  position: relative;
}
.breadcrumb-item::after {
  position: relative;
  content: "\f054";
  font-family: "Font Awesome 6 Free";
  font-weight: 600;
  padding: 0 10px;
}
.breadcrumb-item:last-child::after {
  display: none;
}
.breadcrumb-item a {
  font-size: 14px;
  line-height: 1.5714285714;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  transition: all 0.5s ease;
}
.breadcrumb-item a:hover {
  color: #b7a475;
}

/*========================================================
 お問い合わせボタン
========================================================*/
.contact__btn {
  position: fixed;
  bottom: 10px;
  right: 0;
  background-image: url("../images/common/pic-contact-bg.webp");
  background-repeat: no-repeat;
  background-size: cover;
  height: 50px;
  width: 250px;
  border-top-left-radius: 25px;
  border-bottom-left-radius: 25px;
  transition: all 0.5s ease;
  z-index: 99;
}
.contact__btn a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  color: #000;
  padding: 0 30px;
}
.contact__btn .mail-mark {
  font-size: 20px;
}
.contact__btn .txt {
  font-size: 15px;
  line-height: 2;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
}
.contact__btn .mark {
  background: #fff;
  width: 35px;
  height: 35px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.contact__btn .mark img {
  width: 7px;
  height: 9px;
}
.contact__btn.close {
  transform: translateX(184px);
}
@media screen and (min-width: 768px) and (min-height: 800px) {
  .contact__btn {
    width: 450px;
    height: 150px;
    border-top-left-radius: 75px;
    border-bottom-left-radius: 75px;
  }
  .contact__btn a {
    padding: 0 60px;
  }
  .contact__btn .mail-mark {
    font-size: 25px;
  }
  .contact__btn .txt {
    font-size: 25px;
    line-height: 1.2;
    letter-spacing: 0.2em;
    font-weight: 400;
  }
  .contact__btn.close {
    transform: translateX(326px);
  }
}

/*========================================================
 ページトップ
========================================================*/
.pagetop {
  position: fixed;
  bottom: 80px;
  right: 20px;
  opacity: 0;
  transition: all 0.5s ease;
  z-index: 99;
}
.pagetop a {
  pointer-events: none;
  cursor: default; /* マウスカーソルを矢印に */
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
}
.pagetop::after, .pagetop::before {
  position: absolute;
  content: "";
  background: #000;
  right: 0;
}
.pagetop::after {
  bottom: 0;
  height: 126px;
  width: 1px;
}
.pagetop::before {
  bottom: 126px;
  height: 20px;
  width: 1px;
  transform: rotate(-135deg);
  transform-origin: bottom right;
}
.pagetop__txt {
  writing-mode: vertical-rl; /* 右→左へ縦書き（日本語の標準） */
  text-orientation: mixed; /* 文字ごとに向きを最適化（英数字は横向き） */
}
.pagetop.show {
  opacity: 1;
}
.pagetop.show a {
  pointer-events: auto;
  cursor: pointer; /* マウスカーソルを矢印に */
}
@media screen and (min-width: 960px) and (min-height: 800px) {
  .pagetop {
    bottom: 180px;
  }
}

/*========================================================
 ページネーション
========================================================*/
.pagination .page-numbers {
  display: flex;
  flex-direction: row;
  justify-content: center;
  margin: 50px 0;
}
.pagination .page-numbers-item a {
  border-radius: 50%;
  height: 40px;
  width: 40px;
  background: #b7a475;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 5px;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.05em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #fff;
  transition: all 0.5s ease;
}
.pagination .page-numbers-item a:hover {
  background: #5b7968;
}
.pagination .page-numbers-item:last-child a {
  margin-right: 0px;
}
.pagination .page-numbers-item.current a {
  background: #5b7968;
}

/*========================================================
 テクスチャー設定
========================================================*/
.texture {
  background-image: url("../images/common/pic-texture_1920x3903.webp");
  background-repeat: no-repeat;
  background-size: cover;
  background-blend-mode: overlay;
}

/*========================================================
 ローディング
========================================================*/
/*========================================================
 inview
========================================================*/
.inview-box {
  opacity: 0;
  transform: translate(0, 0);
  transition: all 0.8s ease;
}

[data-inview=from-left] {
  transform: translateX(-50px);
}

.inview-left {
  opacity: 1;
  transform: translateX(0);
}

[data-inview=from-right] {
  transform: translateX(50px);
}

.inview-right {
  opacity: 1;
  transform: translateX(0);
}

[data-inview=from-top] {
  transform: translateY(-50px);
}

.inview-top {
  opacity: 1;
  transform: translateY(0);
}

[data-inview=from-bottom] {
  transform: translateY(50px);
}

.inview-bottom {
  opacity: 1;
  transform: translateY(0);
}

.main-nav {
  position: fixed;
  top: 0;
  right: -350px;
  display: flex;
  flex-direction: column;
  background: #fbfaf6;
  justify-content: flex-start;
  align-items: center;
  height: 100vh;
  overflow-y: scroll;
  width: 350px;
  max-width: 350px;
  padding: 80px 50px;
  z-index: 99;
  transition: all 0.5s ease;
}
@media screen and (min-width: 1024px) {
  .main-nav {
    position: absolute;
    right: 0;
    top: 0;
    flex-direction: row;
    align-items: center;
    width: max-content;
    height: 95px;
    max-width: unset;
    overflow-y: inherit;
    background: rgba(255, 255, 255, 0.5);
    border-bottom-left-radius: 10px;
    padding: 0px 0px 0px 10px;
  }
}
@media screen and (min-width: 1200px) {
  .main-nav {
    padding: 0px 0px 0px 30px;
  }
}
.main-nav.active {
  right: 0px;
  box-shadow: -1px -1px 10px #000;
}
.main-nav .sp-logo {
  display: flex;
  justify-content: center;
  margin-bottom: 50px;
}
.main-nav .sp-logo__visual {
  width: 200px;
  height: auto;
}
@media screen and (min-width: 1024px) {
  .main-nav .sp-logo {
    display: none;
  }
}
.main-nav .nav-menu {
  margin-bottom: 50px;
}
.main-nav .nav-menu .menu-item {
  border-bottom: 1px solid #fff;
}
.main-nav .nav-menu .menu-item:first-child {
  border-top: 1px solid #fff;
}
@media screen and (min-width: 1024px) {
  .main-nav .nav-menu .menu-item {
    border-bottom: 0px;
  }
  .main-nav .nav-menu .menu-item:first-child {
    border-top: 0px;
  }
}
.main-nav .nav-menu .menu-item a {
  position: relative;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  line-height: 1.6923076923;
  letter-spacing: 0.16em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
  padding: 14px 10px;
  transition: all 0.5s ease;
  white-space: nowrap;
}
.main-nav .nav-menu .menu-item a::after {
  position: absolute;
  opacity: 0;
  content: "";
  height: 1px;
  width: 50px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #b7a475;
  transition: all 0.5s ease;
}
@media screen and (min-width: 1024px) {
  .main-nav .nav-menu .menu-item a {
    margin-right: 30px;
    color: #000;
  }
}
.main-nav .nav-menu .menu-item a:hover {
  color: #b7a475;
}
.main-nav .nav-menu .menu-item a:hover::after {
  opacity: 1;
}
.main-nav .nav-menu .menu-item .sub-menu .menu-item {
  padding-left: 20px;
  border: 0;
}
.main-nav .nav-menu .menu-item .sub-menu .menu-item:first-child {
  border-top: 1px solid #fff;
}
.main-nav .nav-menu .menu-item .sub-menu .menu-item a {
  padding-bottom: 0;
  padding-top: 20px;
}
.main-nav .nav-menu .menu-item .sub-menu .menu-item:last-child a {
  padding-bottom: 20px;
}
@media screen and (min-width: 1024px) {
  .main-nav .nav-menu {
    display: flex;
    flex-direction: row;
    margin: 0px;
  }
  .main-nav .nav-menu .menu-item:hover .sub-menu {
    display: flex;
  }
  .main-nav .nav-menu .menu-item a {
    justify-content: center;
    margin-right: 10px;
  }
  .main-nav .nav-menu .menu-item {
    position: relative;
  }
  .main-nav .nav-menu .menu-item .sub-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    display: none;
    flex-direction: column;
    background: rgba(255, 255, 255, 0.9);
    padding: 10px;
    box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.3);
  }
  .main-nav .nav-menu .menu-item .sub-menu a {
    white-space: nowrap;
    margin-right: 0px;
    padding: 15px;
  }
  .main-nav .nav-menu .menu-item .sub-menu a:hover {
    background: #3b5045;
    color: #fff;
  }
  .main-nav .nav-menu .menu-item .sub-menu a:hover::after {
    opacity: 0;
  }
  .main-nav .nav-menu .menu-item .sub-menu .menu-item {
    border-bottom: 1px solid #3b5045;
    padding-left: 0;
  }
  .main-nav .nav-menu .menu-item .sub-menu .menu-item:last-child {
    border-bottom: 0px;
  }
  .main-nav .nav-menu .menu-item .sub-menu .menu-item:last-child a {
    padding-bottom: 15px;
  }
}
.main-nav .sns-link__list {
  display: flex;
  flex-direction: row;
}
.main-nav .sns-link__insta a {
  background: #eb6d5e;
  margin-right: 20px;
}
.main-nav .sns-link__youtube a {
  background: #e61f19;
}
.main-nav .sns-link__insta a, .main-nav .sns-link__youtube a {
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  height: 20px;
  width: 20px;
  transition: all 0.5s ease;
}
.main-nav .sns-link__insta a img, .main-nav .sns-link__youtube a img {
  height: 10px;
  width: auto;
}
.main-nav .sns-link__insta a:hover, .main-nav .sns-link__youtube a:hover {
  background: #4B4949;
}

.side-nav {
  display: none;
  position: fixed;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 45px;
}
.side-nav .nav-menu {
  background: #fff;
  width: 100%;
}
.side-nav .menu-item {
  width: 100%;
}
.side-nav .menu-item a {
  display: flex;
  justify-content: center;
  align-items: center;
  writing-mode: vertical-rl;
  font-size: 13px;
  line-height: 1.1538461538;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #b7a475;
  padding: 20px 5px;
  border-bottom: 1px solid #b7a475;
  width: 100%;
  transition: all 0.5s ease;
}
.side-nav .menu-item a:hover {
  background: #5b7968;
  color: #fff;
}
.side-nav .menu-item:last-child a {
  border-bottom: 0px;
}
.side-nav .current-menu-item a {
  background: #5b7968;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .side-nav {
    display: inline-block;
  }
}

.nav-button {
  position: fixed !important;
  top: 20px;
  right: 10px;
  display: inline-block;
  width: 30px;
  height: 22px;
  position: relative;
  cursor: pointer;
  z-index: 999;
}
.nav-button span {
  display: block;
  position: absolute;
  height: 4px;
  width: 100%;
  background: #000;
  border-radius: 2px;
  transition: all 0.3s ease;
  left: 0;
}
.nav-button span:nth-child(1) {
  top: 0;
}
.nav-button span:nth-child(2) {
  top: 9px;
}
.nav-button span:nth-child(3) {
  top: 18px;
}
.nav-button.active span:nth-child(1) {
  top: 9px;
  transform: rotate(45deg);
}
.nav-button.active span:nth-child(2) {
  opacity: 0;
}
.nav-button.active span:nth-child(3) {
  top: 9px;
  transform: rotate(-45deg);
}
@media screen and (min-width: 1024px) {
  .nav-button {
    display: none;
  }
}

/* CSS Document */
.content {
  position: relative;
  /*
  overflow-x: hidden;
  @include mq(md){
  	overflow-x: visible;
  }
  */
}
.content bg {
  overflow-x: hidden;
}

.content-bg {
  width: 100vw;
}
.content-bg .scroll-img {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  will-change: transform;
  z-index: -1;
}

.section-box {
  position: relative;
  display: flex;
  padding: 80px 0;
  border-top: 1px solid #4B4949;
  width: 100%;
  overflow-x: hidden;
}
.section-box__bg {
  display: flex;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  mix-blend-mode: multiply;
  height: 50vh;
  width: 100%;
  z-index: -1;
}
.section-box__bg img {
  object-fit: cover;
}
.section-box__title {
  display: none;
  writing-mode: vertical-rl; /* 縦書き（右→左に進む、日本語の標準） */
  text-orientation: mixed; /* 漢字かなは縦、英数字は横 */
  font-size: 15px;
  line-height: 1.4;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
}
@media screen and (min-width: 1024px) {
  .section-box__title {
    position: absolute;
    display: flex;
    top: 80px;
    justify-content: center;
    align-items: center;
    left: 2vw;
    transform: translateX(-50%);
  }
}
@media screen and (min-width: 1530px) {
  .section-box__title {
    left: calc((100vw - 1400px) / 2 - 30px);
  }
}
.section-box__visual {
  aspect-ratio: 1.5;
}
.section-box__visual img {
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .section-box__visual {
    aspect-ratio: 2.5;
  }
}
@media screen and (min-width: 1024px) {
  .section-box__visual {
    aspect-ratio: unset;
  }
}

/*========================================================
 Headline
========================================================*/
.line-style01 {
  position: relative;
  display: flex;
  flex-direction: column;
  font-size: 70px;
  line-height: 0.5;
  letter-spacing: 0.1em;
  font-weight: 100;
  font-size: min(14vw, 70px);
  font-family: "Roboto", sans-serif;
  color: #000;
  margin-bottom: 10px;
}
.line-style01 span {
  padding-top: 10px;
  font-size: 13px;
  line-height: 2.3076923077;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
}

.line-style02 {
  display: flex;
  flex-direction: column;
  font-size: 40px;
  line-height: 1.2;
  letter-spacing: 0.12em;
  font-weight: 400;
  font-size: min(10vw, 40px);
  font-family: "Noto Serif JP", serif;
  margin-bottom: 50px;
}
.line-style02 span {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 20px;
  line-height: 2.7;
  letter-spacing: 0.08em;
  font-weight: 400;
  color: #4B4949;
  font-family: "Noto Sans JP", sans-serif;
}
.line-style02 span::before {
  position: relative;
  content: "";
  display: inline-block;
  background-image: url("../images/common/pic-mark02.webp");
  background-repeat: no-repeat;
  width: 15px;
  height: 15px;
  margin-right: 10px;
}

.line-style03 {
  border-top: 1px solid #4B4949;
  border-bottom: 1px solid #4B4949;
  font-size: 20px;
  line-height: 2;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  margin-bottom: 20px;
  padding: 10px 0;
}

.line-style04 {
  font-size: 20px;
  line-height: 2;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  background: #fff;
  margin-bottom: 20px;
  min-height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.line-style05 {
  font-size: 25px;
  line-height: 2;
  letter-spacing: 0.2em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  text-align: center;
  color: #fff;
  margin-bottom: 20px;
  border-radius: 5px;
  box-shadow: 0px 1px 10px rgba(0, 0, 0, 0.2);
}

.line-style06 {
  font-size: 70px;
  line-height: 0.5;
  letter-spacing: 0.06em;
  font-weight: 100;
  font-size: min(12vw, 70px);
  font-family: "Fira Sans", sans-serif;
  color: #000;
  margin-bottom: 50px;
}

.line-style07 {
  font-size: 20px;
  line-height: 2;
  letter-spacing: 0.15em;
  font-weight: 400;
  color: #000;
  font-family: "Noto Serif JP", serif;
}

/*========================================================
 button
========================================================*/
/*========================================================
 block
========================================================*/
/*========================================================
 note
========================================================*/
/*========================================================
 read
========================================================*/
.google-map {
  position: relative;
  width: 100%;
  padding-bottom: 300px;
  height: 0;
  overflow: hidden;
  margin-top: 20px;
  margin-bottom: 50px;
}
@media screen and (min-width: 1024px) {
  .google-map {
    padding-bottom: 450px;
  }
}
.google-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* CSS Document */
.page-top .scroll-wrap {
  position: absolute;
  top: 75vh;
  left: 2vw;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 30;
}
.page-top .scroll-wrap .scroll-line {
  position: relative;
  overflow: hidden;
  height: 100px;
  width: 10px;
}
.page-top .scroll-wrap .scroll-line::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  height: 100px;
  width: 1px;
  background: #4B4949;
}
.page-top .scroll-wrap .scroll-line::before {
  content: "▼";
  position: absolute;
  left: 6px;
  top: -10px;
  transform: translateX(-50%);
  color: #4B4949;
  animation: moveY 1.5s ease-in-out infinite;
  font-size: 10px;
}
.page-top .scroll-wrap .scroll-txt {
  color: #4B4949;
  transform: rotate(90deg);
  position: relative;
  top: 18px;
  left: 2px;
}
.page-top .scroll-wrap .scroll-line-lower {
  position: relative;
  top: 40px;
  width: 1px;
  height: 1000px;
  background: #4B4949;
}
@keyframes moveY {
  0% {
    transform: translateX(-50%) translateY(-10px);
  }
  100% {
    transform: translateX(-50%) translateY(100px);
  }
}
@media screen and (min-width: 1024px) {
  .page-top .scroll-wrap {
    left: var(--side-space);
  }
}
@media screen and (min-width: 1530px) {
  .page-top .scroll-wrap {
    left: calc((100vw - 1400px) / 2);
  }
}

.page-top .kv {
  height: 600px;
  max-height: 600px;
}
.page-top .kv__visual {
  position: relative;
  height: 100%;
  overflow: hidden;
}
.page-top .kv__slider-deco {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 120%;
  max-width: 1050px;
  z-index: 2;
  opacity: 0.5;
}
.page-top .kv-swiper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 90%;
  max-width: 1000px;
  aspect-ratio: 1;
  border-radius: 50%;
  overflow: hidden;
  z-index: 1;
}
.page-top .kv-swiper img {
  object-fit: cover;
}
.page-top .kv .swiper-pagination-bullet {
  width: 50px;
  height: 1px;
  background: #000;
  transition: all 0.5s ease;
  margin-top: 30px;
}
.page-top .kv .swiper-pagination-bullet-active {
  transform: translateY(-5px);
}
.page-top .kv__deco {
  position: absolute;
  top: 0;
  left: 50vw;
  width: 50vw;
  height: 50vh;
  opacity: 0.8;
  z-index: 3;
  mix-blend-mode: overlay;
}
.page-top .kv__deco img {
  object-fit: cover;
}
.page-top .kv__cp {
  position: absolute;
  top: 360px;
  left: 0;
  z-index: 4;
}
.page-top .kv__cp-en {
  font-size: 13px;
  line-height: 1.6153846154;
  letter-spacing: 0.1em;
  font-weight: 400;
  font-size: min(3vw, 18px);
  font-family: "Noto Sans JP", sans-serif;
  margin-bottom: 10px;
}
.page-top .kv__cp-jp {
  font-size: 80px;
  line-height: 1.375;
  letter-spacing: 0.06em;
  font-weight: 400;
  font-size: min(7vw, 80px);
  font-family: "Noto Serif JP", serif;
}
@media screen and (min-width: 580px) {
  .page-top .kv__slider-deco {
    width: 100%;
  }
  .page-top .kv-swiper {
    width: 80%;
  }
}
@media screen and (min-width: 768px) and (min-height: 800px) {
  .page-top .kv {
    height: 800px;
    max-height: 800px;
  }
  .page-top .kv__cp {
    top: 480px;
  }
}
@media screen and (min-width: 1024px) and (min-height: 800px) {
  .page-top .kv {
    height: 1024px;
    max-height: 1024px;
  }
  .page-top .kv__slider-deco {
    top: 0px;
    transform: translateX(-50%) translateY(0%);
    max-width: 1240px;
  }
  .page-top .kv-swiper {
    top: 124px;
    transform: translateX(-50%) translateY(0%);
  }
  .page-top .kv__deco {
    top: -124px;
  }
  .page-top .kv__cp {
    top: 614.4px;
  }
}
@media screen and (min-width: 1200px) and (min-height: 800px) {
  .page-top .kv {
    height: 1180px;
    max-height: 1180px;
  }
}
@media screen and (min-width: 1200px) {
  .page-top .kv__cp {
    left: calc((100vw - 1200px) / 2);
  }
}

.page-top .story {
  position: relative;
  width: 100vw;
  overflow: hidden;
  height: 490px;
  transform: translateX(0);
  margin-top: 50px;
  margin-bottom: 80px;
}
.page-top .story__img {
  position: absolute;
  transform-origin: left top;
}
.page-top .story__img img {
  object-fit: unset;
  width: 100%;
  height: auto;
}
@media screen and (min-width: 1200px) {
  .page-top .story {
    margin-bottom: 120px;
  }
}

.page-top .message {
  overflow-x: clip;
}
.page-top .message__box {
  display: flex;
  flex-direction: column;
  margin-bottom: 80px;
}
.page-top .message__read p {
  font-size: 20px;
  line-height: 3.15;
  letter-spacing: 0.08em;
  font-weight: 400;
  font-size: min(4vw, 20px);
  font-family: "Noto Serif JP", serif;
  color: #000;
}
.page-top .message__visual {
  height: 50vw;
  max-height: 470px;
}
.page-top .message__visual img {
  object-fit: cover;
}
@media screen and (min-width: 1200px) {
  .page-top .message__box {
    flex-direction: row;
  }
  .page-top .message__title {
    width: 40%;
  }
  .page-top .message__read {
    position: relative;
    top: -35px;
    width: 60%;
  }
}

.page-top .occupation.section-box {
  border-top: 0px;
}
.page-top .occupation .section-box__bg {
  top: 0;
}
.page-top .occupation__visual {
  margin-bottom: 50px;
}
.page-top .occupation__body p {
  font-size: 17px;
  line-height: 2.5294117647;
  letter-spacing: 0.06em;
  font-weight: 400;
  font-size: min(4vw, 17px);
  font-family: "Noto Serif JP", serif;
  color: #000;
  margin-bottom: 50px;
}
.page-top .occupation__org-chart {
  display: flex;
  justify-content: center;
}
.page-top .occupation__org-chart img {
  max-width: 385px;
}
.page-top .occupation__list {
  padding-bottom: 30px;
}
.page-top .occupation__item {
  margin-bottom: 40px;
}
.page-top .occupation__item p {
  font-size: 15px;
  line-height: 1.6666666667;
  letter-spacing: 0.04em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
}
@media screen and (min-width: 768px) {
  .page-top .occupation__box {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .page-top .occupation__visual {
    width: 100%;
    order: 1;
  }
  .page-top .occupation__body {
    width: 50%;
    order: 3;
  }
  .page-top .occupation__org-chart {
    position: relative;
    top: -40px;
    width: 50%;
    order: 2;
    align-items: flex-start;
    justify-content: flex-start;
  }
  .page-top .occupation__org-chart img {
    height: auto;
  }
  .page-top .occupation__list {
    order: 4;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
  }
  .page-top .occupation__item {
    width: calc((100% - 40px) / 3);
  }
}
@media screen and (min-width: 1024px) {
  .page-top .occupation .occupation__box {
    display: grid;
    grid-template-columns: 1fr 1fr 365px;
    grid-template-rows: repeat(3, max-content);
    grid-column-gap: 50px;
    grid-row-gap: 0px;
  }
  .page-top .occupation__title {
    grid-area: 1/1/2/3;
  }
  .page-top .occupation__visual {
    grid-area: 1/3/4/4;
    width: calc(100% + (var(--side-space)));
    max-height: 750px;
  }
  .page-top .occupation__body {
    grid-area: 2/2/3/3;
    width: 100%;
  }
  .page-top .occupation__org-chart {
    grid-area: 2/1/3/2;
    width: 100%;
  }
  .page-top .occupation__list {
    grid-area: 3/1/4/3;
  }
}
@media screen and (min-width: 1320px) {
  .page-top .occupation__visual {
    width: calc(100% + (100vw - 1200px) / 2);
  }
}

.page-top .application-guideline.section-box {
  padding-bottom: 0;
}
.page-top .application-guideline .section-box__bg {
  top: 0;
}
.page-top .application-guideline .new-graduate__title {
  background: #B1DE99;
}
.page-top .application-guideline .mid-career__title {
  background: #9BD5E0;
}
.page-top .application-guideline__read {
  font-size: 15px;
  line-height: 1.6666666667;
  letter-spacing: 0em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
  margin-bottom: 50px;
  text-align: center;
}
.page-top .application-guideline__list {
  display: flex;
  flex-direction: column;
  margin-bottom: 50px;
}
.page-top .application-guideline__item {
  border-top: 1px solid #4B4949;
  padding: 20px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 18px;
  line-height: 1.6666666667;
  letter-spacing: 0em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
}
.page-top .application-guideline__item:last-child {
  border-bottom: 1px solid #4B4949;
}
.page-top .application-guideline__item.note {
  font-size: 15px;
  line-height: 1.6666666667;
  letter-spacing: 0em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  text-align: center;
  border-bottom: 0px;
}
@media screen and (min-width: 580px) {
  .page-top .application-guideline__box {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    width: 100%;
  }
  .page-top .application-guideline__body {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
    margin-top: 50px;
  }
  .page-top .application-guideline__body .new-graduate, .page-top .application-guideline__body .mid-career {
    width: calc((100% - 20px) / 2);
  }
  .page-top .application-guideline__visual {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .page-top .application-guideline.section-box {
    padding-bottom: 80px;
  }
}
@media screen and (min-width: 1024px) {
  .page-top .application-guideline__box {
    display: grid;
    grid-template-columns: 1fr 365px;
    grid-template-rows: repeat(2, max-content);
    grid-column-gap: 50px;
    grid-row-gap: 0px;
  }
  .page-top .application-guideline__title {
    grid-area: 1/1/2/2;
  }
  .page-top .application-guideline__body {
    grid-area: 2/1/3/2;
  }
  .page-top .application-guideline__visual {
    grid-area: 1/2/3/3;
    width: calc(100% + (var(--side-space)));
    max-height: 750px;
  }
}
@media screen and (min-width: 1200px) {
  .page-top .application-guideline__box {
    width: 1200px;
  }
}
@media screen and (min-width: 1320px) {
  .page-top .application-guideline__visual {
    width: calc(100% + (100vw - 1200px) / 2);
  }
}

.page-top .schedule .section-box__bg {
  bottom: 0;
}
.page-top .schedule__read {
  font-size: 17px;
  line-height: 2.3529411765;
  letter-spacing: 0.06em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
  margin-bottom: 50px;
}
.page-top .schedule__item {
  position: relative;
  background: #9BD5E0;
  margin-bottom: 30px;
  z-index: 0;
  padding: 20px;
}
.page-top .schedule__item::before {
  position: absolute;
  content: "";
  background: #9BD5E0;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%) rotate(-45deg);
  width: 50px;
  height: 50px;
  display: flex;
  transform-origin: center center;
  z-index: -1;
}
.page-top .schedule__item-range {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  font-size: 15px;
  line-height: 1.6666666667;
  letter-spacing: 0em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  padding: 20px 10px;
  margin-bottom: 20px;
}
.page-top .schedule__item-title {
  font-size: 25px;
  line-height: 2;
  letter-spacing: 0.14em;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  color: #000;
  text-align: center;
  border-bottom: 1px solid #4B4949;
  padding-bottom: 20px;
  margin-bottom: 20px;
}
.page-top .schedule__item-read {
  font-size: 15px;
  line-height: 1.6666666667;
  letter-spacing: 0em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
}
.page-top .schedule__item:last-child {
  background: #B1DE99;
}
.page-top .schedule__item:last-child .schedule__item-title {
  border-bottom: 0px;
  padding-bottom: 0px;
}
.page-top .schedule__item:last-child::before {
  display: none;
}
@media screen and (min-width: 768px) {
  .page-top .schedule__item {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(2, max-content);
    grid-column-gap: 20px;
    grid-row-gap: 0px;
  }
  .page-top .schedule__item-range {
    grid-area: 1/1/2/2;
  }
  .page-top .schedule__item-title {
    grid-area: 2/1/3/2;
    border-bottom: 0px;
    padding-bottom: 0px;
    margin-bottom: 0px;
  }
  .page-top .schedule__item-read {
    grid-area: 1/2/3/3;
    border-left: 1px solid #000;
    padding-left: 20px;
  }
  .page-top .schedule__item:last-child {
    display: flex;
    flex-direction: row;
  }
  .page-top .schedule__item:last-child .schedule__item-range {
    width: 50%;
    margin-bottom: 0;
  }
  .page-top .schedule__item:last-child .schedule__item-title {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 50%;
    border-left: 1px solid #000;
  }
}
@media screen and (min-width: 1024px) {
  .page-top .schedule__item {
    grid-template-columns: 150px 300px 1fr;
    grid-template-rows: max-content;
  }
  .page-top .schedule__item-range {
    grid-area: 1/1/2/2;
    margin-bottom: 0;
  }
  .page-top .schedule__item-title {
    grid-area: 1/2/2/3;
    display: flex;
    align-items: center;
  }
  .page-top .schedule__item-read {
    grid-area: 1/3/2/4;
    display: flex;
    align-items: center;
  }
  .page-top .schedule__item:last-child .schedule__item-range {
    width: 150px;
    min-width: 150px;
    grid-area: 1/1/2/2;
  }
  .page-top .schedule__item:last-child .schedule__item-title {
    width: 100%;
    grid-area: 1/2/2/4;
    border-left: 0;
  }
}

.page-top .guidance .section-box__bg {
  bottom: 0;
}
.page-top .guidance__menus {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: 100%;
}
.page-top .guidance__menus-item input {
  display: none;
}
.page-top .guidance__menus-item input:checked + label {
  background: #B1DE99;
}
.page-top .guidance__menus-item label {
  background: #9BD5E0;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
  padding: 10px 5px;
  height: 100%;
  min-width: 80px;
  min-height: 55px;
  color: #fff;
}
.page-top .guidance__menus-item label:hover {
  cursor: pointer;
}
@media screen and (min-width: 580px) {
  .page-top .guidance__menus {
    padding: 0 40px;
  }
  .page-top .guidance__menus-item {
    width: calc((100% - 30px) / 4);
  }
}
.page-top .guidance__list-box {
  background-color: #fff;
  background-image: radial-gradient(#e4e4e4 1%, transparent 21%), radial-gradient(#e4e4e4 1%, transparent 21%);
  background-position: 0 0, 4px 4px;
  background-size: 8px 8px;
  padding: 10px;
  border-radius: 5px;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.5);
}
.page-top .guidance__list-item {
  background: #fff;
  padding: 10px;
  border-radius: 5px;
}
.page-top .guidance__list-item .read {
  font-size: 17px;
  line-height: 2.3529411765;
  letter-spacing: 0.06em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
}
.page-top .guidance__list-item .read > p {
  padding-bottom: 20px;
}
.page-top .guidance__list-item .memo {
  border-top: 1px solid #4B4949;
  padding: 20px 0;
  font-size: 17px;
  line-height: 2.3529411765;
  letter-spacing: 0.06em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
}
@media screen and (min-width: 580px) {
  .page-top .guidance__list-box {
    padding: 30px;
  }
  .page-top .guidance__list-item {
    padding: 30px;
  }
}

.page-top .required-documents .section-box__bg {
  bottom: 0;
}
.page-top .required-documents .new-graduate__title {
  background: #B1DE99;
}
.page-top .required-documents .mid-career__title {
  background: #9BD5E0;
}
.page-top .required-documents__read {
  font-size: 15px;
  line-height: 1.6666666667;
  letter-spacing: 0em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
  margin-bottom: 50px;
  text-align: center;
}
.page-top .required-documents__list {
  display: flex;
  flex-direction: column;
  margin-bottom: 50px;
}
.page-top .required-documents__item {
  border-top: 1px solid #4B4949;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 65px;
}
.page-top .required-documents__item:last-child {
  border-bottom: 1px solid #4B4949;
}
.page-top .required-documents__item {
  font-size: 18px;
  line-height: 1.6666666667;
  letter-spacing: 0.04em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
}
.page-top .required-documents__item span {
  font-size: 13px;
  line-height: 1.9230769231;
  letter-spacing: 0.04em;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  color: #000;
}
@media screen and (min-width: 580px) {
  .page-top .required-documents__box {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .page-top .required-documents__body {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
    margin-top: 50px;
  }
  .page-top .required-documents__body .new-graduate, .page-top .required-documents__body .mid-career {
    width: calc((100% - 18px) / 2);
  }
  .page-top .required-documents__visual {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .page-top .required-documents.section-box {
    padding-bottom: 80px;
  }
}
@media screen and (min-width: 1024px) {
  .page-top .required-documents__box {
    display: grid;
    grid-template-columns: 1fr 365px;
    grid-template-rows: repeat(2, max-content);
    grid-column-gap: 50px;
    grid-row-gap: 0px;
    width: 100%;
  }
  .page-top .required-documents__title {
    grid-area: 1/1/2/2;
  }
  .page-top .required-documents__body {
    grid-area: 2/1/3/2;
  }
  .page-top .required-documents__visual {
    grid-area: 1/2/3/3;
    width: calc(100% + (var(--side-space)));
    max-height: 750px;
  }
}
@media screen and (min-width: 1200px) {
  .page-top .required-documents__box {
    width: 1200px;
  }
}
@media screen and (min-width: 1320px) {
  .page-top .required-documents__visual {
    width: calc(100% + (100vw - 1200px) / 2);
  }
}

.page-top .contact.section-box {
  position: relative;
  padding-bottom: 0;
  z-index: 20;
  background: #fff;
  height: 700px;
}
.page-top .contact .section-box__bg {
  top: 0;
  height: 500px;
  max-height: 500px;
}
.page-top .contact .section-box__bg img {
  object-fit: cover;
}
.page-top .contact__box {
  position: relative;
}
.page-top .contact__read {
  font-size: 13px;
  line-height: 2.3076923077;
  letter-spacing: 0.22em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  margin-bottom: 50px;
}
.page-top .contact__btn-wrap {
  margin-bottom: 50px;
}
.page-top .contact__btn-wrap a {
  display: flex;
  flex-direction: row;
  align-items: center;
  font-size: 13px;
  line-height: 2.7692307692;
  letter-spacing: 0.32em;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  max-width: 250px;
}
.page-top .contact__btn-wrap a:hover .btn-dec::before {
  width: 50px;
  height: 50px;
}
.page-top .contact__btn-wrap .btn-dec {
  position: relative;
  display: flex;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid #000;
  margin-right: 20px;
}
.page-top .contact__btn-wrap .btn-dec::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #000;
  transition: all 0.5s ease;
}
.page-top .contact__visual {
  position: absolute;
  bottom: 50px;
  right: 0px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 1fr 65px 1fr;
  grid-column-gap: 20px;
  grid-row-gap: 0px;
  z-index: -1;
  width: 70%;
}
.page-top .contact__visual div:nth-child(1) {
  grid-area: 2/1/4/2;
}
.page-top .contact__visual div:nth-child(2) {
  grid-area: 1/2/3/3;
}
@media screen and (min-width: 580px) {
  .page-top .contact__box {
    width: 100%;
  }
  .page-top .contact__visual {
    width: 60%;
  }
}
@media screen and (min-width: 768px) {
  .page-top .contact__visual {
    bottom: 130px;
    max-width: 350px;
  }
}
@media screen and (min-width: 1200px) {
  .page-top .contact.section-box {
    height: 600px;
  }
  .page-top .contact__box {
    width: 1200px;
  }
  .page-top .contact__visual {
    bottom: 50px;
  }
}

.page .page-kv {
  height: 200px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 80px;
}

.page .content {
  padding-bottom: 80px;
}

.page-contact {
  /* 日曜日のカラー設定 */
}
.page-contact td.ui-datepicker-week-end:first-child a.ui-state-default {
  background-color: #ffecec; /* 背景色を設定 */
  color: #e61f19 !important; /* 文字色を設定 */
}
.page-contact {
  /* 土曜日のカラー設定 */
}
.page-contact td.ui-datepicker-week-end:last-child a.ui-state-default {
  /*background-color: #eaeaff;*/ /* 背景色を設定 */
  color: #00f !important; /* 文字色を設定 */
}
.page-contact td.ui-state-disabled .ui-state-default {
  color: #e61f19 !important; /* 文字色を設定 */
}
.page-contact {
  /* ホバー時の動作 */
}
.page-contact td.ui-datepicker-week-end a.ui-state-hover {
  opacity: 0.8;
}
.page-contact {
  /* 当日を示す色はそのまま */
}
.page-contact td.ui-datepicker-week-end a.ui-state-highlight {
  background-color: #fffa90 !important;
}
.page-contact .calendar {
  position: relative;
}
.page-contact .calendar .calendar-select {
  display: none;
  position: absolute;
  top: 40;
  left: 0;
  z-index: 99;
}
.page-contact .ui-datepicker .ui-datepicker-calendar .ui-state-highlight a {
  background: #B1DE99 none;
}
.page-contact #recuit-contact-main .inner, .page-contact #recuit-conf-input .inner {
  max-width: 768px;
}
.page-contact #recuit-contact-main input[type=text], .page-contact #recuit-conf-input input[type=text] {
  height: 30px;
  padding: 5px;
  width: 95%;
  font-size: 16px;
  line-height: 1.5625;
  letter-spacing: 0.15em;
  font-weight: 400;
  height: 60px;
  padding: 10px;
}
.page-contact #recuit-contact-main input[type=text]:focus, .page-contact #recuit-conf-input input[type=text]:focus {
  outline: 0;
}
.page-contact #recuit-contact-main input[type=radio], .page-contact #recuit-conf-input input[type=radio] {
  position: relative;
  top: -1px;
  left: -2px;
  width: 22px;
  height: 22px;
  border: 2px solid #B1DE99;
  border-radius: 50%;
  vertical-align: -2px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.page-contact #recuit-contact-main input[type=radio]:checked:before, .page-contact #recuit-conf-input input[type=radio]:checked:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #B1DE99;
  content: "";
}
.page-contact #recuit-contact-main input[type=checkbox], .page-contact #recuit-conf-input input[type=checkbox] {
  position: relative;
  top: 4px;
  width: 20px;
  height: 20px;
  border: 2px solid #B1DE99;
  vertical-align: -5px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.page-contact #recuit-contact-main input[type=checkbox]:checked::before, .page-contact #recuit-conf-input input[type=checkbox]:checked::before {
  position: absolute;
  top: 2px;
  left: 5px;
  transform: rotate(42deg);
  width: 4px;
  height: 8px;
  border-right: 2px solid #B1DE99;
  border-bottom: 2px solid #B1DE99;
  content: "";
}
.page-contact #recuit-contact-main textarea, .page-contact #recuit-conf-input textarea {
  width: 96%;
  height: 100px;
  font-size: 16px;
  line-height: 1.5625;
  letter-spacing: 0.15em;
  font-weight: 400;
}
.page-contact #recuit-contact-main select, .page-contact #recuit-conf-input select {
  height: 40px;
  width: 80px;
  background: #fff;
  border: 1px solid #8f8f9d;
  border-radius: 4px;
  color: #000;
  font-size: 14px;
  line-height: 1.7857142857;
  letter-spacing: 0.15em;
  font-weight: 400;
  height: 60px;
  padding: 10px;
}
@media screen and (max-width: 768px) {
  .page-contact #recuit-contact-main .calendar-select table td, .page-contact #recuit-contact-main .calendar-select table th, .page-contact #recuit-conf-input .calendar-select table td, .page-contact #recuit-conf-input .calendar-select table th {
    display: table-cell;
    width: auto;
  }
}
.page-contact #recuit-contact-main .hero, .page-contact #recuit-conf-input .hero {
  padding: 40px 0;
  text-align: center;
}
.page-contact #recuit-contact-main .table .item, .page-contact #recuit-conf-input .table .item {
  padding: 20px 0;
  border-bottom: 1px solid #4B4949;
  flex-direction: column;
}
.page-contact #recuit-contact-main .table .item .name, .page-contact #recuit-conf-input .table .item .name {
  font-size: 14px;
  line-height: 1.7857142857;
  letter-spacing: 0.15em;
  font-weight: 700;
  margin-bottom: 10px;
}
.page-contact #recuit-contact-main .table .item .input, .page-contact #recuit-conf-input .table .item .input {
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .page-contact #recuit-contact-main .table .item, .page-contact #recuit-conf-input .table .item {
    display: flex;
    flex-direction: row;
  }
  .page-contact #recuit-contact-main .table .item .name, .page-contact #recuit-conf-input .table .item .name {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    width: 200px;
    min-width: 200px;
    margin-bottom: 0px;
  }
}
.page-contact #recuit-contact-main .input, .page-contact #recuit-conf-input .input {
  display: flex;
  flex-direction: column;
}
.page-contact #recuit-contact-main .input label, .page-contact #recuit-conf-input .input label {
  position: relative;
  left: -6px;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  height: 30px;
}
.page-contact #recuit-contact-main .birthday .input, .page-contact #recuit-conf-input .birthday .input {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.page-contact #recuit-contact-main .birthday .input select, .page-contact #recuit-conf-input .birthday .input select {
  margin-right: 5px;
}
.page-contact #recuit-contact-main .zipcode .input .ctl-group, .page-contact #recuit-conf-input .zipcode .input .ctl-group {
  display: flex;
  flex-direction: row;
}
.page-contact #recuit-contact-main .zipcode .input .ctl-group input, .page-contact #recuit-conf-input .zipcode .input .ctl-group input {
  width: 100px;
}
.page-contact #recuit-contact-main .zipcode .input .ctl-group .search_btn a, .page-contact #recuit-conf-input .zipcode .input .ctl-group .search_btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 100%;
  margin-left: 5px;
  background: #B1DE99;
  color: #fff;
}
.page-contact #recuit-contact-main .school_year .input input, .page-contact #recuit-contact-main .experience_year .input input, .page-contact #recuit-conf-input .school_year .input input, .page-contact #recuit-conf-input .experience_year .input input {
  width: 80px !important;
}
.page-contact #recuit-contact-main .qualification .input p, .page-contact #recuit-conf-input .qualification .input p {
  margin-bottom: 0;
}
.page-contact #recuit-contact-main .calendar-choise .input .selected-days, .page-contact #recuit-conf-input .calendar-choise .input .selected-days {
  font-size: 16px;
  line-height: 1.5625;
  letter-spacing: 0.15em;
  font-weight: 400;
  padding: 20px 0;
}
.page-contact #recuit-contact-main .calendar-choise .input .calendar .open_calendar, .page-contact #recuit-conf-input .calendar-choise .input .calendar .open_calendar {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 120px;
  height: 40px;
  background: #B1DE99;
  color: #fff;
}
.page-contact #recuit-contact-main .agreement, .page-contact #recuit-conf-input .agreement {
  text-align: center;
  padding: 40px 0 0px;
}
.page-contact #recuit-contact-main .agreement a, .page-contact #recuit-conf-input .agreement a {
  color: #B1DE99;
  text-decoration-line: underline;
}
.page-contact #recuit-contact-main .agreement-box, .page-contact #recuit-conf-input .agreement-box {
  display: flex;
  justify-content: center;
}
.page-contact #recuit-contact-main .agreement-box .checkbox, .page-contact #recuit-conf-input .agreement-box .checkbox {
  padding: 0 0 0 10px;
  display: flex;
}
.page-contact #recuit-contact-main .btn-list, .page-contact #recuit-conf-input .btn-list {
  display: flex;
  justify-content: center;
  margin-top: 30px;
}
.page-contact #recuit-contact-main .btn-list .btn a, .page-contact #recuit-conf-input .btn-list .btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 120px;
  height: 40px;
  background: #B1DE99;
  color: #fff;
  padding: 0;
  margin-right: 10px;
}
.page-contact #recuit-contact-main .btn-list .btn a::before, .page-contact #recuit-conf-input .btn-list .btn a::before {
  display: none;
}
.page-contact #recuit-contact-main .btn-list .btn:last-child a, .page-contact #recuit-conf-input .btn-list .btn:last-child a {
  margin-right: 0;
}
.page-contact #recuit-conf-comp {
  display: flex;
  justify-content: center;
  text-align: center;
}
.page-contact #recuit-conf-comp .hero-catch {
  font-size: 20px;
  margin: 20px 0;
}
.page-contact #recuit-conf-comp .hero-txt {
  line-height: 2em;
}
.page-contact .error-message {
  width: 100%;
  color: #e61f19;
  font-weight: 500;
  border: 1px solid #e61f19;
  border-radius: 5px;
  padding: 10px;
  margin-bottom: 20px;
}
.page-contact .error {
  color: #e61f19;
  font-weight: 500;
  margin-bottom: 10px;
}

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