/* ******************************
 *
 * RESPONSIVE MIXIN
 *
 * ****************************** */
/* ******************************
 *
 * FONT SETTINGS
 *
 * ****************************** */
@font-face {
  font-family: "tsukuhou";
  src: url("../font/Tsukuhou-35Point-Gothic.ttf") format("truetype");
}
/* ******************************
 *
 * FONT SETTINGS
 *
 * ****************************** */
/* ******************************
 *
 * KEYFRAMES
 *
 * ****************************** */
@-webkit-keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes loopCl {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
/* ------------------------------
    DEFAULT BLOCK SETTINGS
  ------------------------------ */
@media screen and (min-width: 320px) {
  .spBr {
    display: block;
  }
}
@media screen and (min-width: 1025px) {
  .spBr {
    display: none;
  }
}

@media screen and (min-width: 320px) {
  .pcBr {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .pcBr {
    display: block;
  }
}

/* ------------------------------
    COMMON ELEMENTS
  ------------------------------ */
#breadcrumb ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 320px) {
  #breadcrumb ul {
    gap: 0 1.5rem;
  }
}
@media screen and (min-width: 1025px) {
  #breadcrumb ul {
    gap: 0 3.5rem;
  }
}
#breadcrumb ul li {
  position: relative;
}
@media screen and (min-width: 320px) {
  #breadcrumb ul li {
    font-size: 1rem;
  }
}
@media screen and (min-width: 1025px) {
  #breadcrumb ul li {
    font-size: 1.4rem;
  }
}
#breadcrumb ul li::before {
  position: absolute;
  content: "";
  top: calc(50% - 0.5px);
  height: 1px;
}
@media screen and (min-width: 320px) {
  #breadcrumb ul li::before {
    width: 0.5rem;
    right: -1rem;
  }
}
@media screen and (min-width: 1025px) {
  #breadcrumb ul li::before {
    width: 1.5rem;
    right: -2.5rem;
  }
}
#breadcrumb ul li:nth-last-child(1)::before {
  content: none;
}

.pageFv {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 320px) {
  .pageFv {
    padding: 16rem 5vw 0;
  }
}
@media screen and (min-width: 1025px) {
  .pageFv {
    padding: 24rem 10% 0;
  }
}

