/*=============================================
 * body
 *=============================================*/
body {
  background: #fff;
  color: #000;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 17px;
  line-height: 2;
  letter-spacing: 0.04em;
  min-width: inherit;
  min-height: inherit;
  max-height: 100%;
  word-break: break-word; }

@media screen and (max-width: 767px) {
  body {
    font-size: 15px; } }
/*=============================================
 * <main>
 *=============================================*/
main {
  clear: both;
  width: 100%;
  box-sizing: border-box;
  position: relative;
  margin: 0;
  padding: 0 0 0 170px; }

@media screen and (max-width: 1023px) {
  main {
    padding-left: 100px; } }
@media screen and (max-width: 767px) {
  main {
    padding-left: 50px; } }
/* =============================================
 * Custom
*=============================================*/
.h2 {
  font-weight: 500;
  font-size: 42px;
  line-height: 2;
  letter-spacing: 0.04em; }
  .h2 .en,
  .h2 .sub {
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal;
    line-height: 23px;
    text-transform: uppercase; }
  .h2 .en {
    display: inline-block;
    vertical-align: middle;
    border: 1px solid;
    font-size: 18px;
    margin-bottom: 20px;
    padding: 10px 20px; }
  .h2 .sub {
    display: block;
    font-size: 14px; }

.h-18 {
  font-weight: 500;
  font-size: 18px;
  line-height: 1.5; }

.h-20 {
  font-weight: 500;
  font-size: 20px;
  line-height: 1.5; }

.h-22 {
  font-weight: 500;
  font-size: 22px;
  line-height: 1.5; }

.h-24 {
  font-weight: 500;
  font-size: 24px;
  line-height: 1.5; }

.h-26 {
  font-weight: 500;
  font-size: 26px;
  line-height: 1.5; }

.h-28 {
  font-weight: 500;
  font-size: 28px;
  line-height: 1.5; }

.h-30 {
  font-weight: 500;
  font-size: 30px;
  line-height: 1.5; }

.h-32 {
  font-weight: 500;
  font-size: 32px;
  line-height: 1.5; }

.h-36 {
  font-weight: 500;
  font-size: 36px;
  line-height: 1.5; }

.h-40 {
  font-weight: 500;
  font-size: 40px;
  line-height: 1.5; }

.h-42 {
  font-weight: 500;
  font-size: 42px;
  line-height: 1.5; }

@media screen and (max-width: 767px) {
  .h2 {
    font-size: 24px;
    line-height: 1.4;
    text-align: center; }
    .h2 .en {
      font-size: 13px;
      line-height: 20px;
      padding: 5px 15px; }
    .h2 .sub {
      font-size: 10px;margin-top:8px; }

  .h-18,
  .h-20 {
    font-size: 15px; }

  .h-22,
  .h-24,
  .h-26 {
    font-size: 17px; }

  .h-28,
  .h-30 {
    font-size: 19px; }

  .h-32,
  .h-36 {
    font-size: 21px; } }
/* button */
.button {
  position: relative; }

.button a {
  display: inline-flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0;
  min-width: 200px;
  height: 60px;
  background-color: transparent;
  color: #000;
  border: 1px solid #000;
  font-weight: 500;
  font-size: 17px;
  letter-spacing: 0.04em;
  line-height: 2;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  border-radius: 50px;
  padding: 0 40px 2px 60px; }
  .button a:before {
    content: '';
    width: 5px;
    height: 5px;
    background-color: #000;
    position: absolute;
    top: 50%;
    left: 30px;
    border-radius: 50%;
    transform: translateY(-50%);
    z-index: -1;
    transition: all 0.3s; }

.button a:hover {
  color: #fff;
  opacity: 1; }
  .button a:hover:before {
    width: 100%;
    height: 100%;
    left: 0;
    border-radius: 50px; }

