/* ==================================================
 * Color set
 * ================================================== */
/* ==================================================
 * Font
 * ================================================== */
/* ==================================================
 * width
 * ================================================== */
/* ==================================================
 * layout
 * ================================================== */
/* ==================================================
 * bg
 * ================================================== */
/* ==================================================
 * font text
 * ================================================== */
/* ==================================================
 * other
 * ================================================== */
.btn-01__link, .btn-02__link, .btn-03__link {
  width: 380px;
  max-width: 100%;
  aspect-ratio: 380/70;
  background: url("/img/common/btn-base-red-380.png") center center no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: #fff;
}
.btn-01__link:hover, .btn-02__link:hover, .btn-03__link:hover {
  color: rgba(255, 255, 255, 0.8);
}
.btn-02__link {
  width: 340px;
  max-width: 100%;
  aspect-ratio: 340/70;
  background: url("/img/common/btn-base-red-340.png") center center no-repeat;
  background-size: cover;
}
.btn-03__link {
  width: 340px;
  max-width: 100%;
  aspect-ratio: 340/70;
  background: url("/img/common/btn-base-wht-340.png") center center no-repeat;
  background-size: cover;
  color: #cc0000;
  font-weight: 600;
}
.btn-03__link:hover {
  color: rgba(204, 0, 0, 0.7);
}
.btn-04 {
  display: flex;
}
.btn-04__link {
  border-bottom: solid 1px #fff;
  padding-bottom: 5px;
}
.btn-04__link:hover {
  opacity: 0.8;
}
.btn-05__link {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  border: solid 1px #cc0000;
  position: relative;
}
.btn-05__link span {
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc(100% - 10px);
  height: calc(100% - 5px);
  padding-bottom: 4px;
  background: rgba(204, 0, 0, 0.3);
}
.btn-05__link span::before, .btn-05__link span::after {
  content: "";
  display: inline-block;
  width: calc(100% - 16px);
  height: 1px;
  background: #010001;
  position: absolute;
  z-index: 1;
  transition: 0.3s;
}
.btn-05__link span::before {
  left: 50%;
  transform: translateX(-50%);
  top: -1px;
}
.btn-05__link span::after {
  right: 50%;
  transform: translateX(50%);
  bottom: -1px;
}
.btn-05__link:hover {
  text-shadow: 0 0 6px #cc0000, 0 0 8px #cc0000, 0 0 10px #cc0000, 0 0 12px #cc0000, 0 0 14px #cc0000;
  border: solid 1px #fff;
  box-shadow: 0 0 5px #cc0000, 0 0 10px #cc0000, inset 0 0 5px #cc0000, inset 0 0 10px #cc0000;
}
.btn-05__link:hover span::before, .btn-05__link:hover span::after {
  width: 0%;
}

#side-totop {
  position: fixed;
  right: 40px;
  bottom: 15px;
  z-index: 88;
}