.pageTitleEn {
  font-weight: 700;
  background: linear-gradient(110deg, var(--primary-color) 30%, var(--secondary-color) 70%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 320px) {
  .pageTitleEn {
    font-size: 1.2rem;
    letter-spacing: 0.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .pageTitleEn {
    font-size: 2.8rem;
    letter-spacing: 0.5rem;
  }
}

.pageTitle {
  font-weight: 700;
  background: linear-gradient(110deg, var(--primary-color) 30%, var(--secondary-color) 70%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 320px) {
  .pageTitle {
    font-size: 2.8rem;
    letter-spacing: 0.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .pageTitle {
    font-size: 8.2rem;
    letter-spacing: 0.5rem;
  }
}

.pageDesc {
  opacity: 0.8;
}
@media screen and (min-width: 320px) {
  .pageDesc {
    font-size: 1.2rem;
    letter-spacing: 0.2rem;
    line-height: 2;
    margin-top: 24px;
  }
}
@media screen and (min-width: 1025px) {
  .pageDesc {
    font-size: 2rem;
    letter-spacing: 0.04em;
    line-height: 1.64;
    margin-top: 32px;
  }
}
@media screen and (min-width: 320px) {
  .pageDesc br {
    display: none;
  }
}
@media screen and (min-width: 1025px) {
  .pageDesc br {
    display: block;
  }
}
.pageDesc strong {
  position: relative;
  display: inline-block;
  font-size: 200%;
  padding: 0 4px;
}
.pageDesc strong::before {
  content: "";
  position: absolute;
  left: -4px;
  bottom: 10%;
  width: 100%;
  height: 35%;
  background: var(--tertiary-color);
}
.pageDesc strong span {
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 320px) {
  .pagePoint {
    margin: 32px 0 16px;
  }
}
@media screen and (min-width: 1025px) {
  .pagePoint {
    margin: 32px 0;
  }
}
.pagePoint dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 16px;
}
.pagePoint dt {
  background: -webkit-gradient(linear, left top, right top, from(var(--primary-color)), to(var(--secondary-color)));
  background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
  color: var(--base-color);
  border-radius: 8px;
  text-align: center;
  line-height: 1.36;
}
@media screen and (min-width: 320px) {
  .pagePoint dt {
    width: 6rem;
    font-size: 1.2rem;
    padding: 8px 0;
  }
}
@media screen and (min-width: 1025px) {
  .pagePoint dt {
    width: auto;
    font-size: 1.6rem;
    padding: 8px 32px;
  }
}
@media screen and (min-width: 320px) {
  .pagePoint dd {
    width: calc(100% - 6rem - 16px);
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 1025px) {
  .pagePoint dd {
    width: auto;
    font-size: 2rem;
  }
}

.pageSpec {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
}
.pageSpec dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: var(--gray-color);
  border-radius: 8px;
}
@media screen and (min-width: 320px) {
  .pageSpec dl {
    gap: 16px;
    padding: 8px 16px;
  }
}
@media screen and (min-width: 1025px) {
  .pageSpec dl {
    gap: 32px;
    padding: 8px 24px;
  }
}
.pageSpec dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
@media screen and (min-width: 320px) {
  .pageSpec dt {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .pageSpec dt {
    font-size: 2rem;
  }
}
.pageSpec svg {
  display: block;
}
@media screen and (min-width: 320px) {
  .pageSpec svg {
    width: 1.8rem;
    height: 1.8rem;
  }
}
@media screen and (min-width: 1025px) {
  .pageSpec svg {
    width: 2.4rem;
    height: 2.4rem;
  }
}
@media screen and (min-width: 320px) {
  .pageSpec dd {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 1025px) {
  .pageSpec dd {
    font-size: 3rem;
  }
}

@media screen and (min-width: 320px) {
  .pageFigure {
    padding: 64px 5vw 0;
  }
}
@media screen and (min-width: 1025px) {
  .pageFigure {
    padding: 128px 10vw 64px;
  }
}
.pageFigure img {
  border-radius: 16px;
}

.sectionTitle {
  font-weight: 700;
  background: linear-gradient(110deg, var(--primary-color) 30%, var(--secondary-color) 70%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 320px) {
  .sectionTitle {
    font-size: 2rem;
    line-height: 2;
    letter-spacing: 0.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .sectionTitle {
    font-size: 4rem;
    line-height: 2.2;
    letter-spacing: 0.5rem;
  }
}

.labTopicsList {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 320px) {
  .labTopicsList {
    gap: 1rem 0;
    margin-top: 3rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList {
    gap: 1rem 0;
    margin-top: 5rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList.col2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
}
.labTopicsList .itemInner {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #FFFFFF;
}
@media screen and (min-width: 320px) {
  .labTopicsList .itemInner {
    border-radius: 1rem;
    padding: 16px;
    gap: 0 16px;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .itemInner {
    border-radius: 2rem;
    padding: 3rem 4.5rem 3rem 3.5rem;
    gap: 0 4rem;
  }
}
.labTopicsList .itemInner .title {
  font-weight: 400;
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 320px) {
  .labTopicsList .itemInner .title {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .itemInner .title {
    font-size: 2rem;
  }
}
@media screen and (min-width: 320px) {
  .labTopicsList .itemInner .iconSvg {
    width: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .itemInner .iconSvg {
    width: 2.5rem;
  }
}
.labTopicsList .itemInfo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 320px) {
  .labTopicsList .itemInfo {
    gap: 0 1.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .itemInfo {
    gap: 0 2rem;
  }
}
.labTopicsList .category {
  color: #85afd8;
  font-weight: 700;
  background: rgba(253, 231, 213, 0.2);
  border-radius: 2rem;
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 320px) {
  .labTopicsList .category {
    font-size: 1.2rem;
    padding: 0.1rem 0.8rem 0.2rem 0.8rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .category {
    font-size: 1.2rem;
    padding: 0.3rem 1rem 0.4rem 1rem;
  }
}
.labTopicsList .date {
  color: #85afd8;
  opacity: 0.6;
  letter-spacing: 0.2rem;
}
@media screen and (min-width: 320px) {
  .labTopicsList .date {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .date {
    font-size: 1.2rem;
  }
}
.labTopicsList .itemTitle {
  font-weight: 700;
  letter-spacing: 0.1rem;
}
@media screen and (min-width: 320px) {
  .labTopicsList .itemTitle {
    font-size: 1.4rem;
    margin-top: 1.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .itemTitle {
    font-size: 1.8rem;
    margin-top: 1.5rem;
  }
}
@media screen and (min-width: 320px) {
  .labTopicsList .itemArrow {
    width: 2.5rem;
  }
}
@media screen and (min-width: 1025px) {
  .labTopicsList .itemArrow {
    width: 3.5rem;
  }
}/*# sourceMappingURL=page.css.map */