.button.wh a {
  border-color: #fff;
  color: #fff; }
  .button.wh a:before {
    background-color: #fff; }
  .button.wh a:hover {
    color: #000; }

@media screen and (max-width: 767px) {
  .button {
    text-align: center; }
    .button a {
      min-width: inherit;
      font-size: 14px;
      padding: 0 20px 2px 30px; }
      .button a:before {
        left: 20px; } }
/* -- -- */
.txt-udl {
  text-decoration: underline; }

a.txt-udl:hover {
  text-decoration: none; }

.txt-c {
  text-align: center; }

.txt-j {
  text-align: justify; }

.txt-r {
  text-align: right; }

.cl-blue {
  color: #1471CA; }

.cl-green {
  color: #0F6CA7; }

.cl-red {
  color: #BD3A43; }

.cl-yellow {
  color: #A77930; }

.cl-black {
  color: #4B4B4B; }

.cl-white {
  color: #fff; }

.cl-orange {
  color: #DD6B20; }

.cl-pink {
  color: #BF7A77; }

.udl01 {
  background-image: linear-gradient(#ECE484, #ECE484);
  background-size: 100% 7px;
  background-repeat: no-repeat;
  background-position: left bottom; }

.udl02 {
  background-image: linear-gradient(#002A7D, #002A7D);
  background-size: 100% 17px;
  background-repeat: no-repeat;
  background-position: left bottom; }

.fw-400 {
  font-weight: 400; }

.fw-500 {
  font-weight: 500; }

.fw-700 {
  font-weight: 700; }

.fw-900 {
  font-weight: 900; }

.bdra-10 {
  border-radius: 10px; }

.bdra-20 {
  border-radius: 20px; }

.bdra-30 {
  border-radius: 30px; }

.img_shadow {
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.05); }

.img-obj {
  width: 100%;
  max-width: inherit;
  height: 100%;
  object-fit: cover; }

@media screen and (max-width: 767px) {
  .bdra-20 {
    border-radius: 10px; }

  .bdra-30 {
    border-radius: 15px; } }
/* -- --*/
.w600 {
  max-width: 600px;
  margin: 0 auto; }

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

.w900 {
  max-width: 900px;
  margin: 0 auto; }

.w1000 {
  max-width: 1000px;
  margin: 0 auto; }

/* -- --*/
.section-space {
  padding: 120px 0; }

.pt10 {
  padding-top: 10px; }

.pt20 {
  padding-top: 20px; }

.pt30 {
  padding-top: 30px; }

.pt40 {
  padding-top: 40px; }

.pt50 {
  padding-top: 50px; }

.pt60 {
  padding-top: 60px; }

.pt80 {
  padding-top: 80px; }

.pt120 {
  padding-top: 120px; }

.pb80 {
  padding-bottom: 80px; }

.pb100 {
  padding-bottom: 100px; }

.pb120 {
  padding-bottom: 120px; }

.pb200 {
  padding-bottom: 200px; }

.mt20 {
  margin-top: 20px; }

.mt30 {
  margin-top: 30px; }

.mt40 {
  margin-top: 30px; }

.mt50 {
  margin-top: 50px; }

@media screen and (max-width: 767px) {
  .section-space {
    padding: 50px 0; }

  .pt30,
  .pt40 {
    padding-top: 20px; }

  .pt50,
  .pt60 {
    padding-top: 30px; }

  .pt80 {
    padding-top: 40px; }

  .pt120 {
    padding-top: 50px; }

  .pb80 {
    padding-bottom: 40px; }

  .pb100 {
    padding-bottom: 50px; }

  .pb120 {
    padding-bottom: 50px; }

  .pb200 {
    padding-bottom: 100px; }

  .mt30 {
    margin-top: 20px; } }
/* -- --*/
.bg-cl01 {
  background-color: #1063C5; }

.bg-cl02 {
  background-color: #ECF6FC; }

.bg-cl03 {
  background-color: #CFE3FF; }

/* -- -- */
.img-zoom,
.img-zoom figure {
  display: block;
  overflow: hidden; }

.img-zoom .img,
.img-zoom .img-obj {
  transition: 0.6s ease-in-out; }

.img-zoom:hover .img,
.img-zoom:hover .img-obj {
  transform: scale(1.07); }

/* -- --*/
.photo-full img {
  width: 100%;
  max-width: inherit; }

/* -- --*/
hr {
  border: 0;
  border-bottom: 1px solid #ccc; }

/* -- --*/
.swiper-button-prev,
.swiper-button-next {
  width: 60px;
  height: 60px;
  position: static;
  margin-top: 0;
  transition: all 0.3s;
  filter: drop-shadow(0 -1px 7px rgba(0, 0, 0, 0.1)); }

.swiper-button-prev svg,
.swiper-button-next svg {
  display: none; }

.swiper-button-prev:hover,
.swiper-button-next:hover {
  opacity: 0.7; }

.swiper-button-prev {
  background: url("../img/common/slider-prev.png") no-repeat center top/cover; }

.swiper-button-next {
  background: url("../img/common/slider-next.png") no-repeat center top/cover; }

.swiper-pagination {
  display: flex;
  gap: 10px; }

.swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background-color: #C7C7C7;
  border: 0;
  margin: 0;
  padding: 0;
  opacity: 1;
  box-sizing: border-box;
  transition: all 0.3s; }

.swiper-pagination-bullet-active,
.swiper-pagination-bullet:hover {
  background-color: #1549AC; }

.swiper-horizontal .swiper-button-prev,
.swiper-horizontal .swiper-button-next {
  margin-top: 0; }

.swiper-pagination-bullets.swiper-pagination-horizontal {
  width: auto;
  position: static; }

.swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
  width: 100%;
  height: 4px;
  background-color: #D9D9D9;
  border-radius: 0;
  position: relative;
  top: auto;
  right: auto;
  bottom: auto;
  left: auto; }

.swiper-scrollbar-drag,
.swiper-scrollbar.swiper-scrollbar-horizontal-drag {
  background-color: #008570;
  border-radius: 0; }

.slick-arrow {
  display: block;
  width: 18px;
  height: 36px;
  background-image: url("../img/common/slider-arrow_on.webp");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% auto;
  background-color: transparent;
  font-size: 0;
  border: 0;
  cursor: pointer;
  transition: all 0.3s; }
  .slick-arrow.slick-disabled {
    background-image: url("../img/common/slider-arrow.webp");
    pointer-events: none; }

.slick-arrow:hover {
  opacity: 0.5; }

.slick-next {
  transform: rotate(180deg); }

.slick-dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px; }

.slick-dots li {
  width: 12px;
  height: 12px; }

.slick-dots button {
  display: block;
  width: 100%;
  height: 100%;
  background: #C7C7C7;
  border: 0;
  font-size: 0;
  cursor: pointer;
  transition: all 0.3s;
  border-radius: 50%; }

.slick-dots .slick-active button,
.slick-dots button:hover {
  background-color: #1549AC; }

.slider-nav {
  display: flex;
  align-items: center;
  gap: 15px; }

.slider-nav .slick-dots {
  order: 1; }

.slider-nav .slick-prev {
  order: 2;
  margin-left: 35px; }

.slider-nav .slick-next {
  order: 3; }

/* -- -- */
.tb-style {
  line-height: 25px; }

.tb-style dl {
  display: table;
  width: 100%;
  box-sizing: border-box;
  border-bottom: 2px solid #E8E8E8;
  padding-bottom: 30px; }

.tb-style dl + dl {
  padding-top: 30px; }

.tb-style dl dt,
.tb-style dl dd {
  display: table-cell;
  vertical-align: top;
  text-align: left;
  box-sizing: border-box; }

.tb-style dl dt {
  width: 300px;
  font-weight: 700; }

@media screen and (max-width: 1023px) {
  .tb-style dl dt {
    width: 250px; } }
@media screen and (max-width: 767px) {
  .tb-style dl {
    display: block; }

  .tb-style dl dt,
  .tb-style dl dd {
    display: block;
    width: 100%; }

  .tb-style dl dt {
    width: auto; }

  .tb-style dl dd {
    padding-top: 10px; } }
/* -- -- */
.box-qa .item:not(:last-child) {
  padding-bottom: 100px; }

.box-qa .txt-q {
  line-height: 40px;
  position: relative;
  pointer-events: none;
  padding-left: 48px; }

.box-qa .txt-q:before {
  content: '';
  width: 40px;
  height: 40px;
  background: url("../img/common/icon-q.png") no-repeat center top/cover;
  position: absolute;
  top: 0;
  left: 0; }

.box-qa .txt-a {
  padding-top: 24px; }

@media screen and (max-width: 767px) {
  .box-qa .item:not(:last-child) {
    padding-bottom: 30px; }

  .box-qa .txt-q {
    font-size: 20px;
    line-height: 30px; }

  .box-qa .txt-a {
    padding-top: 16px; } }
/* -- -- */
.ovh {
  overflow: hidden; }

/*=============================================
 * <header>
 *=============================================*/
.list-sns a {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #000;
  width: 24px;
  height: 24px;
  border-radius: 50%; }
  .list-sns a img {
    display: block;
    max-width: 14px; }

header {
  display: flex;
  align-items: center;
  height: 150px;
  box-sizing: border-box;
  transition: all 0.3s;
  position: relative;
  top: 0;
  background-color: #fff;
  color: #000;
  z-index: 2; }

header .wrap {
  display: flex;
  align-items: center;
  gap: 45px;
  width: 100%;
  max-width: 100%;
  padding: 0 50px; }

header .logo {
  flex: 1 0 0;
  position: relative; }

header .logo a {
  display: block;
  max-width: 243px; }

.header-nav {
  display: flex;
  align-items: center;
  gap: 45px; }
  .header-nav .nav-list {
    display: flex;
    align-items: center;
    gap: 45px;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.28;
    letter-spacing: 0.05em; }
    .header-nav .nav-list a {
      border-bottom: 1px solid; }
      .header-nav .nav-list a:not(:hover) {
        border-bottom-color: transparent; }
  .header-nav .list-sns {
    display: flex;
    align-items: center;
    gap: 15px; }

.header-home {
  background-color: transparent;
  color: #fff;
  width: auto;
  position: absolute;
  right: 0;
  left: 170px; }
  .header-home .wrap {
    justify-content: flex-end; }

.header-child {
  margin-left: -170px; }

.fix-navi {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 170px;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  box-sizing: border-box; }
  .fix-navi .logo a {
    display: block;
    padding: 48px 44px 16px; }
  .fix-navi .list-sns {
    display: flex;
    flex-direction: column;
    gap: 15px;
    padding-bottom: 45px; }

.hamburger {
  position: fixed;
  top: 50%;
  left: 74px;
  transform: translate(0%, -50%);
  z-index: 102; }

#navbar {
  display: grid;
  background: #fff;
  color: #000;
  height: 100vh;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  box-sizing: border-box;
  overflow-y: auto;
  transition: all 0.3s linear;
  opacity: 0;
  visibility: hidden;
  padding: 80px 170px;
  z-index: 100; }

#navbar .nav-wrap {
  display: flex;
  align-items: flex-start;
  gap: 30px 10vw;
  width: 100%;
  position: relative;
  margin: auto;
  box-sizing: border-box; }
#navbar .nav-logo {
  flex: 1 0 0; }
  #navbar .nav-logo a {
    display: block;
    max-width: 327px; }
#navbar .nav-list {
  display: grid;
  grid-template-rows: repeat(4, auto);
  grid-auto-flow: column;
  gap: 0 8vw;
  letter-spacing: 0.08em; }
  #navbar .nav-list.h-20 {
    line-height: 3.88; }
  #navbar .nav-list a {
    border-bottom: 1px solid transparent; }
    #navbar .nav-list a:hover {
      border-bottom-color: #000; }

#navbar .list-sns {
  display: flex;
  align-items: center;
  gap: 22px; }
  #navbar .list-sns li {
    width: 24px; }

.navOpen #navbar {
  opacity: 1;
  visibility: visible;
  transform: translateX(0%); }

@media screen and (max-height: 800px) and (min-width: 768px) {
  body.home .hamburger {
    top: 65%; } }
@media screen and (max-width: 1440px) {
  #navbar .nav-wrap {
    gap: 30px 5vw; } }
@media screen and (max-width: 1200px) {
  .header-child .wrap {
    gap: 30px;
    padding: 0 30px; }
  .header-child .header-nav {
    gap: 30px; }
    .header-child .header-nav .nav-list {
      gap: 30px; } }
@media screen and (max-width: 1100px) {
  .header-home .header-nav .nav-list {
    gap: 30px; } }
@media screen and (max-width: 1023px) {
  header .wrap {
    padding: 0 20px; }

  .header-home {
    left: 100px; }
    .header-home .header-nav .nav-list {
      gap: 20px;
      font-size: 16px; }

  .header-child {
    margin-left: -100px; }
    .header-child .wrap {
      padding: 0 5%; }
    .header-child .header-nav .nav-list {
      display: none; }

  .fix-navi {
    width: 100px; }
    .fix-navi .logo a {
      padding: 48px 20px 16px; }

  .hamburger {
    left: 39px; }

  #navbar {
    padding: 100px; }
    #navbar .nav-wrap {
      flex-direction: column;
      align-items: center; }
    #navbar .nav-logo {
      flex: inherit; } }
@media screen and (max-width: 767px) {
	.list-sns a {
	  width: 18px;
	  height: 18px; }
  .header-home {
    display: none; }

  .header-child {
    height: 70px;
    margin-left: -50px; }
    .header-child .logo a {
      max-width: 150px; }

  .fix-navi {
    width: 50px; }
    .fix-navi .logo a {
      padding: 16px 7px; }
    .fix-navi .list-sns {
      padding-bottom: 20px; }

  .hamburger {
    left: 17px; }

  #navbar {
    padding: 50px 50px; }
    #navbar .nav-wrap {
      gap: 30px; }
    #navbar .nav-logo a {
      max-width: 180px; }
    #navbar .nav-list {
      grid-template-rows: 1fr;
      grid-template-columns: 1fr;
      grid-auto-flow: row;
      text-align: center; }
      #navbar .nav-list.h-20 {
        line-height: 3; } }
