/*=============================================
 * body
 *=============================================*/
body {
  background: #252525;
  color: #ccc;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 17px;
  line-height: 2.14;
  letter-spacing: 0;
  min-width: inherit;
  min-height: inherit;
  max-height: 100%;
  word-break: break-word; }

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

/* =============================================
 * Custom
*=============================================*/
.h2 {
  color: #fff;
  font-weight: 700;
  font-size: 22px;
  letter-spacing: 0.06em;
  line-height: 2.74;
  text-align: center; }
  .h2 .sub {
    display: inline-block;
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    font-style: italic;
    font-size: 100px;
    line-height: 1;
    text-transform: uppercase;
    color: transparent;
    position: relative;
    overflow: hidden; }
    .h2 .sub .bg {
      display: block;
      width: 100%;
      height: 100%;
      position: absolute;
      top: 0;
      right: 0;
      transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
      .h2 .sub .bg:before {
        content: '';
        width: 100%;
        height: 100%;
        background-color: #f3f1e7;
        position: absolute;
        top: 0;
        right: 0;
        transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
    .h2 .sub .text {
      display: inline-block;
      transform: translateY(100%);
      transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
      background: url("../img/index/heading-bg.png") no-repeat center/cover;
      -webkit-background-clip: text;
      background-clip: text;
      font-style: italic; }
  .h2[style*="visible"] .sub .bg {
    width: 0; }
  .h2[style*="visible"] .sub .text {
    transform: translateY(0);
    transition-delay: 0.5s; }

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

.h-20 {
  font-weight: 700;
  font-size: 20px;
  line-height: 30px; }

.h-22 {
  font-weight: 700;
  font-size: 22px;
  line-height: 32px; }

.h-24 {
  font-weight: 700;
  font-size: 24px;
  line-height: 35px; }

.h-26 {
  font-weight: 700;
  font-size: 26px;
  line-height: 36px; }

.h-28 {
  font-weight: 700;
  font-size: 28px;
  line-height: 40px; }

.h-30 {
  font-weight: 700;
  font-size: 30px;
  line-height: 44px; }

.h-32 {
  font-weight: 700;
  font-size: 32px;
  line-height: 46px; }

.h-36 {
  font-weight: 700;
  font-size: 36px;
  line-height: 52px; }

.h-40 {
  font-weight: 700;
  font-size: 40px;
  line-height: 60px; }

.h-42 {
  font-weight: 700;
  font-size: 42px;
  line-height: 60px; }

@media screen and (max-width: 767px) {
  .h2 {
    font-size: 18px; }
    .h2 .sub {
      font-size: 50px; }

  .h-18 {
    font-size: 16px;
    line-height: 28px; }

  .h-24 {
    font-size: 20px;
    line-height: 30px; }

  .h-32 {
    font-size: 24px;
    line-height: 35px; } }
/* button */
.button {
  position: relative; }

.button a {
  display: inline-flex;
  align-items: center;
  width: 397px;
  height: 105px;
  background: #9B060C;
  color: #fff;
  font-family: "Oswald", sans-serif;
  font-weight: 600;
  font-style: italic;
  font-size: 32px;
  letter-spacing: 0.06em;
  line-height: 1.3;
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  padding: 0 40px;
  text-transform: uppercase; }
  .button a:after {
    content: '';
    width: 23px;
    height: 23px;
    background: url("../img/common/expand-arrows.png") no-repeat center top/cover;
    position: absolute;
    top: 50%;
    right: 40px;
    transform: translateY(-50%); }
  .button a:hover {
    background-color: #000;
    opacity: 1; }

@media screen and (max-width: 767px) {
  .button {
    text-align: center; }
    .button a {
      width: 100%;
      height: 70px;
      font-size: 20px;
      padding: 0 20px; }
      .button a:after {
        width: 18px;
        height: 18px;
        right: 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: #3182CE; }

.cl-green {
  color: #006030; }

.cl-red {
  color: #BD3A43; }

.cl-yellow {
  color: #F8C625; }

.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; }

.pt80 {
  padding-top: 80px; }

.pt120 {
  padding-top: 120px; }

.pb80 {
  padding-bottom: 80px; }

.pb100 {
  padding-bottom: 100px; }

.pb120 {
  padding-bottom: 120px; }

.pb200 {
  padding-bottom: 200px; }

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

  .pt120 {
    padding-top: 60px; }

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

  .pt80 {
    padding-top: 40px; }

  .pt120 {
    padding-top: 80px; }

  .pb80 {
    padding-bottom: 40px; }

  .pb100 {
    padding-bottom: 50px; }

  .pb120 {
    padding-bottom: 80px; }

  .pb200 {
    padding-bottom: 100px; } }
/* -- --*/
.bg-cl01 {
  background-color: #1A365D; }

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

/* -- -- */
.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 #fff; }

/* -- --*/
.slick-dots {
  display: flex;
  justify-content: center;
  gap: 15px; }
  .slick-dots li {
    width: 8px;
    height: 8px; }
  .slick-dots button {
    display: block;
    width: 100%;
    height: 100%;
    background-color: #C0C0C0;
    border-radius: 50%;
    border: 0;
    font-size: 0;
    cursor: pointer; }
    .slick-dots button:hover {
      background-color: #FF7C7A; }
  .slick-dots .slick-active button {
    background-color: #FF7C7A; }

/* -- --*/
.swiper-button-prev, .swiper-button-next {
  width: 46px;
  height: 46px;
  position: static;
  margin-top: 0;
  transition: all 0.3s; }
  .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: 14px;
    height: 14px;
    background-color: #fff;
    border: 2px solid #D2711D;
    margin: 0;
    padding: 0;
    opacity: 1;
    box-sizing: border-box;
    transition: all 0.3s; }
    .swiper-pagination-bullet-active, .swiper-pagination-bullet:hover {
      background-color: #D2711D; }

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

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

/*=============================================
 * <header>
 *=============================================*/
header {
  width: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  box-sizing: border-box;
  padding: 40px 65px;
  transition: all 0.3s; }
  header.fixed {
    padding: 20px; }
  header .wrap {
    display: flex;
    align-items: center;
    gap: 20px;
    max-width: 100%; }
  header .logo {
    flex: 1 0 0; }
    header .logo a {
      display: block;
      max-width: 250px; }

#navbar {
  display: grid;
  width: 400px;
  height: 100vh;
  background-color: #000;
  color: #fff;
  position: fixed;
  top: 0;
  right: 0;
  box-sizing: border-box;
  padding: 150px 30px;
  overflow-y: auto;
  opacity: 0;
  visibility: hidden;
  transform: translateX(20px);
  transition: all 0.3s linear; }
  #navbar .nav-in {
    margin: auto 0; }
  #navbar .nav-list a {
    display: block;
    border-top: 1px solid;
    border-bottom: 1px solid;
    padding: 10px 0;
    position: relative; }
    #navbar .nav-list a:after {
      content: '';
      width: 15px;
      height: 9px;
      background: url("../img/index/arrow-down.webp") no-repeat center/100% auto;
      position: absolute;
      top: 50%;
      right: 0;
      transform: translateY(-50%) rotate(-90deg); }
  #navbar .nav-list li + li a {
    border-top: 0; }
  #navbar .button {
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0; }
    #navbar .button a {
      width: 100%; }

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

@media screen and (max-width: 1023px) {
  header {
    padding: 20px; }
    header .wrap {
      padding: 0; }
    header.fixed {
      padding: 20px; }
    header .logo a {
      width: 150px; } }
@media screen and (max-width: 767px) {
  header {
    padding: 0 0 0 20px; }
    header.fixed {
      padding: 0 0 0 20px; }

  #navbar {
    width: 100%;
    z-index: -1; } }