.ic-mail-red, .ic-mail-wht, .ic-line-red, .ic-line-wht {
  display: flex;
  justify-content: center;
  align-items: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.ic-mail-red::before, .ic-mail-wht::before, .ic-line-red::before, .ic-line-wht::before {
  content: "";
  display: block;
}
.ic-mail-red::before, .ic-mail-wht::before {
  width: 23px;
  min-width: 23px;
  aspect-ratio: 23/19;
}
.ic-mail-red::before {
  background-image: url("/img/common/ic-mail-red.png");
  background-size: 100%;
}
.ic-mail-wht::before {
  background-image: url("/img/common/ic-mail-wht.png");
  background-size: 100%;
}
.ic-line-red::before, .ic-line-wht::before {
  width: 21px;
  min-width: 21px;
  aspect-ratio: 1/1;
}
.ic-line-red::before {
  background-image: url("/img/common/ic-line-red.png");
  background-size: 100%;
}
.ic-line-wht::before {
  background-image: url("/img/common/ic-line-wht.png");
  background-size: 100%;
}
.ic-outlink {
  display: flex;
  align-items: center;
  -moz-column-gap: 10px;
       column-gap: 10px;
}
.ic-outlink::after {
  content: "";
  display: block;
  width: 21px;
  min-width: 21px;
  aspect-ratio: 21/19;
  background-image: url("/img/common/ic-outlink.png");
  background-size: 100%;
  transition: 0.3s;
}
.ic-outlink:hover::after {
  transform: translate(1px, -1px);
}

.arw-red, .arw-anchor {
  position: relative;
}
.arw-red::after, .arw-anchor::after {
  content: "";
  display: block;
  width: 13px;
  aspect-ratio: 13/18;
  background-image: url("/img/common/arrow-red.png");
  background-size: 100%;
  position: absolute;
  top: 50%;
  right: 25px;
  transform: translateY(-50%);
  transition: 0.3s;
}
.arw-red:hover::after, .arw-anchor:hover::after {
  transform: translate(-2px, -50%);
}
.arw-anchor::after {
  transform: translate(0, -50%) rotate(90deg);
}
.arw-anchor:hover::after {
  transform: translate(0, calc(-50% + 2px)) rotate(90deg);
}

.obj-com-square-top, .obj-com-square-btm {
  position: relative;
  z-index: 1;
}
.obj-com-square-top::before, .obj-com-square-btm::after {
  content: "";
  display: block;
  width: 137px;
  max-width: 7.1354166667%;
  aspect-ratio: 137/92;
  clip-path: polygon(36.5% 0%, 100% 0, 100% 100%, 0% 100%);
  background: #cc0000;
  position: absolute;
  z-index: -1;
}
.obj-com-square-btm::after {
  clip-path: polygon(0 0, 100% 0, 63.5% 100%, 0% 100%);
}
.obj-com-grid {
  position: relative;
  z-index: 1;
}
.obj-com-grid::after {
  content: "";
  display: block;
  background: url("/img/common/ptn-grid.png");
  position: absolute;
  z-index: -1;
}
.obj-com-ruler {
  position: relative;
  z-index: 1;
}
.obj-com-ruler::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 51px;
  background: url("/img/common/ptn-ruler.png");
  background-repeat: repeat-x;
  position: absolute;
  left: 0;
  z-index: -1;
}
.obj-com-bg-rt::before, .obj-com-bg-lft::before {
  content: "";
  display: inline-block;
  width: 399px;
  max-width: 20.78125%;
  aspect-ratio: 399/987;
  background-image: url("/img/common/bg-cyber.png");
  background-size: 100%;
  position: absolute;
  z-index: -1;
}
.obj-com-bg-rt::before {
  right: 0;
  bottom: 0;
  transform: translateY(1px);
}
.obj-com-bg-lft::before {
  top: 0;
  left: 0;
  transform: translateY(-1px) scale(-1, -1);
}
.obj-com-fourCorners-top, .obj-com-fourCorners-btm {
  width: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}
.obj-com-fourCorners-top::before, .obj-com-fourCorners-top::after, .obj-com-fourCorners-btm::before, .obj-com-fourCorners-btm::after {
  content: "";
  display: block;
  height: 50px;
  aspect-ratio: 1/1;
  border-top: solid 4px #cc0000;
  border-left: solid 4px #cc0000;
}
.obj-com-fourCorners-top::after, .obj-com-fourCorners-btm::after {
  position: absolute;
  top: 0;
  right: 0;
  transform: scaleX(-1);
}
.obj-com-fourCorners-btm {
  top: inherit;
  bottom: 0;
  transform: scaleY(-1);
}
.obj-com-cyber-01 {
  position: relative;
  z-index: 1;
}
.obj-com-cyber-01::before {
  content: "";
  display: block;
  width: 94px;
  aspect-ratio: 94/206;
  background-image: url("/img/common/obj-cyber-01.png");
  background-size: 100%;
  position: absolute;
  z-index: -1;
}

