@charset "utf-8";

.u-section {
  margin: 0 auto;
  text-align: left;
  max-width: clamp(var(--section-width) * 1em/16, var(--section-width) / 1600*100vw, var(--section-width) * 1.2em/16);
  width: calc(325/375*100%);
  &.is-wide {
    --section-width: 1200;
  }
}
@media screen and (max-width: 1024px) {
  .u-section {
    width: calc(335/375*100%);
  }
}

.u-targetline {
  overflow: visible;
}
.u-targetline__txt {
  border-bottom: 1px solid currentColor;
}
.u-targetline.is-line .u-targetline__txt {
  border: 0;
}
@media (any-hover: hover) {
  .u-target {
    transition: opacity var(--transition);
  }
  .u-target:hover {
    opacity: .6;
  }
  .u-targetcolor {
    transition: color var(--transition);
  }
  .u-targetcolor:hover {
    color: var(--hover-color);
  }
  .u-targetbgcolor {
    transition: background-color var(--transition);
  }
  .u-targetbgcolor:hover {
    background-color: var(--hover-color);
  }
  .u-targetline__txt {
    position: relative;
    border: 0;
  }
    .u-targetline__txt::after {
      content: "";
      display: block;
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 1px;
      background-color: currentColor;
    }
  .u-targetline.is-line .u-targetline__txt::after {
      transform: scale(0, 1);
  }
  .u-targetline:hover .u-targetline__txt::after {
    animation-name: lineanim;
    animation-duration: .6s;
    animation-timing-function: ease;
  }
  .u-targetline.is-line .u-targetline__txt::after {
    transition: transform var(--transition);
    transform-origin: top right;
  }
  .u-targetline.is-line:hover .u-targetline__txt::after {
    animation: none;
    transform: scale(1, 1);
    transform-origin: top left;
  }
  @keyframes lineanim {
    0% {
        transform:  scale(1, 1);
        transform-origin: top right;
    }
    50% {
        transform:  scale(0, 1);
        transform-origin: top right;
    }
    51% {
        transform:  scale(0, 1);
        transform-origin: top left;
    }
    100% {
        transform:  scale(1, 1);
        transform-origin: top left;
    }
  }
  .u-targetcolor {
    transition: color var(--transition);
  }
  .u-targetcolor:hover {
    color: var(--hover-color);
  }
}

.u-animateblock {
  visibility: hidden;
  opacity: 0;
}

.u-bg {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.u-vt {
  writing-mode: vertical-rl;
  font-family: var(--font-family-noyakuhan);
  font-feature-settings: 'pkna';
}
.u-hr {
  writing-mode: horizontal-tb;
  font-family: var(--font-family);
  font-feature-settings : "palt";
}

.u-sentence {
  --sentence-fs: 16;
  --sentence-line-height: 1.8;
  --sentence-letter-spacing: 0;
  font-size: calc(var(--sentence-fs) * 1em/16);
  line-height: var(--sentence-line-height);
  letter-spacing: calc(var(--sentence-letter-spacing) * 1em);
}

.u-objectfit {
  object-fit: cover;
  height: 100%;
}

.u-fsajust {
  --ajust-fontsize: 16;
  font-size: clamp(var(--ajust-fontsize) * 1em/16, var(--ajust-fontsize) / 1600*100vw, var(--ajust-fontsize) * 1.1em/16);
}

.u-shippori {
  font-family: YakuHanMP, 'Shippori Mincho', serif;
}
.u-shippori.is-medium {
  font-weight: 500;
}
.u-shippori.is-semibold {
  font-weight: 600;
}
.u-shippori.is-bold {
  font-weight: 700;
}
.u-en {
  font-family: 'Cinzel', serif;
}
.u-gothic.is-bold {
  font-weight: 700;
}