@charset "UTF-8";
@media only screen and (max-width: 768px) {
  .c-mv {
    background-image: url("../img/img-main_sp.jpg");
  }
}
@media print, screen and (min-width: 769px) {
  .c-mv {
    background-image: url("../img/img-main.jpg");
  }
}

@media only screen and (max-width: 768px) {
  .p-factory {
    margin-bottom: 13.3333333333vw;
    padding-inline: 8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-factory {
    margin: 0 auto min(100px, 7.1428571429vw);
    width: min(990px, 70.7142857143vw);
  }
}

.p-pagelink {
  display: -ms-grid;
  display: grid;
}
@media only screen and (max-width: 768px) {
  .p-pagelink {
    gap: 1.3333333333vw;
    -ms-grid-columns: 1fr 1.3333333333vw 1fr;
    grid-template-columns: repeat(2, 1fr);
    margin-bottom: 13.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-pagelink {
    gap: min(10px, 0.7142857143vw);
    -ms-grid-columns: 1fr min(10px, 0.7142857143vw) 1fr min(10px, 0.7142857143vw) 1fr min(10px, 0.7142857143vw) 1fr min(10px, 0.7142857143vw) 1fr;
    grid-template-columns: repeat(5, 1fr);
    margin-bottom: min(96px, 6.8571428571vw);
  }
}
.p-pagelink a {
  border: 2px solid var(--bc01);
  color: var(--bc01);
  display: -ms-grid;
  display: grid;
  font-weight: bold;
  place-content: center;
  position: relative;
  text-align: center;
  transition: 0.3s ease-in-out;
}
@media only screen and (max-width: 768px) {
  .p-pagelink a {
    font-size: 3.2vw;
    height: 14.9333333333vw;
    padding-bottom: 1.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-pagelink a {
    font-size: min(15px, 1.0714285714vw);
    height: min(84px, 6vw);
  }
}
@media only screen and (max-width: 768px) {
  .p-pagelink a br {
    display: none;
  }
}
.p-pagelink a::after {
  background: var(--bc01);
  content: "";
  display: block;
  mask-image: url("../../../img/icon-arrow01.svg");
  mask-repeat: no-repeat;
  mask-size: cover;
  position: absolute;
  rotate: 90deg;
  transition: 0.3s ease-in-out;
}
@media only screen and (max-width: 768px) {
  .p-pagelink a::after {
    bottom: 2.6666666667vw;
    height: 2.9333333333vw;
    left: 50%;
    translate: -50%;
    width: 2vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-pagelink a::after {
    height: min(12px, 0.8571428571vw);
    right: min(20px, 1.4285714286vw);
    top: 50%;
    translate: 0 -50%;
    width: min(8px, 0.5714285714vw);
  }
}
@media print, screen and (min-width: 769px) {
  .p-pagelink a:hover {
    background: var(--bc01);
    color: #fff;
  }
}
@media print, screen and (min-width: 769px) {
  .p-pagelink a:hover::after {
    background: #fff;
  }
}

@media only screen and (max-width: 768px) {
  .p-sec + .p-sec {
    margin-top: 13.3333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-sec + .p-sec {
    margin-top: min(86px, 6.1428571429vw);
  }
}

.c-ttl03 {
  align-items: center;
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 768px) {
  .c-ttl03 {
    margin-bottom: 3.2vw;
    padding-bottom: 1.8666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .c-ttl03 {
    margin-bottom: min(15px, 1.0714285714vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-access-lead {
    font-size: 3.7333333333vw;
    margin-bottom: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-lead {
    font-size: min(15px, 1.0714285714vw);
    margin-bottom: min(36px, 2.5714285714vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-access-item + .p-access-item {
    margin-top: 6.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-item + .p-access-item {
    margin-top: min(32px, 2.2857142857vw);
  }
}

@media only screen and (max-width: 768px) {
  .p-access-text {
    font-size: 3.7333333333vw;
    padding-left: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-text {
    font-size: min(15px, 1.0714285714vw);
    padding-left: min(20px, 1.4285714286vw);
  }
}

.p-access-sub {
  background: var(--bc03);
}
@media only screen and (max-width: 768px) {
  .p-access-sub + .p-access-sub {
    margin-top: 2.9333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-sub + .p-access-sub {
    margin-top: min(11px, 0.7857142857vw);
  }
}

.p-access-sub-title a {
  display: -ms-grid;
  display: grid;
  place-content: center start;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .p-access-sub-title a {
    font-size: 3.7333333333vw;
    height: 14.4vw;
    padding-left: 4.5333333333vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-sub-title a {
    font-size: min(15px, 1.0714285714vw);
    height: min(60px, 4.2857142857vw);
    padding-left: min(30px, 2.1428571429vw);
  }
}
.p-access-sub-title a::before, .p-access-sub-title a::after {
  background: var(--bc01);
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  transition: 0.3s ease-in-out;
  translate: 0 -50%;
}
@media only screen and (max-width: 768px) {
  .p-access-sub-title a::before, .p-access-sub-title a::after {
    height: 0.2666666667vw;
    right: 4.2666666667vw;
    width: 2.6666666667vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-sub-title a::before, .p-access-sub-title a::after {
    height: min(2px, 0.1428571429vw);
    right: min(30px, 2.1428571429vw);
    width: min(12px, 0.8571428571vw);
  }
}
.p-access-sub-title a::before {
  rotate: 90deg;
}
.p-access-sub-title a.is-active::before {
  rotate: 180deg;
}

.p-access-sub-main {
  display: none;
}
@media only screen and (max-width: 768px) {
  .p-access-sub-main {
    padding: 0 4vw 8vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-sub-main {
    padding: 0 min(30px, 2.1428571429vw) min(15px, 1.0714285714vw);
  }
}

.p-access-sub-item {
  position: relative;
}
@media only screen and (max-width: 768px) {
  .p-access-sub-item {
    display: flex;
    flex-direction: column;
  }
}
.p-access-sub-item + .p-access-sub-item {
  border-top: 1px solid var(--bc04);
}
@media only screen and (max-width: 768px) {
  .p-access-sub-item + .p-access-sub-item {
    margin-top: 4vw;
    padding-top: 4vw;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-sub-item + .p-access-sub-item {
    margin-top: min(15px, 1.0714285714vw);
    padding-top: min(15px, 1.0714285714vw);
  }
}

.p-access-sub-heading {
  color: var(--bc01);
  font-weight: bold;
  margin-left: 1em;
  text-indent: -1em;
}
@media only screen and (max-width: 768px) {
  .p-access-sub-heading {
    font-size: 3.7333333333vw;
    order: 1;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-sub-heading {
    font-size: min(15px, 1.0714285714vw);
  }
}
.p-access-sub-heading::before {
  content: "・";
}

.p-access-sub-text {
  padding-left: 1em;
}
@media only screen and (max-width: 768px) {
  .p-access-sub-text {
    font-size: 3.7333333333vw;
    order: 2;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-sub-text {
    font-size: min(15px, 1.0714285714vw);
    padding-right: min(270px, 19.2857142857vw);
  }
}

.p-access-links {
  display: flex;
  flex-direction: row-reverse;
}
@media only screen and (max-width: 768px) {
  .p-access-links {
    gap: min(10px, 0.7142857143vw);
    margin-top: 4.6666666667vw;
    order: 3;
  }
}
@media print, screen and (min-width: 769px) {
  .p-access-links {
    bottom: 0;
    gap: min(5px, 0.3571428571vw);
    position: absolute;
    right: 0;
  }
}
@media only screen and (max-width: 768px) {
  .p-access-links li {
    width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .p-access-links li a {
    padding-left: 0;
    place-content: center;
    width: 100%;
  }
}