.deco-stripe::after {
  content: "";
  display: block;
  width: 68px;
  aspect-ratio: 68/8;
  background-image: url("/img/common/deco-stripe.png");
  background-size: 100%;
  margin: 20px auto 0 auto;
}
.deco-dot {
  display: flex;
  align-items: flex-start;
  -moz-column-gap: 20px;
       column-gap: 20px;
}
.deco-dot::before {
  content: "";
  display: block;
  width: 35px;
  min-width: 35px;
  aspect-ratio: 35/15;
  background-image: url("/img/common/deco-dot.png");
  background-size: 100%;
  transform: translateY(10px);
}
.deco-circle {
  display: flex;
  align-items: center;
  -moz-column-gap: 15px;
       column-gap: 15px;
}
.deco-circle::before {
  content: "";
  display: block;
  width: 27px;
  min-width: 27px;
  aspect-ratio: 1/1;
  background-image: url("/img/common/deco-circle.png");
  background-size: 100%;
}

.frame-com-cyber {
  position: relative;
  z-index: 1;
}
.frame-com-cyber::before, .frame-com-cyber::after {
  content: "";
  display: inline-block;
  width: 347px;
  max-width: 100%;
  aspect-ratio: 347/181;
  background-image: url("/img/common/frame-cyber.png");
  background-size: 100%;
  filter: drop-shadow(0 0 5px #cc0000) drop-shadow(0 0 5px #cc0000) drop-shadow(0 0 10px #cc0000);
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
}
.frame-com-cyber::after {
  top: inherit;
  right: inherit;
  left: 0;
  bottom: 0;
  transform: scale(-1, -1);
}

.line-com-top {
  border-top: solid 28px #cc0000;
  position: relative;
}
.line-com-top::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 4px;
  background: #010001;
  position: absolute;
  left: 0;
  top: 0;
  transform: translateY(-24px);
  z-index: 1;
}

.tbl {
  width: 100%;
}
.tbl td {
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}
.tbl-01 th, .tbl-01 td {
  padding: 15px 3%;
  vertical-align: middle;
}
.tbl-01 th {
  width: 30%;
  border-bottom: solid 1px #cc0000;
}
.tbl-01 td {
  border-bottom: solid 1px rgba(204, 0, 0, 0.4);
  font-weight: 300;
}

.com-layout {
  display: flex;
}
.com-tel .tel {
  font-family: "Orbitron", sans-serif;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.05em;
}
.com-txt-shadow {
  text-shadow: 0 0 6px #cc0000, 0 0 8px #cc0000, 0 0 10px #cc0000, 0 0 12px #cc0000, 0 0 14px #cc0000;
}
.com-frame {
  border: solid 2px #fff;
  box-shadow: 0 0 5px #cc0000, 0 0 20px #cc0000, inset 0 0 5px #cc0000, inset 0 0 20px #cc0000;
}
@media screen and (max-width: 768px) {
  .com-frame {
    border-width: 1px;
  }
}
.com-frame-img {
  display: inline-block;
  border: solid 2px #fff;
  padding: 10px;
  box-shadow: 0 0 5px #cc0000, 0 0 20px #cc0000, inset 0 0 5px #cc0000, inset 0 0 20px #cc0000;
}
@media screen and (max-width: 768px) {
  .com-frame-img {
    border-width: 1px;
    padding: 2vw;
  }
}

.layout-clm-2 {
  display: flex;
  flex-wrap: wrap;
  gap: 60px;
}
.layout-clm-2 .list-item,
.layout-clm-2 .layout-item {
  width: calc((100% - 60px) / 2);
}
.layout-clm-2-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 60px;
}
.layout-clm-2-c .list-item,
.layout-clm-2-c .layout-item {
  width: calc((100% - 60px) / 2);
}
.layout-clm-3 {
  display: flex;
  flex-wrap: wrap;
  gap: 50px;
}
.layout-clm-3 .list-item,
.layout-clm-3 .layout-item {
  width: calc((100% - 100px) / 3);
}
.layout-clm-3-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 50px;
}
.layout-clm-3-c .list-item,
.layout-clm-3-c .layout-item {
  width: calc((100% - 100px) / 3);
}
.layout-clm-4 {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}
.layout-clm-4 .list-item,
.layout-clm-4 .layout-item {
  width: calc((100% - 120px) / 4);
}
.layout-clm-4-c {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
}
.layout-clm-4-c .list-item,
.layout-clm-4-c .layout-item {
  width: calc((100% - 120px) / 4);
}