/*=============================================
 * <footer>
 *=============================================*/
footer {
  font-weight: 700;
  text-align: center;
  padding: 150px 0; }
  footer .logo a {
    display: inline-block;
    width: 250px; }
  footer .txt {
    font-size: 16px;
    line-height: 3.13;
    padding-top: 110px; }
  footer address {
    font-weight: 700;
    padding-top: 80px; }

@media screen and (max-width: 767px) {
	footer .logo a {
    display: inline-block;
    width: 150px; }
  footer {
    padding: 80px 0; }
    footer .txt {
		font-size:13px;
      line-height: 2;
      padding-top: 40px; }
    footer address {
		font-size:11px;
      padding-top: 40px; } }
/*=============================================
 * 
 *=============================================*/
.ft-fixed {
  position: fixed;
  bottom: 90px;
  right: 80px;
  z-index: 10;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s; }
  .ft-fixed.fixed {
    opacity: 1;
    visibility: visible; }
  .ft-fixed.stop {
    opacity: 0;
    visibility: hidden; }

@media screen and (max-width: 1440px) {
  .ft-fixed {
    bottom: 0;
    right: 0; } }
@media screen and (max-width: 767px) {
  .ft-fixed {
    right: 10px;
    bottom: 10px;
    left: 10px; } }
/*=============================================
 * footer common 
 *=============================================*/