/*=============================================
 * <footer>
 *=============================================*/
footer {
  background-color: #1F397C;
  color: #fff;
  margin-left: -170px;
  padding: 150px 170px 20vw;
  overflow: hidden; }

footer .wrap {
  display: flex;
  align-items: flex-start;
  gap: 30px 10vw;
  width: 100%;
  max-width: 100%; }

footer .logo {
  flex: 1 0 0; }
  footer .logo a {
    display: block;
    max-width: 327px; }
footer nav {
  display: grid;
  grid-template-rows: repeat(4, auto);
  grid-auto-flow: column;
  gap: 0 8vw;
  letter-spacing: 0.08em; }
  footer nav.h-20 {
    line-height: 3.88; }
  footer nav a {
    border-bottom: 1px solid transparent; }
    footer nav a:hover {
      border-bottom-color: #fff; }
footer .f-sns {
  display: flex;
  align-items: center;
  gap: 22px; }
  footer .f-sns li {
    width: 24px; }

footer address {
  font-size: 14px;
  letter-spacing: 0.02em;
  position: absolute;
  top: 180px;
  left: 0; }

footer .f-title {
  width: max-content;
  opacity: 0.21;
  position: absolute;
  bottom: 0;
  left: 50%;
  color: #fff;
  text-align: right;
  transform: translateX(-50%); }
  footer .f-title .sub {
    font-family: "Zen Old Mincho", serif;
    font-weight: 700;
    font-style: normal;
    font-size: 2.4vw;
    line-height: 1.28;
    padding-bottom: 3vw; }
  footer .f-title h2 {
    font-family: "Marcellus", serif;
    font-weight: 400;
    font-style: normal;
    font-size: 9.38vw;
    line-height: 0.72;
    letter-spacing: 0;
    text-transform: uppercase; }

@media screen and (max-width: 1200px) {
  footer .wrap {
    gap: 30px 3vw; }
  footer nav {
    gap: 0 3vw; } }
@media screen and (max-width: 1023px) {
  footer {
    margin-left: -100px;
    padding: 150px 100px 20vw; }
    footer .wrap {
      flex-direction: column;
      align-items: center;
      gap: 30px; }
    footer .logo {
      flex: inherit; }
      footer .logo a {
        margin: 0 auto; }
    footer address {
		font-size:11px;
      position: static;
      text-align: center; } }
@media screen and (max-width: 767px) {
  footer {
    margin-left: -50px;
    padding: 50px 50px 20vw; }
    footer .wrap {
      padding-right: 0; }
    footer .logo a {
      max-width: 200px; }
    footer nav {
      grid-template-rows: 1fr;
      grid-template-columns: 1fr;
      grid-auto-flow: row;
      gap: 20px;
      text-align: center; }
	  footer .f-sns li {
    width: 18px; }
      footer nav.h-20 {
        font-size: 14px;
        line-height: 1.7; } }
/*=============================================
 * 
 *=============================================*/
.ft-fixed {
  width: 100%;
  position: fixed;
  bottom: 0px;
  left: 0px;
  z-index: 90;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s; }

.ft-fixed.fixed {
  opacity: 1;
  visibility: visible; }

.ft-fixed.stop {
  opacity: 0;
  visibility: hidden; }

.ft-fixed ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr); }