.list-blog .list-item, .list-news .list-item, .list-privacy .list-item, .list-blog .list-item {
  width: 100%;
}
.list-info dl {
  display: flex;
  align-items: flex-start;
}
.list-reason__item {
  width: 840px;
  max-width: 100%;
  padding: 60px;
  display: flex;
  flex-direction: column;
  row-gap: 25px;
  position: relative;
  z-index: 1;
}
.list-reason__item:nth-child(even) {
  margin-left: auto;
}
.list-reason__num {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(60px, -40%);
  font-family: "Orbitron", sans-serif;
  letter-spacing: 0.02em;
  font-weight: 500;
  text-shadow: 0 0 6px #cc0000, 0 0 8px #cc0000, 0 0 10px #cc0000, 0 0 12px #cc0000, 0 0 14px #cc0000;
  font-weight: 500;
  line-height: 1;
  font-size: 50px;
  font-size: 5rem;
}
@media screen and (max-width: 768px) {
  .list-reason__num {
    font-size: 60px;
    font-size: 7.8125vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-reason__num {
    font-size: 40px;
  }
}
.list-reason__ttl {
  font-size: 30px;
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  .list-reason__ttl {
    font-size: 40px;
    font-size: 5.2083333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-reason__ttl {
    font-size: 26.6666666667px;
  }
}
.list-job-txt__item {
  width: 100%;
}
.list-job-txt__ttl {
  margin-bottom: 30px;
  color: #cc0000;
  font-size: 30px;
  font-size: 3rem;
}
@media screen and (max-width: 768px) {
  .list-job-txt__ttl {
    font-size: 40px;
    font-size: 5.2083333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-job-txt__ttl {
    font-size: 26.6666666667px;
  }
}
.list-label__item {
  min-width: 170px;
  padding: 15px 40px;
  text-align: center;
  background: rgba(204, 0, 0, 0.3);
  clip-path: polygon(15px 0, 100% 0, 100% calc(100% - 15px), calc(100% - 15px) 100%, 0 100%, 0 15px);
}
.list-job-img {
  -moz-column-gap: 3.13%;
       column-gap: 3.13%;
}
.list-job-img__item {
  width: 308px;
  max-width: 100%;
  aspect-ratio: 1/1;
  display: inline-block;
  border: solid 2px #fff;
  padding: 10px;
  box-shadow: 0 0 5px #cc0000, 0 0 20px #cc0000, inset 0 0 5px #cc0000, inset 0 0 20px #cc0000;
}
@media screen and (max-width: 768px) {
  .list-job-img__item {
    border-width: 1px;
    padding: 2vw;
  }
}
.list-job-card__item {
  width: 511px;
  max-width: 100%;
  aspect-ratio: 511/249;
  background: url("/img/top/job-openings-frame.png") center center no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.list-job-card__inner {
  display: flex;
  flex-direction: column;
  row-gap: 8px;
}
.list-job-card__ttl {
  font-weight: 600;
  font-size: 40px;
  font-size: 4rem;
}
@media screen and (max-width: 768px) {
  .list-job-card__ttl {
    font-size: 50px;
    font-size: 6.5104166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-job-card__ttl {
    font-size: 33.3333333333px;
  }
}
.list-job-card__txt {
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-job-card__txt {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-job-card__txt {
    font-size: 20px;
  }
}
.list-blog__link {
  display: block;
  border-bottom: solid 1px #ba0000;
  padding: 30px;
  position: relative;
}
.list-blog__link:hover {
  background: rgba(204, 0, 0, 0.2);
}
.list-blog time {
  font-family: "Orbitron", sans-serif;
  letter-spacing: 0.02em;
  font-weight: 500;
  color: #cc0000;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .list-blog time {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-blog time {
    font-size: 18.6666666667px;
  }
}
.list-blog__bx {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 15px;
}
.list-blog__ttl {
  margin-top: 10px;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  text-align: left;
}
.list-point {
  display: flex;
  flex-wrap: wrap;
  gap: 35px;
}
.list-point .list-item,
.list-point .layout-item {
  width: calc((100% - 35px) / 2);
}
.list-point {
  row-gap: 45px;
}
.list-point__item {
  padding: 45px;
  min-height: 150px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.list-point__num {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(60px, -30%);
  z-index: -1;
  font-family: "Orbitron", sans-serif;
  letter-spacing: 0.02em;
  font-weight: 500;
  text-shadow: 0 0 6px #cc0000, 0 0 8px #cc0000, 0 0 10px #cc0000, 0 0 12px #cc0000, 0 0 14px #cc0000;
  font-size: 26px;
  font-size: 2.6rem;
}
@media screen and (max-width: 768px) {
  .list-point__num {
    font-size: 36px;
    font-size: 4.6875vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-point__num {
    font-size: 24px;
  }
}
.list-point__num span {
  margin-left: 10px;
}
.list-point__txt {
  line-height: 1.8;
  font-size: 20px;
  font-size: 2rem;
}
@media screen and (max-width: 768px) {
  .list-point__txt {
    font-size: 30px;
    font-size: 3.90625vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .list-point__txt {
    font-size: 20px;
  }
}
.list-point .frame-com-cyber::before, .list-point .frame-com-cyber:after {
  width: 280px;
  max-width: 100%;
}
.list-gallery__item {
  display: inline-block;
  border: solid 2px #fff;
  padding: 10px;
  box-shadow: 0 0 5px #cc0000, 0 0 20px #cc0000, inset 0 0 5px #cc0000, inset 0 0 20px #cc0000;
}
@media screen and (max-width: 768px) {
  .list-gallery__item {
    border-width: 1px;
    padding: 2vw;
  }
}
.list-gallery__item {
  position: relative;
  z-index: 1;
}
.list-gallery__item:nth-child(4n-3)::after {
  content: "";
  display: inline-block;
  width: 5000px;
  height: 51px;
  background: url("/img/common/ptn-ruler.png");
  background-repeat: repeat-x;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}
.list-anchor__item {
  min-width: 520px;
}
.list-anchor__item a {
  height: 100%;
}
.list-anchor .btn-05 span {
  padding: 24px 4vw;
}

.tag-main__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  font-size: 18px;
  font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
  .tag-main__list {
    font-size: 28px;
    font-size: 3.6458333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-main__list {
    font-size: 18.6666666667px;
  }
}
.tag-main__link {
  display: block;
  background: rgba(204, 0, 0, 0.7);
  padding: 10px 20px;
  border-radius: 4px;
}
.tag-main__link:hover {
  opacity: 0.8;
}
.tag-sub__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 14px;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .tag-sub__list {
    font-size: 24px;
    font-size: 3.125vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .tag-sub__list {
    font-size: 16px;
  }
}
.tag-sub__item {
  color: rgba(204, 0, 0, 0.8);
}
.tag-sub__item::before {
  content: "#";
  display: inline-block;
}

.ttl-main {
  display: flex;
  flex-direction: column;
}
.ttl-main .en {
  font-family: "Orbitron", sans-serif;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-weight: 700;
  line-height: 1.1666666667;
  font-size: 120px;
  font-size: 12rem;
}
@media screen and (max-width: 768px) {
  .ttl-main .en {
    font-size: 130px;
    font-size: 16.9270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-main .en {
    font-size: 86.6666666667px;
  }
}
.ttl-main .rb {
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-main .rb {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-main .rb {
    font-size: 22.6666666667px;
  }
}
.ttl-main.txt-aln-c {
  align-items: center;
}
.ttl-main.txt-aln-c .deco-dot {
  justify-content: center;
}
.ttl-main.txt-aln-rt {
  align-items: flex-end;
}
.ttl-main.txt-aln-rt .deco-dot {
  justify-content: flex-end;
}
.ttl-sub {
  border-left: solid #cc0000 6px;
  padding: 10px 20px 15px 20px;
  margin-bottom: 30px;
  font-weight: 500;
  font-size: 24px;
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-sub {
    font-size: 34px;
    font-size: 4.4270833333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-sub {
    font-size: 22.6666666667px;
  }
}
.ttl-01 {
  margin-bottom: 80px;
  text-align: center;
  line-height: 1.2962962963;
  font-size: 54px;
  font-size: 5.4rem;
}
@media screen and (max-width: 768px) {
  .ttl-01 {
    font-size: 64px;
    font-size: 8.3333333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .ttl-01 {
    font-size: 42.6666666667px;
  }
}
.ttl-02 {
  border-bottom: solid 1px #cc0000;
  padding-bottom: 10px;
  position: relative;
  z-index: 1;
}
.ttl-02::before, .ttl-02::after {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1/1;
  border-radius: 50rem;
  background: #cc0000;
  position: absolute;
  left: 0;
  bottom: 0;
  transform: translateY(55%);
  z-index: -1;
}
.ttl-02::after {
  left: inherit;
  right: 0;
}
.ttl-03 {
  border-bottom: solid 1px #cc0000;
  padding-bottom: 15px;
  position: relative;
  z-index: 1;
}
.ttl-03::before, .ttl-03::after {
  content: "";
  display: inline-block;
  width: 30px;
  height: 1px;
  background: #cc0000;
  position: absolute;
  bottom: 0;
  z-index: -1;
}
.ttl-03::before {
  right: 100%;
  transform: translate(3px, 9px) rotate(-35deg);
}
.ttl-03::after {
  left: 100%;
  transform: translate(-3px, -8px) rotate(-35deg);
}

.txt-plain {
  line-height: 1.8823529412;
  font-weight: 300;
}
.txt-outline {
  color: #010001;
  display: inline-block;
  position: relative;
  z-index: 1;
}
.txt-outline::before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  -webkit-text-stroke: 5px #cc0000;
  text-stroke: 5px #cc0000;
  paint-order: stroke fill;
  stroke-linejoin: round;
}

.header-nav__item,
.drawer-nav__item,
.footer-nav__item {
  line-height: 1;
}

.header-nav {
  margin-top: 1.5vw;
}
.header-nav__list {
  display: flex;
  justify-content: flex-end;
  -moz-column-gap: 35px;
       column-gap: 35px;
}
.header-nav__link:hover {
  text-shadow: 0 0 6px #cc0000, 0 0 8px #cc0000, 0 0 10px #cc0000, 0 0 12px #cc0000, 0 0 14px #cc0000;
}

.footer-nav__link:hover,
.footer-sub__link:hover {
  opacity: 0.8;
}

.footer-nav__list {
  display: flex;
  justify-content: center;
  -moz-column-gap: 40px;
       column-gap: 40px;
}

.footer-sub__list {
  display: flex;
  justify-content: flex-end;
  -moz-column-gap: 15px;
       column-gap: 15px;
  font-size: 14px;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .footer-sub__list {
    font-size: 24px;
    font-size: 3.125vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .footer-sub__list {
    font-size: 16px;
  }
}

.header-bar {
  width: 100%;
  min-width: 1260px;
  padding: 40px 50px 0 50px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
}

.mv, .sv {
  width: 100%;
  position: relative;
  z-index: 1;
}
.mv img, .sv img {
  display: block;
  width: 100%;
}

.mv {
  aspect-ratio: 1920/950;
  background: url("/img/top/mv-bg.png") center bottom no-repeat;
  background-size: 100%;
}
.mv-cc {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: -1;
}
.mv-cc__main {
  width: 1121px;
  max-width: 58.3854166667%;
  margin: 0 auto;
}
.mv-cc__txt {
  margin-top: 2.4vw;
  line-height: 1.6;
  font-size: 20px;
  font-size: 1.0416666667vw;
}
@media screen and (max-width: 1120px) {
  .mv-cc__txt {
    font-size: 13.3333333333px;
  }
}
@media screen and (min-width: 1920px) {
  .mv-cc__txt {
    font-size: 20px;
  }
}
.mv-cc__en {
  text-shadow: 0 0 6px #cc0000, 0 0 8px #cc0000, 0 0 10px #cc0000, 0 0 12px #cc0000, 0 0 14px #cc0000;
  margin-top: 10.7vw;
  letter-spacing: 0.1em;
  font-size: 54px;
  font-size: 2.8125vw;
}
@media screen and (max-width: 1120px) {
  .mv-cc__en {
    font-size: 36px;
  }
}
@media screen and (min-width: 1920px) {
  .mv-cc__en {
    font-size: 54px;
  }
}

.sv {
  aspect-ratio: 1920/604;
  background: url("/img/common/sv-bg.png") center bottom no-repeat;
  background-size: 100%;
}
.sv-ttl {
  width: 1080px;
  max-width: 56.25%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  row-gap: 3vw;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -40%);
  z-index: -1;
  transition: 0.3s;
}
.sv-ttl__en {
  font-family: "Orbitron", sans-serif;
  letter-spacing: 0.02em;
  font-weight: 500;
  text-shadow: 0 0 6px #cc0000, 0 0 8px #cc0000, 0 0 10px #cc0000, 0 0 12px #cc0000, 0 0 14px #cc0000;
  letter-spacing: 0.1em;
  font-size: 26px;
  font-size: 1.3541666667vw;
}
@media screen and (max-width: 1120px) {
  .sv-ttl__en {
    font-size: 17.3333333333px;
  }
}
@media screen and (min-width: 1920px) {
  .sv-ttl__en {
    font-size: 26px;
  }
}
.sv-about .sv-ttl__rb, .sv-notfound .sv-ttl__rb {
  width: 38.89%;
}
.sv-blog .sv-ttl__rb {
  width: 19.81%;
}
.sv-company .sv-ttl__rb {
  width: 28.15%;
}
.sv-complete .sv-ttl__rb, .sv-job .sv-ttl__rb {
  width: 27.5%;
}
.sv-contact .sv-ttl__rb {
  width: 66.76%;
}
.sv-notfound .sv-ttl__rb {
  width: 80.46%;
}
.sv-privacy .sv-ttl__rb {
  width: 65.93%;
}
.sv-recruit .sv-ttl__rb {
  width: 28.24%;
}
.sv-site .sv-ttl__rb {
  width: 38.8%;
}
@media screen and (max-width: 1520px) {
  .sv .sv-ttl {
    row-gap: 2vw;
    transform: translate(-50%, -20%);
  }
}

#ctn-top {
  position: relative;
  z-index: 1;
}

.top-about, .top-reason, .top-job-openings, .top-blog {
  padding: 180px 0;
}

.top-about {
  background: url("/img/common/bg-cyber.png") right bottom no-repeat;
  background-size: 20.78%;
}
.top-about .ttl-main {
  margin-bottom: 110px;
}
.top-about .obj-img {
  position: relative;
  z-index: 1;
}
.top-about .obj-img::before {
  content: "";
  display: block;
  width: 787px;
  max-width: 100%;
  aspect-ratio: 787/389;
  background-image: url("/img/top/about-obj.png");
  background-size: 100%;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(250px, -180px);
  z-index: -1;
}
.top-about.obj-com-square-top::before {
  right: 0;
  bottom: -1px;
}
.top-about.obj-com-grid::after {
  width: 620px;
  max-width: 32.2916666667%;
  height: 406px;
  left: 0;
  bottom: 0;
  transform: translateY(-45%);
}

.top-reason .ttl-main {
  margin-bottom: 130px;
}
.top-reason.obj-com-square-btm::after {
  top: -1px;
  left: 0;
}

.top-job-description {
  padding: 150px 0 190px 0;
}
.top-job-description .ttl-main {
  margin-bottom: 100px;
}
.top-job-description .obj-01, .top-job-description .obj-02 {
  position: relative;
  z-index: 1;
}
.top-job-description .obj-01::before, .top-job-description .obj-02::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 0;
  z-index: -1;
}
.top-job-description .obj-01::before {
  width: 130px;
  aspect-ratio: 130/314;
  background-image: url("/img/top/job-description-obj-01.png");
  background-size: 100%;
  left: 0;
  transform: translate(-225px, 130px);
}
.top-job-description .obj-02::after {
  width: 13px;
  aspect-ratio: 13/152;
  background-image: url("/img/top/job-description-obj-02.png");
  background-size: 100%;
  right: 0;
  transform: translate(200px, 560px);
}
.top-job-description .obj-com-ruler::after {
  top: 50%;
  transform: translateY(-50%);
}

.top-job-openings {
  background: url("/img/top/job-openings-bg.png") left 7.29% top no-repeat;
  background-size: 54.84%;
}
.top-job-openings .ttl-main {
  margin-bottom: 110px;
}
.top-job-openings.obj-com-square-top::before {
  right: 0;
  top: 0;
  transform: translateY(calc(-99px - 100%));
}
.top-job-openings.obj-com-square-btm::after {
  top: 0;
  left: 0;
  transform: translateY(-1px);
}

.top-contact {
  padding: 180px 0 0;
}
.top-contact .ttl-main {
  margin-bottom: 120px;
}

.top-blog .cts-1080 {
  min-height: 400px;
}
.top-blog .btn {
  position: absolute;
  left: 0;
  bottom: 65px;
  z-index: 1;
}
.top-blog .obj {
  position: relative;
  z-index: 1;
}
.top-blog .obj::before {
  content: "";
  display: inline-block;
  width: 169px;
  aspect-ratio: 169/204;
  background-image: url("/img/top/blog-obj.png");
  background-size: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-120px, -60px);
  z-index: -1;
}

#ctn-lower section {
  padding: 140px 0;
}
#ctn-lower .ttl-main {
  margin-bottom: 60px;
  font-weight: 600;
  text-align: center;
  font-size: 54px;
  font-size: 5.4rem;
}
@media screen and (max-width: 768px) {
  #ctn-lower .ttl-main {
    font-size: 64px;
    font-size: 8.3333333333vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  #ctn-lower .ttl-main {
    font-size: 42.6666666667px;
  }
}

.low-profile .obj-com-cyber-01::before {
  top: 0;
  right: 0;
  transform: translate(50px, -30px);
}
.low-profile.obj-com-grid::after {
  width: 620px;
  max-width: 32.2916666667%;
  height: 406px;
  left: 0;
  bottom: 0;
  transform: translate(0, -140px);
}

.low-workplace .obj-com-cyber-01::before {
  top: 0;
  left: 0;
  transform: translate(-90px, 120px) scaleY(-1);
}

.low-job .job-en {
  font-family: "Orbitron", sans-serif;
  letter-spacing: 0.02em;
  font-weight: 500;
  opacity: 0.5;
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(0, -40%);
  z-index: -1;
  font-size: 100px;
  font-size: 10rem;
}
@media screen and (max-width: 768px) {
  .low-job .job-en {
    font-size: 110px;
    font-size: 14.3229166667vw;
  }
}
@media screen and (max-width: 768px) and (min-width: 539px) {
  .low-job .job-en {
    font-size: 73.3333333333px;
  }
}

.low-greeting.obj-com-grid::after {
  width: 620px;
  max-width: 32.2916666667%;
  height: 406px;
  left: 0;
  bottom: 0;
}

.low-access.obj-com-ruler::after {
  bottom: 0;
  transform: translateY(-254px);
}

#footer {
  border-top: solid 20px #cc0000;
}
#footer.obj-com-square-top::before {
  right: 0;
  bottom: 100%;
  transform: translateY(-19px);
}
#footer.obj-com-square-btm::after {
  left: 0;
  bottom: 0;
}/*# sourceMappingURL=style.css.map */