@charset "utf-8";

.ud-main {
  position: relative;
}

/* パンくずリスト 
========================================*/
.breadcrumb {
  margin-bottom: 16px;
  display: flex;
  gap: 0 8px;
  font-weight: 400;
  flex-wrap: wrap;
}

.breadcrumb-current {
  color: var(--color-blue);
}

/* under-mv
========================================*/
.ud-mv {
  position: relative;
}
.ud-mv-inr {
  position: relative;
  height: 415px;
  width: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 1;
}

.ud-mv-ttl {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--color-white);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: max-content;
  text-shadow: 5px 5px 5px rgba(0, 0, 0, 0.2);
  overflow: hidden;
}

.ud-mv-ttl-ja {
  display: inline-block;
  font-size: var(--fs-xxxl);
  letter-spacing: 0.16em;
  font-weight: 700;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--color-white);
}

.ud-mv-ttl-en {
  display: block;
  font-family: var(--font-jost);
  font-size: var(--fs-md);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
}

.ud-mv-bg {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translate(-50%, -30%);
  width: 100%;
  height: auto;
  max-width: none;
  max-height: none;
  z-index: -1;
  pointer-events: none;
  object-fit: cover;
}

@media screen and (max-width: 960px) {
  .ud-mv-bg {
    width: 1000px;
  }
}

@media screen and (max-width: 600px) {
  .ud-mv-bg {
    width: 800px;
  }
}

@media screen and (max-width: 960px) {
  .ud-mv-inr {
    height: 320px;
  }
}

@media screen and (max-width: 600px) {
  .ud-mv-inr {
    height: 220px;
  }
}

.ud-ft-bg {
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translate(0, 20%);
  width: 50vw;
  max-width: 572px;
  height: auto;
  object-fit: contain;
  z-index: -1;
}

@media screen and (max-width: 1400px) {
  .ud-ft-bg {
    display: none;
  }
}

/* single-page
========================================*/
.single-hd {
  gap: 16px;
}

.single-hd time {
  font-size: var(--fs-xs);
  font-weight: 400;
}

.single-ttl {
  font-size: var(--fs-lg);
  letter-spacing: 0.16em;
}

/* ページネーション */
.single-pagination a {
  color: var(--color-blue);
  font-size: var(--fs-sm);
  border-bottom: 1px solid var(--color-blue);
}

/* 背景 個別アイテム*/
.ud-main .cmn-bg.circle-5 {
  top: 200px;
  left: 3%;
}

.ud-main .cmn-bg.circle-6.ud-circle-6-1 {
  top: 540px;
  left: 5%;
}
.ud-main .cmn-bg.circle-4-sm {
  bottom: 8%;
  left: 8%;
}

.ud-main .cmn-bg.circle-7 {
  right: 3%;
  top: 50%;
}
.ud-main .cmn-bg.circle-6.ud-circle-6-2 {
  right: 3%;
  top: 70%;
}

@media screen and (max-width: 1800px) {
  .ud-main .cmn-bg.circle-5,
  .ud-main .cmn-bg.circle-4-sm,
  .ud-main .cmn-bg.circle-6.ud-circle-6-1 {
    transform: translateX(-50%);
  }
  .ud-main .cmn-bg.circle-7,
  .ud-main .cmn-bg.circle-6.ud-circle-6-2 {
    transform: translateX(50%);
  }
}

@media screen and (max-width: 1400px) {
  .ud-main .cmn-bg.circle-5,
  .ud-main .cmn-bg.circle-6.ud-circle-6-1,
  .ud-main .cmn-bg.circle-4-sm,
  .ud-main .cmn-bg.circle-7,
  .ud-main .cmn-bg.circle-6.ud-circle-6-2 {
    display: none;
  }
}

/* 背景リピート */
.ud-bg {
  position: relative;
  z-index: 10;
}
.ud-bg::before {
  content: "";
  position: absolute;
  top: 120px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  background-image: var(--ud-bg-img);
  background-repeat: repeat-y;
  background-position: center top;
  background-size: auto;
  z-index: 0;
  pointer-events: none;
}

/* content-ttl(縦のライン装飾あり)
======================================== */
.cont-ttl-line {
  position: relative;
  padding-left: calc(24px + 3px);
}

.cont-ttl-line:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 3px;
  height: 100%;
  background-color: var(--color-blue);
  z-index: 1;
}

.cont-ttl-line::after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
  display: block;
  width: 3px;
  height: 9px;
  background-color: var(--color-blue-dark);
  z-index: 2;
}

.cont-ttl-en {
  font-family: var(--font-jost);
  font-size: var(--fs-lg-2);
  display: block;
}

.cont-ttl-ja {
  color: var(--color-blue-works1);
  display: block;
}

@media screen and (max-width: 600px) {
  .cont-ttl-line {
    padding-left: calc(16px + 3px);
    line-height: 1.5;
  }
}

/* content-ttl-solid (枠線つき)
======================================== */
.content-ttl-solid {
  text-align: center;
}
.content-ttl-solid p {
  font-weight: 600;
  padding: 10px 30px;
  color: var(--color-blue-works1);
  border: 1px solid var(--color-blue-works1);
  background-color: var(--color-white);
  letter-spacing: 0.22em;
  font-size: var(--fs-md-2);
  display: inline-block;
  box-shadow: 3.7px 3.7px 0 rgba(70, 131, 192, 0.2);
}
@media screen and (max-width: 600px) {
  .content-ttl-solid p {
    padding: 8px 20px;
    line-height: 1.5;
    letter-spacing: 0.1em;
  }
}

/* content-ttl-2(縦と横のライン装飾あり)
======================================== */
.ser-ttl .solid-line {
  content: "";
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
  width: calc(100vw - 100% - 3rem);
  height: 10px;
  background-color: var(--color-steel-blue);
}

.ser-ttl .small {
  font-size: var(--fs-md);
  letter-spacing: 0.1em;
}

@media screen and (max-width: 600px) {
  .ser-ttl .small {
    font-size: var(--fs-base);
  }
}