.ft-fixed ul a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  font-weight: 700;
  font-size: 15px;
  color: #fff; }

.ft-fixed ul a.inq {
  background-color: #1471CA; }

.ft-fixed ul a.line {
  background-color: #06C755; }

/*=============================================
 * footer common 
 *=============================================*/
.contact {
  padding: 70px 0 85px; }

.contact .wrap {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  background: url("../img/common/contact-bg.webp") no-repeat center/cover;
  color: #fff;
  border-radius: 24px;
  padding: 140px 50px 110px; }

.contact h2 {
  width: 300px;
  font-weight: 700;
  font-size: 50px;
  line-height: 60px; }

.contact h2 .sub {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0.1em;
  line-height: 16px;
  padding-top: 8px; }

.contact h2 .sub:before {
  content: '';
  border-top: 1px solid #fff;
  flex: 1 0 0; }

.contact .txt {
  font-weight: 700;
  font-size: 18px;
  line-height: 1.75;
  padding-top: 80px; }

.contact .tel {
  text-align: center; }

.contact .tel a {
  display: inline-block;
  background: url("../img/common/icon-tel-wh.png") no-repeat center left/52px auto;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 800;
  font-size: 72px;
  line-height: 90px;
  padding-left: 60px; }

.contact .tel .time {
  display: block;
  font-weight: 500;
  font-size: 20px;
  line-height: 30px; }

.contact .list-btn {
  display: flex;
  gap: 10px;
  padding-top: 40px; }

.contact .list-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 325px;
  height: 80px;
  color: #fff;
  font-weight: 700;
  font-size: 20px;
  line-height: 30px;
  border-radius: 50px;
  position: relative; }

.contact .list-btn a:after {
  content: '';
  width: 50px;
  height: 50px;
  background: url("../img/common/arrow-circle-right-1.png") no-repeat center top/cover;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%); }