.section__cta {
  background-color: #3182CE;
  padding: 60px 0; }
  .section__cta .wrap {
    background: url("../img/common/cta-bg.jpg") no-repeat center/cover;
    border-radius: 10px;
    padding: 40px 60px 85px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.16); }
  .section__cta h2 {
    color: #1A365D; }
  .section__cta .txt,
  .section__cta .tel,
  .section__cta .time,
  .section__cta .button {
    padding-top: 20px; }
  .section__cta .txt {
    max-width: 614px; }
  .section__cta .tel {
    color: #3182CE;
    font-weight: 700;
    font-size: 48px;
    line-height: 70px; }
    .section__cta .tel a {
      display: inline-flex;
      align-items: center;
      gap: 10px; }
      .section__cta .tel a:before {
        content: '';
        width: 60px;
        height: 60px;
        background: #3182CE url("../img/common/icon-tel.png") no-repeat center top/cover;
        border-radius: 50%;
        display: block; }

@media screen and (max-width: 1023px) {
  .section__cta .wrap {
    background-image: url("../img/common/cta-bg_tbl.jpg");
    padding: 40px 60px; }
  .section__cta h2 {
    font-size: 28px;
    line-height: 40px; }
  .section__cta .txt {
    max-width: 406px; }
  .section__cta .tel {
    font-size: 36px;
    line-height: 52px; }
    .section__cta .tel a:before {
      width: 50px;
      height: 50px; }
  .section__cta .time {
    font-size: 18px; } }
@media screen and (max-width: 767px) {
  .section__cta {
    padding: 40px 20px; }
    .section__cta .wrap {
      background-image: url("../img/common/cta-bg_sp.jpg");
      padding: 40px 20px; }
    .section__cta h2 {
      font-size: 24px;
      line-height: 35px; }
    .section__cta .tel {
      font-size: 32px;
      line-height: 46px; }
      .section__cta .tel a:before {
        width: 37px;
        height: 37px; }
    .section__cta .time {
      font-size: 16px;
      line-height: 24px;
      padding-top: 10px; }
    .section__cta .button {
      padding-top: 40px; } }
/*=============================================
 * KV
 *=============================================*/
#kv {
  width: 100%;
  height: 460px;
  color: #fff;
  position: relative; }
  #kv:after {
    content: '';
    width: 100%;
    height: 100%;
    background-color: rgba(45, 55, 72, 0.8);
    position: absolute;
    top: 0;
    left: 0; }
  #kv .kv-img {
    position: absolute;
    top: 0;
    left: 0; }
  #kv .wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    z-index: 1; }
  #kv .kv-title {
    font-weight: 700;
    font-size: 60px;
    line-height: 87px; }
    #kv .kv-title .sub {
      display: block;
      text-transform: uppercase;
      font-size: 24px;
      line-height: 30px;
      padding-top: 5px; }
  #kv .kv-desc {
    max-width: 825px;
    font-weight: 500;
    font-size: 18px;
    letter-spacing: 0.06em;
    line-height: 2;
    margin: 0 auto;
    padding-top: 30px; }
    #kv .kv-desc .button {
      text-align: center;
      padding-top: 30px; }

@media screen and (max-width: 1023px) {
  #kv {
    height: calc(100vh - 80px); }
    #kv .wrap {
      flex-direction: column;
      gap: 40px; }
    #kv .kv-title {
      font-size: 48px;
      line-height: 70px; }
      #kv .kv-title .sub {
        font-size: 20px;
        line-height: 24px; }
    #kv .kv-desc {
      max-width: 562px;
      padding: 0 0 20px; }
      #kv .kv-desc .button {
        padding-top: 40px; } }
@media screen and (max-width: 767px) {
  #kv .wrap {
    gap: 40px; }
  #kv .kv-title {
    font-size: 42px;
    line-height: 61px; }
    #kv .kv-title .sub {
      font-size: 18px;
      line-height: 22px; }
  #kv .kv-desc {
    font-size: 16px;
    padding-bottom: 0; }
    #kv .kv-desc .button {
      padding-top: 20px; }
      #kv .kv-desc .button a {
        height: auto;
        line-height: 36px;
        letter-spacing: 0.06em;
        text-align: left;
        padding: 16px 20px 17px; } }
/*=============================================
 * breadcrumbs
 *=============================================*/
.breadcrumbs {
  font-weight: 700;
  font-size: 14px;
  line-height: 20px;
  overflow-x: auto;
  box-sizing: border-box;
  max-width: 100%;
  position: absolute;
  top: 40px;
  left: 0; }

.breadcrumbs ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  width: max-content; }
  .breadcrumbs ul li {
    position: relative; }
    .breadcrumbs ul li + li {
      padding-left: 20px; }
      .breadcrumbs ul li + li:before {
        content: '';
        background: url("../img/common/arrow-right-wh.png") no-repeat center top/cover;
        width: 14px;
        height: 14px;
        position: absolute;
        top: 50%;
        left: 0;
        transform: translateY(-50%); }

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

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

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

@media screen and (max-width: 1023px) {
  .breadcrumbs {
    position: static; } }
@media screen and (max-width: 767px) {
  .breadcrumbs ul li + li {
    padding-left: 16px; }
    .breadcrumbs ul li + li:before {
      width: 8px;
      height: 10px; } }
/* =============================================
 * 404
 *=============================================*/
.error404 .breadcrumbs {
  display: none; }

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

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

@media screen and (max-width: 767px) {
  #content-404 {
    padding: 50px 0; }
    #content-404 .wrap {
      text-align: justify; }
    #content-404 .txt {
      font-size: 14px;
      letter-spacing: 0;
      padding-top: 20px; }

  #content-404 .button {
    padding-top: 30px; } }
/* =============================================
 * 
 *=============================================*/
.appear {
  opacity: 0;
  filter: blur(16px);
  opacity: 0;
  transition-delay: 1000ms;
  transition-duration: 1000ms; }

.appear[style*="visible"] {
  filter: blur(0px);
  opacity: 1;
  transition-delay: 100ms;
  transition-duration: 800ms; }

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