@charset "UTF-8";
/* ============================================================================
文字色
============================================================================== */
.blue {
  color: #0071be; }

.white {
  color: white; }

.orange {
  color: #fd9834; }

.yellow {
  color: #fde439; }

.black {
  color: #333 !important; }

/* ============================================================================
青背景アニメーション
============================================================================== */
.bg_blue {
  position: relative; }

.bg_blue:nth-child(odd)::before {
  position: absolute;
  content: "";
  width: calc(100% + (50vw - 50%) + 110px);
  width: 0%;
  height: 100%;
  background: #e4f0fd;
  top: 0;
  left: 0;
  margin-left: calc(50% - 50vw);
  z-index: -1;
  transition: all 0.5s;
  border-radius: 0 12px 12px 0; }
  @media screen and (max-width: 991px) {
    .bg_blue:nth-child(odd)::before {
      border-radius: 0 0.6rem 0.6rem 0; } }

.bg_blue:nth-child(even)::before {
  position: absolute;
  content: "";
  width: calc(100% + (50vw - 50%) + 110px);
  width: 0%;
  height: 100%;
  background: #e4f0fd;
  top: 0;
  right: 0;
  margin-right: calc(50% - 50vw);
  z-index: -1;
  border-radius: 12px 0 0 12px;
  transition: all 0.5s; }
  @media screen and (max-width: 991px) {
    .bg_blue:nth-child(even)::before {
      border-radius: 0.6rem 0 0 0.6rem; } }

.bg_blue.is-active::before {
  width: calc(100% + (50vw - 50%) + 110px); }
  @media screen and (max-width: 991px) {
    .bg_blue.is-active::before {
      width: calc(100vw - 2rem); } }

.productList_optionPage .bg_blue::before {
  background-color: #f4f6fa; }

/* ============================================================================
電話
============================================================================== */
@media (in-width: 992px) {
  a[href^="tel"] {
    pointer-events: none;
    /* リンクをクリック不能にする */ } }
/* ============================================================================
fadeIn
============================================================================== */
.js-scroll-fade {
  position: relative;
  opacity: 0;
  transform: translateY(5%);
  transition: all 1s cubic-bezier(0.155, 0.91, 0.695, 0.95); }

.js-scroll-fade.-left {
  transform: translateY(0) translateX(-5%); }

.js-scroll-fade.-right {
  transform: translateY(0) translateX(5%); }

.is-scroll-fade {
  opacity: 1;
  transform: translateY(0) translateX(0) !important; }

.delay_1 {
  transition-delay: 0.2s; }

.delay_2 {
  transition-delay: 0.4s; }

.delay_3 {
  transition-delay: 0.6s; }

.delay_4 {
  transition-delay: 0.8s; }

.delay_5 {
  transition-delay: 1s; }

/* ============================================================================
section
============================================================================== */
section {
  padding-top: 70px;
  padding-bottom: 90px; }
  @media screen and (max-width: 991px) {
    section {
      padding-top: 4rem;
      padding-bottom: 4rem; } }

section.privacy {
  padding-top: 0; }

html.is-fixed {
  overflow: hidden; }

body {
  overflow-x: hidden; }

main {
  position: relative;
  overflow: hidden; }

main::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  background-color: black;
  top: 0;
  left: 0;
  z-index: 4;
  opacity: 0;
  transition: all 0.3s;
  pointer-events: none; }

main.is-hover::before {
  opacity: 0.4; }

img {
  max-width: 100%;
  height: auto; }

/* ============================================================================
inner
============================================================================== */
.inner {
  margin: 0 auto;
  padding: 0 25px;
  max-width: 1150px;
  width: 100%;
  height: 100%; }
  @media screen and (max-width: 991px) {
    .inner {
      padding: 0 2rem;
      max-width: 540px; } }

.inner_s {
  max-width: 1010px; }
  @media screen and (max-width: 991px) {
    .inner_s {
      max-width: 540px; } }

/* ============================================================================
ボタン
============================================================================== */
.btn {
  color: white;
  display: inline-flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.4rem;
  width: 100%;
  padding: 8px 18px;
  border-radius: 20px;
  transition: all 0.3s; }

.btn:hover {
  opacity: 0.7; }

.btn img {
  object-fit: contain;
  width: 1.6rem; }

.btn_orange {
  background-color: #f38f2c; }

.en .btn_orange {
  justify-content: center;
  gap: 5px; }

.btn_blue {
  background-color: #51a4dd; }

.btn_en {
  font-size: 1.8rem; }

.roundBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 17px;
  border-radius: 25px;
  font-size: 1.6rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.2em;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .roundBtn {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .roundBtn {
      font-size: 1.1rem;
      padding: 1rem; } }

@media screen and (max-width: 991px) {
  .en .roundBtn {
    letter-spacing: normal; } }

.roundBtn:hover {
  opacity: 0.7; }

.roundBtn_white {
  background-color: white;
  color: #03356c;
  border: 1px solid #03356c; }

.roundBtn_white:hover {
  background-color: #03356c;
  color: white;
  opacity: 1; }

.roundBtn_transparent {
  border: 1px solid white;
  color: white; }

.roundBtn_transparent:hover {
  background-color: white;
  color: #03356c;
  opacity: 1; }

.roundBtn_navy {
  border: 1px solid #03356c;
  background-color: #03356c;
  color: white; }

.roundBtn_navy:hover {
  opacity: 1;
  background-color: white;
  color: #03356c; }

/* ============================================================================
タイトル
============================================================================== */
.ttl h2 {
  text-align: center;
  font-size: 3.5rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #03356c;
  line-height: 1; }
  @media screen and (max-width: 991px) {
    .ttl h2 {
      font-size: 2rem;
      letter-spacing: 0.05em;
      font-weight: 700;
      line-height: 1.25; } }

.ttl span {
  display: block;
  text-align: center;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #bdc4d0;
  line-height: 1;
  margin-top: 30px; }
  @media screen and (max-width: 991px) {
    .ttl span {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .ttl span {
      font-size: 1rem;
      margin-top: 1.4rem; } }

.ttl p {
  text-align: center;
  color: #03356c;
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1;
  margin-bottom: 18px; }
  @media screen and (max-width: 991px) {
    .ttl p {
      font-weight: 700;
      font-size: 1.2rem;
      letter-spacing: 0.05em;
      line-height: 1.25;
      margin-bottom: 1rem; } }

/* ============================================================================
lead
============================================================================== */
.lead {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 900;
  line-height: calc(28/18);
  letter-spacing: 0.1em;
  margin-top: 32px; }
  @media screen and (max-width: 991px) {
    .lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .lead {
      font-size: 1.2rem;
      line-height: calc(35/24); } }

/* ============================================================================
MV
============================================================================== */
.mv {
  position: relative;
  padding-top: 0; }
  @media screen and (max-width: 991px) {
    .mv {
      padding-top: 0; } }

.mv_shadow {
  position: absolute;
  display: none;
  content: "";
  width: 150vw;
  top: 0;
  left: 0;
  z-index: -1; }

.mv_inner {
  position: relative;
  max-width: 1600px;
  max-width: 83.33vw;
  margin: 0 auto;
  padding: 0 25px; }
  @media screen and (max-width: 991px) {
    .mv_inner {
      max-width: initial;
      padding: 0 2rem; } }

.mv_ttl {
  position: absolute;
  min-width: 35.3125vw;
  top: 4.16vw;
  left: 25px;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .mv_ttl {
      position: relative;
      width: fit-content;
      left: initial;
      top: initial;
      margin-left: auto; } }

.mv_ttl p:nth-child(1) {
  font-weight: bold;
  letter-spacing: 0.1em;
  font-size: 3.125vw; }
  @media screen and (max-width: 991px) {
    .mv_ttl p:nth-child(1) {
      width: fit-content;
      margin-left: auto;
      font-size: 2rem; } }
  .mv_ttl p:nth-child(1) span {
    position: relative;
    display: inline-block;
    -webkit-text-stroke: 5px black;
    text-stroke: 5px black; }
    @media screen and (max-width: 991px) {
      .mv_ttl p:nth-child(1) span {
        font-size: 2.5rem;
        -webkit-text-stroke: 3px black;
        text-stroke: 3px black; } }
  .mv_ttl p:nth-child(1) span::before {
    position: absolute;
    display: block;
    content: "変えるだけ";
    -webkit-text-stroke: initial;
    color: white;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    z-index: 1; }

.en .mv_ttl p:nth-child(1) span::before {
  content: "the hinges,"; }
@media screen and (max-width: 991px) {
  .en .mv_ttl p:nth-child(1) {
    letter-spacing: 0.05em;
    font-size: 1.8rem; }
    .en .mv_ttl p:nth-child(1) span {
      font-size: 2rem; } }

.mv_ttl p:nth-child(2) {
  font-size: 4.6875vw;
  font-weight: bold;
  line-height: 6.77vw;
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .mv_ttl p:nth-child(2) {
      font-size: 3rem;
      line-height: 3.5rem; } }
  .mv_ttl p:nth-child(2) span {
    display: inline-block;
    overflow: hidden;
    line-height: 1; }
  .mv_ttl p:nth-child(2) strong {
    display: inline-block;
    color: #0196ff;
    font-size: 6.77vw; }
    @media screen and (max-width: 991px) {
      .mv_ttl p:nth-child(2) strong {
        font-size: 5.5rem; } }

.en .mv_ttl p:nth-child(2) strong {
  padding-bottom: 3rem; }
@media screen and (max-width: 991px) {
  .en .mv_ttl p:nth-child(2) {
    line-height: 4.5rem; }
    .en .mv_ttl p:nth-child(2) span {
      padding-top: 0; } }

.en .mv_ttl {
  width: 52vw; }
  @media screen and (max-width: 991px) {
    .en .mv_ttl {
      position: relative;
      z-index: 5;
      width: fit-content;
      margin-right: -0.5rem; } }

.mv_ttl img {
  width: 100%; }

.mv_video {
  position: relative;
  width: 70.3125vw;
  margin-left: auto;
  margin-right: calc(50% - 50vw); }
  @media screen and (max-width: 991px) {
    .mv_video {
      width: 100vw;
      margin-left: calc(50% - 50vw);
      margin-top: -7rem;
      height: 40rem;
      overflow: hidden; } }

.mv_video::before {
  position: absolute;
  content: "";
  background: url(../img/img-index/mv_txt.png) center center/contain no-repeat;
  width: 650px;
  width: 33.8vw;
  height: 215px;
  height: 11.2vw;
  left: 50%;
  bottom: -70px;
  bottom: -3.6vw;
  transform: translateX(-50%); }
  @media screen and (max-width: 991px) {
    .mv_video::before {
      width: 16.5rem;
      bottom: -1.25rem;
      height: 5rem;
      right: 0.5rem;
      left: initial;
      transform: translateX(0); } }

.mv_video::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  transform: translateX(-100%);
  background-color: white;
  animation: cover_anime 3s 0.2s cubic-bezier(1, 0, 0, 1) forwards; }

@keyframes cover_anime {
  0% {
    transform: translateX(-100%); }
  50% {
    transform: translateX(0); }
  100% {
    transform: translateX(100%); } }
.mv_video video {
  aspect-ratio: 1350/700;
  width: 100%;
  height: 100%;
  object-fit: cover; }
  @media screen and (max-width: 991px) {
    .mv_video video {
      height: 100%;
      width: 100%;
      aspect-ratio: 640/700; } }

.mv_content {
  position: relative;
  max-width: 1200px;
  max-width: 62.5vw;
  margin: 0 auto;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .mv_content {
      max-width: 414px;
      width: 100%;
      margin-top: 1.6rem; } }

.mv_lead {
  position: relative;
  z-index: 5;
  font-size: 5rem;
  font-size: 2.6vw;
  font-weight: 900;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: calc(65/50); }
  @media screen and (max-width: 991px) {
    .mv_lead {
      font-weight: 700;
      text-align: left;
      font-size: 2.3rem;
      line-height: calc(72/46);
      letter-spacing: normal;
      margin-top: 3.5rem; } }

.mv_lead .navy {
  display: inline-block;
  position: relative;
  color: #03356c; }

.mv_lead .navy::before {
  content: "カンテックの";
  display: block;
  font-weight: 900;
  font-size: 3rem;
  font-size: 1.5625vw;
  letter-spacing: 0.1em;
  color: #333;
  line-height: 1;
  left: 0;
  text-align: left; }
  @media screen and (max-width: 991px) {
    .mv_lead .navy::before {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .mv_lead .navy::before {
      font-size: 1.2rem; } }

@media screen and (max-width: 991px) {
  .mv_lead_en {
    font-size: 1.6rem; } }

.mv_lead_en .navy::before {
  content: "KANTEC's"; }

.mv_lead .fuchi {
  z-index: 1;
  position: relative;
  display: inline-block;
  color: white;
  color: transparent;
  color: white; }

.mv_lead .fuchi::before {
  position: absolute;
  content: "開閉をアシスト";
  -webkit-text-stroke: 5px black;
  top: 51%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
  z-index: -1; }
  @media screen and (max-width: 991px) {
    .mv_lead .fuchi::before {
      -webkit-text-stroke: 0.25rem black; } }

.mv_txt {
  width: fit-content;
  font-size: 1.8rem;
  font-size: 0.9375vw;
  font-weight: 400;
  line-height: calc(30/18);
  letter-spacing: 0.2em;
  margin: 0 auto;
  margin-top: 42px;
  margin-top: 2.1875vw; }
  @media screen and (max-width: 991px) {
    .mv_txt {
      font-size: 1.2rem;
      line-height: calc(40/24);
      letter-spacing: 0.1em; } }

.mv_img {
  position: absolute;
  width: 350px;
  width: 18.2vw;
  left: 0;
  top: -10.9375vw;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .mv_img {
      width: 12.5rem;
      top: -3.1rem; } }
  .mv_img img {
    width: 100%; }

.mv_img picture {
  position: relative;
  display: block;
  overflow: hidden; }

.mv_img picture::before {
  position: absolute;
  top: 0;
  left: -75%;
  z-index: 2;
  display: block;
  content: '';
  width: 50%;
  height: 100%;
  background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.8) 100%);
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.8) 100%);
  -webkit-transform: skewX(-60deg);
  transform: skewX(-60deg);
  animation: shine 3s  ease-in-out infinite; }

@keyframes shine {
  10% {
    left: 125%; }
  50% {
    left: 125%; }
  100% {
    left: 125%; } }
.mv_img2 {
  position: absolute;
  width: 260px;
  width: 18.5vw;
  right: -10vw;
  top: -2vw;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .mv_img2 {
      width: 9.5rem;
      bottom: 9.8rem;
      top: initial;
      right: -2rem; } }
  .mv_img2 img {
    width: 100%; }

@media screen and (max-width: 991px) {
  .mv_img2.--en {
    bottom: 15rem;
    width: 7rem; } }

.mv_circle {
  position: absolute;
  width: 240px;
  height: 240px;
  width: 10.15625vw;
  height: 10.15625vw;
  left: -2.6vw;
  top: -6.25vw; }
  @media screen and (max-width: 991px) {
    .mv_circle {
      width: 7.2rem;
      height: 7.2rem;
      left: -1rem;
      top: 0; } }

.mv_circle svg {
  -webkit-animation: donut-spin 10s linear infinite;
  animation: donut-spin 10s linear infinite;
  overflow: visible; }

.mv_circle path {
  fill: none; }

.mv_circle text {
  fill: #0071be;
  font-size: 1rem; }

@keyframes donut-spin {
  to {
    transform: rotate(1turn); } }
/* ============================================================================
サービス（トップページ）
============================================================================== */
.topService {
  position: relative;
  background-color: #e1efff;
  padding-top: 140px;
  padding-bottom: 80px; }
  @media screen and (max-width: 991px) {
    .topService {
      padding-top: 10rem;
      padding-bottom: 2.3rem; } }

.topService_inner.inner {
  position: relative;
  max-width: 1120px; }

.topService_ttl {
  position: absolute;
  top: -165px;
  left: 50px; }
  @media screen and (max-width: 991px) {
    .topService_ttl {
      left: 2rem;
      top: -11.3rem; } }

.topService_ttl span {
  position: relative;
  display: block;
  max-width: fit-content;
  color: white;
  background-color: #03356c;
  font-size: 2.8rem;
  font-weight: 900;
  height: 54px;
  letter-spacing: 0.1em;
  line-height: calc(33/28);
  overflow: hidden;
  padding-block: 10px;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .topService_ttl span {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .topService_ttl span {
      height: 2.6rem;
      font-size: 1.5rem;
      padding-block: 0.6rem; } }

@media screen and (max-width: 991px) {
  .topService_ttl.--en span {
    font-size: 1rem;
    letter-spacing: 0.025em; } }

.topService_ttl span.is-active {
  padding-inline: 16px; }
  @media screen and (max-width: 991px) {
    .topService_ttl span.is-active {
      padding-inline: 1.6rem; } }

@media screen and (max-width: 991px) {
  .topService_ttl.--en span.is-active {
    padding-inline: 0.8rem; } }

.topService_ttl span::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  background-color: #03356c;
  transition: all 1s; }

.topService_ttl span.is-active::before {
  width: 0; }

.topService_ttl span + span {
  margin-top: 12px; }
  @media screen and (max-width: 991px) {
    .topService_ttl span + span {
      margin-top: 0.5rem; } }

.topService_cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px; }
  @media screen and (max-width: 991px) {
    .topService_cards {
      grid-template-columns: repeat(2, 1fr);
      gap: 1.8rem 1.5rem; } }
  .topService_cards img {
    width: 100%; }

.topService_card p {
  text-align: center;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #03356c;
  margin-top: 12px; }
  @media screen and (max-width: 991px) {
    .topService_card p {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .topService_card p {
      font-size: 1.1rem;
      margin-top: 0.7rem; } }

.topService_txt {
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-align: center;
  margin-top: 34px; }
  @media screen and (max-width: 991px) {
    .topService_txt {
      text-align: left;
      font-size: 1.1rem;
      line-height: calc(35/22);
      margin-top: 2rem; } }

/* ============================================================================
media（トップページ）
============================================================================== */
.media_ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  line-height: calc(36/30);
  letter-spacing: 0.1em;
  font-weight: 900;
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .media_ttl {
      position: relative;
      display: block;
      width: fit-content;
      font-size: 1.6rem;
      font-weight: 700;
      line-height: calc(50/36);
      padding-left: 3rem;
      margin: 0 auto; } }

.media_ttl span {
  font-size: calc(100% + 0.5rem);
  color: #0196ff; }

.media_ttl img {
  margin-right: 20px; }
  @media screen and (max-width: 991px) {
    .media_ttl img {
      position: absolute;
      left: 0;
      margin: 0; } }

.media_img {
  position: relative;
  text-align: center;
  margin-top: 22px;
  display: block; }
  @media screen and (max-width: 991px) {
    .media_img {
      margin-top: 1.9rem; } }
  .media_img img {
    width: 100%; }

.media_img::before {
  position: absolute;
  content: "";
  width: 180px;
  height: 94px;
  left: 50%;
  transform: translateX(-50%);
  bottom: 90px;
  background: url(../img/img-index/yellow_arrow.png) center center/contain no-repeat;
  animation: arrow_pc 3s steps(1) infinite;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .media_img::before {
      background-image: url(../img/img-index/yellow_arrow_sp.png);
      animation: arrow_sp 3s steps(1) infinite;
      bottom: 9.5rem;
      left: 4.2rem;
      transform: translateX(0);
      width: 4rem;
      height: 7.5rem; } }

@keyframes arrow_pc {
  0% {
    left: calc(50% - 75px); }
  25% {
    left: calc(50% - 25px); }
  50% {
    left: calc(50% + 25px); }
  75% {
    left: calc(50% + 75px); } }
@keyframes arrow_pc2 {
  0% {
    left: calc(50% - 15px); }
  25% {
    left: calc(50% - 5px); }
  50% {
    left: calc(50% + 5px); }
  75% {
    left: calc(50% + 15px); } }
@keyframes arrow_sp {
  0% {
    top: calc(50% - 5px); }
  33% {
    top: calc(50%); }
  66% {
    top: calc(50% + 5px); } }
.media_movie {
  position: relative;
  max-width: 720px;
  margin: 0 auto;
  margin-top: 110px; }
  @media screen and (max-width: 991px) {
    .media_movie {
      margin-top: 6rem; } }

.media_movie::before {
  position: absolute;
  content: "";
  width: 232px;
  top: -100px;
  right: -164px;
  height: 200px;
  background: url(../img/img-index/media_img_02.png) center center/contain no-repeat;
  z-index: -1; }
  @media screen and (max-width: 991px) {
    .media_movie::before {
      width: 10rem;
      height: 6rem;
      right: -4rem;
      top: -5rem; } }

@media screen and (max-width: 991px) {
  .en .media_movie {
    margin-top: 5rem; } }

@media screen and (max-width: 991px) {
  .en .media_movie::before {
    right: -2rem;
    top: -3rem; } }

.media_movie_ttl {
  position: relative;
  text-align: center;
  width: fit-content;
  margin-left: 42px; }
  @media screen and (max-width: 991px) {
    .media_movie_ttl {
      margin-left: 1.3rem; } }
  .media_movie_ttl::before {
    position: absolute;
    content: "";
    background-color: #636363;
    width: 1px;
    height: 38px;
    transform: rotate(-30deg);
    bottom: -10px;
    left: -40px; }
    @media screen and (max-width: 991px) {
      .media_movie_ttl::before {
        left: -1.25rem;
        bottom: -0.5rem;
        height: 1.9rem; } }
  .media_movie_ttl::after {
    position: absolute;
    content: "";
    background-color: #636363;
    width: 1px;
    height: 38px;
    transform: rotate(30deg);
    bottom: -10px;
    right: -40px; }
    @media screen and (max-width: 991px) {
      .media_movie_ttl::after {
        right: -1.25rem;
        bottom: -0.5rem;
        height: 1.9rem; } }

.media_movie_ttl > span {
  font-size: 2.8rem;
  font-weight: 900;
  line-height: calc(30/25);
  letter-spacing: 0.1em;
  position: relative;
  display: inline-block; }
  .media_movie_ttl > span::before {
    position: absolute;
    content: "";
    width: 0%;
    height: 4px;
    bottom: -10px;
    left: 0;
    background-color: #0071be;
    transition: all 0.3s; }
    @media screen and (max-width: 991px) {
      .media_movie_ttl > span::before {
        bottom: -0.5rem;
        height: 0.2rem; } }
  @media screen and (max-width: 991px) {
    .media_movie_ttl > span {
      font-size: 1.4rem;
      font-weight: 700; } }

.media_movie_ttl.is-active > span::before {
  width: 100%; }

.media_movie_ttl > span > span {
  font-size: calc(100% + 0.5rem);
  color: #0196ff; }

.media_youtube {
  margin-top: 30px; }
  @media screen and (max-width: 991px) {
    .media_youtube {
      margin-top: 1.3rem; } }

.media_youtube iframe {
  aspect-ratio: 710/400;
  object-fit: cover;
  width: 100%;
  height: 100%; }

/* ============================================================================
取り付け可能（トップページ）
============================================================================== */
.attach {
  background-color: #edf4f6; }

.attach_inner.inner {
  max-width: 1040px; }

.attach_ttl {
  font-size: 3.4rem;
  text-align: center;
  font-weight: 900;
  line-height: calc(50/34);
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .attach_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .attach_ttl {
      font-size: 2rem;
      text-align: left;
      line-height: calc(60/40); } }

.attach_ttl span {
  position: relative;
  z-index: 1;
  display: inline-block;
  color: #03356c; }

.attach_ttl span::before {
  position: absolute;
  content: "";
  width: 0%;
  height: 10px;
  left: 0;
  bottom: 5px;
  z-index: -1;
  transition: all 0.5s; }

.attach_ttl span.bg_orange::before {
  background-color: #fd9834; }

.attach_ttl span.bg_yellow::before {
  background-color: #fde439;
  transition-delay: 0.4s; }

.attach_ttl.is-active span::before {
  width: 100%; }

.attach_txt {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(30/16);
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .attach_txt {
      font-size: 1.1rem;
      margin-top: 1.5rem;
      line-height: calc(35/22); } }

.attach_cards {
  width: fit-content;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 65px;
  margin-inline: auto;
  margin-top: 38px; }
  @media screen and (max-width: 991px) {
    .attach_cards {
      margin-top: 1.2rem;
      grid-template-columns: 1fr;
      gap: 2rem; } }

.attach_card {
  position: relative;
  max-width: 400px; }
  @media screen and (max-width: 991px) {
    .attach_card {
      max-width: 25rem;
      margin: 0 auto; } }

.attach_tag {
  position: absolute;
  display: flex;
  align-items: center;
  background-color: #03356c;
  color: white;
  line-height: 1;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  padding: 10px 60px 10px 16px;
  clip-path: polygon(0 0, 100% 0%, calc(100% - 30px) 100%, 0% 100%);
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .attach_tag {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .attach_tag {
      font-size: 1.2rem;
      padding: 0.5rem 3rem 0.5rem 0.8rem; } }
  .attach_tag img {
    display: inline-block;
    margin-right: 12px; }

/* ============================================================================
製品のご案内（トップページ）
============================================================================== */
.topProduct {
  background: url(../img/img-index/bg_produce.webp) center center/cover no-repeat;
  padding-top: 90px;
  padding-bottom: 90px; }
  @media screen and (max-width: 991px) {
    .topProduct {
      background-image: url(../img/img-index/bg_product_sp.webp);
      padding-top: 4rem;
      padding-bottom: 4rem; } }

.topProduct_ttl h2 {
  color: white; }

.topProduct_lead {
  text-align: center;
  color: white;
  font-size: 1.6rem;
  font-weight: 900;
  line-height: calc(25/16);
  letter-spacing: 0.1em;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .topProduct_lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .topProduct_lead {
      text-align: left;
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.15em; } }

.topProduct_main {
  display: grid;
  grid-template-columns: calc(66% - 15px) calc(34% - 15px);
  margin-top: 43px;
  gap: 30px; }
  @media screen and (max-width: 991px) {
    .topProduct_main {
      margin-top: 2.4rem;
      grid-template-columns: 1fr;
      gap: 2.7rem; } }

.topProduct_balancer {
  border-radius: 5px;
  box-shadow: 0 0 3px rgba(0, 0, 0, 0.3); }
  .topProduct_balancer .topProduct_subttl {
    padding-left: 87px; }
    @media screen and (max-width: 991px) {
      .topProduct_balancer .topProduct_subttl {
        padding-left: 1.2rem; } }
    .topProduct_balancer .topProduct_subttl img {
      position: absolute;
      right: 33px;
      top: 50%;
      transform: translateY(-50%); }
      @media screen and (max-width: 991px) {
        .topProduct_balancer .topProduct_subttl img {
          width: 6.4rem;
          right: 1.5rem; } }
  .topProduct_balancer .topProduct_subttl::before {
    left: 33px; }
    @media screen and (max-width: 991px) {
      .topProduct_balancer .topProduct_subttl::before {
        left: 0.5rem; } }

.topProduct_subttl {
  position: relative;
  height: 80px;
  display: flex;
  font-size: 3rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  background-color: #03356c;
  color: white;
  align-items: center; }
  @media screen and (max-width: 991px) {
    .topProduct_subttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .topProduct_subttl {
      font-size: 1.7rem;
      padding: 1.2rem;
      height: auto; } }

.topProduct_subttl::before {
  position: absolute;
  content: "";
  background: url(../img/img-index/produce_icon_01.png) center center/contain no-repeat;
  width: 100px;
  height: 102px;
  top: 0; }
  @media screen and (max-width: 991px) {
    .topProduct_subttl::before {
      width: 5rem;
      height: 5rem; } }

.topProduct_cards {
  display: flex;
  flex-grow: 1;
  justify-content: center;
  gap: 30px;
  padding: 30px 25px 40px;
  background-color: #f1f8fe; }
  @media screen and (max-width: 991px) {
    .topProduct_cards {
      flex-direction: column;
      padding: 2rem; } }

.topProduct_card {
  background-color: white;
  width: 300px;
  padding: 20px; }
  @media screen and (max-width: 991px) {
    .topProduct_card {
      width: 100%;
      padding: 2.2rem; } }

.topProduct_card a {
  display: block;
  transition: all 0.2s; }

.topProduct_card a:hover .topProduct_img img {
  transform: scale(1.1); }

.topProduct_img {
  display: block;
  text-align: center;
  height: 217px; }
  @media screen and (max-width: 991px) {
    .topProduct_img {
      width: 13rem;
      height: auto;
      margin: 0 auto; } }

.topProduct_img img {
  object-fit: contain;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .topProduct_img img {
      width: 100%; } }

.topProduct_name {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 2.2rem;
  min-height: 60px;
  line-height: calc(30/22);
  font-weight: 900;
  color: #03356c;
  letter-spacing: 0.05em;
  margin-top: 18px; }
  @media screen and (max-width: 991px) {
    .topProduct_name {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .topProduct_name {
      font-size: 1.4rem;
      min-height: initial;
      line-height: calc(35/28);
      margin-top: 1.6rem; } }

.topProduct_txt {
  text-align: left;
  margin-top: 8px;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: calc(18/14); }
  @media screen and (max-width: 991px) {
    .topProduct_txt {
      font-size: 1.1rem; } }

.topProduct_onetouch {
  display: flex;
  flex-direction: column; }
  .topProduct_onetouch .topProduct_subttl {
    justify-content: center; }
  .topProduct_onetouch .topProduct_subttl::before {
    left: 9px; }

.topProduct_btn {
  margin-top: 52px;
  max-width: 300px;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .topProduct_btn {
      max-width: 17.5rem;
      margin-top: 3rem; } }

/* ============================================================================
news（トップページ）
============================================================================== */
.news {
  position: relative; }

.news_main {
  max-width: 800px;
  max-height: 300px;
  overflow-y: scroll;
  margin-inline: auto;
  margin-top: 30px; }
  @media screen and (max-width: 991px) {
    .news_main {
      margin-top: 1.5rem; } }

.news_main::-webkit-scrollbar {
  width: 15px; }
  @media screen and (max-width: 991px) {
    .news_main::-webkit-scrollbar {
      width: 0.75rem; } }

.news_main::-webkit-scrollbar-track {
  background-color: #f2f2f2; }

.news_main::-webkit-scrollbar-thumb {
  background-color: #125796;
  border-radius: 8px; }

.news::before {
  position: absolute;
  content: "";
  width: 450px;
  height: 456px;
  background: url(../img/img-index/bg_news.png) center center/contain no-repeat;
  right: 170px;
  bottom: -93px;
  z-index: -1; }
  @media screen and (max-width: 991px) {
    .news::before {
      right: 1.6rem;
      width: 22.5rem;
      bottom: -1.2rem;
      height: 22.5rem; } }

/* ============================================================================
キャップバランサーで対策を！（トップページ）
============================================================================== */
.manga {
  background-color: #f7fbff;
  overflow: hidden; }

.manga_ttl {
  text-align: center;
  font-size: 4rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: calc(48/40); }
  @media screen and (max-width: 991px) {
    .manga_ttl {
      font-weight: 700;
      white-space: nowrap;
      font-size: 2rem; } }

@media screen and (max-width: 991px) {
  .en .manga_ttl {
    white-space: initial; } }

.manga_ttl span {
  display: block;
  color: #D90000;
  font-size: 2.8rem;
  font-weight: 900;
  line-height: calc(33/28);
  letter-spacing: 0.05em;
  margin-bottom: 10px; }
  @media screen and (max-width: 991px) {
    .manga_ttl span {
      font-size: 1.4rem;
      font-weight: 700; } }

.manga_box {
  max-width: 960px;
  background-color: white;
  margin-inline: auto;
  margin-top: 50px;
  box-shadow: 0 0 8px rgba(0, 113, 190, 0.08);
  border-radius: 10px;
  padding: 0px 103px 103px; }
  @media screen and (max-width: 991px) {
    .manga_box {
      margin-top: 2rem;
      padding: 0;
      padding-bottom: 2.5rem; } }

.manga_box picture {
  position: relative;
  display: block;
  max-height: 685px;
  overflow: hidden;
  max-width: 754px;
  margin: 0 auto;
  transition: max-height 1s ease; }
  @media screen and (max-width: 991px) {
    .manga_box picture {
      max-height: 26rem;
      transition: max-height 2s ease; } }

.manga_box picture.is-active {
  max-height: 6000px; }

.manga_box picture::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 125px;
  bottom: 0;
  left: 0;
  background: linear-gradient(to bottom, transparent 0%, white 40%);
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .manga_box picture::before {
      height: 4rem;
      background: linear-gradient(to bottom, transparent 0%, white 70%); } }

.manga_box picture.is-active::before {
  opacity: 0; }

.manga_btn {
  position: relative;
  height: 60px;
  max-width: 400px;
  margin: 0 auto; }
  @media screen and (max-width: 991px) {
    .manga_btn {
      max-width: 17.5rem;
      height: 3.5rem; } }

.manga_btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  font-weight: 900;
  color: #03356c;
  letter-spacing: 0.2em;
  height: 100%;
  border-radius: 30px;
  border: 2px solid #03356c;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .manga_btn a {
      font-weight: 700; } }
  .manga_btn a:hover {
    opacity: 0.8; }
  @media screen and (max-width: 991px) {
    .manga_btn a {
      font-size: 1.1rem; } }

.manga_btn span {
  position: absolute;
  display: inline-block;
  width: 28px;
  height: 28px;
  background-color: #03356c;
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
  right: 29px;
  pointer-events: none; }
  @media screen and (max-width: 991px) {
    .manga_btn span {
      width: 1.2rem;
      height: 1.2rem;
      right: 1.3rem; } }

.manga_btn span::before {
  position: absolute;
  content: "";
  background-color: white;
  width: 12px;
  height: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }
  @media screen and (max-width: 991px) {
    .manga_btn span::before {
      width: 0.6rem; } }

.manga_btn span::after {
  position: absolute;
  content: "";
  background-color: white;
  width: 12px;
  height: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .manga_btn span::after {
      width: 0.6rem; } }

.manga_btn.is-active span::after {
  transform: translate(-50%, -50%); }

/* ============================================================================
よくあるご質問（トップページ）
============================================================================== */
.excursion + .faq {
  padding-top: 145px; }
  @media screen and (max-width: 991px) {
    .excursion + .faq {
      padding-top: 4.5rem; } }

.faq_inner.inner {
  max-width: 950px; }

.faq_lists {
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .faq_lists {
      margin-top: 2.4rem; } }

.faq_list {
  position: relative;
  cursor: pointer; }

.faq_list span {
  position: absolute;
  display: inline-block;
  width: 28px;
  height: 28px;
  background-color: #03356c;
  border-radius: 50%;
  top: 13px;
  right: 29px; }
  @media screen and (max-width: 991px) {
    .faq_list span {
      width: 2rem;
      height: 2rem;
      top: 1.65rem;
      right: 1rem; } }

.faq_list span::before {
  position: absolute;
  content: "";
  background-color: white;
  width: 12px;
  height: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); }
  @media screen and (max-width: 991px) {
    .faq_list span::before {
      width: 0.8rem; } }

.faq_list span::after {
  position: absolute;
  content: "";
  background-color: white;
  width: 12px;
  height: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(90deg);
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .faq_list span::after {
      width: 0.8rem; } }

.faq_list.is-active span::after {
  transform: translate(-50%, -50%); }

.faq_list p:nth-child(1) {
  font-size: 1.8rem;
  font-weight: 900;
  line-height: calc(27/18);
  letter-spacing: 0.2em;
  background-color: #e1efff;
  border-radius: 5px;
  padding: 14px 65px 14px 40px; }
  @media screen and (max-width: 991px) {
    .faq_list p:nth-child(1) {
      text-indent: -2.25em;
      font-size: 1.2rem;
      font-weight: 700;
      padding: 1rem 3.8rem 1rem 1rem;
      padding-left: 3.25em; } }
  .faq_list p:nth-child(1)::first-letter {
    color: #03356c; }

@media screen and (max-width: 991px) {
  .faq_list p:nth-child(1) {
    display: flex;
    align-items: center;
    min-height: 65px; } }

.en .faq_list p:nth-child(1) {
  letter-spacing: normal; }
  @media screen and (max-width: 991px) {
    .en .faq_list p:nth-child(1) {
      text-indent: -1.8em; } }

.faq_list p:nth-child(2) {
  display: none;
  font-size: 1.8rem;
  font-weight: 400;
  background-color: #eff6ff;
  padding: 20px 70px 20px 78px; }
  @media screen and (max-width: 991px) {
    .faq_list p:nth-child(2) {
      font-size: 1.2rem;
      line-height: calc(35/24);
      padding: 1rem 3.3rem 1rem 3.75rem; } }

.faq_list p:nth-child(2) a {
  text-decoration: underline; }

.faq_list + .faq_list {
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .faq_list + .faq_list {
      margin-top: 1.5rem; } }

.faq_btn {
  max-width: 220px;
  width: 100%;
  margin: 0 auto;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .faq_btn {
      max-width: 12.5rem;
      margin-top: 2rem; } }

/* ============================================================================
お問い合わせ（トップページ）
============================================================================== */
.contact {
  position: relative;
  overflow: hidden;
  background: url(../img/img-common/bg_contact.webp) center center/cover no-repeat; }

.contact_2 {
  padding-top: 50px;
  padding-bottom: 50px; }
  @media screen and (max-width: 991px) {
    .contact_2 {
      padding-top: 4rem;
      padding-bottom: 3rem; } }

.excursion + .contact {
  margin-top: 100px; }
  @media screen and (max-width: 991px) {
    .excursion + .contact {
      margin-top: 4rem; } }

.contact::before {
  position: absolute;
  content: "";
  background: url(../img/img-index/bg_contact.png) center center/contain no-repeat;
  top: -70px;
  left: 0;
  width: 393px;
  height: 545px;
  pointer-events: none; }
  @media screen and (max-width: 991px) {
    .contact::before {
      width: 20rem;
      height: 27.2rem;
      top: -3.5rem; } }

.contact_inner.inner {
  max-width: 1150px; }

.contact_inner.inner_s {
  max-width: 930px; }

.contact_box {
  background-color: white;
  border-radius: 10px;
  padding: 50px 80px 40px; }
  @media screen and (max-width: 991px) {
    .contact_box {
      padding: 3rem 2rem; } }

.contact_ttl2 h2 {
  font-size: 3rem; }
  @media screen and (max-width: 991px) {
    .contact_ttl2 h2 {
      font-size: 1.7rem; } }

.contact_top {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(25/16);
  letter-spacing: 0.1em;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .contact_top {
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.05em;
      margin-top: 1.4rem; } }

.contact_wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
  margin-top: 34px; }
  @media screen and (max-width: 991px) {
    .contact_wrap {
      grid-template-columns: 1fr;
      margin-top: 1.6rem; } }

.en .contact_wrap {
  display: block; }

.contact_tel {
  width: fit-content;
  margin: 0 auto; }
  .contact_tel h3 {
    color: #03356c;
    font-size: 2rem;
    font-weight: 900;
    letter-spacing: 0.1em; }
    @media screen and (max-width: 991px) {
      .contact_tel h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .contact_tel h3 {
        font-size: 1.2rem;
        text-align: center; } }

.contact_number {
  display: flex;
  align-items: flex-start;
  gap: 10px; }
  @media screen and (max-width: 991px) {
    .contact_number {
      margin-top: 0.2rem; } }
  .contact_number img {
    width: 20px;
    margin-top: 3px; }
    @media screen and (max-width: 991px) {
      .contact_number img {
        width: 1rem;
        margin-top: 1px; } }
  .contact_number a {
    font-size: 4rem;
    color: #333;
    font-weight: 900;
    line-height: calc(42/40); }
    @media screen and (max-width: 991px) {
      .contact_number a {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .contact_number a {
        color: #333;
        font-size: 2.2rem; } }
    .contact_number a span {
      color: #333;
      display: block;
      text-align: center;
      font-size: 1.4rem;
      font-weight: 900;
      letter-spacing: 0.1em;
      line-height: calc(18/14);
      margin-top: 8px; }
      @media screen and (max-width: 991px) {
        .contact_number a span {
          font-weight: 700; } }
      @media screen and (max-width: 991px) {
        .contact_number a span {
          font-size: 1rem;
          margin-top: 0.4rem; } }

.en .contact_btns {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: fit-content;
  margin: 0 auto;
  gap: 40px; }
  @media screen and (max-width: 991px) {
    .en .contact_btns {
      width: 100%;
      grid-template-columns: 1fr;
      gap: 1.5rem;
      margin-top: 2rem; } }

.en .contact_2 .contact_btns {
  width: 100%;
  grid-template-columns: 1fr; }

.en .contact_tel {
  display: none;
  padding-bottom: 2.5em; }
  @media screen and (max-width: 991px) {
    .en .contact_tel {
      padding-bottom: 3.5em; } }

.en .contact_number {
  position: relative; }

.en .contact_number a {
  font-size: 3rem; }
  @media screen and (max-width: 991px) {
    .en .contact_number a {
      font-size: 1.8rem; } }

.en .contact_number a span {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  white-space: nowrap; }
  @media screen and (max-width: 991px) {
    .en .contact_number a span {
      white-space: initial; } }

@media screen and (max-width: 991px) {
  .contact_btns {
    margin-top: 2rem; } }

.contact_btn {
  max-width: 330px;
  width: 100%; }
  @media screen and (max-width: 991px) {
    .contact_btn {
      margin: 0 auto;
      min-width: 15rem; } }
  .contact_btn a {
    position: relative;
    font-size: 2rem;
    font-weight: 900;
    justify-content: center;
    letter-spacing: 0.05em;
    padding: 14px 34px 14px 75px;
    border-radius: 30px; }
    @media screen and (max-width: 991px) {
      .contact_btn a {
        font-weight: 700;
        font-size: 1.4rem;
        padding: 1rem 1.7rem 1rem 3.4rem; } }
    .contact_btn a img {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      left: 30px;
      width: 3rem; }
      @media screen and (max-width: 991px) {
        .contact_btn a img {
          width: 1.75rem;
          left: 1.5rem; } }
  .contact_btn .btn_en {
    font-size: 1.8rem; }
    @media screen and (max-width: 991px) {
      .contact_btn .btn_en {
        font-size: 1.4rem; } }

.en .contact_btn {
  max-width: 350px;
  margin: 0 auto; }
  @media screen and (max-width: 991px) {
    .en .contact_btn {
      max-width: 350px; } }

.en .contact_btn a {
  font-size: 2.2rem;
  padding: 20px 34px 20px 70px;
  letter-spacing: 0.05em;
  border-radius: 40px; }
  @media screen and (max-width: 991px) {
    .en .contact_btn a {
      font-weight: 700;
      font-size: 1.4rem;
      padding: 1rem 1.7rem 1rem 3.4rem; } }

.contact_btn + .contact_btn {
  margin-top: 10px; }
  @media screen and (max-width: 991px) {
    .contact_btn + .contact_btn {
      margin-top: 1.5rem; } }

.en .contact_btn {
  margin-top: 0 !important; }

.contact_cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 36px; }
  @media screen and (max-width: 991px) {
    .contact_cards {
      grid-template-columns: 1fr;
      margin-top: 2.5rem;
      gap: 1rem; } }

.contact_card {
  position: relative;
  background-color: #f1f8fe;
  border: 1px solid #03356c;
  border-radius: 5px;
  padding: 16px 22px; }
  @media screen and (max-width: 991px) {
    .contact_card {
      padding: 1.3rem 1rem; } }

.contact_icon {
  display: block;
  text-align: center; }
  .contact_icon img {
    width: 50px; }
    @media screen and (max-width: 991px) {
      .contact_icon img {
        position: absolute;
        left: 1.2rem;
        top: 0.6rem;
        width: 2.5rem; } }

.contact_lead {
  text-align: center;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: normal;
  color: #03356c;
  margin-top: 8px; }
  @media screen and (max-width: 991px) {
    .contact_lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .contact_lead {
      text-align: left;
      font-size: 1.2rem;
      margin-top: 0;
      margin-left: 3.5rem; } }

.contact_txt {
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: calc(20/15);
  margin-top: 8px; }
  @media screen and (max-width: 991px) {
    .contact_txt {
      font-size: 1rem;
      line-height: calc(30/20); } }

/* ============================================================================
仮想ページMV
============================================================================== */
.subMv {
  position: relative;
  padding-bottom: 0; }
  @media screen and (max-width: 991px) {
    .subMv {
      padding-top: 5.8rem;
      margin-top: 0; } }

.subMv_ttl {
  position: relative;
  z-index: 1; }

.subMv_ttl > span {
  position: relative;
  display: block;
  width: fit-content;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1;
  color: #03356c;
  padding-bottom: 15px; }
  @media screen and (max-width: 991px) {
    .subMv_ttl > span {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .subMv_ttl > span {
      font-size: 1.1rem;
      padding-bottom: 0.4rem; } }

.subMv_ttl > span::before {
  position: absolute;
  content: "";
  width: 0%;
  height: 2px;
  background: #03356c;
  left: 0;
  bottom: 0;
  transition: all 0.3s; }

.subMv_ttl.is-active span::before {
  width: 100%; }

.subMv_ttl h1 {
  font-size: 4.6rem;
  font-weight: 900;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .subMv_ttl h1 {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .subMv_ttl h1 {
      font-size: 2.1rem;
      line-height: calc(55/42);
      margin-top: 1rem; } }
  .subMv_ttl h1 span {
    display: inline-block;
    transition: opacity 1s cubic-bezier(0.19, 1, 0.22, 1), clip-path 1s cubic-bezier(0.19, 1, 0.22, 1), transform 1s cubic-bezier(0.19, 1, 0.22, 1), -webkit-clip-path 1s cubic-bezier(0.19, 1, 0.22, 1); }

.en .subMv_ttl h1 {
  letter-spacing: 0.05em; }

.subMv_img {
  position: relative;
  display: block;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-top: 48px; }
  @media screen and (max-width: 991px) {
    .subMv_img {
      margin-top: 2.5rem; } }

.subMv_feature .subMv_img::before {
  position: absolute;
  content: "";
  width: 7.8125vw;
  height: 4.16666vw;
  left: 50%;
  transform: translateX(-50%);
  bottom: 9.21875vw;
  background: url(../img/img-index/yellow_arrow.png) center center/contain no-repeat;
  animation: arrow_pc2 3s steps(1) infinite;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .subMv_feature .subMv_img::before {
      background-image: url(../img/img-index/yellow_arrow_sp.png);
      animation: arrow_sp 3s steps(1) infinite;
      bottom: 44.84vw;
      right: 24.375vw;
      left: initial;
      transform: translateX(0);
      width: 4rem;
      height: 7.5rem; } }

.subMv_img img {
  width: 100%; }

.subMv_lead {
  position: relative;
  z-index: 1;
  font-size: 2rem;
  line-height: calc(35/20);
  letter-spacing: 0.1em;
  font-weight: 900;
  margin-top: 38px; }
  @media screen and (max-width: 991px) {
    .subMv_lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .subMv_lead {
      font-size: 1rem;
      margin-top: 1.6rem; } }

.subMv_lead_list {
  position: relative;
  z-index: 1;
  font-weight: 900;
  margin-top: 42px; }
  @media screen and (max-width: 991px) {
    .subMv_lead_list {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .subMv_lead_list {
      margin-top: 2.4rem; } }

.subMv_lead_install {
  position: relative;
  z-index: 1;
  font-weight: 900;
  margin-top: 30px; }
  @media screen and (max-width: 991px) {
    .subMv_lead_install {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .subMv_lead_install {
      margin-top: 2.4rem; } }

.subMv_lead_guide {
  letter-spacing: 0.15em;
  margin-top: 40px; }
  @media screen and (max-width: 991px) {
    .subMv_lead_guide {
      margin-top: 2.6rem; } }

.subMv_freestop {
  padding-top: 70px;
  padding-bottom: 143px; }
  @media screen and (max-width: 991px) {
    .subMv_freestop {
      padding-top: 6rem;
      padding-bottom: 6rem; } }

.subMv_freestop::before {
  position: absolute;
  content: "";
  width: 600px;
  height: 350px;
  bottom: 0;
  right: 154px;
  background: url(../img/img-freestop/freestop_txt.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .subMv_freestop::before {
      width: 15rem;
      height: 8.8rem;
      bottom: 7.1rem;
      right: 0.6rem; } }

.subMv_standard {
  padding-bottom: 140px; }
  @media screen and (max-width: 991px) {
    .subMv_standard {
      padding-bottom: 6.5rem; } }

.subMv_standard::before {
  position: absolute;
  content: "";
  width: 600px;
  height: 251px;
  bottom: 0;
  right: 140px;
  background: url(../img/img-standard/standard_txt.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .subMv_standard::before {
      width: 15rem;
      height: 8.8rem;
      bottom: 7.1rem;
      right: 0.6rem; } }

.subMv_list::before {
  position: absolute;
  content: "";
  width: 100%;
  max-width: 200px;
  max-height: 200px;
  bottom: -18px;
  height: 100%;
  background: url(../img/img-product-list/list_01.png) center center/contain no-repeat;
  right: calc(50% - min(28vw,355px));
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .subMv_list::before {
      width: 7.7rem;
      height: 7.7rem;
      top: 7rem;
      right: 4.6rem; } }

.subMv_list::after {
  position: absolute;
  content: "";
  background: url(../img/img-product-list/list_02.jpg) center center/contain no-repeat;
  width: 100%;
  max-width: 360px;
  height: 100%;
  max-height: 256px;
  right: calc(50% - min(34vw,580px));
  top: 0; }
  @media screen and (max-width: 991px) {
    .subMv_list::after {
      width: 18rem;
      height: 12.5rem;
      top: 4.9rem;
      right: -2.6rem; } }

.subMv_faq {
  padding-bottom: 60px; }
  @media screen and (max-width: 991px) {
    .subMv_faq {
      padding-bottom: 3rem; } }

.subMv_faq::after {
  position: absolute;
  content: "";
  background: url(../img/img-product-list/list_02.jpg) center center/contain no-repeat;
  width: 100%;
  max-width: 360px;
  height: 100%;
  max-height: 256px;
  right: calc(50% - min(34vw,580px));
  top: 0; }
  @media screen and (max-width: 991px) {
    .subMv_faq::after {
      width: 18rem;
      height: 12.5rem;
      top: 4.9rem;
      right: -2.6rem; } }

.subMv_handy {
  padding-bottom: 140px; }
  @media screen and (max-width: 991px) {
    .subMv_handy {
      padding-top: 6.5rem;
      padding-bottom: 9.4rem; } }

.subMv_handy::before {
  position: absolute;
  content: "";
  width: 100%;
  max-width: 273px;
  max-height: 160px;
  height: 100%;
  background: url(../img/img-handy/list_01.png) center center/contain no-repeat;
  top: min(2.5vw, 48px);
  right: calc(50% - min(22vw,490px));
  z-index: 1;
  display: none; }
  @media screen and (max-width: 991px) {
    .subMv_handy::before {
      width: 13.6rem;
      height: 8rem;
      top: 7rem;
      right: 4.4rem;
      display: none; } }

.subMv_handy::after {
  position: absolute;
  content: "";
  background: url(../img/img-product-list/list_02.jpg) center center/contain no-repeat;
  width: 100%;
  max-width: 360px;
  height: 100%;
  max-height: 256px;
  right: calc(50% - min(34vw,580px));
  top: 0; }
  @media screen and (max-width: 991px) {
    .subMv_handy::after {
      width: 18rem;
      height: 12.5rem;
      top: 4.9rem;
      right: -2.6rem; } }

.subMv_form::after {
  position: absolute;
  content: "";
  background: url(../img/img-product-list/list_02.jpg) center center/contain no-repeat;
  width: 100%;
  max-width: 360px;
  height: 100%;
  max-height: 256px;
  right: calc(50% - min(34vw,580px));
  top: 0; }
  @media screen and (max-width: 991px) {
    .subMv_form::after {
      width: 18rem;
      height: 12.5rem;
      top: 4.9rem;
      right: -2.6rem; } }

.subMv_install {
  padding-bottom: 66px; }
  @media screen and (max-width: 991px) {
    .subMv_install {
      padding-bottom: 2.8rem; } }

.subMv_install::before {
  position: absolute;
  content: "";
  background: url(../img/img-option/list_01.png) center center/contain no-repeat;
  max-width: 180px;
  width: 100%;
  max-height: 200px;
  height: 100%;
  top: 76px;
  right: calc(50% - min(28vw,355px));
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .subMv_install::before {
      width: 6.8rem;
      height: 7.6rem;
      top: 7rem;
      right: 5.2rem; } }

.subMv_install::after {
  position: absolute;
  content: "";
  background: url(../img/img-product-list/list_02.jpg) center top/contain no-repeat;
  width: 100%;
  max-width: 360px;
  height: 100%;
  max-height: 256px;
  right: calc(50% - min(34vw,580px));
  top: 0; }
  @media screen and (max-width: 991px) {
    .subMv_install::after {
      width: 18rem;
      height: 12.5rem;
      top: 4.9rem;
      right: -2.6rem; } }

.subMv_guide {
  padding-bottom: 38px; }

.subMv_guide::before {
  position: absolute;
  content: "";
  background: url(../img/img-handy/list_01.png) center center/contain no-repeat;
  max-width: 211px;
  width: 17vw;
  max-height: 200px;
  height: 100%;
  top: 83px;
  right: calc(50% - min(45vw,565px));
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .subMv_guide::before {
      width: 8rem;
      height: 7.6rem;
      top: 7rem;
      right: 1.4rem; } }

.subMv_guide::after {
  position: absolute;
  content: "";
  background: url(../img/img-product-list/list_02.jpg) center top/contain no-repeat;
  width: 100%;
  max-width: 360px;
  height: 100%;
  max-height: 256px;
  right: calc(50% - min(580px,580px));
  top: 0; }
  @media screen and (max-width: 991px) {
    .subMv_guide::after {
      width: 18rem;
      height: 12.5rem;
      top: 4.9rem;
      right: -2.6rem; } }

/* ============================================================================
キャップバランサー
============================================================================== */
.cap {
  position: relative;
  padding-top: 110px;
  padding-bottom: 110px; }
  @media screen and (max-width: 991px) {
    .cap {
      padding-top: 3.9rem;
      padding-bottom: 2.7rem; } }

.cap::before {
  position: absolute;
  content: "";
  background: url(../img/img-feature/cap_txt.png) center center/contain no-repeat;
  width: 1360px;
  height: 416px;
  bottom: 25px;
  left: 52.5%;
  transform: translateX(-50%);
  z-index: -1; }
  @media screen and (max-width: 991px) {
    .cap::before {
      width: 30rem;
      height: 9.2rem;
      bottom: 7rem;
      left: 50%; } }

.cap_ttl {
  text-align: center;
  font-size: 4rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .cap_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .cap_ttl {
      font-size: 1.9rem;
      line-height: calc(55/38); } }

.cap_lead {
  font-weight: 900;
  text-align: center;
  font-size: 2.2rem;
  line-height: calc(40/22);
  letter-spacing: 0.1em;
  margin-top: 42px; }
  @media screen and (max-width: 991px) {
    .cap_lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .cap_lead {
      text-align: left;
      font-size: 1.2rem;
      line-height: calc(40/24);
      letter-spacing: 0.05em;
      margin-top: 1.8rem; } }

.cap_gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 56px;
  margin-top: 48px; }
  @media screen and (max-width: 991px) {
    .cap_gallery {
      gap: 0;
      margin-top: 1.6rem; } }

.cap_txt {
  font-size: 1.5rem;
  font-weight: 400;
  line-height: calc(25/15);
  letter-spacing: 0.1em;
  margin-top: 32px; }
  @media screen and (max-width: 991px) {
    .cap_txt {
      font-size: 1.1rem;
      line-height: calc(35/22);
      margin-top: 2rem; } }

/* ============================================================================
様々な設備に取付可能です
============================================================================== */
.cap2 {
  background-color: #e1efff;
  padding-top: 90px; }
  @media screen and (max-width: 991px) {
    .cap2 {
      padding-top: 3.8rem;
      padding-bottom: 4.2rem; } }

.cap2_txt {
  width: fit-content;
  font-size: 1.5rem;
  line-height: calc(21/15);
  font-weight: 400;
  letter-spacing: 0.1em;
  margin-inline: auto;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .cap2_txt {
      font-size: 1.1rem;
      line-height: calc(35/22);
      margin-top: 2rem; } }

.cap2_slider {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-top: 48px; }
  @media screen and (max-width: 991px) {
    .cap2_slider {
      margin-top: 3rem; } }

.cap2_slider_item {
  position: relative;
  margin: 0 20px;
  width: 338px; }
  @media screen and (max-width: 991px) {
    .cap2_slider_item {
      width: 18rem;
      margin: 0 1.5rem; } }

.cap2_slider picture {
  display: block; }

.cap2_slider_item span {
  position: absolute;
  color: #03356c;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: normal;
  bottom: -6px;
  left: 0px; }
  @media screen and (max-width: 991px) {
    .cap2_slider_item span {
      font-weight: 700;
      position: relative;
      font-size: 1.1rem;
      letter-spacing: 0.1em;
      display: block;
      bottom: 0;
      margin-top: -0.5rem; } }

.en .cap2_slider_item span {
  bottom: -26px; }
  @media screen and (max-width: 991px) {
    .en .cap2_slider_item span {
      bottom: 0; } }

.en .cap2_slider .slick-list {
  padding-bottom: 26px; }
  @media screen and (max-width: 991px) {
    .en .cap2_slider .slick-list {
      padding-bottom: 0; } }

/* ============================================================================
3つの改善
============================================================================== */
.improve {
  background-color: #03356c;
  padding-top: 90px; }
  @media screen and (max-width: 991px) {
    .improve {
      padding-top: 60px; } }

.improve_ttl {
  position: relative;
  text-align: center;
  color: #f38f2c;
  font-weight: 900;
  font-size: 4rem;
  line-height: calc(48/40);
  letter-spacing: 0.2em;
  width: fit-content;
  margin: 0 auto; }
  @media screen and (max-width: 991px) {
    .improve_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .improve_ttl {
      font-size: 2.2rem;
      padding-left: 7.6rem; } }
  .improve_ttl span {
    display: block;
    font-size: 2.8rem;
    color: white;
    margin-bottom: 20px; }
    @media screen and (max-width: 991px) {
      .improve_ttl span {
        font-size: 1.4rem;
        margin-bottom: 0.6rem;
        letter-spacing: 0.1em; } }

@media screen and (max-width: 991px) {
  .en .improve_ttl {
    font-size: 1.6rem; }
    .en .improve_ttl span {
      font-size: 1.2rem;
      margin-top: 0.6rem; } }

.improve_ttl::before {
  position: absolute;
  content: "";
  width: 140px;
  height: 111px;
  background: url(../img/img-feature/improve_01.png) center center/contain no-repeat;
  top: -10px;
  left: -168px; }
  @media screen and (max-width: 991px) {
    .improve_ttl::before {
      width: 7rem;
      height: 5.5rem;
      left: 0;
      top: initial;
      bottom: 0; } }

.improve_lists {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .improve_lists {
      grid-template-columns: 1fr;
      gap: 2rem;
      margin-top: 3rem; } }

.improve_list {
  position: relative;
  background-color: white;
  padding: 55px 24px 28px;
  border-radius: 5px; }
  @media screen and (max-width: 991px) {
    .improve_list {
      max-width: 23rem;
      margin-inline: auto;
      padding: 2.5rem 2rem 1.6rem; } }

.improve_tag {
  position: absolute;
  top: 0;
  left: 0;
  color: white;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: 1;
  background-color: #0071be;
  clip-path: polygon(0 0, 100% 0%, calc(100% - 20px) 100%, 0% 100%);
  padding: 6px 30px 8px 16px; }
  @media screen and (max-width: 991px) {
    .improve_tag {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .improve_tag {
      font-size: 0.9rem;
      padding: 0.5rem 1.5rem 0.5rem 0.5rem;
      clip-path: polygon(0 0, 100% 0%, calc(100% - 1rem) 100%, 0% 100%); } }
  .improve_tag span {
    font-size: 2.4rem; }
    @media screen and (max-width: 991px) {
      .improve_tag span {
        font-size: 1.3rem; } }

.improve_subttl {
  text-align: center;
  font-size: 2.6rem;
  font-weight: 900;
  line-height: calc(36/26);
  letter-spacing: 0.2em;
  color: #0071be; }
  @media screen and (max-width: 991px) {
    .improve_subttl {
      font-size: 1.6rem;
      font-weight: 700; } }

.en .improve_subttl {
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.1em;
  min-height: 10.8rem; }
  @media screen and (max-width: 991px) {
    .en .improve_subttl {
      min-height: auto; } }

.improve_icon {
  width: 72px;
  height: 73px;
  margin: 0 auto;
  margin-top: 12px; }
  @media screen and (max-width: 991px) {
    .improve_icon {
      width: 4.6rem;
      height: 4.6rem;
      margin-top: 1rem; } }
  .improve_icon img {
    object-fit: contain;
    max-height: 100%;
    max-width: 100%;
    object-position: center; }

.improve_txt {
  font-size: 1.4rem;
  font-weight: 900;
  line-height: calc(20/14);
  letter-spacing: 0.1em;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .improve_txt {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .improve_txt {
      font-size: 1.2rem;
      font-weight: 400;
      line-height: calc(34/24);
      letter-spacing: 0.05em; } }

.improve_movie {
  margin-top: 80px; }
  @media screen and (max-width: 991px) {
    .improve_movie {
      margin-top: 2.5rem; } }
  .improve_movie h3 {
    text-align: center;
    font-size: 2.5rem;
    font-weight: 900;
    line-height: calc(30/25);
    letter-spacing: 0.1em;
    color: white; }
    @media screen and (max-width: 991px) {
      .improve_movie h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .improve_movie h3 {
        font-size: 1.6rem;
        letter-spacing: 0.05em; } }

.improve_youtube {
  width: 720px;
  margin: 0 auto;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .improve_youtube {
      width: 100%;
      margin-top: 1.5rem; } }
  .improve_youtube iframe {
    aspect-ratio: 720/406;
    width: 100%;
    height: 100%; }

/* ============================================================================
カンテック製品の特徴
============================================================================== */
.feature {
  padding-top: 100px; }
  @media screen and (max-width: 991px) {
    .feature {
      padding-top: 4rem; } }

.feature_items {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .feature_items {
      margin-top: 2.5rem; } }

.feature_item {
  position: relative;
  display: grid;
  align-items: center;
  grid-template-columns: repeat(2, 1fr);
  padding-block: 60px;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .feature_item {
      grid-template-columns: 1fr;
      padding: 2.4rem 2rem; } }

.feature_item + .feature_item {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .feature_item + .feature_item {
      margin-top: 3rem; } }

.feature_item:nth-child(2) .feature_content {
  order: 1; }

.feature_content {
  margin: 0 30px; }
  @media screen and (max-width: 991px) {
    .feature_content {
      display: contents; } }
  .feature_content h3 {
    font-size: 3rem;
    font-weight: 900;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .feature_content h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .feature_content h3 {
        text-align: center;
        order: -2;
        letter-spacing: 0.15em;
        font-size: 1.7rem; } }
  .feature_content p {
    font-size: 1.5rem;
    font-weight: 400;
    line-height: calc(25/15);
    letter-spacing: 0.05em;
    margin-top: 32px; }
    @media screen and (max-width: 991px) {
      .feature_content p {
        font-size: 1.1rem;
        line-height: calc(35/22);
        margin-top: 1.5rem; } }
  .feature_content p + p {
    margin-top: 1em; }

.feature_btn {
  max-width: 220px;
  width: 100%;
  margin-inline: auto;
  margin-top: 28px; }
  .feature_btn a {
    background-color: transparent; }
  @media screen and (max-width: 991px) {
    .feature_btn {
      max-width: 15rem;
      margin-top: 2rem; } }

.feature_btn_en {
  max-width: 280px; }

.feature_img {
  text-align: center; }
  @media screen and (max-width: 991px) {
    .feature_img {
      order: -1;
      margin-top: 2rem; } }

.feature_gallery {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px 18px; }
  @media screen and (max-width: 991px) {
    .feature_gallery {
      order: -1;
      margin-top: 2rem;
      gap: 1rem; } }

.feature_gallery picture {
  display: block; }

.feature_gallery picture:nth-child(2) {
  margin-top: 75px; }
  @media screen and (max-width: 991px) {
    .feature_gallery picture:nth-child(2) {
      margin-top: 3.7rem; } }

.feature_gallery picture:nth-child(3) {
  margin-top: -85px; }
  @media screen and (max-width: 991px) {
    .feature_gallery picture:nth-child(3) {
      margin-top: -3.7rem; } }

/* ============================================================================
製品紹介
============================================================================== */
.product {
  background: url(../img/img-feature/bg_product.jpg) center center/cover no-repeat;
  padding-top: 80px; }
  @media screen and (max-width: 991px) {
    .product {
      background: url(../img/img-feature/bg_product_sp.jpg) center center/cover no-repeat;
      padding-top: 4rem; } }

.product_ttl h2 {
  color: white; }

.product_items {
  margin-top: 42px; }
  @media screen and (max-width: 991px) {
    .product_items {
      margin-top: 2rem; } }

.product_item {
  position: relative; }

.product_item + .product_item {
  margin-top: 50px; }

.product_img {
  position: relative;
  z-index: 1;
  display: block;
  max-width: 400px;
  transform: translateX(-10%); }
  @media screen and (max-width: 991px) {
    .product_img {
      max-width: 20rem;
      margin-inline: auto;
      transform: translateY(10%); } }
  .product_img img {
    max-width: 100%; }

.product_content {
  position: relative;
  max-width: 750px;
  background-color: white;
  margin-left: auto;
  margin-top: -350px;
  padding: 50px 45px 120px 250px; }
  @media screen and (max-width: 991px) {
    .product_content {
      max-width: 28rem;
      margin-inline: auto;
      margin-top: -10.5rem;
      padding: 12.5rem 2rem 2.5rem; } }

.product_item:nth-child(1) .product_content::before {
  position: absolute;
  content: "";
  background: url(../img/img-feature/product_03.png) center center/contain no-repeat;
  bottom: 0;
  left: 27px;
  width: 320px;
  height: 135px;
  z-index: 2; }
  @media screen and (max-width: 991px) {
    .product_item:nth-child(1) .product_content::before {
      width: 12.8rem;
      height: 5.2rem;
      left: 1.2rem;
      bottom: 9.5rem; } }

.product_item:nth-child(2) .product_content::before {
  position: absolute;
  content: "";
  background: url(../img/img-feature/product_06.png) center center/contain no-repeat;
  bottom: 0;
  left: 27px;
  width: 320px;
  height: 188px;
  z-index: 2; }
  @media screen and (max-width: 991px) {
    .product_item:nth-child(2) .product_content::before {
      width: 12.8rem;
      height: 7.5rem;
      bottom: 8.2rem;
      left: 1.6rem; } }

.product_subttl {
  font-size: 3rem;
  font-weight: 900;
  color: #03356c;
  letter-spacing: 0.05em;
  line-height: calc(40/30);
  margin-bottom: 20px; }
  @media screen and (max-width: 991px) {
    .product_subttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .product_subttl {
      text-align: center;
      font-size: 1.7rem;
      line-height: calc(45/34);
      margin-bottom: 1rem; } }

.product_txt {
  margin-top: 5px; }
  @media screen and (max-width: 991px) {
    .product_txt {
      margin-top: 1.5rem; } }

.product_txt_en {
  width: 60%; }

.product_txt p {
  font-size: 1.5rem;
  font-weight: 400;
  line-height: calc(25/15);
  letter-spacing: 0.05em; }
  .product_txt p small {
    display: block;
    font-size: 1.3rem;
    line-height: calc(20/13); }
    @media screen and (max-width: 991px) {
      .product_txt p small {
        font-size: 1rem;
        line-height: calc(25/20); } }
  @media screen and (max-width: 991px) {
    .product_txt p {
      font-size: 1.1rem;
      line-height: calc(35/22); } }

.product_txt p + p {
  margin-top: 1em; }

.product_list {
  background-color: rgba(0, 113, 190, 0.1);
  padding: 21px 26px 26px;
  border-radius: 5px;
  margin-top: 10px; }
  @media screen and (max-width: 991px) {
    .product_list {
      border-radius: 0.25rem;
      padding: 1.3rem 1.7rem;
      margin-top: 1.3rem; } }
  .product_list h3 {
    text-align: center;
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .product_list h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .product_list h3 {
        font-size: 1.4rem; } }
  .product_list ul {
    margin-top: 18px; }
    @media screen and (max-width: 991px) {
      .product_list ul {
        margin-top: 1.4rem; } }
  .product_list li {
    position: relative;
    font-size: 1.5rem;
    font-weight: 900;
    line-height: 2;
    letter-spacing: 0.05em;
    padding-left: 1em; }
    @media screen and (max-width: 991px) {
      .product_list li {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .product_list li {
        font-size: 1.1rem;
        line-height: calc(35/22); } }
  .product_list li::before {
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: #284b8a;
    left: 0;
    top: 50%;
    transform: translateY(-50%); }
    @media screen and (max-width: 991px) {
      .product_list li::before {
        width: 0.5rem;
        height: 0.5rem;
        top: 0.5rem;
        transform: translateY(0); } }

.en .product_list li::before {
  top: 12px;
  transform: translateY(0); }
  @media screen and (max-width: 991px) {
    .en .product_list li::before {
      top: 0.5rem; } }

.product_list + .product_txt {
  padding-inline: 12px; }
  @media screen and (max-width: 991px) {
    .product_list + .product_txt {
      padding: 0; } }

.product_btn {
  max-width: 200px;
  width: 100%;
  margin-top: 28px;
  margin-left: 30px; }
  @media screen and (max-width: 991px) {
    .product_btn {
      max-width: 15rem;
      margin-inline: auto;
      margin-top: 5.8rem; } }

.product_btn_en {
  max-width: fit-content;
  margin-left: 0; }

.product_btn_en a {
  font-size: 1.1rem; }

.product_img2 {
  position: absolute; }
  .product_img2 img {
    max-width: 100%; }

.product_item:nth-child(1) .product_img2 {
  width: 224px;
  right: 35px;
  bottom: 30px; }
  @media screen and (max-width: 991px) {
    .product_item:nth-child(1) .product_img2 {
      width: 11.5rem;
      right: 1.5rem;
      bottom: 7rem; } }

.product_item:nth-child(1) .product_img2_en {
  width: 160px; }
  @media screen and (max-width: 991px) {
    .product_item:nth-child(1) .product_img2_en {
      width: 150px;
      bottom: 8rem; } }

.product_item:nth-child(2) .product_img2 {
  width: 244px;
  right: -4px;
  bottom: 16px; }
  @media screen and (max-width: 991px) {
    .product_item:nth-child(2) .product_img2 {
      width: 12.2rem;
      right: 1.15rem;
      bottom: 7.8rem; } }

.product_btn2 {
  max-width: 300px;
  width: 100%;
  margin-inline: auto;
  margin-top: 48px; }
  @media screen and (max-width: 991px) {
    .product_btn2 {
      max-width: 12.5rem;
      margin-top: 2.5rem; } }

/* ============================================================================
導入事例
============================================================================== */
.case {
  background-color: #e1efff;
  overflow: hidden; }

@media screen and (max-width: 991px) {
  .case_lead {
    margin-top: 2rem; } }

.case_slider {
  max-width: 1090px;
  margin-inline: auto;
  margin-top: 70px; }
  @media screen and (max-width: 991px) {
    .case_slider {
      max-width: 32rem;
      margin-top: 1.2rem; } }

.case_slider .slick-list {
  overflow: unset; }
  @media screen and (max-width: 991px) {
    .case_slider .slick-list {
      overflow: hidden; } }

.case_card {
  position: relative;
  display: grid !important;
  grid-template-columns: 45.125% 1fr;
  align-items: flex-end;
  gap: 5rem;
  width: 960px;
  background-color: white;
  border-radius: 12px;
  padding: 70px 38px 70px 45px;
  transform-origin: bottom right;
  margin: 0 65px;
  transition: all 0.5s; }
  @media screen and (max-width: 991px) {
    .case_card {
      width: 25rem;
      width: 77.33vw;
      gap: 0;
      grid-template-columns: 1fr;
      margin: 0 1.5rem;
      padding: 4.6rem 2rem 1.25rem; } }

.case_card:not(.slick-center) {
  transform: scale(0.795); }
  @media screen and (max-width: 991px) {
    .case_card:not(.slick-center) {
      transform: scale(1); } }

.case_card.slick-center + .case_card {
  transform-origin: bottom left; }

.case_tag {
  position: absolute;
  font-size: 1.8rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.1em;
  color: white;
  background-color: #03356c;
  border-radius: 0 20px 20px 0;
  padding: 10px 28px;
  top: 31px;
  left: 0; }
  @media screen and (max-width: 991px) {
    .case_tag {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .case_tag {
      font-size: 1.1rem;
      line-height: calc(28/22);
      border-radius: 0 1rem 1rem 0;
      padding: 0.5rem 1.3rem;
      top: 1rem; } }

@media screen and (max-width: 991px) {
  .case_img {
    display: block;
    margin-top: 1.5rem; } }

.case_img_en {
  height: 80%; }
  @media screen and (max-width: 991px) {
    .case_img_en {
      height: 90%; } }

.case_img img {
  width: 100%; }
  @media screen and (max-width: 991px) {
    .case_img img {
      height: 100%;
      object-fit: cover; } }

@media screen and (max-width: 991px) {
  .case_content {
    display: contents; } }

.case_head {
  font-size: 2.6rem;
  font-weight: 900;
  color: #03356c;
  line-height: calc(40/26);
  letter-spacing: 0.15em; }
  @media screen and (max-width: 991px) {
    .case_head {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .case_head {
      order: -1;
      font-size: 1.4rem;
      line-height: calc(40/28);
      letter-spacing: 0.1em; } }

.case_head_en {
  font-size: 2rem;
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .case_head_en {
      font-size: 1.6rem; } }

.case_wrap {
  display: grid;
  align-items: center;
  grid-template-columns: 1fr 12rem;
  gap: 1.2rem;
  margin-top: -34px; }
  @media screen and (max-width: 991px) {
    .case_wrap {
      width: calc(100% + 1.1rem);
      grid-template-columns: 1fr 6rem;
      gap: 1rem;
      margin-top: -1rem; } }

@media screen and (max-width: 991px) {
  .en .case_wrap {
    margin-top: 1rem; } }

.case_head2 {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 900;
  line-height: calc(28/15);
  letter-spacing: 0.05em;
  color: #03356c;
  background-color: #b8defa;
  padding-inline: 14px 4px;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .case_head2 {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .case_head2 {
      text-align: center;
      font-size: 1.1rem;
      line-height: calc(28/22);
      padding: 0.5rem 0.2rem; } }

.case_head2_en {
  font-size: 1.2rem;
  line-height: 1.45;
  padding-block: 6px; }

.case_txt {
  font-size: 1.5rem;
  line-height: calc(25/15);
  letter-spacing: 0.1em;
  font-weight: 400;
  padding-right: 40px;
  margin-top: 8px; }
  @media screen and (max-width: 991px) {
    .case_txt {
      padding: 0;
      font-size: 1.1rem;
      line-height: calc(35/22);
      margin-top: 1.6rem; } }

.case .slide-arrow {
  position: absolute;
  top: 50%;
  width: 50px;
  height: 50px;
  transform: translateY(-50%);
  cursor: pointer;
  transition: all 0.3s;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .case .slide-arrow {
      display: grid;
      place-items: center;
      color: #03356c;
      font-size: 2.6rem;
      width: 3rem;
      height: 3rem; } }

.case .slide-arrow:hover {
  opacity: 0.8; }

.case .prev-arrow {
  left: -2.5rem;
  background: url(../img/img-common/arrow_prev.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .case .prev-arrow {
      left: -1.525rem;
      background: none; } }

.case .next-arrow {
  right: -2.5rem;
  background: url(../img/img-common/arrow_next.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .case .next-arrow {
      right: -1.525rem;
      background: none; } }

.slick-dotted.slick-slider {
  margin-bottom: 0; }

/* ============================================================================
開発・技術・設計
============================================================================== */
.bg {
  background-color: #fff;
  background-image: radial-gradient(#f7f7f7 2px, transparent 2px);
  background-size: 20px 20px;
  padding-bottom: 270px; }
  @media screen and (max-width: 991px) {
    .bg {
      background-size: 1rem 1rem;
      background-image: radial-gradient(#f7f7f7 0.1rem, transparent 0.1rem);
      padding-bottom: 4rem; } }

.bg_items {
  max-width: 865px;
  margin-inline: auto;
  margin-top: 48px; }
  @media screen and (max-width: 991px) {
    .bg_items {
      margin-top: 2.3rem; } }

.bg_item {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6.2rem;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .bg_item {
      grid-template-columns: 1fr;
      gap: 0; } }

.bg_item:nth-child(1)::before {
  position: absolute;
  content: "STORY";
  font-size: 8rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  color: #03356c;
  opacity: 0.08;
  z-index: -1;
  left: 140px;
  top: 92px; }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(1)::before {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(1)::before {
      font-size: 3rem;
      top: 4.65rem;
      left: initial;
      right: 0; } }

.bg_item:nth-child(2)::before {
  position: absolute;
  content: "TECNOLOGY";
  font-size: 7rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  color: #03356c;
  opacity: 0.08;
  z-index: -1;
  right: -3.5rem;
  top: 102px; }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(2)::before {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(2)::before {
      font-size: 3rem;
      right: 0;
      top: 5rem; } }

@media screen and (max-width: 991px) {
  .bg_item:nth-child(2)::after {
    position: absolute;
    content: "";
    width: 15rem;
    height: 26.2rem;
    background: url(../img/img-feature/bg_02_sp_2.png) center center/contain no-repeat;
    right: 0;
    bottom: -4.4rem;
    z-index: -1; } }

.bg_item:nth-child(3)::before {
  position: absolute;
  content: "DESIGN\APRODUCTION";
  font-size: 5rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: calc(45/50);
  white-space: pre;
  color: #03356c;
  opacity: 0.08;
  z-index: -1;
  left: 80px;
  top: 102px; }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(3)::before {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(3)::before {
      font-size: 2.5rem;
      line-height: 1;
      top: 3.5rem;
      left: initial;
      right: 0; } }

.bg_item:nth-child(4)::before {
  position: absolute;
  content: "QUALITY\AMANAGEMENT";
  white-space: pre;
  font-size: 5rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: calc(45/50);
  color: #03356c;
  opacity: 0.08;
  z-index: -1;
  right: -1.6rem;
  top: 106px; }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(4)::before {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(4)::before {
      font-size: 2.5rem;
      line-height: 1;
      top: 3.5rem;
      left: initial;
      right: 0; } }

.bg_item + .bg_item {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .bg_item + .bg_item {
      margin-top: 3.8rem; } }

@media screen and (max-width: 991px) {
  .bg_content {
    display: contents; } }

.bg_head {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1.4rem;
  font-size: 1.6rem;
  font-weight: 900;
  line-height: calc(24/16);
  letter-spacing: 0.2em;
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .bg_head {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_head {
      font-size: 1rem;
      gap: 0.5rem;
      line-height: calc(24/20); } }

.bg_head::before {
  display: inline-block;
  content: "";
  background: url(../img/img-common/icon.png) center center/contain no-repeat;
  width: 2.4rem;
  height: 2.4rem; }
  @media screen and (max-width: 991px) {
    .bg_head::before {
      width: 1.5rem;
      height: 1.5rem; } }

.bg_lead {
  color: #03356c;
  font-size: 2.6rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  line-height: calc(40/26);
  font-feature-settings: "palt";
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .bg_lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_lead {
      font-size: 1.7rem;
      line-height: calc(50/34);
      letter-spacing: 0.1em;
      width: fit-content;
      margin-left: 2.5rem;
      margin-top: 0.7rem; } }

@media screen and (max-width: 991px) {
  .en .bg_lead {
    margin-left: 1.5rem; } }

.bg_lead_en {
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .bg_lead_en {
      letter-spacing: 0.05em; } }

.bg_lead span {
  display: inline-block; }

.bg_txt {
  text-align: justify;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: calc(25/14);
  letter-spacing: 0.05em;
  margin-top: 52px; }
  @media screen and (max-width: 991px) {
    .bg_txt {
      font-size: 1.1rem;
      line-height: calc(35/22);
      order: 1;
      margin-top: 2rem; } }

@media screen and (max-width: 991px) {
  .en .bg_txt {
    letter-spacing: 0.01em; } }

.bg_item:nth-child(even) .bg_img {
  order: -1; }
  @media screen and (max-width: 991px) {
    .bg_item:nth-child(even) .bg_img {
      order: initial; } }

@media screen and (max-width: 991px) {
  .bg_img {
    display: block;
    max-width: 25rem;
    margin-inline: auto;
    margin-top: 2.6rem; } }

.bg_img img {
  display: inline-block;
  max-width: 100%; }

@media screen and (max-width: 991px) {
  .bg_list {
    order: 2; } }

.bg_list li {
  position: relative;
  font-weight: 400;
  font-size: 1.4rem;
  line-height: calc(20/14);
  letter-spacing: 0.05em;
  padding-left: 1.8rem; }
  @media screen and (max-width: 991px) {
    .bg_list li {
      font-size: 1.1rem;
      line-height: calc(35/22);
      padding-left: 1em; } }

.bg_list li + li {
  margin-top: 4px; }

.bg_list li::before {
  position: absolute;
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  background-color: #03356c;
  top: 0.7rem;
  border-radius: 50%;
  left: 0; }
  @media screen and (max-width: 991px) {
    .bg_list li::before {
      width: 0.5rem;
      height: 0.5rem;
      top: 0.5rem; } }

.bg_list2 {
  margin-left: 12px;
  margin-top: 18px; }
  @media screen and (max-width: 991px) {
    .bg_list2 {
      order: 2;
      margin-top: 1rem; } }

.bg_list2 li {
  font-size: 1.4rem;
  font-weight: 900;
  line-height: calc(24/14);
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .bg_list2 li {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_list2 li {
      font-size: 1rem;
      line-height: 1.5; } }

.bg_list2 li:first-child {
  font-weight: 900;
  font-size: 1.6rem;
  line-height: calc(24/16);
  color: #03356c;
  letter-spacing: 0.2em; }
  @media screen and (max-width: 991px) {
    .bg_list2 li:first-child {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .bg_list2 li:first-child {
      font-size: 1.2rem; } }

.bg_list2 + .bg_list2 {
  margin-top: 18px; }

/* ============================================================================
キャップバランサーとは
============================================================================== */
.productAbout {
  position: relative;
  z-index: 1;
  background: linear-gradient(transparent 70px, #edf4f6 70px);
  padding-top: 0px;
  margin-top: -90px; }
  @media screen and (max-width: 991px) {
    .productAbout {
      background: linear-gradient(transparent 3.8rem, #edf4f6 3.8rem);
      margin-top: -3.8rem; } }

.productAbout_handy {
  background: linear-gradient(transparent 76px, #edf4f6 76px);
  margin-top: -84px; }
  @media screen and (max-width: 991px) {
    .productAbout_handy {
      background: linear-gradient(transparent 6.4rem, #edf4f6 6.4rem);
      margin-top: -6.3rem; } }

.productAbout_gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px; }
  @media screen and (max-width: 991px) {
    .productAbout_gallery {
      max-width: 24.3rem;
      margin: 0 auto;
      gap: 2rem;
      grid-template-columns: 1fr; } }

.productAbout_gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover; }

.productAbout_youtube iframe {
  aspect-ratio: 520/254;
  height: 100%;
  width: 100%; }

.productAbout_items {
  margin-top: 64px; }
  @media screen and (max-width: 991px) {
    .productAbout_items {
      margin-top: 4.6rem; } }

.productAbout_item {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 28px; }
  @media screen and (max-width: 991px) {
    .productAbout_item {
      grid-template-columns: 1fr;
      gap: 0; } }

.productAbout_item + .productAbout_item {
  margin-top: 42px; }
  @media screen and (max-width: 991px) {
    .productAbout_item + .productAbout_item {
      margin-top: 3.5rem; } }

@media screen and (max-width: 991px) {
  .productAbout_content {
    display: contents; } }
.productAbout_content h3 {
  position: relative;
  font-size: 2.4rem;
  font-weight: 900;
  line-height: 1;
  color: #03356c;
  letter-spacing: 0.05em;
  padding-bottom: 18px; }
  @media screen and (max-width: 991px) {
    .productAbout_content h3 {
      order: -2;
      font-weight: 700;
      font-size: 1.4rem;
      line-height: 1.25;
      padding-bottom: 1rem; } }
.productAbout_content h3::before {
  position: absolute;
  content: "";
  width: calc(100% + 50px);
  left: 0;
  bottom: 0;
  background-color: #03346a;
  opacity: 0.55;
  height: 1px; }
.productAbout_content p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(25/16);
  letter-spacing: 0.05em;
  margin-top: 16px; }
  @media screen and (max-width: 991px) {
    .productAbout_content p {
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.1em;
      margin-top: 1.2rem; } }

.productAbout_content_wide {
  grid-column: 1/3; }

.productAbout_img {
  position: relative;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .productAbout_img {
      max-width: 25rem;
      margin: 0 auto;
      order: -1;
      margin-top: 1.5rem; } }

.productAbout_img_1 {
  display: block; }

.productAbout_lists {
  margin-top: 18px;
  counter-reset: number 0; }
  @media screen and (max-width: 991px) {
    .productAbout_lists {
      margin-top: 1.6rem; } }

.productAbout_list {
  position: relative;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(26/16);
  letter-spacing: 0.05em;
  padding-left: 30px; }
  @media screen and (max-width: 991px) {
    .productAbout_list {
      font-size: 1.1rem;
      line-height: calc(30/22);
      padding-left: 2rem; } }
  .productAbout_list small {
    display: inline-block;
    font-size: 1.3rem; }
    @media screen and (max-width: 991px) {
      .productAbout_list small {
        font-size: 1rem;
        line-height: calc(25/20);
        margin-top: 0.6rem; } }

.productAbout_list + .productAbout_list {
  margin-top: 10px; }

.productAbout_list::before {
  position: absolute;
  content: counter(number) ".";
  counter-increment: number 1;
  left: 0;
  top: -10px;
  font-size: 2.6rem;
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0.075em;
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .productAbout_list::before {
      font-size: 1.8rem;
      top: -0.6rem; } }

.productAbout_lsit2 {
  position: relative;
  font-size: 1.5rem;
  line-height: calc(25/15);
  letter-spacing: 0.05em;
  padding-left: 1em; }
  @media screen and (max-width: 991px) {
    .productAbout_lsit2 {
      font-size: 1rem;
      line-height: 1.5; } }

.productAbout_lsit2::before {
  position: absolute;
  content: "";
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  background-color: #03356c;
  width: 6px;
  height: 6px; }
  @media screen and (max-width: 991px) {
    .productAbout_lsit2::before {
      width: 0.4rem;
      height: 0.4rem; } }

/* ============================================================================
導入実績
============================================================================== */
.productCase {
  position: relative;
  background-color: #03346a;
  padding-top: 78px;
  padding-bottom: 108px; }
  @media screen and (max-width: 991px) {
    .productCase {
      padding-top: 4rem;
      padding-bottom: 4rem; } }

.productCase::before {
  position: absolute;
  content: "";
  background: url(../img/img-freestop/bg_case.png) center center/contain no-repeat;
  width: 28.07vw;
  height: 28.385vw;
  top: -4.43vw;
  left: 5.2vw; }
  @media screen and (max-width: 991px) {
    .productCase::before {
      width: 13.5rem;
      height: 13.6rem;
      left: -2.8rem;
      top: -2.3rem; } }

.productCase_ttl {
  position: relative;
  z-index: 1;
  width: fit-content; }
  .productCase_ttl h2 {
    color: white; }

.en .productCase_ttl {
  text-shadow: 0 0 3px black; }

.productCase_img {
  position: absolute;
  width: 26vw;
  right: calc(50% - min(35vw,672px));
  top: 3.125vw; }
  @media screen and (max-width: 991px) {
    .productCase_img {
      width: 61.86vw;
      top: 2rem;
      right: -13.86vw; } }

.productCase_img img {
  width: 100%; }

.productCase_txt {
  position: relative;
  z-index: 1;
  color: white;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: calc(25/15);
  letter-spacing: 0.1em;
  margin-top: 32px; }
  @media screen and (max-width: 991px) {
    .productCase_txt {
      font-size: 1.2rem;
      line-height: calc(35/24); } }

.en .productCase_txt {
  text-shadow: 0 0 3px black; }

.productCase_lists {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  transform: skewX(20deg);
  margin-top: 38px;
  gap: 16px;
  width: fit-content;
  margin-left: 28px; }
  @media screen and (max-width: 991px) {
    .productCase_lists {
      margin-top: 1rem;
      gap: 0.8rem;
      transform: skewX(10deg);
      transform-origin: top left;
      margin-left: 0; } }

.productCase_list {
  width: 340px;
  color: #03356c;
  background-color: rgba(255, 255, 255, 0.8);
  font-size: 2rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.2em;
  padding-block: 16px;
  text-align: center; }
  @media screen and (max-width: 991px) {
    .productCase_list {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productCase_list {
      width: 12rem;
      font-size: 1.1rem;
      letter-spacing: 0.05em;
      padding-block: 0.75rem; } }

.en .productCase_list {
  display: flex;
  font-size: 1.8rem;
  align-items: center;
  justify-content: center;
  letter-spacing: normal; }
  @media screen and (max-width: 991px) {
    .en .productCase_list {
      font-size: 1.1rem; } }

@media screen and (max-width: 991px) {
  .productCase_handy .productCase_list:nth-child(1) {
    letter-spacing: -0.15em; } }

@media screen and (max-width: 991px) {
  .en .productCase_handy .productCase_list:nth-child(1) {
    letter-spacing: normal; } }

.productCase_list span {
  display: inline-block;
  transform: skewX(-20deg); }
  @media screen and (max-width: 991px) {
    .productCase_list span {
      transform: skewX(-10deg); } }

.productCase_items {
  margin-top: 66px; }
  @media screen and (max-width: 991px) {
    .productCase_items {
      margin-top: 4rem; } }

.productCase_item {
  position: relative;
  background-color: white;
  padding: 46px 60px 44px 60px;
  border-radius: 10px;
  display: grid;
  grid-template-columns: 345px 1fr;
  gap: 28px 36px; }
  @media screen and (max-width: 991px) {
    .productCase_item {
      display: block;
      padding: 2.5rem 1.5rem 2.2rem; } }

.productCase_item + .productCase_item {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .productCase_item + .productCase_item {
      margin-top: 3rem; } }

.productCase_number {
  position: absolute;
  letter-spacing: 0.1em;
  line-height: 1;
  font-size: 1.8rem;
  font-weight: 900;
  font-family: "Century Gothic", sans-serif;
  color: #a3adbe;
  left: 60px;
  top: -20px; }
  @media screen and (max-width: 991px) {
    .productCase_number {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productCase_number {
      font-size: 1.1rem;
      left: 1.5rem;
      top: -1rem; } }
  .productCase_number span {
    display: inline-block;
    font-size: 5rem;
    font-weight: normal;
    letter-spacing: normal; }
    @media screen and (max-width: 991px) {
      .productCase_number span {
        font-size: 2.7rem; } }

.productCase_item_ttl {
  grid-column: 1/3;
  font-size: 2.2rem;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .productCase_item_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productCase_item_ttl {
      display: grid;
      align-items: flex-start;
      grid-template-columns: 5.5rem 1fr;
      gap: 1rem;
      font-size: 1.4rem;
      line-height: calc(35/28); } }
  .productCase_item_ttl span {
    display: inline-block;
    padding: 6px 10px;
    font-size: 1.6rem;
    font-weight: 900;
    letter-spacing: 0.15em;
    color: white;
    background-color: #03356c;
    margin-right: 20px; }
    @media screen and (max-width: 991px) {
      .productCase_item_ttl span {
        font-size: 1rem;
        padding: 0.5rem 0.4rem;
        margin-right: 0;
        font-weight: 700; } }

.en .productCase_item_ttl {
  white-space: initial;
  line-height: 1.25; }
  @media screen and (max-width: 991px) {
    .en .productCase_item_ttl {
      display: flex;
      flex-wrap: wrap; } }
  .en .productCase_item_ttl span {
    margin-bottom: 0.5rem; }
    @media screen and (max-width: 991px) {
      .en .productCase_item_ttl span {
        margin-bottom: 0; } }

@media screen and (max-width: 991px) {
  .productCase_item_img {
    display: block;
    margin-top: 1.3rem; } }

.productCase_item_text {
  text-align: justify;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .productCase_item_text {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-top: 1.4rem; } }
  .productCase_item_text strong {
    font-weight: 900;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .productCase_item_text strong {
        font-weight: 700; } }
  .productType_option_content strong {
    font-weight: 900;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .productType_option_content strong {
        font-weight: 700; } }

/* ============================================================================
製品情報
============================================================================== */
.productType {
  background-color: #f1f8fe;
  padding-top: 78px; }
  @media screen and (max-width: 991px) {
    .productType {
      padding-top: 3.8rem; } }

.productType_standard {
  background-color: #edf4f6; }

.productType_handy {
  background-color: #edf4f6; }

.productType_head {
  text-align: center;
  margin-top: 40px; }
  @media screen and (max-width: 991px) {
    .productType_head {
      margin-top: 2.6rem; } }
  .productType_head h3 {
    font-size: 2.5rem;
    font-weight: 900;
    letter-spacing: 0.1em; }
    @media screen and (max-width: 991px) {
      .productType_head h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productType_head h3 {
        font-size: 1.3rem;
        letter-spacing: 0.05em; } }
    .productType_head h3 span {
      display: block;
      font-size: 1.5rem;
      font-weight: 400;
      letter-spacing: 0.05em; }
      @media screen and (max-width: 991px) {
        .productType_head h3 span {
          font-size: 1rem; } }
  .productType_head > p {
    font-size: 1.6rem;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: calc(25/16);
    margin-top: 22px; }
    @media screen and (max-width: 991px) {
      .productType_head > p {
        text-align: left;
        font-size: 1.1rem;
        line-height: calc(30/22); } }

.productType_btn {
  width: fit-content;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px;
  margin-inline: auto;
  margin-top: 40px; }
  @media screen and (max-width: 991px) {
    .productType_btn {
      width: 100%;
      gap: 2rem;
      margin-top: 1.8rem; } }

.productType_btn_4 {
  max-width: 960px;
  width: 100%;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-inline: auto;
  margin-bottom: 50px;}
  @media screen and (max-width: 991px) {
    .productType_btn_4 {
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem; 
      margin-bottom: 3rem;} }

.productType_btn li {
  position: relative;
  max-width: 320px;
  width: 100%;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .productType_btn li {
      width: 100%; } }

.productType_btn li:hover {
  opacity: 0.8; }

.productType_btn li::before {
  position: absolute;
  content: "";
  background: url(../img/img-freestop/cap_white_icon.png) center center/contain no-repeat;
  width: 100px;
  height: 100px;
  left: 2px;
  top: -20px;
  pointer-events: none; }
  @media screen and (max-width: 991px) {
    .productType_btn li::before {
      width: 5rem;
      height: 5rem;
      left: 0.3rem;
      top: -1rem; } }

.productType_btn li::after {
  position: absolute;
  content: "<";
  font-size: 1.5rem;
  line-height: 1;
  color: white;
  left: 50%;
  transform: translateX(-50%) rotate(-90deg);
  font-family: "Hiragino Sans W6", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W6", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  bottom: 8px;
  pointer-events: none; }
  @media screen and (max-width: 991px) {
    .productType_btn li::after {
      font-size: 1rem; } }

.productType_btn li a {
  display: block;
  padding: 14px 26px 28px;
  border-radius: 12px;
  height: 100%;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .productType_btn li a {
      padding: 0.9rem 0.7rem 2rem; } }

.productType_btn li:nth-child(1) a {
  background-color: #276bb6; }

.productType_btn li:nth-child(2) a {
  background-color: #1c5390; }

.productType_btn li:nth-child(3) a {
  background-color: #205da0; }

.productType_btn li:nth-child(4) a {
  background-color: #1c5390; }

.productType_btn_4 li:nth-child(2) a {
  background-color: #2463a8; }

.productType_btn li p:nth-child(1) {
  text-align: center;
  color: white;
  font-size: 3.4rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.2em;
  padding-bottom: 11px;
  border-bottom: 1px solid white; }

.en .productType_btn li p:nth-child(1)  {
  font-size: 3.2rem;
}
  @media screen and (max-width: 991px) {
    .productType_btn li p:nth-child(1) {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productType_btn li p:nth-child(1) {
      font-size: 1.7rem;
      padding-bottom: 0.6rem; } }

.productType_btn li p:nth-child(2) {
  text-align: center;
  color: white;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: calc(20/16);
  margin-top: 11px; }
  @media screen and (max-width: 991px) {
    .productType_btn li p:nth-child(2) {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productType_btn li p:nth-child(2) {
      font-size: 1rem;
      line-height: calc(28/20);
      margin-top: 0.6rem; } }

.productType_units {
  margin-top: 65px; }
  @media screen and (max-width: 991px) {
    .productType_units {
      margin-top: 3rem; } }

.productType_unit {
  position: relative;
  background-color: white;
  padding: 50px 50px 70px; }
  @media screen and (max-width: 991px) {
    .productType_unit {
      padding: 2.5rem 1.35rem 3.6rem; } }

.productType_unit::before {
  position: absolute;
  content: "";
  width: 90px;
  height: 90px;
  background: url(../img/img-freestop/cap_blue_icon.png) center center/contain no-repeat;
  top: 28px;
  left: 28px; }
  @media screen and (max-width: 991px) {
    .productType_unit::before {
      width: 4.5rem;
      height: 4.5rem;
      top: 1rem;
      left: 0.5rem; } }

.productType_unit + .productType_unit {
  margin-top: 86px; }
  @media screen and (max-width: 991px) {
    .productType_unit + .productType_unit {
      margin-top: 4rem; } }

.productType_unit_ttl {
  font-size: 4rem;
  font-weight: 900;
  letter-spacing: 0.2em;
  line-height: calc(36/40);
  color: #276bb6;
  padding-bottom: 30px;
  padding-left: 38px;
  border-bottom: 1px solid rgba(0, 113, 190, 0.55); }
  @media screen and (max-width: 991px) {
    .productType_unit_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productType_unit_ttl {
      font-size: 2rem;
      padding-left: 1rem;
      padding-bottom: 1rem; } }
  .productType_unit_ttl span {
    display: block;
    color: #333;
    font-size: 1.8rem;
    font-weight: 900;
    line-height: calc(21/18);
    letter-spacing: 0.1em;
    margin-bottom: 12px; }
    @media screen and (max-width: 991px) {
      .productType_unit_ttl span {
        font-size: 1rem;
        font-weight: 700; } }

  .productType_unit_ttl em.release {
    color: red;
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.1em;}
    @media screen and (max-width: 991px) {
      .productType_unit_ttl em.release {
        font-size: 1rem;
        font-weight: 700; } }

@media screen and (max-width: 991px) {
  .en .productType_unit_ttl {
    font-size: 1.6rem; } }

.productType_unit:nth-child(2) .productType_unit_ttl {
  color: #1c5390; }

.productType_handy .productType_unit:nth-child(1) .productType_unit_ttl {
  color: #03356c; }

.productType_standard .productType_unit:nth-child(1) .productType_unit_ttl {
  color: #276bb6; }

.productType_standard .productType_unit:nth-child(2) .productType_unit_ttl {
  color: #2463a8; }

.productType_standard .productType_unit:nth-child(3) .productType_unit_ttl {
  color: #205da0; }

.productType_standard .productType_unit:nth-child(4) .productType_unit_ttl {
  color: #1c5390; }

.productType_gallery {
  display: grid;
  grid-template-columns: 1fr 465px;
  width: calc(100% - 92px);
  margin-inline: auto;
  margin-top: 38px; }
  @media screen and (max-width: 991px) {
    .productType_gallery {
      width: 100%;
      display: block;
      margin-top: 1.4rem; } }

.productType_gallery > picture:nth-child(1) {
  display: block; }
  @media screen and (max-width: 991px) {
    .productType_gallery > picture:nth-child(1) {
      width: 20rem;
      margin: 0 auto; } }

.productType_gallery picture:nth-child(2) {
  display: block; }
  @media screen and (max-width: 991px) {
    .productType_gallery picture:nth-child(2) {
      width: 24rem;
      margin-inline: auto;
      margin-top: 0.8rem;
      margin-bottom: 2.2rem; } }

.productType_handy .productType_gallery > picture:nth-child(1) {
  display: block;
  text-align: center; }

.productType_handy .productType_gallery > picture:nth-child(2) {
  text-align: center;
  display: block; }
  @media screen and (max-width: 991px) {
    .productType_handy .productType_gallery > picture:nth-child(2) {
      width: 20rem;
      margin: 0 auto;
      margin-top: 2rem; } }

.productType_gallery picture:nth-child(3) {
  display: block;
  text-align: center;
  margin-top: 40px;
  grid-column: 1/3; }
  @media screen and (max-width: 991px) {
    .productType_gallery picture:nth-child(3) {
      margin-top: 2rem; } }
  .productType_gallery picture:nth-child(3) img {
    max-width: 598px; }
    @media screen and (max-width: 991px) {
      .productType_gallery picture:nth-child(3) img {
        max-width: 100%; } }

.productType_option {
  position: relative;
  grid-column: 1/3;
  margin-top: -52px; }
  @media screen and (max-width: 991px) {
    .productType_option {
      margin-top: 0; } }
  .productType_option picture {
    position: relative;
    z-index: 1; }
    @media screen and (max-width: 991px) {
      .productType_option picture {
        display: block;
        width: 12.6rem; } }

.productType_option_content {
  width: 450px;
  background-color: #f1f8fe;
  border-radius: 12px;
  padding: 38px 34px 46px 126px;
  margin-left: 168px;
  margin-top: -156px; }
  @media screen and (max-width: 991px) {
    .productType_option_content {
      width: 100%;
      margin: 0;
      padding: 2rem 1.1rem 1.5rem;
      margin-top: -5rem; } }
  .productType_option_content h4 {
    position: relative;
    font-size: 2.2rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0.1em;
    color: #276bb6;
    padding-bottom: 10px; }
    @media screen and (max-width: 991px) {
      .productType_option_content h4 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productType_option_content h4 {
        font-size: 1.4rem;
        letter-spacing: 0.05em;
        text-align: right; } }
  .productType_option_content h4::before {
    position: absolute;
    content: "";
    width: calc(100% + 40px);
    left: -40px;
    bottom: 0;
    height: 1px;
    background-color: #276bb6; }
    @media screen and (max-width: 991px) {
      .productType_option_content h4::before {
        width: 100%;
        left: initial;
        right: 0; } }
  .productType_option_content p {
    font-size: 1.5rem;
    line-height: calc(20/15);
    letter-spacing: 0.1em;
    margin-top: 12px; }
    @media screen and (max-width: 991px) {
      .productType_option_content p {
        font-size: 1.1rem;
        line-height: calc(30/22);
        letter-spacing: 0.05rem;
        margin-top: 1.5rem; } }

@media screen and (max-width: 991px) {
  .en .productType_option_content {
    margin-top: -1rem; } }

.productType_table {
  max-width: 800px;
  margin-inline: auto;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .productType_table {
      width: calc(100% + 2.7rem);
      overflow-x: scroll;
      margin-top: 3rem;
      margin-left: -1.35rem;
      padding-inline: 1.35rem; } }

.productType_table > div:nth-child(1) {
  padding: 13px 25px 18px;
  border: 1px solid #5289c5; }
  @media screen and (max-width: 991px) {
    .productType_table > div:nth-child(1) {
      min-width: 70rem;
      padding: 0.8rem; } }

.productType_unit:nth-child(2) .productType_table {
  border-color: #1c5390; }

.productType_row {
  display: grid;
  grid-template-columns: 13% 33% 16% 1fr;
  gap: 5px; }

.productType_row p {
  min-height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  line-height: calc(21/16);
  padding-block: 12px; }
  @media screen and (max-width: 991px) {
    .productType_row p {
      font-size: 1.1rem; } }
  .productType_row p small {
    font-size: 1.3rem; }
    @media screen and (max-width: 991px) {
      .productType_row p small {
        font-size: 0.8rem; } }
  .productType_row p sup {
    font-size: 1.3rem;
    margin-bottom: 0.5rem; }
    @media screen and (max-width: 991px) {
      .productType_row p sup {
        font-size: 0.8rem; } }
.productType_row p:last-child {
  flex-direction: column; }

.productType_row:nth-child(3),
.productType_row:nth-child(5) {
  background-color: rgba(39, 107, 182, 0.05); }

.productTYpe_row_first p {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  text-align: center;
  color: white;
  background-color: #276bb6;
  line-height: 15px;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  padding-block: 8px; }
  @media screen and (max-width: 991px) {
    .productTYpe_row_first p {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productTYpe_row_first p {
      font-size: 1.2rem;
      padding-block: 0.4rem; } }
  .productTYpe_row_first p small {
    font-size: 1.2rem; }
    @media screen and (max-width: 991px) {
      .productTYpe_row_first p small {
        font-size: 1.1rem; } }
.productTYpe_row_first p:nth-child(2) {
  flex-direction: column; }

.en .productTYpe_row_first p {
  letter-spacing: normal;
  font-size: 1.2rem; }
  @media screen and (max-width: 991px) {
    .en .productTYpe_row_first p {
      font-size: 1rem; } }

.productType_unit:nth-child(2) .productTYpe_row_first p {
  background-color: #1c5390; }

.productType_standard .productType_unit:nth-child(1) .productTYpe_row_first p {
  background-color: #5289c5; }

.productType_standard .productType_unit:nth-child(2) .productTYpe_row_first p {
  background-color: #2463a8; }

.productType_standard .productType_unit:nth-child(3) .productTYpe_row_first p {
  background-color: #205da0; }

.productType_standard .productType_unit:nth-child(4) .productTYpe_row_first p {
  background-color: #1c5390; }

.productType_note {
  width: fit-content;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: calc(20/13);
  letter-spacing: 0.05em;
  width: fit-content;
  margin-inline: auto;
  margin-top: 8px; }
  @media screen and (max-width: 991px) {
    .productType_note {
      font-size: 0.9rem;
      line-height: calc(25/18);
      margin: 0;
      margin-top: 1rem; } }
  @media screen and (max-width: 991px) {
    .productType_note li {
      text-indent: -3em;
      margin-left: 3em; } }

@media screen and (max-width: 991px) {
  .productType_standard .productType_note li {
    text-indent: 0;
    margin-left: 0; } }

.productType_pdf_btn {
  max-width: 450px;
  margin-inline: auto;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .productType_pdf_btn {
      max-width: 25rem;
      margin-top: 1.8rem; } }

.en .productType_pdf_btn {
  max-width: 525px; }

.productType_waterproof {
  position: relative;
  max-width: 800px;
  display: flex;
  align-items: center;
  margin-inline: auto;
  margin-top: 72px; }
  @media screen and (max-width: 991px) {
    .productType_waterproof {
      flex-wrap: wrap; } }
  .productType_waterproof img {
    max-width: 35px;
    margin-right: 16px;
    display: inline-block; }
    @media screen and (max-width: 991px) {
      .productType_waterproof img {
        width: 2.2rem;
        margin-right: 1rem; } }
  .productType_waterproof h3 {
    font-size: 2.2rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    color: #4975a6;
    margin-right: 20px; }
    @media screen and (max-width: 991px) {
      .productType_waterproof h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productType_waterproof h3 {
        font-size: 1.4rem; } }
  .productType_waterproof p {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    margin-right: 12px; }
    @media screen and (max-width: 991px) {
      .productType_waterproof p {
        font-size: 1.1rem;
        line-height: calc(1);
        margin-top: 15px; } }

.en .productType_waterproof {
  flex-wrap: wrap; }

.en .productType_waterproof_btn {
  margin-left: auto; }
  @media screen and (max-width: 991px) {
    .en .productType_waterproof_btn {
      position: relative; } }

.productType_waterproof + .productType_table {
  margin-top: 10px; }

@media screen and (max-width: 991px) {
  .productType_waterproof_btn {
    position: absolute;
    top: 0;
    right: 0; } }
.productType_waterproof_btn a {
  display: inline-block;
  position: relative;
  font-size: 1.4rem;
  font-weight: 900;
  color: #4975a6;
  border: 1px solid #4975a6;
  letter-spacing: 0.05em;
  line-height: 1;
  padding: 6px 30px 6px 16px;
  border-radius: 15px;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .productType_waterproof_btn a {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productType_waterproof_btn a {
      font-size: 1rem;
      padding: 0.4rem 1.6rem 0.4rem 1rem; } }
.productType_waterproof_btn a::before {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 6px;
  right: 10px;
  background-color: #4975a6;
  clip-path: polygon(0 0, 50% 100%, 100% 0); }
  @media screen and (max-width: 991px) {
    .productType_waterproof_btn a::before {
      width: 0.5rem;
      height: 0.375rem;
      right: 0.7rem; } }
.productType_waterproof_btn a:hover {
  background-color: #4975a6;
  color: white; }
  .productType_waterproof_btn a:hover::before {
    background-color: white; }

.pdfBtn {
  position: relative;
  display: inline-block;
  width: 100%;
  font-size: 1.6rem;
  font-weight: 900;
  line-height: calc(20/16);
  letter-spacing: 0.1em;
  align-items: center;
  border-radius: 40px;
  border: 1px solid #cccccc;
  padding: 20px 50px;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .pdfBtn {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .pdfBtn {
      font-size: 1.1rem;
      line-height: calc(25/22);
      padding: 1rem 2.2rem; } }

@media screen and (max-width: 991px) {
  .en .pdfBtn {
    padding-right: 7rem; } }

.productType_standard .pdfBtn {
  padding-left: 90px; }
  @media screen and (max-width: 991px) {
    .productType_standard .pdfBtn {
      padding-left: 2.2rem; } }

.pdfBtn:hover {
  opacity: 0.7; }

.productType_pdf_btn .disabled-btn {
  pointer-events: none; /* クリックも無効化したい場合 */
  cursor: default;      /* カーソルも普通の矢印にする */
}

.productType_pdf_btn .disabled-btn:hover {
  background-color: inherit; /* 他と同じに戻す */
  color: inherit;
}

.pdfBtn::before {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  background: url(../img/img-common/pdf_icon.png) center center/contain no-repeat;
  width: 30px;
  height: 30px;
  right: 40px; }
  @media screen and (max-width: 991px) {
    .pdfBtn::before {
      width: 2.5rem;
      height: 2.5rem;
      right: 3rem; } }

.productType_box {
  padding: 30px 24px 36px;
  border: 2px dotted #03356c;
  border-radius: 12px;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .productType_box {
      padding: 1.5rem 1.3rem 2rem; } }
  .productType_box p {
    font-size: 1.5rem;
    line-height: calc(30/15);
    letter-spacing: 0.05em; }
    @media screen and (max-width: 991px) {
      .productType_box p {
        font-size: 1.1rem;
        line-height: calc(30/22); } }
    .productType_box p strong {
      color: #03356c; }

.productType_box_btn {
  max-width: 220px;
  margin-inline: auto;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .productType_box_btn {
      max-width: 15rem;
      margin-top: 1rem; } }

.en .productType_box_btn {
  max-width: fit-content; }

/* ============================================================================
回遊リンク
============================================================================== */
.excursion {
  padding-top: 100px; }
  @media screen and (max-width: 991px) {
    .excursion {
      padding-top: 3rem; } }

.excursion_items {
  display: grid;
  grid-template-columns: repeat(2, 1fr); }
  @media screen and (max-width: 991px) {
    .excursion_items {
      grid-template-columns: 1fr; } }

.excursion_item {
  padding: 77px 20px 57px; }
  @media screen and (max-width: 991px) {
    .excursion_item {
      padding: 3rem 1rem 2.5rem; } }

.excursion_item:nth-child(1) {
  background: url(../img/img-freestop/bg_excursion_01.jpg) center center/cover no-repeat; }

.excursion_item:nth-child(2) {
  background: url(../img/img-freestop/bg_excursion_02.jpg) center center/cover no-repeat; }

.excursion_ttl {
  text-align: center;
  font-size: 3rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.1em;
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .excursion_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .excursion_ttl {
      font-size: 1.9rem; } }

.excursion_ttl.white {
  color: white; }

.excursion_txt {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 900;
  line-height: calc(25/15);
  letter-spacing: 0.1em;
  margin-top: 24px;
  min-height: 75px; }
  @media screen and (max-width: 991px) {
    .excursion_txt {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .excursion_txt {
      font-size: 1.1rem;
      line-height: calc(35/22);
      letter-spacing: 0.05em;
      margin-top: 1.25rem;
      min-height: unset; } }

.excursion_btn {
  max-width: 250px;
  margin: 0 auto;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .excursion_btn {
      max-width: 16rem;
      margin-top: 2rem; } }

.excursion_item:nth-child(2) .excursion_btn {
  max-width: 200px; }
  @media screen and (max-width: 991px) {
    .excursion_item:nth-child(2) .excursion_btn {
      max-width: 16rem; } }

.en .excursion_btn {
  max-width: fit-content !important; }

/* ============================================================================
製品一覧
============================================================================== */
.productList {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .productList {
      margin-top: 2.8rem; } }

.productList_item {
  position: relative;
  padding-block: 50px;
  transform: translate(0, 0) !important;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .productList_item {
      width: calc(100% - 2.6rem);
      margin: 0 auto;
      padding-top: 2.3rem;
      padding-bottom: 2.6rem; } }

.productList_item::after {
  position: absolute; }
  @media screen and (max-width: 991px) {
    .productList_item::after {
      font-size: 7.5rem;
      letter-spacing: 0.05em; } }

.productList_item_bg {
  position: absolute;
  display: flex;
  white-space: nowrap;
  font-size: 20rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #03356c;
  opacity: 0.1;
  width: fit-content;
  white-space: nowrap;
  z-index: -1;
  line-height: 1;
  top: 50%;
  transform: translateY(-50%) translateX(100%);
  left: -182px;
  animation: flowing 120s linear infinite;
  transition: all 5s ease-in-out; }
  @media screen and (max-width: 991px) {
    .productList_item_bg {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productList_item_bg {
      font-size: 7.5rem;
      top: 41rem;
      transform: translateY(0); } }

.productList_item:nth-child(2) .productList_item_bg {
  bottom: 26px; }
  @media screen and (max-width: 991px) {
    .productList_item:nth-child(2) .productList_item_bg {
      bottom: 4.5rem; } }

.productList_item_bg > div {
  display: flex;
  gap: 0.5em; }

@keyframes flowing {
  0% {
    transform: translateY(-50%) translateX(0); }
  100% {
    transform: translateY(-50%) translateX(-100%); } }
.productList_item.is-scroll-fade::after {
  transform: translateY(-50%) translateX(0%); }

.productList_wrap {
  display: grid;
  grid-template-columns: 1fr 41.6666%;
  gap: 40px; }
  @media screen and (max-width: 991px) {
    .productList_wrap {
      grid-template-columns: 1fr;
      gap: 0; } }

.productList_content {
  width: calc(100% - 36px);
  margin-left: auto; }
  @media screen and (max-width: 991px) {
    .productList_content {
      display: contents;
      margin: 0;
      width: 100%; } }

.productList_ttl {
  position: relative;
  padding-bottom: 26px; }
  @media screen and (max-width: 991px) {
    .productList_ttl {
      padding-bottom: 1.5rem;
      order: -3; } }
  .productList_ttl span {
    display: flex;
    font-weight: 900;
    align-items: center;
    font-size: 1.8rem;
    gap: 10px;
    letter-spacing: 0.1em;
    color: #03356c;
    opacity: 0.5; }
    @media screen and (max-width: 991px) {
      .productList_ttl span {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productList_ttl span {
        font-size: 0.9rem;
        gap: 0.5rem; } }
  .productList_ttl span img {
    width: 2.6rem;
    opacity: 0.5; }
    @media screen and (max-width: 991px) {
      .productList_ttl span img {
        width: 1.3rem; } }
  .productList_ttl h3 {
    font-size: 4rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0.1em;
    color: #03356c;
    margin-top: 6px; }
    @media screen and (max-width: 991px) {
      .productList_ttl h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productList_ttl h3 {
        font-size: 1.9rem;
        margin-top: 0.5rem; } }

.productList_ttl::before {
  position: absolute;
  content: "";
  width: 0;
  height: 2px;
  left: 0;
  bottom: 0;
  margin-left: calc(50% - 50vw);
  background-color: #03356c;
  opacity: 0.1;
  transition: all 0.8s;
  transition-delay: 0.3s; }

.productList_ttl + .productList_txt {
  margin-top: 28px; }
  @media screen and (max-width: 991px) {
    .productList_ttl + .productList_txt {
      margin-top: 1.5rem; } }

@media screen and (max-width: 991px) {
  .productList_txt {
    display: contents; } }
.productList_txt > p:nth-child(1) {
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  font-feature-settings: "palt";
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .productList_txt > p:nth-child(1) {
      font-weight: 700;
      order: -2;
      font-size: 1.35rem;
      letter-spacing: 0.1em;
      margin-top: 1.6rem; } }
.productList_txt > p:nth-child(2) {
  font-size: 1.6rem;
  line-height: calc(28/16);
  letter-spacing: 0.1em;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .productList_txt > p:nth-child(2) {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-top: 1.5rem;
      margin-left: 0; } }

.productList_img {
  position: relative;
  display: block;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .productList_img {
      width: 100%;
      margin-top: 1.6rem; } }

@media screen and (max-width: 991px) {
  .productList_optionPage .productList_img {
    order: -1;
    max-width: 20rem;
    margin-inline: auto; } }

.productList_cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  width: calc(100% + 32px);
  margin-left: -16px;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .productList_cards {
      grid-template-columns: 1fr;
      width: 25rem;
      gap: 3.1rem;
      margin-inline: auto;
      margin-top: 6.8rem; } }

.productList_card {
  display: flex;
  flex-direction: column;
  background-color: white;
  box-shadow: 0 0 8px rgba(3, 53, 108, 0.3);
  border-radius: 12px;
  padding: 28px 40px 40px; }
  @media screen and (max-width: 991px) {
    .productList_card {
      padding: 2.5rem 2rem 2.2rem;
      border-radius: 0.6rem; } }

.productList_card_ttl {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  font-weight: 900;
  line-height: calc(35/30);
  min-height: 88px;
  letter-spacing: 0.05em;
  padding-bottom: 18px; }
  @media screen and (max-width: 991px) {
    .productList_card_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productList_card_ttl {
      font-size: 1.5rem;
      line-height: calc(40/30);
      min-height: unset;
      padding-bottom: 1.5rem; } }

.productList_card_ttl::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 4px;
  background-color: #03356c;
  left: 0;
  bottom: 0; }
  @media screen and (max-width: 991px) {
    .productList_card_ttl::before {
      height: 0.2rem; } }

.productList_card_img {
  display: block;
  text-align: center;
  margin-top: 26px; }
  @media screen and (max-width: 991px) {
    .productList_card_img {
      margin-top: 1.4rem; } }

.productList_card_txt {
  font-size: 1.6rem;
  font-weight: 400;
  flex-grow: 1;
  line-height: calc(25/16);
  letter-spacing: 0.05em;
  margin-top: 26px; }
  @media screen and (max-width: 991px) {
    .productList_card_txt {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-top: 1.4rem; } }

.productList_card_youtube {
  margin-top: 16px; }
  @media screen and (max-width: 991px) {
    .productList_card_youtube {
      margin-top: 1rem; } }

.productList_card_youtube iframe {
  aspect-ratio: 420/226;
  width: 100%;
  height: 100%; }

.productList_card_btn {
  max-width: 200px;
  width: 100%;
  margin-inline: auto;
  margin-top: 28px; }
  @media screen and (max-width: 991px) {
    .productList_card_btn {
      max-width: 15rem;
      margin-top: 2rem; } }

.en .productList_card_btn {
  max-width: fit-content; }

.productList_border {
  border-top: 1px dashed rgba(3, 52, 106, 0.4);
  display: block;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .productList_border {
      margin-top: 2.5rem; } }

.productList_option {
  width: calc(100% - 36px - 72px);
  margin-left: 36px;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .productList_option {
      width: 100%;
      margin: 0;
      margin-top: 2.5rem; } }

.productList_option_wrap {
  display: grid;
  grid-template-columns: 1fr 31.818%;
  gap: 40px; }
  @media screen and (max-width: 991px) {
    .productList_option_wrap {
      grid-template-columns: 1fr;
      gap: 0; } }

@media screen and (max-width: 991px) {
  .productList_option_img {
    order: -1;
    display: block;
    max-width: 14rem;
    margin: 0 auto;
    margin-top: 1.6rem; } }

.productList_option_content {
  margin-top: 28px; }
  @media screen and (max-width: 991px) {
    .productList_option_content {
      display: contents; } }
  .productList_option_content h3 {
    font-size: 3.6rem;
    font-weight: 900;
    color: #03356c;
    letter-spacing: 0.15em;
    line-height: 1; }
    @media screen and (max-width: 991px) {
      .productList_option_content h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productList_option_content h3 {
        order: -2;
        text-align: center;
        font-size: 1.7rem; } }
    .productList_option_content h3 span {
      display: block;
      font-size: 1.8rem;
      letter-spacing: 0.1em;
      margin-bottom: 10px; }
      @media screen and (max-width: 991px) {
        .productList_option_content h3 span {
          display: inline-block;
          font-size: 1.1rem;
          vertical-align: middle;
          margin-bottom: 0; } }
  .productList_option_content p {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: calc(28/16);
    letter-spacing: 0.1em;
    margin-top: 28px; }
    @media screen and (max-width: 991px) {
      .productList_option_content p {
        font-size: 1.1rem;
        line-height: calc(35/22);
        letter-spacing: 0.05em;
        margin-top: 1.4rem; } }

.productList_option_btn {
  max-width: 220px;
  width: 100%;
  margin: 0 auto;
  margin-top: 30px; }
  @media screen and (max-width: 991px) {
    .productList_option_btn {
      max-width: 15rem;
      margin-top: 1.5rem; } }

.productList_item + .productList_item {
  margin-top: 100px; }
  @media screen and (max-width: 991px) {
    .productList_item + .productList_item {
      margin-top: 3rem; } }

.productList_item:nth-child(even) .productList_ttl::before {
  left: initial;
  right: 0;
  margin-right: calc(50% - 50vw);
  margin-left: initial;
  width: 0; }
.productList_item:nth-child(even) .productList_ttl.is-scroll-fade::before {
  width: calc(960px + 50vw - 50% + 60px); }
  @media screen and (max-width: 991px) {
    .productList_item:nth-child(even) .productList_ttl.is-scroll-fade::before {
      width: calc(100vw - 2rem); } }

.productList_optionPage .productList_item:nth-child(even) .productList_ttl::before {
  margin-right: calc(480px - 100vw + 146px); }
  @media screen and (max-width: 991px) {
    .productList_optionPage .productList_item:nth-child(even) .productList_ttl::before {
      margin-right: calc(50% - 50vw); } }

.productList_optionPage .productList_item:nth-child(even) .productList_ttl.is-scroll-fade::before {
  width: calc(960px  + (100vw - 960px));
  max-width: unset; }
  @media screen and (max-width: 991px) {
    .productList_optionPage .productList_item:nth-child(even) .productList_ttl.is-scroll-fade::before {
      width: calc(100vw - 2rem);
      max-width: unset; } }

.productList_item:nth-child(2) {
  padding-left: 36px;
  padding-right: 50px; }
  @media screen and (max-width: 991px) {
    .productList_item:nth-child(2) {
      padding-inline: 0; } }

.productList_optionPage .productList_item:nth-child(2) {
  padding-inline: 0; }

.productList_wrap2 {
  display: grid;
  align-items: flex-start;
  grid-template-columns: 300px 1fr;
  gap: 60px;
  margin-top: 32px; }
  @media screen and (max-width: 991px) {
    .productList_wrap2 {
      grid-template-columns: 1fr;
      gap: 0;
      margin-top: 0; } }
  .productList_wrap2 .productList_content {
    margin-top: -12px; }
    @media screen and (max-width: 991px) {
      .productList_wrap2 .productList_content {
        display: contents; } }
    .productList_wrap2 .productList_content p:nth-child(2) {
      font-weight: 400; }
  @media screen and (max-width: 991px) {
    .productList_wrap2 .productList_btn {
      order: 2; } }

.productList_btn {
  max-width: 200px;
  margin: 0 auto;
  margin-top: 28px; }
  @media screen and (max-width: 991px) {
    .productList_btn {
      max-width: 15rem;
      width: 100%; } }

.en .productList_btn {
  max-width: fit-content; }

@media screen and (max-width: 991px) {
  .productList_img2 {
    order: 1;
    max-width: 20rem;
    margin: 0 auto;
    margin-top: 1.1rem; } }

.productList_ttl.is-scroll-fade::before {
  width: calc(960px + 50vw - 50% + 76px); }
  @media screen and (max-width: 991px) {
    .productList_ttl.is-scroll-fade::before {
      width: calc(100vw - 2rem); } }

.productList_corres {
  line-height: 1;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .productList_corres {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productList_corres {
      font-size: 1rem;
      margin-top: 1rem; } }
  .productList_corres span {
    display: inline-block;
    font-size: 1.5rem;
    font-weight: 900;
    color: #03356c;
    border: 1px solid #03356c;
    padding: 6px 10px;
    margin-right: 12px; }
    @media screen and (max-width: 991px) {
      .productList_corres span {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productList_corres span {
        font-size: 1rem;
        padding: 0.5rem 0.6rem;
        margin-bottom: 1rem; } }
  .productList_corres small {
    display: block;
    font-weight: 400;
    font-size: 1.5rem;
    margin-top: 8px; }
    @media screen and (max-width: 991px) {
      .productList_corres small {
        font-size: 1rem;
        margin-top: 0.8rem; } }
  .productList_corres a {
    text-decoration: underline;
    transition: all 0.3s; }
  .productList_corres a:hover {
    opacity: 0.8; }

.en .productList_corres {
  white-space: nowrap; }
  @media screen and (max-width: 991px) {
    .en .productList_corres {
      white-space: initial;
      line-height: 1.25; } }

.productList_note {
  width: fit-content;
  font-size: 1.6rem;
  line-height: calc(25/16);
  font-weight: 400;
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .productList_note {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin: 0;
      margin-top: 2rem; } }

.productList_holder {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  width: 88%;
  gap: 10rem;
  margin-top: 26px; }
  @media screen and (max-width: 991px) {
    .productList_holder {
      grid-template-columns: 1fr;
      width: 17.5rem;
      gap: 1.25rem;
      margin-inline: auto; } }

.productList_holder_list p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(25/16);
  letter-spacing: 0.1em;
  margin-top: 18px; }
  @media screen and (max-width: 991px) {
    .productList_holder_list p {
      font-size: 1.1rem;
      letter-spacing: initial;
      margin-top: 0.8rem; } }
.productList_holder_list p strong {
  display: block;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  color: #03356c;
  margin-bottom: 4px; }
  @media screen and (max-width: 991px) {
    .productList_holder_list p strong {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productList_holder_list p strong {
      text-align: center;
      font-size: 1.2rem;
      line-height: calc(35/24); } }

/* ============================================================================
取付方法のご案内
============================================================================== */
.install_content {
  background-color: #e4f0fd;
  padding-top: 75px;
  padding-bottom: 75px; }
  @media screen and (max-width: 991px) {
    .install_content {
      padding-top: 4rem;
      padding-bottom: 4rem; } }

.install_content_lead {
  width: fit-content;
  margin: 0 auto;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: calc(30/18); }
  @media screen and (max-width: 991px) {
    .install_content_lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .install_content_lead {
      font-size: 1.1rem; } }

.install_content_gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
  margin-top: 48px; }
  @media screen and (max-width: 991px) {
    .install_content_gallery {
      max-width: 25rem;
      grid-template-columns: 1fr;
      gap: 2rem;
      margin-inline: auto;
      margin-top: 1rem; } }

.install_content_youtube iframe {
  aspect-ratio: 450/300;
  width: 100%;
  height: 100%; }

/* ============================================================================
傾斜している場合
============================================================================== */
.slope {
  padding-top: 80px;
  padding-bottom: 80px; }
  @media screen and (max-width: 991px) {
    .slope {
      padding-top: 3rem;
      padding-bottom: 2.5rem; } }

.slope_inner.inner {
  max-width: 900px; }

.slope_ttl {
  font-size: 2.4rem;
  font-weight: 900;
  color: #03356c;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .slope_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .slope_ttl {
      font-size: 1.4rem; } }

.slope_txt {
  font-size: 1.5rem;
  font-weight: 400;
  line-height: calc(25/15);
  letter-spacing: 0.1em;
  margin-top: 10px; }
  @media screen and (max-width: 991px) {
    .slope_txt {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-top: 1.4rem; } }

.slope_gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 18px; }
  @media screen and (max-width: 991px) {
    .slope_gallery {
      max-width: 25rem;
      grid-template-columns: 1fr;
      gap: 1.5rem;
      margin-inline: auto;
      margin-top: 0.7rem; } }

.slope_youtube {
  max-width: 720px;
  margin: 0 auto;
  margin-top: 80px; }
  @media screen and (max-width: 991px) {
    .slope_youtube {
      max-width: 25rem;
      margin-top: 2.5rem; } }

.slope_youtube iframe {
  aspect-ratio: 720/406;
  width: 100%;
  height: 100%; }

/* ============================================================================
選定ガイド
============================================================================== */
.install_guide {
  padding-top: 88px;
  padding-bottom: 80px;
  background: url(../img/img-install/bg_guide.jpg) center center/cover no-repeat; }
  @media screen and (max-width: 991px) {
    .install_guide {
      padding-top: 3.5rem;
      padding-bottom: 2rem; } }

.install_guide_txt {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 900;
  line-height: calc(30/15);
  letter-spacing: 0.1em;
  margin-top: 36px; }
  @media screen and (max-width: 991px) {
    .install_guide_txt {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .install_guide_txt {
      font-size: 1.1rem;
      line-height: calc(35/22);
      letter-spacing: 0.05em;
      margin-top: 1.4rem; } }

.install_guide_btn {
  max-width: 250px;
  margin-inline: auto;
  margin-top: 36px; }
  @media screen and (max-width: 991px) {
    .install_guide_btn {
      max-width: 16rem;
      margin-top: 1.5rem; } }

.en .install_guide_btn {
  max-width: fit-content; }

/* ============================================================================
取付方法
============================================================================== */
.install_head {
  padding-top: 64px;
  padding-bottom: 60px; }
  @media screen and (max-width: 991px) {
    .install_head {
      padding-top: 4rem;
      padding-bottom: 4rem; } }

.install_head_txt {
  width: fit-content;
  font-size: 2.2rem;
  font-weight: 900;
  line-height: calc(45/22);
  letter-spacing: 0.2em;
  margin: 0 auto; }
  @media screen and (max-width: 991px) {
    .install_head_txt {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .install_head_txt {
      text-align: center;
      font-size: 1.4rem;
      line-height: calc(45/28); } }
  .install_head_txt span {
    position: relative;
    display: inline-block;
    padding-inline: 8px;
    margin-left: -8px;
    transform: translate(0, 0) !important;
    opacity: 1 !important; }
    @media screen and (max-width: 991px) {
      .install_head_txt span {
        margin-top: 0.25rem; } }
  .install_head_txt span::before {
    position: absolute;
    content: "";
    left: 0;
    top: 0;
    width: 0%;
    height: 100%;
    background: rgba(255, 255, 38, 0.7);
    transition: all 1s;
    z-index: -1; }

.install_head_txt span.is-scroll-fade::before {
  width: 100%; }

.install_head_links {
  display: flex;
  justify-content: center;
  gap: 118px;
  margin-top: 55px; }
  @media screen and (max-width: 991px) {
    .install_head_links {
      gap: 1.9rem;
      margin-top: 3rem; } }

.install_head_link p {
  text-align: center;
  font-size: 2rem;
  font-weight: 900;
  color: #03356c;
  letter-spacing: 0.2em;
  line-height: 25px; }
  @media screen and (max-width: 991px) {
    .install_head_link p {
      font-weight: 700;
      font-size: 1.2rem;
      line-height: 1.5rem;
      letter-spacing: 0.1em; } }
  .install_head_link p small {
    font-size: 1.6rem; }
    @media screen and (max-width: 991px) {
      .install_head_link p small {
        font-size: 1rem; } }
.install_head_link a {
  display: block;
  text-align: center;
  margin-top: 14px;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .install_head_link a {
      margin-top: 0.7rem; } }

@media screen and (max-width: 991px) {
  .en .install_head_link p small {
    font-size: 0.8rem; } }

.en .install_head_link p {
  letter-spacing: normal; }
  @media screen and (max-width: 991px) {
    .en .install_head_link p {
      font-size: 1rem; } }

.install_head_link a:hover {
  opacity: 0.8; }

.install {
  background-color: #e4f0fd; }
  @media screen and (max-width: 991px) {
    .install {
      padding-top: 3rem;
      padding-bottom: 4rem; } }

.install_unit {
  background-color: white;
  padding: 50px 70px 60px; }
  @media screen and (max-width: 991px) {
    .install_unit {
      padding: 1.8rem 1.5rem 1.5rem; } }

.install_unit + .install_unit {
  margin-top: 52px; }
  @media screen and (max-width: 991px) {
    .install_unit + .install_unit {
      margin-top: 2.7rem; } }

.install_unit_head p {
  display: inline-block;
  color: white;
  background-color: #f38f2c;
  font-size: 1.8rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.1em;
  padding: 8px 10px; }
  @media screen and (max-width: 991px) {
    .install_unit_head p {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .install_unit_head p {
      font-size: 1rem;
      padding: 0.5rem 0.7rem; } }
.install_unit_head h2 {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 3.4rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  line-height: 1;
  gap: 14px;
  margin-top: 1.4rem;
  padding-bottom: 28px; }
  @media screen and (max-width: 991px) {
    .install_unit_head h2 {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .install_unit_head h2 {
      font-size: 1.8rem;
      gap: 0.7rem;
      margin-top: 1rem;
      padding-bottom: 1rem; } }
  .install_unit_head h2 span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #f38f2c;
    border-radius: 50%;
    border: 2px solid #f38f2c;
    font-size: 2.6rem;
    width: 4.6rem;
    height: 4.6rem; }
    @media screen and (max-width: 991px) {
      .install_unit_head h2 span {
        width: 2.3rem;
        height: 2.3rem;
        font-size: 1.3rem;
        border: 0.1rem solid #f38f2c; } }
.install_unit_head h2::before {
  position: absolute;
  content: "";
  width: calc(100% + 140px);
  height: 1px;
  left: -70px;
  bottom: 0;
  background-color: #000000;
  opacity: 0.1; }
  @media screen and (max-width: 991px) {
    .install_unit_head h2::before {
      width: calc(100% + 3rem);
      left: -1.5rem; } }

.en .install_unit_head h2 {
  letter-spacing: normal; }

.install_unit:nth-child(3) {
  padding-bottom: 3.3rem; }
  .install_unit:nth-child(3) .install_unit_head p {
    background-color: #60ace0; }
  .install_unit:nth-child(3) .install_unit_head h2 span {
    color: #60ace0;
    border-color: #60ace0; }

.install_txt {
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: calc(25/15);
  margin-top: 28px; }
  @media screen and (max-width: 991px) {
    .install_txt {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-top: 1.4rem; } }

.install_lists {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 28px; }
  @media screen and (max-width: 991px) {
    .install_lists {
      grid-template-columns: 1fr;
      margin-top: 1.1rem; } }

.install_list {
  grid-column: 1/3; }
  @media screen and (max-width: 991px) {
    .install_list {
      grid-column: initial; } }

@media screen and (max-width: 991px) {
  .install_unit:nth-child(3) .install_list:nth-child(2) {
    grid-column: initial; }
    .install_unit:nth-child(3) .install_list:nth-child(2) picture {
      max-width: 17rem; } }

.install_unit:nth-child(2) .install_list:nth-child(3) {
  grid-column: 2/3; }
  @media screen and (max-width: 991px) {
    .install_unit:nth-child(2) .install_list:nth-child(3) {
      grid-column: initial; }
      .install_unit:nth-child(2) .install_list:nth-child(3) picture {
        max-width: 17rem; } }

.install_list + .install_list {
  margin-top: 52px; }
  @media screen and (max-width: 991px) {
    .install_list + .install_list {
      margin-top: 3rem; } }

.install_list_ttl {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .install_list_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .install_list_ttl {
      font-size: 1.2rem;
      gap: 0.5rem; } }
  .install_list_ttl img {
    opacity: 0.5;
    width: 1.5rem; }

.install_gallery {
  display: flex;
  justify-content: center;
  margin-top: 30px; }
  @media screen and (max-width: 991px) {
    .install_gallery {
      flex-direction: column;
      gap: 1.5rem;
      margin-top: 1rem; } }

.install_gallery picture {
  display: block;
  width: 50%; }
  @media screen and (max-width: 991px) {
    .install_gallery picture {
      width: 100%;
      max-width: 22.5rem;
      margin: 0 auto; } }

.install_note {
  text-align: center;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1;
  margin-left: 60px;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .install_note {
      text-align: left;
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-left: 0;
      margin-top: 1.2rem; } }

.install_note--right {
  max-width: 880px;
  margin-inline: auto;
  text-align: right;
}

@media screen and (max-width: 991px) {
  .install_note--right {
    text-align: left;
  }
}

.install_table {
  max-width: 880px;
  margin-inline: auto;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .install_table {
      width: calc(100% + 3rem);
      overflow-x: scroll;
      padding-inline: 1.5rem;
      padding-bottom: 0rem;
      margin-left: -1.5rem;
      margin-top: 1.2rem; } }

.install_table > div:nth-child(1) {
  padding: 30px 40px;
  border: 1px solid #f38f2c; }
  @media screen and (max-width: 991px) {
    .install_table > div:nth-child(1) {
      padding: 1.3rem 1rem;
      min-width: 60rem; } }
.scroll-hint-icon {
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 991px) {
  .en .install_table > div:nth-child(1) {
    min-width: 70rem; } }

.install_table dl {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 3px; }
  @media screen and (max-width: 991px) {
    .install_table dl {
      grid-template-columns: 8rem 1fr;
      gap: 0.15rem; } }

.install_table dt {
  display: grid;
  place-items: center;
  text-align: center;
  background-color: #f38f2c;
  color: white;
  font-size: 1.6rem;
  font-weight: 900;
  height: 50px; }
  @media screen and (max-width: 991px) {
    .install_table dt {
      font-size: 1rem;
      height: 2.5rem;
      font-weight: 700; } }

.en .install_table dt {
  line-height: 1.25;
  font-size: 1rem; }

.install_table dd {
  display: grid;
  place-items: center;
  height: 50px; }
  @media screen and (max-width: 991px) {
    .install_table dd {
      height: 2.5rem; } }

.install_table dd ul {
  height: 100%;
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  width: 100%; }

.install_table dd:nth-child(2) ul {
  background-color: rgba(254, 244, 233, 0.8); }

.install_table dd li {
  display: grid;
  place-items: center;
  text-align: center;
  font-size: 1.6rem;
  font-weight: 900; }
  @media screen and (max-width: 991px) {
    .install_table dd li {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .install_table dd li {
      font-size: 1rem; } }

.install_box {
  padding: 36px 46px;
  border: 2px solid #51a4dd;
  margin-top: 72px; }
  @media screen and (max-width: 991px) {
    .install_box {
      padding: 1.6rem 1.5rem;
      border-width: 0.1rem;
      margin-top: 3.7rem; } }
  .install_box h3 {
    font-size: 2.4rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    color: #51a4dd; }
    @media screen and (max-width: 991px) {
      .install_box h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .install_box h3 {
        font-size: 1.4rem; } }
  .install_box p {
    width: 50%;
    float: left;
    font-size: 1.5rem;
    font-weight: 400;
    line-height: calc(25/15);
    letter-spacing: 0.1em;
    margin-top: 16px; }
    @media screen and (max-width: 991px) {
      .install_box p {
        width: 100%;
        float: initial;
        font-size: 1.1rem;
        line-height: calc(30/22);
        margin-top: 1.2rem; } }
    .install_box p span {
      color: #51a4dd;
      font-weight: 900; }
      @media screen and (max-width: 991px) {
        .install_box p span {
          font-weight: 700; } }

.install_box_gallery {
  text-align: center;
  margin-top: 8px; }
  @media screen and (max-width: 991px) {
    .install_box_gallery {
      max-width: 20rem;
      grid-template-columns: 1fr;
      gap: 1rem;
      margin-inline: auto;
      margin-top: 0.6rem; } }

/* ============================================================================
選定ガイド
============================================================================== */
.guideFlow {
  background-color: #edf4f6;
  padding-top: 82px;
  padding-bottom: 48px; }
  @media screen and (max-width: 991px) {
    .guideFlow {
      padding-top: 5rem;
      padding-bottom: 3rem; } }

.guideFlow_items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 60px; }
  @media screen and (max-width: 991px) {
    .guideFlow_items {
      grid-template-columns: 1fr;
      max-width: 25rem;
      margin-inline: auto;
      gap: 6.6rem; } }

.guideFlow_item {
  position: relative;
  display: flex;
  flex-direction: column;
  background-color: white;
  border-radius: 12px;
  padding: 38px 20px 20px; }
  @media screen and (max-width: 991px) {
    .guideFlow_item {
      padding: 3.4rem 2rem 1.6rem;
      border-radius: 0.6rem;
      transition-delay: 0s; } }

.guideFlow_item:not(:last-child)::before {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%) translateX(-100%);
  width: 25px;
  height: 34px;
  right: -44px;
  background: url(../img/img-guide/arrow.png) center center/contain no-repeat;
  opacity: 0;
  transition: all 0.5s; }
  @media screen and (max-width: 991px) {
    .guideFlow_item:not(:last-child)::before {
      width: 1.4rem;
      top: initial;
      height: 2rem;
      left: 50%;
      right: initial;
      bottom: -3.5rem;
      transform: translateY(-50%) translateX(-50%) rotate(90deg); } }

.guideFlow_item.is-scroll-fade::before {
  opacity: 1;
  transform: translate(0, -50%); }
  @media screen and (max-width: 991px) {
    .guideFlow_item.is-scroll-fade::before {
      transform: translate(-50%, 0%) rotate(90deg); } }

.guideFlow_item:nth-child(1)::before {
  transition-delay: 0.2s; }

.guideFlow_item:nth-child(2)::before {
  transition-delay: 0.4s; }
  @media screen and (max-width: 991px) {
    .guideFlow_item:nth-child(2)::before {
      transition-delay: 1s !important; } }

.guideFlow_check {
  position: absolute;
  text-align: center;
  left: 50%;
  transform: translateX(-50%);
  font-size: 5rem;
  font-weight: 900;
  color: #028ae6;
  line-height: 1;
  font-family: "Century Gothic", sans-serif;
  top: -44px; }
  @media screen and (max-width: 991px) {
    .guideFlow_check {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .guideFlow_check {
      font-size: 3.5rem;
      top: -2rem; } }

.guideFlow_check span {
  display: block;
  font-size: 1.8rem; }
  @media screen and (max-width: 991px) {
    .guideFlow_check span {
      font-size: 1.2rem; } }

.guideFlow_icon {
  width: 80px;
  margin: 0 auto; }
  @media screen and (max-width: 991px) {
    .guideFlow_icon {
      width: 5rem; } }

.guideFlow_ttl {
  text-align: center;
  font-size: 2.2rem;
  font-weight: 900;
  line-height: calc(30/22);
  letter-spacing: 0.1em;
  color: #03356c;
  margin-top: 10px; }
  @media screen and (max-width: 991px) {
    .guideFlow_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .guideFlow_ttl {
      font-size: 1.4rem;
      margin-top: 1rem;
      line-height: 1.5rem; } }
  .guideFlow_ttl span {
    font-size: 1.8rem; }
    @media screen and (max-width: 991px) {
      .guideFlow_ttl span {
        font-size: 1.2rem; } }

@media screen and (max-width: 991px) {
  .en .guideFlow_ttl {
    font-size: 1.2rem; } }

.guideFLow_txt {
  flex-grow: 1;
  font-size: 1.6rem;
  line-height: calc(25/16);
  letter-spacing: 0.05em;
  margin-top: 7px; }
  @media screen and (max-width: 991px) {
    .guideFLow_txt {
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.1em;
      margin-top: 0.8rem; } }

.guideFlow_btn {
  max-width: 160px;
  width: 100%;
  margin-inline: auto;
  margin-top: 15px; }
  @media screen and (max-width: 991px) {
    .guideFlow_btn {
      width: 12.5rem;
      margin-top: 1.2rem; } }

@media screen and (max-width: 991px) {
  .en .guideFlow_btn {
    max-width: fit-content;
    width: 100%; } }

.guideFlow_btn a {
  display: inline-block;
  width: 100%;
  position: relative;
  background-color: #028ae6;
  border-radius: 20px;
  line-height: 1;
  letter-spacing: 0.1em;
  color: white;
  font-size: 1.4rem;
  padding: 13px 36px;
  border: 1px solid #028ae6;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .guideFlow_btn a {
      font-size: 1.1rem;
      border-radius: 1.5rem;
      letter-spacing: 0.2em;
      padding: 0.9rem 2.4rem; } }

.guideFlow_btn a::before {
  position: absolute;
  content: "";
  background: white;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 6px;
  right: 24px;
  clip-path: polygon(0 0, 50% 100%, 100% 0); }
  @media screen and (max-width: 991px) {
    .guideFlow_btn a::before {
      width: 0.6rem;
      height: 0.45rem;
      right: 1.5rem; } }

.guideFlow_btn a:hover {
  color: #028ae6;
  background-color: white; }
  .guideFlow_btn a:hover::before {
    background-color: #028ae6; }

/* ============================================================================
鳥受けできないケース
============================================================================== */
.guideCase {
  padding-top: 50px;
  padding-bottom: 65px; }
  @media screen and (max-width: 991px) {
    .guideCase {
      padding-top: 4rem;
      padding-bottom: 4rem; } }

.guideCase_box {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 30px;
  padding: 25px 32px;
  border: 1px solid #03356c; }
  @media screen and (max-width: 991px) {
    .guideCase_box {
      gap: 0;
      grid-template-columns: 1fr;
      padding: 1rem 2rem 1.5rem; } }

.guideCase_ttl {
  display: flex;
  align-items: center;
  font-size: 2.2rem;
  font-weight: 900;
  gap: 14px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding-bottom: 16px;
  border-bottom: 2px solid #03356c; }
  @media screen and (max-width: 991px) {
    .guideCase_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .guideCase_ttl {
      gap: 1rem;
      font-size: 1.4rem;
      padding-bottom: 0.6rem; } }
  .guideCase_ttl img {
    width: 30px; }
    @media screen and (max-width: 991px) {
      .guideCase_ttl img {
        width: 1.9rem; } }

.guideCase_txt {
  font-size: 1.5rem;
  line-height: calc(25/15);
  letter-spacing: 0.05em;
  padding-left: 5px;
  margin-top: 12px; }
  @media screen and (max-width: 991px) {
    .guideCase_txt {
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.1em;
      margin-top: 1.5rem;
      padding: 0; } }
  .guideCase_txt span {
    color: #03356c; }

@media screen and (max-width: 991px) {
  .guideCase_img {
    margin-inline: auto;
    margin-top: 0.6rem; } }

/* ============================================================================
３つのチェック項目
============================================================================== */
.check {
  position: relative;
  z-index: 1;
  background-color: #03356c; }

.check_ttl h2 {
  color: white; }

.check_items {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .check_items {
      margin-top: 2.5rem; } }

.check_item {
  background-color: white;
  border-radius: 10px;
  padding: 20px 42px 44px; }
  @media screen and (max-width: 991px) {
    .check_item {
      padding: 2rem 1.5rem; } }

.check_item + .check_item {
  margin-top: 80px; }
  @media screen and (max-width: 991px) {
    .check_item + .check_item {
      margin-top: 3.5rem; } }

.check_head {
  position: relative;
  display: flex;
  align-items: flex-end;
  font-size: 3rem;
  font-weight: 900;
  color: #03356c;
  letter-spacing: 0.1em;
  margin-left: -8px;
  gap: 12px;
  z-index: 1; }
  @media screen and (max-width: 991px) {
    .check_head {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .check_head {
      min-height: 2.5em;
      align-items: center;
      font-size: 1.6rem;
      line-height: calc(40/34);
      padding-left: 5.1rem;
      gap: 0; } }
  .check_head small {
    font-size: 2rem; }
    @media screen and (max-width: 991px) {
      .check_head small {
        font-size: 1.2rem; } }

@media screen and (max-width: 991px) {
  .en .check_head {
    letter-spacing: normal;
    font-size: 1.4rem; } }

.check_number {
  color: #028ae6;
  text-align: center;
  font-family: "Century Gothic", sans-serif;
  font-size: 7rem;
  line-height: 1; }
  @media screen and (max-width: 991px) {
    .check_number {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      left: 0;
      font-size: 3.5rem; } }
  .check_number span {
    display: block;
    font-size: 1.8rem; }
    @media screen and (max-width: 991px) {
      .check_number span {
        font-size: 0.9rem; } }

.checkbox_wrap {
  position: relative;
  display: grid;
  grid-template-columns: 610px 1fr;
  align-items: flex-start;
  gap: 30px;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .checkbox_wrap {
      display: block;
      margin-top: 1.6rem; } }

.checkbox_wrap1 {
  align-items: flex-end; }
  @media screen and (max-width: 991px) {
    .checkbox_wrap1 {
      margin-top: 1.6rem; } }
  @media screen and (max-width: 991px) {
    .checkbox_wrap1 .check_box {
      padding-bottom: 5rem; } }

.check_box {
  padding: 20px 20px 20px 30px;
  border-radius: 12px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(25/16);
  letter-spacing: 0.05em;
  text-align: justify;
  border: 2px dotted #03356c; }
  @media screen and (max-width: 991px) {
    .check_box {
      font-size: 1.1rem;
      line-height: calc(30/22);
      border-width: 1px;
      padding: 1.5rem 1.25rem 7rem; } }
  .check_box strong {
    display: block;
    font-size: 2rem;
    font-weight: 900;
    margin-bottom: 12px; }
    @media screen and (max-width: 991px) {
      .check_box strong {
        font-size: 1.2rem;
        font-weight: 700; } }
  .check_box span {
    font-weight: 900;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .check_box span {
        font-size: 1.1rem;
        font-weight: 700; } }

@media screen and (max-width: 991px) {
  .en .check_box strong {
    letter-spacing: normal; } }

@media screen and (max-width: 991px) {
  .check_img1 {
    position: absolute;
    width: 12rem;
    transform: translateY(0);
    bottom: 0.5rem;
    right: 0.5rem; } }

@media screen and (max-width: 991px) {
  .en .check_img1 {
    width: 10rem;
    bottom: 1rem;
    right: 1rem; } }

@media screen and (max-width: 991px) {
  .check_img2 {
    position: absolute;
    width: 12rem;
    bottom: 1.5rem;
    right: 1.5rem; } }

.check_img2 img {
  width: 100%; }

.check_lists {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-top: 46px; }
  @media screen and (max-width: 991px) {
    .check_lists {
      grid-template-columns: 1fr;
      gap: 2.5rem;
      margin-top: 3rem; } }

.check_lists2 {
  position: relative;
  margin-top: 48px; }
  @media screen and (max-width: 991px) {
    .check_lists2 {
      margin-top: 3rem; } }

.check_lists2 .check_list {
  padding: 80px 40px 20px; }
  @media screen and (max-width: 991px) {
    .check_lists2 .check_list {
      padding: 5.5rem 1.5rem 2rem; } }

.check_lists2_txt {
  position: absolute;
  left: 100px;
  width: 100%;
  top: 30px;
  font-size: 2rem;
  font-weight: 900;
  line-height: calc(25/20);
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .check_lists2_txt {
      width: auto;
      font-weight: 700;
      font-size: 1.1rem;
      line-height: calc(30/22);
      top: 1.5rem;
      right: 1.5rem;
      left: initial; } }

.en .check_lists2_txt {
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .en .check_lists2_txt {
      font-size: 1rem;
      right: 0;
      width: calc(100% - 3rem);
      top: 3rem; } }

.check_list {
  position: relative;
  padding: 60px 30px 84px; }
  @media screen and (max-width: 991px) {
    .check_list {
      padding: 4.8rem 2rem 1rem; } }

.check_list:nth-child(1) {
  background-color: #fef4e9; }

.check_list:nth-child(2) {
  background-color: #edf6fc; }

.check_list_icon {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  left: 50%;
  transform: translateX(-50%);
  width: 70px;
  height: 70px;
  top: -20px;
  border-radius: 50%;
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .check_list_icon {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .check_list_icon {
      width: 4.2rem;
      height: 4.2rem;
      font-size: 1.4rem;
      transform: translateX(0%);
      left: 1rem;
      top: -1rem; } }

@media screen and (max-width: 991px) {
  .en .check_list_icon {
    left: 50%;
    transform: translateX(-50%); } }

.check_lists2 .check_list_icon {
  transform: translateX(0);
  left: 20px; }
  @media screen and (max-width: 991px) {
    .check_lists2 .check_list_icon {
      left: 0.7rem; } }

@media screen and (max-width: 991px) {
  .en .check_lists2 .check_list {
    padding-top: 8rem; } }

.yes {
  background-color: #f38f2c; }

.no {
  background-color: #51a4dd; }

.check_list_wrap {
  display: grid;
  gap: 18px;
  align-items: center;
  grid-template-columns: 120px 1fr; }
  @media screen and (max-width: 991px) {
    .check_list_wrap {
      grid-template-columns: 7.5rem 1fr;
      gap: 0.5rem; } }

.check_list_wrap_top {
  align-items: flex-start; }

.check_list_txt {
  font-size: 2rem;
  font-weight: 900;
  line-height: calc(25/20);
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .check_list_txt {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .check_list_txt {
      font-size: 1.2rem;
      letter-spacing: 0.05em;
      line-height: calc(30/26); } }
  .check_list_txt small {
    display: block;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: calc(20/14);
    letter-spacing: 0.05em; }
    @media screen and (max-width: 991px) {
      .check_list_txt small {
        font-size: 0.9rem;
        letter-spacing: normal;
        line-height: calc(25/18); } }

.check_list_txt span {
  display: inline-block;
  line-height: 1;
  color: white;
  font-size: 1.5rem;
  font-weight: 900;
  padding: 5px 8px;
  background-color: #028ae6;
  margin-top: 6px; }
  @media screen and (max-width: 991px) {
    .check_list_txt span {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .check_list_txt span {
      display: inline-flex;
      align-items: center;
      font-size: 1rem;
      padding: 0.4rem 0.6rem; } }
  .check_list_txt span img {
    display: inline-block;
    width: 18px;
    margin-right: 0.7rem; }
    @media screen and (max-width: 991px) {
      .check_list_txt span img {
        width: 1.2rem; } }

@media screen and (max-width: 991px) {
  .en .check_list_txt span {
    font-size: 0.8rem; } }

.check_list_btn {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 23px;
  max-width: 200px;
  width: 100%;
  margin-inline: auto;
  margin-top: 14px; }
  @media screen and (max-width: 991px) {
    .check_list_btn {
      position: relative;
      max-width: 12.5rem;
      left: initial;
      transform: translateX(0);
      bottom: initial;
      margin-top: 1rem; } }

@media screen and (max-width: 991px) {
  .en .check_list_btn {
    max-width: fit-content; } }

.check_list_btn a {
  display: inline-block;
  width: 100%;
  text-align: center;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.15em;
  color: #f4810e;
  background-color: white;
  border-radius: 20px;
  padding-block: 12px;
  line-height: 1;
  border: 1px solid #f4810e;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .check_list_btn a {
      font-weight: 700;
      font-size: 1.1rem;
      padding-block: 1rem; } }

.en .check_list_btn a {
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .en .check_list_btn a {
      padding-inline: 1em;
      letter-spacing: 0.15em; } }

.check_list_btn a:hover {
  color: white;
  background-color: #f4810e; }

.check_list_btn_blue a {
  border-color: #51a4dd;
  color: #51a4dd; }

.check_list_btn_blue a:hover {
  background-color: #51a4dd;
  color: white; }

.check_list_lead {
  position: absolute;
  left: calc(50% + 1rem);
  transform: translateX(-50%);
  width: 100%;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  top: 1.3rem;
  display: none; }
  @media screen and (max-width: 991px) {
    .check_list_lead {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .check_list_lead {
      display: block; } }

.check_list_boxs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px; }
  @media screen and (max-width: 991px) {
    .check_list_boxs {
      grid-template-columns: 1fr;
      gap: 1rem; } }

.check_list_box {
  position: relative;
  background-color: white;
  border-radius: 5px;
  padding: 20px 20px 80px; }
  @media screen and (max-width: 991px) {
    .check_list_box {
      padding: 1.5rem 1rem 1.5rem; } }

.check_list_txt2 {
  font-size: 1.5rem;
  line-height: calc(22/15);
  letter-spacing: 0.05em;
  margin-top: 16px; }
  @media screen and (max-width: 991px) {
    .check_list_txt2 {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-top: 1.2rem; } }
  .check_list_txt2 span {
    font-weight: 900;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .check_list_txt2 span {
        font-weight: 700; } }

/* ============================================================================
取付けの可否
============================================================================== */
.answer {
  padding-top: 70px;
  padding-bottom: 60px; }
  @media screen and (max-width: 991px) {
    .answer {
      padding-top: 3.8rem;
      padding-bottom: 3rem; } }

.answer_ttl h2 {
  font-size: 3rem; }
  @media screen and (max-width: 991px) {
    .answer_ttl h2 {
      font-size: 1.5rem; } }

@media screen and (max-width: 991px) {
  .en .answer_ttl h2 {
    font-size: 1.3rem; } }

.answer_txt {
  max-width: 735px;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(25/16);
  letter-spacing: 0.1em;
  margin-inline: auto;
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .answer_txt {
      font-size: 1.1rem;
      line-height: calc(30/22);
      margin-top: 1.4rem; } }

.answer_arrow {
  background-color: #f38f2c;
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  width: 300px;
  height: 45px;
  margin-inline: auto;
  margin-top: 20px;
  animation: fuwafuwa 2s linear infinite; }
  @media screen and (max-width: 991px) {
    .answer_arrow {
      width: 15rem;
      height: 2.25rem;
      margin-top: 0.8rem; } }

@keyframes fuwafuwa {
  0% {
    transform: translateY(0); }
  50% {
    transform: translateY(-10%); }
  100% {
    transform: translateY(0); } }
.check_item_txt {
  margin-top: 14px; }
  @media screen and (max-width: 991px) {
    .check_item_txt {
      margin-top: 1.5rem; } }
  .check_item_txt p {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: calc(25/16);
    letter-spacing: 0.05em; }
    @media screen and (max-width: 991px) {
      .check_item_txt p {
        font-size: 1.1rem;
        line-height: calc(30/22); } }
  .check_item_txt p + p {
    margin-top: 1em; }

.check_item_figure {
  display: block;
  max-width: 800px;
  margin-inline: auto;
  margin-top: 28px; }
  @media screen and (max-width: 991px) {
    .check_item_figure {
      margin-top: 1rem; } }

.check_torque {
  margin-top: 42px; }
  @media screen and (max-width: 991px) {
    .check_torque {
      margin-top: 2.1rem; } }
  .check_torque p {
    font-size: 1.8rem;
    font-weight: 900;
    line-height: calc(30/18); }
    @media screen and (max-width: 991px) {
      .check_torque p {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .check_torque p {
        text-align: center;
        font-size: 1.2rem; } }
  .check_torque p:nth-child(1) {
    text-align: center; }
  .check_torque p:nth-child(3) {
    width: fit-content;
    margin-inline: auto;
    margin-top: 52px; }
    @media screen and (max-width: 991px) {
      .check_torque p:nth-child(3) {
        text-align: left;
        margin-top: 2.4rem; } }

.check_btn {
  max-width: 300px;
  width: 100%;
  margin-top: 22px;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .check_btn {
      max-width: 15rem;
      margin-top: 1rem; } }

.check_torque_btn {
  margin-inline: auto;
  max-width: 500px;
  margin-inline: auto;
  margin-top: 14px; }
  @media screen and (max-width: 991px) {
    .check_torque_btn {
      max-width: 25rem;
      margin-top: 1rem; } }

.check_torque_btn a {
  position: relative;
  display: inline-block;
  text-align: center;
  padding-block: 22px;
  width: 100%;
  color: white;
  font-size: 2.4rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.5em;
  border-radius: 10px;
  background-color: #0071be;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .check_torque_btn a {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .check_torque_btn a {
      font-size: 1.4rem;
      letter-spacing: 0.3em;
      padding-block: 1rem;
      border-radius: 1rem; } }

.en .check_torque_btn a {
  letter-spacing: normal; }

.check_torque_btn a:hover {
  opacity: 0.8; }

.check_torque_btn a::before {
  position: absolute;
  content: "";
  top: 50%;
  width: 40px;
  height: 40px;
  left: 62px;
  transform: translateY(-50%);
  background: url(../img/img-guide/check_icon_01.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .check_torque_btn a::before {
      width: 2rem;
      height: 2rem;
      left: 2.5rem; } }

.en .check_torque_btn a::before {
  left: 24px; }
  @media screen and (max-width: 991px) {
    .en .check_torque_btn a::before {
      display: none; } }

.check_torque_btn a::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 8px;
  right: 40px;
  background-color: white;
  clip-path: polygon(0 0, 50% 100%, 100% 0); }
  @media screen and (max-width: 991px) {
    .check_torque_btn a::after {
      width: 0.5rem;
      height: 0.375rem;
      right: 1.5rem; } }

/* ============================================================================
トルク計算
============================================================================== */
.torque {
  background-color: #e4f0fd; }

.torque_inner.inner {
  max-width: 1050px; }

.torque_ttl {
  position: relative;
  width: fit-content;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .torque_ttl {
      padding-left: 2rem; } }

.torque_ttl::before {
  position: absolute;
  content: "";
  width: 152px;
  height: 127px;
  top: 50%;
  transform: translateY(-50%);
  left: -152px;
  background: url(../img/img-guide/torque_01.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .torque_ttl::before {
      width: 7.6rem;
      height: 6.3rem;
      bottom: 0;
      left: -5.4rem; } }

.en .torque_ttl::before {
  left: -198px; }
  @media screen and (max-width: 991px) {
    .en .torque_ttl::before {
      left: -1rem;
      bottom: -5rem;
      top: initial; } }

.torque_lead {
  font-size: 1.6rem;
  line-height: calc(25/16);
  letter-spacing: 0.1em;
  text-align: center;
  margin-top: 32px; }
  @media screen and (max-width: 991px) {
    .torque_lead {
      text-align: left;
      font-size: 1.1rem;
      line-height: calc(30/22); } }
  .torque_lead strong {
    display: block;
    font-size: 1.8rem;
    margin-bottom: 12px; }
    @media screen and (max-width: 991px) {
      .torque_lead strong {
        text-align: center;
        font-size: 1.2rem;
        margin-bottom: 1.2rem; } }

.torque_box {
  background-color: white;
  box-shadow: 0 0 10px rgba(3, 53, 108, 0.2);
  border-radius: 10px;
  padding: 40px 32px 52px;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .torque_box {
      padding: 1.5rem 0.5rem 3.5rem;
      border-radius: 0.5rem;
      margin-top: 1rem; } }

.torque_box_2 {
  padding: 60px 30px; }
  @media screen and (max-width: 991px) {
    .torque_box_2 {
      padding: 2rem 1.5rem;
      margin-top: 2rem; } }

.torque_middle {
  margin-top: 62px; }
  @media screen and (max-width: 991px) {
    .torque_middle {
      margin-top: 2.5rem; } }
  .torque_middle p {
    text-align: center;
    font-size: 2rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0.15em; }
    @media screen and (max-width: 991px) {
      .torque_middle p {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .torque_middle p {
        font-size: 1.2rem;
        line-height: calc(26/24); } }

.torque_arrow {
  margin: 0 auto;
  margin-top: 20px;
  width: 200px;
  height: 30px;
  background-color: #03356c;
  clip-path: polygon(0 0, 50% 100%, 100% 0); }
  @media screen and (max-width: 991px) {
    .torque_arrow {
      width: 10rem;
      height: 1.5rem;
      margin-top: 1.5rem; } }

.torque_bottom {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .torque_bottom {
      margin-top: 2.3rem; } }
  .torque_bottom p {
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    line-height: calc(30/18);
    width: fit-content;
    margin: 0 auto; }
    @media screen and (max-width: 991px) {
      .torque_bottom p {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .torque_bottom p {
        font-size: 1.2rem;
        line-height: calc(35/24); } }

.torque_btn {
  max-width: 300px;
  width: 100%;
  margin-inline: auto;
  margin-top: 18px;
  cursor: pointer; }
  @media screen and (max-width: 991px) {
    .torque_btn {
      max-width: 15rem;
      margin-top: 1.2rem; } }

@media screen and (max-width: 991px) {
  .torque_units {
    margin-top: 2.3rem; } }

.torque_unit {
  position: relative;
  z-index: 1; }

.torque_unit:not(:last-child)::before {
  position: absolute;
  content: "";
  height: 100%;
  background-color: #edf6fc;
  width: 1px;
  left: 25px;
  top: 0;
  z-index: -1; }
  @media screen and (max-width: 991px) {
    .torque_unit:not(:last-child)::before {
      left: 1.5rem; } }

.torque_unit + .torque_unit {
  padding-top: 55px; }
  @media screen and (max-width: 991px) {
    .torque_unit + .torque_unit {
      padding-top: 3rem; } }

.torque_unit_ttl {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  gap: 16px; }
  @media screen and (max-width: 991px) {
    .torque_unit_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .torque_unit_ttl {
      gap: 0.6rem;
      font-size: 1.1rem;
      padding-left: 3.6rem;
      line-height: calc(30/22); } }
  .torque_unit_ttl > span {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: 900;
    color: #0071be;
    background-color: #e4f0fd; }
    @media screen and (max-width: 991px) {
      .torque_unit_ttl > span {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .torque_unit_ttl > span {
        position: absolute;
        left: 0;
        top: 50%;
        transform: translateY(-50%);
        font-size: 1.3rem;
        width: 3rem;
        height: 3rem; } }
  .torque_unit_ttl a {
    text-decoration: underline;
    font-size: 1.4rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    font-feature-settings: "palt";
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .torque_unit_ttl a {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .torque_unit_ttl a {
        display: block;
        font-size: 1rem;
        position: absolute;
        bottom: -1.5em;
        right: 1.2rem; } }
    .torque_unit_ttl a span {
      font-size: 1.2rem; }
      @media screen and (max-width: 991px) {
        .torque_unit_ttl a span {
          font-size: 1rem; } }

.torque_lists {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  padding-left: 60px;
  margin-top: 26px; }
  @media screen and (max-width: 991px) {
    .torque_lists {
      grid-template-columns: 1fr;
      gap: 1rem;
      margin-top: 2.5rem;
      padding-left: 2rem; } }

.torque_lists_2 {
  max-width: 732px;
  padding-left: 0;
  margin-inline: auto;
  margin-top: 62px; }
  @media screen and (max-width: 991px) {
    .torque_lists_2 {
      margin-top: 2rem; } }

.torque_list {
  font-size: 1.4rem;
  font-weight: 900;
  line-height: calc(24/14); }
  @media screen and (max-width: 991px) {
    .torque_list {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .torque_list {
      font-size: 0.9rem;
      line-height: 2rem; } }

.torque_list p {
  display: flex;
  align-items: center;
  font-feature-settings: "palt";
  gap: 8px; }
  @media screen and (max-width: 991px) {
    .torque_list p {
      gap: 0.4rem;
      white-space: nowrap;
      letter-spacing: 0; } }
  .torque_list p span {
    border-radius: 50%;
    color: white;
    background-color: #0071be;
    width: 25px;
    height: 25px;
    display: flex;
    align-items: center;
    justify-content: center; }
    @media screen and (max-width: 991px) {
      .torque_list p span {
        font-size: 1rem;
        width: 1.75rem;
        height: 1.75rem; } }
  .torque_list p > span.no_bg {
    background-color: transparent;
    display: none; }
    @media screen and (max-width: 991px) {
      .torque_list p > span.no_bg {
        display: inline-block; } }

.torque_list input,
.torque_list select {
  display: inline-block;
  height: 40px;
  width: 250px;
  border: 1px solid #cacaca;
  border-radius: 5px;
  margin-top: 10px;
  margin-right: 10px;
  padding-inline: 0.5em;
  appearance: none; }
  @media screen and (max-width: 991px) {
    .torque_list input,
    .torque_list select {
      width: 12.5rem;
      height: 2rem;
      margin-left: 1.8rem;
      margin-top: 0; } }

.torque_list select {
  background: url(../img/img-guide/select_arrow.png) 95% center/13px no-repeat; }

@media screen and (max-width: 991px) {
  .torque_scroll {
    overflow-x: scroll; } }

.torque_table {
  width: 100%; }
  @media screen and (max-width: 991px) {
    .torque_table {
      min-width: 66rem; } }
  .torque_table tr {
    display: grid;
    grid-template-columns: 290px 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
    line-height: 1;
    padding-block: 10px;
    padding-inline: 20px; }
    @media screen and (max-width: 991px) {
      .torque_table tr {
        grid-template-columns: 20rem 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
        padding-block: 1rem;
        padding-inline: 2rem; } }
  .torque_table tr:nth-child(odd) {
    background: rgba(2, 138, 230, 0.1); }
  .torque_table td {
    font-size: 1.4rem;
    font-weight: 900; }
    @media screen and (max-width: 991px) {
      .torque_table td {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .torque_table td {
        font-size: 1rem; } }
  .torque_table td:not(:first-child) {
    text-align: center;
    letter-spacing: 0.1em; }

#curve_chart {
  width: 450px;
  height: 450px;
  margin: 0 auto;
  margin-top: 3px; }
  @media screen and (max-width: 991px) {
    #curve_chart {
      width: 22.5rem;
      height: 22.5rem; } }

.torque_note {
  width: fit-content;
  margin: 0 auto;
  font-size: 1.4rem;
  line-height: calc(20/14);
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .torque_note {
      max-width: 22.5rem;
      font-size: 1rem;
      line-height: calc(25/20);
      margin-top: 1rem; } }

.torque_btn input {
  background-color: #0071be;
  border-color: #0071be; }

/* ============================================================================
ストッパーピン
============================================================================== */
.pin {
  width: 92%;
  border: 2px dotted #03356c;
  border-radius: 12px;
  margin-top: 48px;
  margin-inline: auto;
  padding: 30px 50px; }
  @media screen and (max-width: 991px) {
    .pin {
      max-width: 23rem;
      width: 100%;
      border-radius: 0.6rem;
      border-width: 0.1rem;
      padding: 1.5rem 1rem;
      margin-top: 3rem; } }

.pin_ttl {
  display: flex;
  align-items: center;
  color: #03356c;
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  line-height: 1;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(3, 53, 108, 0.1); }
  @media screen and (max-width: 991px) {
    .pin_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .pin_ttl {
      flex-wrap: wrap;
      font-size: 1.3rem;
      padding-bottom: 0.6rem; } }
  .pin_ttl img {
    width: 26px;
    margin-right: 10px; }
    @media screen and (max-width: 991px) {
      .pin_ttl img {
        width: 1.3rem;
        margin-right: 0.5rem; } }
  .pin_ttl small {
    font-size: 1.5rem;
    font-weight: 900;
    color: #333333; }
    @media screen and (max-width: 991px) {
      .pin_ttl small {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .pin_ttl small {
        font-size: 1.3rem;
        margin-top: 0.5rem;
        font-feature-settings: "palt"; } }

.pin_wrap {
  display: grid;
  grid-template-columns: 1fr 230px;
  gap: 34px;
  margin-top: 18px;
  padding-right: 20px; }
  @media screen and (max-width: 991px) {
    .pin_wrap {
      max-width: 187.5rem;
      grid-template-columns: 1fr;
      gap: 1.5rem;
      margin-top: 0.9rem;
      padding: 0; } }
  @media screen and (max-width: 991px) {
    .pin_wrap picture {
      width: 14.4rem;
      display: block;
      margin: 0 auto; } }
  .pin_wrap p {
    font-size: 1.5rem;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: calc(25/15); }
    @media screen and (max-width: 991px) {
      .pin_wrap p {
        font-size: 1rem;
        line-height: 1.5;
        order: 1; } }

/* ============================================================================
フリーストップ型との違い
============================================================================== */
.difference {
  padding-top: 76px;
  padding-bottom: 65px;
  background-color: #edf4f6; }
  @media screen and (max-width: 991px) {
    .difference {
      padding-top: 4rem;
      padding-bottom: 4rem; } }

.difference_ttl {
  font-size: 2.8rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.15em;
  color: #03356c;
  text-align: center; }
  @media screen and (max-width: 991px) {
    .difference_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .difference_ttl {
      font-size: 1.6rem; } }

.difference_wrap {
  max-width: 875px;
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 30px;
  margin-inline: auto;
  margin-top: 42px; }
  @media screen and (max-width: 991px) {
    .difference_wrap {
      grid-template-columns: 1fr;
      gap: 0;
      margin-top: 1.5rem; } }

@media screen and (max-width: 991px) {
  .difference_content {
    display: contents; } }
.difference_content p {
  font-size: 1.6rem;
  font-weight: 400;
  line-height: calc(25/16);
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .difference_content p {
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.1em;
      margin-top: 1.4rem; } }
  .difference_content p span {
    font-weight: 900;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .difference_content p span {
        font-weight: 700; } }

.difference_btn {
  max-width: 350px;
  width: 100%;
  margin-inline: auto;
  margin-top: 34px; }
  @media screen and (max-width: 991px) {
    .difference_btn {
      max-width: 22.5rem;
      margin-top: 1.9rem; } }
  .difference_btn a {
    font-size: 1.6rem;
    line-height: calc(25/16);
    text-align: center;
    letter-spacing: 0.05em;
    background-color: #284b8a;
    border-radius: 35px;
    padding-block: 12px; }
    @media screen and (max-width: 991px) {
      .difference_btn a {
        font-size: 1.1rem;
        line-height: calc(30/22);
        letter-spacing: 0.2em;
        padding-block: 0.6rem; } }

.difference_img {
  text-align: center; }
  @media screen and (max-width: 991px) {
    .difference_img {
      max-width: 25rem;
      margin-inline: auto;
      order: -1; } }

/* ============================================================================
防水タイプが必要なケース
============================================================================== */
.productWater_wrap {
  max-width: 875px;
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 30px;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .productWater_wrap {
      grid-template-columns: 1fr;
      gap: 0; } }

@media screen and (max-width: 991px) {
  .productWater_content {
    display: contents; } }
.productWater_content h2 {
  display: flex;
  align-items: center;
  color: #03356c;
  gap: 18px;
  font-size: 2.8rem;
  font-weight: 900;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .productWater_content h2 {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .productWater_content h2 {
      order: -2;
      justify-content: center;
      font-size: 1.6rem;
      gap: 1.1rem; } }
.productWater_content h2 img {
  width: 45px; }
  @media screen and (max-width: 991px) {
    .productWater_content h2 img {
      width: 2.8rem; } }
.productWater_content p {
  margin-top: 24px; }
  @media screen and (max-width: 991px) {
    .productWater_content p {
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.1em;
      margin-top: 1.5rem; } }
  .productWater_content p span {
    font-weight: 900;
    color: #03356c; }
    @media screen and (max-width: 991px) {
      .productWater_content p span {
        font-weight: 700; } }

@media screen and (max-width: 991px) {
  .productWater_img {
    max-width: 25rem;
    order: -1;
    display: block;
    margin-inline: auto;
    margin-top: 1.5rem; } }

.productWater_box {
  max-width: 875px;
  margin-inline: auto;
  margin-top: 40px;
  padding: 20px 34px;
  border: 2px dotted #03356c;
  border-radius: 12px; }
  @media screen and (max-width: 991px) {
    .productWater_box {
      max-width: 27rem;
      padding: 1.5rem 1.4rem;
      margin-inline: auto;
      margin-top: 1rem; } }
  .productWater_box h3 {
    color: #03356c;
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.05em; }
    @media screen and (max-width: 991px) {
      .productWater_box h3 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .productWater_box h3 {
        font-size: 1.1rem;
        font-weight: 900;
        line-height: calc(25/22); } }
  @media screen and (max-width: 991px) and (max-width: 991px) {
    .productWater_box h3 {
      font-weight: 700; } }

  .productWater_box p {
    font-size: 1.8rem;
    line-height: calc(25/18);
    font-weight: 400;
    letter-spacing: 0.05em;
    margin-top: 4px; }
    @media screen and (max-width: 991px) {
      .productWater_box p {
        font-size: 1.1rem;
        letter-spacing: 0.1em;
        line-height: calc(30/22);
        margin-top: 0.8rem; } }

/* ============================================================================
資料請求
============================================================================== */
.document {
  background-color: #e4f0fd;
  padding-top: 80px;
  padding-bottom: 90px; }
  @media screen and (max-width: 991px) {
    .document {
      padding-top: 3rem;
      padding-bottom: 4rem; } }

.document_box {
  background-color: white;
  padding: 60px 40px; }
  @media screen and (max-width: 991px) {
    .document_box {
      padding: 2.5rem 1.8rem; } }

.document_box + .document_box {
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .document_box + .document_box {
      margin-top: 3rem; } }

.document_box_ttl {
  position: relative;
  display: flex;
  align-items: center;
  gap: 30px;
  padding-left: 40px; }
  @media screen and (max-width: 991px) {
    .document_box_ttl {
      gap: 0;
      justify-content: space-between;
      padding-left: 0.5rem; } }
  .document_box_ttl h2 {
    font-size: 3rem;
    font-weight: 900;
    color: #03356c;
    letter-spacing: 0.2em; }
    @media screen and (max-width: 991px) {
      .document_box_ttl h2 {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .document_box_ttl h2 {
        font-size: 1.5rem;
        letter-spacing: 0.1em; } }

.document_box_ttl::before {
  position: absolute;
  content: "";
  width: 70px;
  height: 70px;
  top: -14px;
  left: 0;
  background: url(../img/img-request/icon.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .document_box_ttl::before {
      width: 3.5rem;
      height: 3.5rem;
      top: -1.5rem; } }

.document_btn a {
  position: relative;
  color: #03356c;
  border: 1px solid #03356c;
  display: inline-block;
  font-size: 1.4rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.05em;
  padding: 7px 27px 7px 19px;
  border-radius: 15px;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .document_btn a {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .document_btn a {
      font-size: 1rem;
      padding: 0.4rem 1.7rem 0.4rem 1rem; } }
.document_btn a::before {
  position: absolute;
  content: "";
  width: 6px;
  height: 8px;
  top: 50%;
  transform: translateY(-50%);
  right: 11px;
  background-color: #03356c;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .document_btn a::before {
      width: 0.375rem;
      height: 0.5rem;
      right: 0.6rem; } }
.document_btn a:hover {
  background-color: #03356c;
  color: white; }
  .document_btn a:hover::before {
    background-color: white; }

.document_head {
  display: grid;
  grid-template-columns: 1fr 34% 21.3%;
  margin-top: 20px;
  border-bottom: 1px solid rgba(3, 53, 108, 0.55); }
  @media screen and (max-width: 991px) {
    .document_head {
      grid-template-columns: 1fr 28% 26%;
      margin-top: 1.3rem; } }

.document_head2 {
  display: grid;
  grid-template-columns: 1fr 18.75% 18.75%;
  padding-inline: 40px;
  margin-top: 20px;
  border-bottom: 1px solid rgba(3, 53, 108, 0.55); }
  @media screen and (max-width: 991px) {
    .document_head2 {
      padding: 0;
      grid-template-columns: 1fr 26% 26%; } }

.document_head span,
.document_head2 span {
  display: block;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 900;
  color: #03356c;
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .document_head span,
    .document_head2 span {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .document_head span,
    .document_head2 span {
      font-size: 1rem; } }

.document_table {
  display: grid;
  width: calc(100% - 80px);
  grid-template-columns: 1fr 36.875% 18.75%;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .document_table {
      width: 100%;
      grid-template-columns: 1fr 28% 26%; } }

.document_table2 {
  display: grid;
  width: calc(100% - 80px);
  grid-template-columns: 1fr 18.75% 18.75%;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .document_table2 {
      width: 100%;
      grid-template-columns: 1fr 26% 26%; } }

.document_name {
  display: grid;
  grid-template-rows: repeat(10, 80px); }
  @media screen and (max-width: 991px) {
    .document_name {
      grid-template-rows: repeat(17, 4.5rem); } }
  .document_name p {
    display: flex;
    align-items: center;
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    padding-left: 30px;
    border-bottom: 1px solid rgba(3, 53, 108, 0.3);
    font-feature-settings: "palt"; }
    @media screen and (max-width: 991px) {
      .document_name p {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .document_name p {
        height: 9rem;
       }
      .document_name p {
        grid-row: span 2;
        font-size: 1.2rem;
        padding-left: 1rem;
        line-height: calc(30/24); } }
       
      .document_name_2 p {
        grid-row: span 1;
        height: auto;
      }

.document_name_2 {
  grid-template-rows: repeat(2, 80px); }
  @media screen and (max-width: 991px) {
    .document_name_2 {
      grid-template-rows: repeat(2, 4.5rem); } }

.document_figure {
  display: grid;
  grid-template-rows: repeat(10, 80px); }
  @media screen and (max-width: 991px) {
    .document_figure {
      grid-template-rows: repeat(17, 4.5rem); } }
  .document_figure ul {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    border-bottom: 1px solid rgba(3, 53, 108, 0.3); }
.document_figure ul.three {
  grid-row: span 3;
}
    @media screen and (max-width: 991px) {
      .document_figure ul {
        font-weight: 700; } }
    @media screen and (max-width: 991px) {
      .document_figure ul {
        grid-template-columns: repeat(3, 1fr);
        grid-row: span 2;
        justify-content: center;
        flex-direction: column;
        font-size: 1.1rem;
        height: 9rem;
        padding: 0.5rem; } }
  .document_figure ul li {
    background-color: #f1f8fe;
    padding: 10px 0px 10px 20px; }
    @media screen and (max-width: 991px) {
      .document_figure ul li {
        display: flex;
        width: 100%;
        align-items: center;
        max-height: 30px;
        height: 100%;
        padding: 0.4rem 0 0.2rem 0.9rem;
        border-radius: 0; } }
  .document_figure ul li:first-child {
    border-radius: 5px 0 0 5px; }
    @media screen and (max-width: 991px) {
      .document_figure ul li:first-child {
        border-radius: 5px 5px 0 0; } }
  .document_figure ul li:last-child {
    padding-right: 20px;
    border-radius: 0 5px 5px 0; }
    @media screen and (max-width: 991px) {
      .document_figure ul li:last-child {
        padding-right: 0;
        border-radius: 0 0 5px 5px; } }

.document_figure_2 {
  grid-template-rows: repeat(2, 80px); }
  @media screen and (max-width: 991px) {
    .document_figure_2 {
      grid-template-rows: repeat(2, 4.5rem); } }
  @media screen and (max-width: 991px) and (max-width: 991px) {
    .document_figure_2 ul {
      grid-row: span 1;
      height: auto;
    }
    .document_figure_2 ul li:first-child {
      border-radius: 5px; } }

.document_manual {
  display: grid;
  grid-template-rows: repeat(10, 80px); }
  @media screen and (max-width: 991px) {
    .document_manual {
      grid-template-rows: repeat(17, 4.5rem); } }
  .document_manual ul {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.8rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    border-left: 1px solid rgba(3, 53, 108, 0.3);
    border-bottom: 1px solid rgba(3, 53, 108, 0.3);
    grid-row: span 2; }
.document_manual ul.one {
  grid-row: span 1;
}
.document_manual ul.three {
  grid-row: span 3;
}
    @media screen and (max-width: 991px) {
      .document_manual ul.one {
        grid-row: span 2;
      }
      .document_manual ul.three {
        grid-row: span 6;
      }
      .document_manual ul {
        padding-left: 0.5rem;
        grid-row: span 4;
        font-weight: 700; } }
  .document_manual ul li {
    background-color: #f1f8fe;
    padding: 10px 20px;
    border-radius: 5px; }
    @media screen and (max-width: 991px) {
      .document_manual ul li {
        display: flex;
        align-items: center;
        max-height: 30px;
        height: 100%;
        padding: 0.2rem 0.9rem;
        padding: 0.4rem 0.4rem 0.4rem 0.9rem; } }

.document_manual_2 {
  grid-template-rows: repeat(2, 80px); }
  @media screen and (max-width: 991px) {
    .document_manual_2 {
      grid-template-rows: repeat(2, 4.5rem); } }
  .document_manual_2 ul {
    border-left: none; }
    @media screen and (max-width: 991px) {
      .document_manual_2 ul {
        border-left: 1px solid rgba(3, 53, 108, 0.3);
        padding: 0.5rem; } }
  .document_manual_2 ul:nth-child(1),
  .document_manual_2 ul:nth-child(2) {
    grid-row: span 1; }
  @media screen and (max-width: 991px) {
    .document_manual_2 li {
      width: 100%; } }

form input[type="checkbox"] {
  appearance: none;
  display: none;
  border: none;
  background-color: transparent; }

form input[type="checkbox"] + span {
  position: relative;
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  padding-left: 30px; }
  @media screen and (max-width: 991px) {
    form input[type="checkbox"] + span {
      font-size: 1.1rem;
      line-height: 1.8rem;
      padding-left: 1.8rem; } }

form input[type="checkbox"] + span::before {
  position: absolute;
  content: "";
  width: 20px;
  height: 20px;
  background-color: white;
  border-radius: 2px;
  border: 1px solid #03356c;
  left: 0;
  top: 47%;
  transform: translateY(-50%); }
  @media screen and (max-width: 991px) {
    form input[type="checkbox"] + span::before {
      width: 1.4rem;
      height: 1.4rem;
      border-radius: 2px; } }

form input[type="checkbox"] + span::after {
  content: '';
  position: absolute;
  width: 7px;
  height: 11px;
  top: 50%;
  margin-top: -2px;
  left: 6px;
  -webkit-transform: translateY(-50%) rotate(45deg);
  transform: translateY(-50%) rotate(45deg);
  border-right: 2px solid #bf0005;
  border-bottom: 2px solid #bf0005;
  opacity: 0; }
  @media screen and (max-width: 991px) {
    form input[type="checkbox"] + span::after {
      left: 5px; } }

form input[type="checkbox"]:checked + span::after {
  opacity: 1; }

/* ============================================================================
フォーム
============================================================================== */
.request {
  padding-bottom: 0; }

.request_form {
  margin-top: 100px; }
  @media screen and (max-width: 991px) {
    .request_form {
      margin-top: 4rem; } }

@media screen and (max-width: 991px) {
  .form_inner.inner_s {
    max-width: unset; } }

.form_head {
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .form_head {
      font-weight: 700; } }

.cmn_table_type04 {
  margin-top: 20px; }

.cmn_table_type04 th small {
  display: inline-block;
  font-weight: normal;
  font-size: 1.3rem;
  margin-top: 4px; }
  @media screen and (max-width: 991px) {
    .cmn_table_type04 th small {
      font-size: 0.8rem; } }

form td input + p {
  font-size: 1.3rem;
  line-height: calc(19/13);
  letter-spacing: 0.1em;
  margin-top: 12px; }

form td p:nth-child(1) {
  font-size: 1.3rem;
  letter-spacing: 0.1em;
  margin-bottom: 8px; }

.in_checkOuter {
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .in_checkOuter {
      margin-top: 0.4rem; } }

.in_checkOuter:first-child {
  margin-top: 0; }

.in_checkOuter ul {
  display: grid;
  row-gap: 20px;
  width: 100%;
  grid-template-columns: 30% 26% 1fr 26%; }
  @media screen and (max-width: 991px) {
    .in_checkOuter ul {
      grid-template-columns: repeat(2, 1fr);
      gap: 1rem 0.5rem; } }
  .in_checkOuter ul input[type="checkbox"] + span {
    font-size: 1.4rem; }
    @media screen and (max-width: 991px) {
      .in_checkOuter ul input[type="checkbox"] + span {
        font-size: 1.1rem; } }

.en .in_checkOuter ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 20px; }
  @media screen and (max-width: 991px) {
    .en .in_checkOuter ul {
      gap: 1rem 0.5rem; } }

tr:first-child .in_checkOuter ul {
  grid-template-columns: 27% 29% 1fr 26%; }
  @media screen and (max-width: 991px) {
    tr:first-child .in_checkOuter ul {
      grid-template-columns: repeat(2, 1fr); } }

@media screen and (max-width: 991px) {
  .form_tbl_caution {
    display: block;
    margin-top: 0.5rem; } }

@media screen and (max-width: 991px) {
  .form #contents .mail em.tx_min {
    margin-top: 0.5rem; } }

.form_privacy {
  max-width: 700px;
  padding: 20px;
  margin-inline: auto;
  margin-top: 60px;
  border: 1px solid #333; }
  @media screen and (max-width: 991px) {
    .form_privacy {
      margin-top: 3rem;
      padding: 2rem; } }

.form_privacy p {
  width: fit-content;
  font-size: 1.4rem;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .form_privacy p {
      font-size: 1.1rem; } }

.form_privacy p a {
  text-decoration: underline; }

@media screen and (max-width: 991px) {
  .tx_min {
    margin-top: 0.5rem; } }

@media screen and (max-width: 991px) {
  form td p:nth-child(1) {
    font-size: 1.1rem;
    letter-spacing: 0.05em; } }

label {
  display: block;
  line-height: 1; }

/* ============================================================================
確認画面
============================================================================== */
.chk {
  padding-bottom: 0; }
  @media screen and (max-width: 991px) {
    .chk {
      padding-top: 10rem; } }

.form_send_text {
  text-align: center;
  margin-bottom: 2em; }

/* ============================================================================
サンクスページ
============================================================================== */
.thanks {
  padding-bottom: 0; }
  @media screen and (max-width: 991px) {
    .thanks {
      padding-top: 10rem; } }

.form_block_thanks {
  position: relative;
  z-index: 1;
  display: table;
  margin: 0 auto 30px; }

.form #contents input[type="submit"].btn_top {
  display: block;
  margin-inline: auto; }

/* ============================================================================
よくある質問
============================================================================== */
.faqTab {
  background-color: #e1efff;
  padding-block: 40px; }

.faqTab ul {
  max-width: 840px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px 30px;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .faqTab ul {
      grid-template-columns: repeat(2, 1fr);
      gap: 0.5rem; } }

.faqTab li {
  height: 70px; }

.faqTab li a {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: white;
  font-size: 1.6rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: #03356c;
  border-radius: 10px;
  transition: all 0.3s; }
  @media screen and (max-width: 991px) {
    .faqTab li a {
      font-weight: 700;
      text-align: center;
      font-size: 1.2rem;
      line-height: calc(30/24);
      border-radius: 0.5rem; } }

.en .en .faqTab li {
  height: 80px; }

@media screen and (max-width: 991px) {
  .en .en .faqTab li:last-child {
    grid-column: 1/3; } }

.en .faqTab li a {
  text-align: center;
  font-size: 1.4rem;
  letter-spacing: normal;
  line-height: 1.25; }

.faqTab li a:hover {
  opacity: 0.8; }

.faqTab li a::before {
  position: absolute;
  content: "";
  left: 50%;
  transform: translateX(-50%);
  width: 8px;
  height: 7px;
  bottom: 10px;
  background: #03356c;
  clip-path: polygon(0 0, 50% 100%, 100% 0); }
  @media screen and (max-width: 991px) {
    .faqTab li a::before {
      width: 0.6rem;
      height: 0.5rem; } }

.faq_page {
  padding-top: 100px; }
  @media screen and (max-width: 991px) {
    .faq_page {
      padding-top: 4rem; } }

@media screen and (max-width: 991px) {
  .faq_page .faq_ttl h2 {
    font-size: 1.6rem;
    letter-spacing: 0.2em; } }

@media screen and (max-width: 991px) {
  .en .faq_page .faq_ttl h2 {
    letter-spacing: normal; } }

@media screen and (max-width: 991px) {
  .faq_page .faq_lists {
    margin-top: 1.8rem; } }

.faq_unit + .faq_unit {
  margin-top: 90px; }
  @media screen and (max-width: 991px) {
    .faq_unit + .faq_unit {
      margin-top: 0;
      padding-top: 3.5rem; } }

/* ============================================================================
inquiry
============================================================================== */
.inquiry_top {
  background-color: #f1f8fe;
  background-color: #e4f0fd;
  padding-top: 40px;
  padding-bottom: 40px; }
  @media screen and (max-width: 991px) {
    .inquiry_top {
      padding-top: 3rem;
      padding-bottom: 3rem; } }

.inquiry_top .contact_cards {
  margin-top: 0; }

.inquiry_top_contact .contact_card {
  background-color: white;
  border-style: dotted; }

.inquiry_top_wrap {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 30px; }
  @media screen and (max-width: 991px) {
    .inquiry_top_wrap {
      display: block;
      margin-top: 2.1rem; } }

.inquiry_top_wrap p {
  font-size: 1.5rem;
  line-height: calc(22/15);
  letter-spacing: 0.05em; }
  @media screen and (max-width: 991px) {
    .inquiry_top_wrap p {
      font-size: 1.1rem;
      line-height: calc(30/22); } }

@media screen and (max-width: 991px) {
  .inqruy_top_btn {
    max-width: 15rem;
    margin-top: 1.5rem;
    margin-left: auto; } }

.inqruy_top_btn a {
  gap: 12px;
  padding-block: 12px; }
  @media screen and (max-width: 991px) {
    .inqruy_top_btn a {
      gap: 0.45rem;
      padding: 0.75rem; } }

.inqruy_top_btn a img {
  width: 20px; }
  @media screen and (max-width: 991px) {
    .inqruy_top_btn a img {
      width: 1.5rem; } }

.inquiry_form {
  margin-top: 42px; }
  @media screen and (max-width: 991px) {
    .inquiry_form {
      margin-top: 0; } }

/* ============================================================================
table
============================================================================== */
/*===================================
  
  table

===================================*/
.tbl_bd {
  margin: 0;
  padding: 0px;
  width: 100%;
  table-layout: fixed;
  word-wrap: break-word;
  white-space: normal;
  margin-top: 40px; }

.tbl_bd th, .tbl_bd td {
  font-size: 1.5rem;
  vertical-align: middle;
  border-bottom: 2px solid #bbbbbb;
  padding: 20px 15px;
  line-height: 1.6; }

.tbl_bd th {
  font-weight: 900;
  border-bottom-color: #03356c;
  width: 20%; }
  @media screen and (max-width: 991px) {
    .tbl_bd th {
      font-weight: 700; } }

.tbl_bd td {
  padding-left: 20px; }

.tbl_bd td a {
  text-decoration: underline;
  transition: all 0.2s; }

.tbl_bd td a:hover {
  opacity: 0.8; }

/* SP */
@media screen and (max-width: 991px) {
  .tbl_bd th, .tbl_bd td {
    font-size: 1.2rem;
    padding: 15px 10px; }

  .tbl_bd th {
    width: 30%; }

  .tbl_bd td {
    padding-left: 25px; } }
/* ============================================================================
アクセス
   - block_map
============================================================================== */
.map {
  background-color: #f1f8fe; }

.map_inner.inner {
  max-width: 930px; }

.block_map_address {
  font-size: 1.5rem;
  margin-bottom: 10px;
  margin-top: 40px; }

.block_map_iframe {
  height: 440px; }

.block_map_iframe iframe {
  width: 100%;
  height: 100%;
  border: 3px solid white; }

.block_map_link {
  margin-top: 10px;
  text-align: right; }

/* SP */
@media screen and (max-width: 991px) {
  .block_map_address {
    font-size: 1.2rem; }

  .block_map_iframe {
    height: 300px; } }
.link_outer {
  position: relative;
  padding-right: 30px;
  text-decoration: none; }

.link_outer::before {
  content: '';
  position: absolute;
  background: url(../img/img-common/icon_outer.png) left center no-repeat;
  background-size: contain;
  width: 18px;
  height: 18px;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto; }

.link_outer:hover {
  text-decoration: underline; }

/* SP */
@media screen and (max-width: 991px) {
  .link_outer {
    font-size: 1.1rem;
    padding-right: 25px; }

  .link_outer::before {
    width: 15px;
    height: 15px; } }
/* ============================================================================
沿革
============================================================================== */
.history {
  padding-top: 80px;
  padding-bottom: 30px; }
  @media screen and (max-width: 991px) {
    .history {
      padding-top: 4rem; } }

.company_history {
  position: relative;
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .company_history {
      margin-top: 3rem; } }

.company_history::before {
  content: '';
  position: absolute;
  width: 2px;
  height: 100%;
  top: 10px;
  left: 9px;
  background: #7fb8de; }

.company_history > dl {
  position: relative;
  display: flex;
  align-items: flex-start;
  margin-bottom: 32px; }

.company_history > dl:last-child::before {
  content: '';
  position: absolute;
  width: 2px;
  height: 8px;
  bottom: -42px;
  left: 9px;
  background: #7fb8de; }

.company_history > dl:last-child::after {
  content: '';
  position: absolute;
  width: 2px;
  height: 10px;
  bottom: -27px;
  left: 9px;
  background: #7fb8de; }

.company_history_date {
  padding-left: 35px;
  position: relative;
  display: flex;
  justify-content: space-between;
  font-weight: 900; }
  @media screen and (max-width: 991px) {
    .company_history_date {
      font-weight: 700; } }

.company_history_date::before {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  background: #0071be;
  border: 5px solid #7fb8de;
  border-radius: 50%; }

.company_history_img {
  display: block;
  margin-top: 30px; }

/* PC */
@media print, screen and (min-width: 992px) {
  .company_history > dl {
    justify-content: space-between; }

  .company_history > dl > dd {
    width: 660px; }

  .company_history_date {
    width: 180px; } }
/* SP */
@media screen and (max-width: 991px) {
  .company_history > dl {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 50px; }

  .company_history > dl > dd {
    margin-left: 30px;
    width: calc(100% - 120px); }

  .company_history_date {
    padding-left: 35px;
    justify-content: flex-start;
    flex-wrap: wrap;
    width: 100px; }

  .company_history_date > span {
    display: block;
    margin: 0 0 0 auto;
    text-align: right; }

  .company_history_date::before {
    bottom: auto; }

  .company_history_img {
    margin-top: 30px;
    width: 70%; } }
/* ============================================================================
企業理念
============================================================================== */
.philosophy {
  position: relative;
  background-color: #e4f0fd;
  padding-top: 80px; }
  @media screen and (max-width: 991px) {
    .philosophy {
      padding-top: 4rem;
      padding-bottom: 15.5rem; } }

.philosophy::before {
  position: absolute;
  content: "";
  width: 220px;
  height: 220px;
  background: url(../img/img-company/philosophy_02.png) center center/contain no-repeat;
  top: 130px;
  left: calc(50% - 550px); }
  @media screen and (max-width: 991px) {
    .philosophy::before {
      top: 6rem;
      left: 1rem;
      width: 11rem;
      height: 11rem; } }

.philosophy_content {
  position: relative;
  z-index: 1;
  max-width: 545px;
  width: 100%;
  margin-top: 50px; }
  @media screen and (max-width: 991px) {
    .philosophy_content {
      margin-top: 2rem; } }

.philosophy_content h3 {
  color: #03356c;
  font-size: 2.4rem;
  font-weight: 900;
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .philosophy_content h3 {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .philosophy_content h3 {
      font-size: 1.5rem;
      line-height: calc(43/30);
      text-indent: -8em;
      margin-left: 8em; } }

.en .philosophy_content h3 {
  white-space: nowrap; }
  @media screen and (max-width: 991px) {
    .en .philosophy_content h3 {
      font-size: 1.3rem;
      white-space: initial;
      text-indent: 0;
      margin-left: 0; } }

.philosophy_content h3 span {
  display: inline-block;
  vertical-align: middle;
  width: 100px;
  height: 1px;
  background-color: #03356c;
  margin-left: 5px; }
  @media screen and (max-width: 991px) {
    .philosophy_content h3 span {
      width: 5rem; } }

.philosophy_lists {
  counter-reset: number 0;
  margin-top: 36px; }
  @media screen and (max-width: 991px) {
    .philosophy_lists {
      margin-top: 1.6rem; } }

.philosophy_lists li {
  position: relative;
  font-size: 1.8rem;
  font-weight: 900;
  opacity: 0;
  transition: all 0.3s 0.3s;
  line-height: calc(24/18);
  letter-spacing: 0.1em;
  padding-left: 35px; }
  @media screen and (max-width: 991px) {
    .philosophy_lists li {
      font-size: 1.1rem;
      line-height: calc(30/22);
      letter-spacing: 0.05em;
      padding-left: 3rem;
      font-weight: 700; } }

.philosophy_lists li:nth-child(2) {
  width: 425px;
  margin-left: auto;
  margin-top: 20px;
  transition: all 0.3s 0.6s; }
  @media screen and (max-width: 991px) {
    .philosophy_lists li:nth-child(2) {
      width: calc(100% - 3rem);
      margin-top: 1.2rem; } }

.philosophy_content.is-scroll-fade .philosophy_lists li {
  opacity: 1; }

.philosophy_lists li::before {
  position: absolute;
  counter-increment: number 1;
  content: counter(number) ".";
  color: #03356c;
  left: 0;
  top: -10px;
  font-weight: 400;
  font-style: italic;
  font-size: 2.8rem;
  font-family: "Century Gothic", sans-serif; }
  @media screen and (max-width: 991px) {
    .philosophy_lists li::before {
      font-size: 1.8rem; } }

.philosophy_img {
  position: absolute;
  bottom: 0;
  right: calc(50% - 600px);
  width: 600px; }
  @media screen and (max-width: 991px) {
    .philosophy_img {
      width: 30rem;
      right: initial;
      left: 50%;
      transform: translateX(-50%); } }

/* ============================================================================
採用情報
============================================================================== */
.about {
  padding-top: 70px;
  padding-bottom: 75px;
  background-color: #e4f0fd; }
  @media screen and (max-width: 991px) {
    .about {
      padding-top: 4rem;
      padding-bottom: 4rem; } }

.about_inner.inner {
  max-width: 970px; }

.about_wrap {
  display: grid;
  grid-template-columns: 1fr 32%;
  gap: 20px; }
  @media screen and (max-width: 991px) {
    .about_wrap {
      gap: 0;
      grid-template-columns: 1fr; } }

@media screen and (max-width: 991px) {
  .about_content {
    display: contents; } }

.about_bigText {
  color: #03356c;
  font-size: 2.2rem;
  font-weight: 900;
  line-height: calc(35/22);
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .about_bigText {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .about_bigText {
      font-size: 1.4rem;
      letter-spacing: 0.05em;
      line-height: calc(50/30); } }

.about_text {
  font-size: 1.6rem;
  line-height: calc(30/16);
  letter-spacing: 0.1em;
  margin-top: 16px; }
  @media screen and (max-width: 991px) {
    .about_text {
      order: 1;
      font-size: 1.2rem;
      line-height: calc(40/22);
      margin-top: 1.6rem; } }

@media screen and (max-width: 991px) {
  .about_img {
    display: block;
    width: 20rem;
    margin-inline: auto;
    margin-top: 1.25rem; } }

@media screen and (max-width: 991px) {
  .about .cap2_slider {
    margin-top: 2rem; } }

.about .cap2_slider_item {
  width: 235px; }
  @media screen and (max-width: 991px) {
    .about .cap2_slider_item {
      width: 12rem;
      margin: 0 0.75rem; } }

/* ============================================================================
JOIN US
============================================================================== */
.recruit {
  position: relative;
  padding-top: 100px;
  padding-bottom: 30px; }
  @media screen and (max-width: 991px) {
    .recruit {
      padding-top: 3rem; } }

.recruit::before {
  position: absolute;
  content: "JOIN US";
  font-size: 15rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: 1;
  left: calc(50% - 560px);
  opacity: 0.1;
  top: -26px; }
  @media screen and (max-width: 991px) {
    .recruit::before {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .recruit::before {
      font-size: 5rem;
      top: -4px;
      left: 2px; } }

.recruit_ttl h2 {
  text-align: left;
  letter-spacing: 0.2em; }
  @media screen and (max-width: 991px) {
    .recruit_ttl h2 {
      text-align: center;
      line-height: calc(50/36);
      letter-spacing: 0.1em; } }

.recruit_wrap {
  display: grid;
  grid-template-columns: 48% 1fr;
  gap: 35px;
  margin-top: 40px; }
  @media screen and (max-width: 991px) {
    .recruit_wrap {
      grid-template-columns: 1fr;
      margin-top: 1.6rem; } }

.recruit_txt {
  display: block;
  max-width: 425px;
  font-weight: 400;
  font-size: 1.8rem;
  line-height: calc(30/18);
  letter-spacing: 0.1em; }
  @media screen and (max-width: 991px) {
    .recruit_txt {
      font-size: 1.2rem;
      line-height: calc(40/22); } }

@media screen and (max-width: 991px) {
  .recruit_img {
    max-width: 22.5rem;
    margin-inline: auto; } }

/* ============================================================================
エントリー方法
============================================================================== */
.entry {
  position: relative;
  background-color: #edf4f6;
  padding: 40px 35px;
  border-radius: 10px;
  margin-top: 60px; }
  @media screen and (max-width: 991px) {
    .entry {
      padding: 2rem 1.3rem 2rem;
      border-radius: 0.5rem;
      margin-top: 3rem; } }

.entry::before {
  position: absolute;
  content: "";
  width: 200px;
  height: 164px;
  bottom: 0;
  right: 50px;
  background: url(../img/img-recruit/entry_icon.png) center center/contain no-repeat; }
  @media screen and (max-width: 991px) {
    .entry::before {
      width: 12.5rem;
      height: 10rem;
      right: 2rem; } }

.entry_ttl {
  position: relative;
  z-index: 1;
  padding-left: 30px;
  padding-bottom: 20px;
  border-bottom: 1px solid #03356c; }
  @media screen and (max-width: 991px) {
    .entry_ttl {
      padding-left: 0;
      padding-bottom: 0.7rem; } }

.entry_ttl h2 {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1;
  color: #03356c; }
  @media screen and (max-width: 991px) {
    .entry_ttl h2 {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .entry_ttl h2 {
      font-size: 1.6rem; } }

.entry_ttl h2 span {
  display: inline-block;
  color: #333;
  font-size: 1.6rem;
  font-weight: 400;
  margin-left: 30px; }
  @media screen and (max-width: 991px) {
    .entry_ttl h2 span {
      font-size: 1rem;
      margin-left: 0;
      margin-top: 0.6rem; } }

.entry_lists {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  padding-inline: 72px;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .entry_lists {
      grid-template-columns: 1fr;
      padding: 0;
      margin-top: 1rem; } }

@media screen and (max-width: 991px) {
  .entry_list {
    width: 20rem;
    margin-inline: auto; } }

.entry_list_ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 73px;
  height: 25px;
  font-size: 1.5rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  color: white;
  background: #03356c;
  border-radius: 13px; }
  @media screen and (max-width: 991px) {
    .entry_list_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .entry_list_ttl {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .entry_list_ttl {
      width: 5rem;
      height: 1.75rem;
      font-size: 1.1rem; } }

.entry_tel {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 10px; }
  @media screen and (max-width: 991px) {
    .entry_tel {
      justify-content: center;
      gap: 0.75rem;
      margin-top: 1rem; } }

.entry_tel img {
  max-width: 20px; }
  @media screen and (max-width: 991px) {
    .entry_tel img {
      max-width: 1rem; } }

.entry_tel a {
  display: block;
  text-align: center;
  font-size: 3.4rem;
  font-weight: 900;
  line-height: 1; }
  @media screen and (max-width: 991px) {
    .entry_tel a {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .entry_tel a {
      width: calc(100% - 1rem - 0.75rem);
      font-size: 2rem;
      letter-spacing: 0.05em; } }

.entry_tel a span {
  display: block;
  font-size: 1.4rem;
  margin-top: 6px; }
  @media screen and (max-width: 991px) {
    .entry_tel a span {
      font-size: 1rem;
      letter-spacing: normal;
      margin-top: 0.45rem; } }

@media screen and (max-width: 991px) {
  .entry_list + .entry_list {
    margin-top: 2rem; } }

.entry_mail {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-top: 20px; }
  @media screen and (max-width: 991px) {
    .entry_mail {
      justify-content: center;
      gap: 0.6rem;
      margin-top: 0.8rem; } }

.entry_mail img {
  max-width: 30px; }
  @media screen and (max-width: 991px) {
    .entry_mail img {
      max-width: 1.5rem; } }

.entry_mail a {
  font-size: 2rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-decoration: underline; }
  @media screen and (max-width: 991px) {
    .entry_mail a {
      font-weight: 700; } }
  @media screen and (max-width: 991px) {
    .entry_mail a {
      font-size: 1.3rem; } }

/*===================================
  
  プライバシーポリシー

===================================*/
.privacy_lead {
  padding-top: 50px; }

.privacy_list {
  margin-top: 60px; }

.privacy_list > dl:not(:last-child) {
  margin-bottom: 30px; }

.privacy_contact {
  margin-top: 60px;
  line-height: 2; }

.ttl_bd {
  color: #03356c;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 0.2em;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #03356c; }

@media screen and (max-width: 991px) {
  .en .ttl_bd {
    letter-spacing: 0.1em; } }

@media screen and (max-width: 991px) {
  .privacy_lead {
    padding-top: 0; }

  .privacy_list {
    margin-top: 30px; }

  .privacy_list > dl:not(:last-child) {
    margin-bottom: 25px; }

  .privacy_contact {
    margin-top: 30px; }

  .ttl_bd {
    font-size: 1.4rem; } }
.form #contents .btn_wrp input[type="submit"] {
  background-color: #03356c; }

/* 202509 */
.topBnr {
  padding-block: 50px 35px;
  margin-bottom: 90px;
  background: url(../img/img-index/bg_bnr_product.jpg) center center / cover no-repeat;
}

.topBnr__img a {
  transition: all 0.45s;
}

.topBnr__img a:hover {
  opacity: 0.8;
}

@media screen and (max-width: 991px) {
  .topBnr {
    padding-block: 6rem;
    background-image: url(../img/img-index/bg_bnr_product_sp.jpg);
  }
}

.bnr_img {
  max-width: 100%;
  width: 100%;
  text-align: center;
}

/* 202601 */
.column {
  background-color: #0071be;
}

.column_ttl h2 {
  color: #fff;
}

.column_btn {
  margin-top: 52px;
  max-width: 300px;
  margin-inline: auto; }
  @media screen and (max-width: 991px) {
    .column_btn {
      max-width: 17.5rem;
      margin-top: 3rem; } }

@media screen and (max-width: 991px) {
  .column_main {
    overflow: auto;
    margin-inline: calc(50% - 50vw);
  }
}

.column .flex_column {
  justify-content: flex-start;
  gap: 25px;
  margin-top: 35px;
}

@media screen and (max-width: 991px) {
  .column .flex_column {
    flex-wrap: nowrap;
    min-width: fit-content;
    padding-inline: 2rem;
    margin-top: 2rem;
    gap: 1.5rem;
  }
}

.column .flex_column .flex_item {
  width: calc(25% - 25px * 3/4);
  border: none;
}

@media screen and (max-width: 991px) {
  .column .flex_column .flex_item {
    width: 22rem;
  }
}

.column .flex_column .flex_item a span.img img {
  height: auto;
  aspect-ratio: 215/140;
}

@media screen and (max-width: 991px) {
  .column .flex_column .flex_item a span.img img {
    aspect-ratio: 440/295;
  }
}

.column .flex_column .flex_item a span.txt {
  padding: 8px 8px 15px;
}

.column .flex_column .flex_item a span.txt i.cat, .articlelist-category i.cat {
  max-width: 55%;
  padding-inline: 6px;
}

.column .userinfo {
  right: 10px;
}