.contact .list-btn a.inq {
  background-color: #1471CA; }

.contact .list-btn a.line {
  background-color: #06C755; }

.contact .list-btn a:hover {
  background-color: #333;
  opacity: 1; }

@media screen and (max-width: 1440px) {
  .contact .list-btn a {
    width: 300px; } }
@media screen and (max-width: 1200px) {
  .contact .wrap {
    padding: 100px 30px; }

  .contact .txt {
    font-size: 14px; }

  .contact .tel a {
    font-size: 60px; }

  .contact .tel .time {
    font-size: 16px;
    line-height: 24px; }

  .contact .list-btn a {
    width: 280px; } }
@media screen and (max-width: 1023px) {
  .contact .wrap {
    flex-direction: column;
    align-items: center;
    gap: 50px; }

  .contact .txt {
    padding-top: 20px; }

  .contact .list-btn a {
    width: 320px; } }
@media screen and (max-width: 767px) {
  .contact {
    padding: 0; }

  .contact .wrap {
    gap: 30px;
    border-radius: 0;
    padding: 40px 20px; }

  .contact h2 {
    width: 180px;
    font-size: 30px;
    line-height: 40px;
    margin: 0 auto; }

  .contact .tel a {
    background-size: 32px auto;
    font-size: 40px;
    line-height: 50px;
    padding-left: 40px; }

  .contact .list-btn {
    flex-direction: column; }

  .contact .list-btn a {
    width: 100%;
    height: 70px; } }
@media screen and (min-width: 1201px) {
  .contact .wrap {
    max-width: 1140px; } }
@media screen and (min-width: 1441px) {
  .contact .wrap {
    max-width: 1320px; } }
/*=============================================
 * KV
 *=============================================*/
#kv {
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: 36vw;
  position: relative;
  color: #fff; }

#kv .kv-img {
  background-color: #000;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0; }

#kv .kv-img img {
  width: 100%;
  max-width: inherit;
  height: 100%;
  object-fit: cover; }

#kv .wrap {
  width: 100%;
  max-width: 100%;
  padding: 0 8vw; }

#kv .kv-title {
  font-family: "Marcellus", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 9.38vw;
  line-height: 0.7;
  letter-spacing: 0;
  text-transform: uppercase; }

@media screen and (max-width: 767px) {
	#kv {
  height: 66vw; }

  #kv .wrap {
    padding: 0 5%; }

  #kv .kv-title {
    font-size: 12vw; } }
/*=============================================
 * breadcrumbs
 *=============================================*/
.breadcrumbs {
  font-size: 14px;
  line-height: 37px;
  letter-spacing: 0.04em;
  box-sizing: border-box;
  margin-bottom: 80px;
  padding: 16px 26px;
  color: #888; }

.breadcrumbs .wrap {
  max-width: 100%;
  overflow-x: auto; }

.breadcrumbs ul {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  width: max-content; }

.breadcrumbs ul li {
  display: flex;
  align-items: center;
  gap: 10px;
  position: relative; }

.breadcrumbs ul li + li:before {
  content: '>';
  color: #B9B9B9; }

.breadcrumbs a {
  display: block;
  color: #333;
  text-decoration: underline; }

.breadcrumbs a:hover {
  text-decoration: none; }

.breadcrumbs span {
  word-break: break-all; }

@media screen and (max-width: 1023px) {
  .breadcrumbs {
    font-size: 12px;
    position: static; } }
@media screen and (max-width: 767px) {
  .breadcrumbs {
    margin-bottom: 50px;
    padding: 10px 20px; }

  .breadcrumbs .wrap {
    padding: 0; } }
/* =============================================
 * 404
 *=============================================*/
.error404 .breadcrumbs {
  display: none; }

#content-404 {
  padding-top: 340px; }

#content-404 .txt {
  padding-top: 30px; }

#content-404 .button {
  text-align: center;
  padding-top: 40px; }

@media screen and (max-width: 767px) {
  #content-404 {
    padding-top: 100px; }

  #content-404 .wrap {
    text-align: justify; }

  #content-404 .txt {
    font-size: 14px;
    letter-spacing: 0;
    padding-top: 20px; }

  #content-404 .button {
    padding-top: 30px; } }
/*=============================================
 * 
 *=============================================*/
#lead {
  padding-bottom: 48px; }

#lead h2 {
  letter-spacing: 0.03em;
  line-height: 1.5;
  margin-bottom: 40px; }

#lead .txt {
  font-size: 17px;
  letter-spacing: 0.04em;
  line-height: 2.42; }

#lead .tel {
  text-align: center;
  padding-top: 40px; }

#lead .tel a {
  display: inline-block;
  background: url("../img/common/icon-tel.png") no-repeat center left/52px auto;
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 800;
  font-size: 72px;
  line-height: 90px;
  padding-left: 60px; }

#lead .tel .time {
  display: block;
  font-weight: 500;
  font-size: 13px;
  line-height: 16px; }

@media screen and (max-width: 767px) {
  #lead h2 {
    font-size: 20px;
    line-height: 2;
    margin-bottom: 20px; }

  #lead .txt {
    font-size: 16px;
    line-height: 2; }

  #lead .tel {
    padding-top: 20px; }

  #lead .tel a {
    background-size: 32px auto;
    font-size: 40px;
    line-height: 50px;
    padding-left: 40px; } }

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