@charset "UTF-8";
.mt-120 {
  margin-top: 120px;
}

.mt-80 {
  margin-top: 80px;
}

.mt-60 {
  margin-top: 60px;
}

.mt-40 {
  margin-top: 40px;
}

.mt-30 {
  margin-top: 30px;
}

.pt-120 {
  padding-top: 120px;
}

.pt-80 {
  padding-top: 80px;
}

.pt-60 {
  padding-top: 60px;
}

.pt-40 {
  padding-top: 40px;
}

.pt-30 {
  padding-top: 30px;
}

.textDark {
  color: #232323 !important;
}

.textCyan {
  color: #45e1e5 !important;
}

.textMedeumGray {
  color: #999 !important;
}

.textPaleGray {
  color: #e4e4e4 !important;
}

.bgDark {
  background-color: #232323 !important;
}

.bgCyan {
  background-color: #45e1e5 !important;
}

.bgGray99 {
  background-color: #999 !important;
}

.bgGrayB3 {
  background-color: #b3b3b3 !important;
}

.bgGrayF0 {
  background-color: #f0f0f0 !important;
}

.bgGrayFA {
  background-color: #fafafa !important;
}

.bgWhite {
  background-color: #fff !important;
}

.webFont {
  font-family: Montserrat, sans-serif !important;
}

.webFontRegular {
  font-family: Montserrat, sans-serif !important;
  font-weight: 400 !important;
}

.webFontMedium {
  font-family: Montserrat, sans-serif !important;
  font-weight: 500 !important;
}

.webFontBold {
  font-family: Montserrat, sans-serif !important;
  font-weight: 700 !important;
}

html {
  box-sizing: border-box;
  font-size: 12px;
}

body {
  color: #232323;
  line-height: 1.8;
  font-family: Hiragino Kaku Gothic ProN, "ヒラギノ角ゴ Pro W3", Hiragino Sans,
    "游ゴシック", Yu Gothic, YuGothic, Meiryo, "メイリオ", Helvetica Neue,
    Helvetica, Arial, Sans-Serif;
  font-weight: 400;
  font-feature-settings: "palt";
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: unset;
  background-color: #fff;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
  letter-spacing: 0.03em;
}

img {
  max-width: 100%;
}

ul {
  list-style: none;
  padding: 0;
}

a {
  text-decoration: underline;
}

a:hover {
  transition: 0.2s;
}

h1,
h2,
h3,
h4,
h5,
h6,
dl,
dt,
dd,
ul,
li,
p {
  margin-bottom: 0;
  padding: 0;
}

* {
  box-sizing: border-box;
  box-sizing: inherit;
  margin: 0;
  padding: 0;
}

.col-1,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9,
.col-10,
.col-11,
.col-12,
.col,
.col-auto,
.col-md-1,
.col-md-2,
.col-md-3,
.col-md-4,
.col-md-5,
.col-md-6,
.col-md-7,
.col-md-8,
.col-md-9,
.col-md-10,
.col-md-11,
.col-md-12,
.col-md,
.col-md-auto,
.col-xl-1,
.col-xl-2,
.col-xl-3,
.col-xl-4,
.col-xl-5,
.col-xl-6,
.col-xl-7,
.col-xl-8,
.col-xl-9,
.col-xl-10,
.col-xl-11,
.col-xl-12,
.col-xl,
.col-xl-auto {
  position: relative;
  width: 100%;
}

.col {
  flex-basis: 0;
  flex-grow: 1;
  max-width: 100%;
}

.col-auto {
  flex: 0 0 auto;
  width: auto;
  max-width: 100%;
}

.col-1 {
  flex: 0 0 8.333333%;
  max-width: 8.333333%;
}

.col-2 {
  flex: 0 0 16.666667%;
  max-width: 16.666667%;
}

.col-3 {
  flex: 0 0 25%;
  max-width: 25%;
}

.col-4 {
  flex: 0 0 33.333333%;
  max-width: 33.333333%;
}

.col-5 {
  flex: 0 0 41.666667%;
  max-width: 41.666667%;
}

.col-6 {
  flex: 0 0 50%;
  max-width: 50%;
}

.col-7 {
  flex: 0 0 58.333333%;
  max-width: 58.333333%;
}

.col-8 {
  flex: 0 0 66.666667%;
  max-width: 66.666667%;
}

.col-9 {
  flex: 0 0 75%;
  max-width: 75%;
}

.col-10 {
  flex: 0 0 83.333333%;
  max-width: 83.333333%;
}

.col-11 {
  flex: 0 0 91.666667%;
  max-width: 91.666667%;
}

.col-12 {
  flex: 0 0 100%;
  max-width: 100%;
}

.order-first {
  order: -1;
}

.order-last {
  order: 13;
}

.order-0 {
  order: 0;
}

.order-1 {
  order: 1;
}

.order-2 {
  order: 2;
}

.order-3 {
  order: 3;
}

.order-4 {
  order: 4;
}

.order-5 {
  order: 5;
}

.order-6 {
  order: 6;
}

.order-7 {
  order: 7;
}

.order-8 {
  order: 8;
}

.order-9 {
  order: 9;
}

.order-10 {
  order: 10;
}

.order-11 {
  order: 11;
}

.order-12 {
  order: 12;
}

.offset-1 {
  margin-left: 8.333333%;
}

.offset-2 {
  margin-left: 16.666667%;
}

.offset-3 {
  margin-left: 25%;
}

.offset-4 {
  margin-left: 33.333333%;
}

.offset-5 {
  margin-left: 41.666667%;
}

.offset-6 {
  margin-left: 50%;
}

.offset-7 {
  margin-left: 58.333333%;
}

.offset-8 {
  margin-left: 66.666667%;
}

.offset-9 {
  margin-left: 75%;
}

.offset-10 {
  margin-left: 83.333333%;
}

.offset-11 {
  margin-left: 91.666667%;
}

@media (min-width: 640px) {
  .col-md {
    flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
  }

  .col-md-auto {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
  }

  .col-md-1 {
    flex: 0 0 8.333333%;
    max-width: 8.333333%;
  }

  .col-md-2 {
    flex: 0 0 16.666667%;
    max-width: 16.666667%;
  }

  .col-md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }

  .col-md-4 {
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
  }

  .col-md-5 {
    flex: 0 0 41.666667%;
    max-width: 41.666667%;
  }

  .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }

  .col-md-7 {
    flex: 0 0 58.333333%;
    max-width: 58.333333%;
  }

  .col-md-8 {
    flex: 0 0 66.666667%;
    max-width: 66.666667%;
  }

  .col-md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }

  .col-md-10 {
    flex: 0 0 83.333333%;
    max-width: 83.333333%;
  }

  .col-md-11 {
    flex: 0 0 91.666667%;
    max-width: 91.666667%;
  }

  .col-md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .order-md-first {
    order: -1;
  }

  .order-md-last {
    order: 13;
  }

  .order-md-0 {
    order: 0;
  }

  .order-md-1 {
    order: 1;
  }

  .order-md-2 {
    order: 2;
  }

  .order-md-3 {
    order: 3;
  }

  .order-md-4 {
    order: 4;
  }

  .order-md-5 {
    order: 5;
  }

  .order-md-6 {
    order: 6;
  }

  .order-md-7 {
    order: 7;
  }

  .order-md-8 {
    order: 8;
  }

  .order-md-9 {
    order: 9;
  }

  .order-md-10 {
    order: 10;
  }

  .order-md-11 {
    order: 11;
  }

  .order-md-12 {
    order: 12;
  }

  .offset-md-0 {
    margin-left: 0;
  }

  .offset-md-1 {
    margin-left: 8.333333%;
  }

  .offset-md-2 {
    margin-left: 16.666667%;
  }

  .offset-md-3 {
    margin-left: 25%;
  }

  .offset-md-4 {
    margin-left: 33.333333%;
  }

  .offset-md-5 {
    margin-left: 41.666667%;
  }

  .offset-md-6 {
    margin-left: 50%;
  }

  .offset-md-7 {
    margin-left: 58.333333%;
  }

  .offset-md-8 {
    margin-left: 66.666667%;
  }

  .offset-md-9 {
    margin-left: 75%;
  }

  .offset-md-10 {
    margin-left: 83.333333%;
  }

  .offset-md-11 {
    margin-left: 91.666667%;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .col-xl {
    flex-basis: 0;
    flex-grow: 1;
    max-width: 100%;
  }

  .col-xl-auto {
    flex: 0 0 auto;
    width: auto;
    max-width: 100%;
  }

  .col-xl-1 {
    flex: 0 0 8.333333%;
    max-width: 8.333333%;
  }

  .col-xl-2 {
    flex: 0 0 16.666667%;
    max-width: 16.666667%;
  }

  .col-xl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }

  .col-xl-4 {
    flex: 0 0 33.333333%;
    max-width: 33.333333%;
  }

  .col-xl-5 {
    flex: 0 0 41.666667%;
    max-width: 41.666667%;
  }

  .col-xl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }

  .col-xl-7 {
    flex: 0 0 58.333333%;
    max-width: 58.333333%;
  }

  .col-xl-8 {
    flex: 0 0 66.666667%;
    max-width: 66.666667%;
  }

  .col-xl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }

  .col-xl-10 {
    flex: 0 0 83.333333%;
    max-width: 83.333333%;
  }

  .col-xl-11 {
    flex: 0 0 91.666667%;
    max-width: 91.666667%;
  }

  .col-xl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .order-xl-first {
    order: -1;
  }

  .order-xl-last {
    order: 13;
  }

  .order-xl-0 {
    order: 0;
  }

  .order-xl-1 {
    order: 1;
  }

  .order-xl-2 {
    order: 2;
  }

  .order-xl-3 {
    order: 3;
  }

  .order-xl-4 {
    order: 4;
  }

  .order-xl-5 {
    order: 5;
  }

  .order-xl-6 {
    order: 6;
  }

  .order-xl-7 {
    order: 7;
  }

  .order-xl-8 {
    order: 8;
  }

  .order-xl-9 {
    order: 9;
  }

  .order-xl-10 {
    order: 10;
  }

  .order-xl-11 {
    order: 11;
  }

  .order-xl-12 {
    order: 12;
  }

  .offset-xl-0 {
    margin-left: 0;
  }

  .offset-xl-1 {
    margin-left: 8.333333%;
  }

  .offset-xl-2 {
    margin-left: 16.666667%;
  }

  .offset-xl-3 {
    margin-left: 25%;
  }

  .offset-xl-4 {
    margin-left: 33.333333%;
  }

  .offset-xl-5 {
    margin-left: 41.666667%;
  }

  .offset-xl-6 {
    margin-left: 50%;
  }

  .offset-xl-7 {
    margin-left: 58.333333%;
  }

  .offset-xl-8 {
    margin-left: 66.666667%;
  }

  .offset-xl-9 {
    margin-left: 75%;
  }

  .offset-xl-10 {
    margin-left: 83.333333%;
  }

  .offset-xl-11 {
    margin-left: 91.666667%;
  }
}

.d-none {
  display: none !important;
}

.d-inline {
  display: inline !important;
}

.d-inline-block {
  display: inline-block !important;
}

.d-block {
  display: block !important;
}

.d-table {
  display: table !important;
}

.d-table-row {
  display: table-row !important;
}

.d-table-cell {
  display: table-cell !important;
}

.d-flex {
  display: flex !important;
}

.d-inline-flex {
  display: inline-flex !important;
}

@media (min-width: 640px) {
  .d-md-none {
    display: none !important;
  }

  .d-md-inline {
    display: inline !important;
  }

  .d-md-inline-block {
    display: inline-block !important;
  }

  .d-md-block {
    display: block !important;
  }

  .d-md-table {
    display: table !important;
  }

  .d-md-table-row {
    display: table-row !important;
  }

  .d-md-table-cell {
    display: table-cell !important;
  }

  .d-md-flex {
    display: flex !important;
  }

  .d-md-inline-flex {
    display: inline-flex !important;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .d-xl-none {
    display: none !important;
  }

  .d-xl-inline {
    display: inline !important;
  }

  .d-xl-inline-block {
    display: inline-block !important;
  }

  .d-xl-block {
    display: block !important;
  }

  .d-xl-table {
    display: table !important;
  }

  .d-xl-table-row {
    display: table-row !important;
  }

  .d-xl-table-cell {
    display: table-cell !important;
  }

  .d-xl-flex {
    display: flex !important;
  }

  .d-xl-inline-flex {
    display: inline-flex !important;
  }
}

.flex-row {
  flex-direction: row !important;
}

.flex-column {
  flex-direction: column !important;
}

.flex-row-reverse {
  flex-direction: row-reverse !important;
}

.flex-column-reverse {
  flex-direction: column-reverse !important;
}

.flex-wrap {
  flex-wrap: wrap !important;
}

.flex-nowrap {
  flex-wrap: nowrap !important;
}

.flex-wrap-reverse {
  flex-wrap: wrap-reverse !important;
}

.flex-fill {
  flex: 1 1 auto !important;
}

.flex-grow-0 {
  flex-grow: 0 !important;
}

.flex-grow-1 {
  flex-grow: 1 !important;
}

.flex-shrink-0 {
  flex-shrink: 0 !important;
}

.flex-shrink-1 {
  flex-shrink: 1 !important;
}

.justify-content-start {
  justify-content: flex-start !important;
}

.justify-content-end {
  justify-content: flex-end !important;
}

.justify-content-center {
  justify-content: center !important;
}

.justify-content-between {
  justify-content: space-between !important;
}

.justify-content-around {
  justify-content: space-around !important;
}

.align-items-start {
  align-items: flex-start !important;
}

.align-items-end {
  align-items: flex-end !important;
}

.align-items-center {
  align-items: center !important;
}

.align-items-baseline {
  align-items: baseline !important;
}

.align-items-stretch {
  align-items: stretch !important;
}

.align-content-start {
  align-content: flex-start !important;
}

.align-content-end {
  align-content: flex-end !important;
}

.align-content-center {
  align-content: center !important;
}

.align-content-between {
  align-content: space-between !important;
}

.align-content-around {
  align-content: space-around !important;
}

.align-content-stretch {
  align-content: stretch !important;
}

.align-self-auto {
  align-self: auto !important;
}

.align-self-start {
  align-self: flex-start !important;
}

.align-self-end {
  align-self: flex-end !important;
}

.align-self-center {
  align-self: center !important;
}

.align-self-baseline {
  align-self: baseline !important;
}

.align-self-stretch {
  align-self: stretch !important;
}

@media (min-width: 640px) {
  .flex-md-row {
    flex-direction: row !important;
  }

  .flex-md-column {
    flex-direction: column !important;
  }

  .flex-md-row-reverse {
    flex-direction: row-reverse !important;
  }

  .flex-md-column-reverse {
    flex-direction: column-reverse !important;
  }

  .flex-md-wrap {
    flex-wrap: wrap !important;
  }

  .flex-md-nowrap {
    flex-wrap: nowrap !important;
  }

  .flex-md-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }

  .flex-md-fill {
    flex: 1 1 auto !important;
  }

  .flex-md-grow-0 {
    flex-grow: 0 !important;
  }

  .flex-md-grow-1 {
    flex-grow: 1 !important;
  }

  .flex-md-shrink-0 {
    flex-shrink: 0 !important;
  }

  .flex-md-shrink-1 {
    flex-shrink: 1 !important;
  }

  .justify-content-md-start {
    justify-content: flex-start !important;
  }

  .justify-content-md-end {
    justify-content: flex-end !important;
  }

  .justify-content-md-center {
    justify-content: center !important;
  }

  .justify-content-md-between {
    justify-content: space-between !important;
  }

  .justify-content-md-around {
    justify-content: space-around !important;
  }

  .align-items-md-start {
    align-items: flex-start !important;
  }

  .align-items-md-end {
    align-items: flex-end !important;
  }

  .align-items-md-center {
    align-items: center !important;
  }

  .align-items-md-baseline {
    align-items: baseline !important;
  }

  .align-items-md-stretch {
    align-items: stretch !important;
  }

  .align-content-md-start {
    align-content: flex-start !important;
  }

  .align-content-md-end {
    align-content: flex-end !important;
  }

  .align-content-md-center {
    align-content: center !important;
  }

  .align-content-md-between {
    align-content: space-between !important;
  }

  .align-content-md-around {
    align-content: space-around !important;
  }

  .align-content-md-stretch {
    align-content: stretch !important;
  }

  .align-self-md-auto {
    align-self: auto !important;
  }

  .align-self-md-start {
    align-self: flex-start !important;
  }

  .align-self-md-end {
    align-self: flex-end !important;
  }

  .align-self-md-center {
    align-self: center !important;
  }

  .align-self-md-baseline {
    align-self: baseline !important;
  }

  .align-self-md-stretch {
    align-self: stretch !important;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .flex-xl-row {
    flex-direction: row !important;
  }

  .flex-xl-column {
    flex-direction: column !important;
  }

  .flex-xl-row-reverse {
    flex-direction: row-reverse !important;
  }

  .flex-xl-column-reverse {
    flex-direction: column-reverse !important;
  }

  .flex-xl-wrap {
    flex-wrap: wrap !important;
  }

  .flex-xl-nowrap {
    flex-wrap: nowrap !important;
  }

  .flex-xl-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }

  .flex-xl-fill {
    flex: 1 1 auto !important;
  }

  .flex-xl-grow-0 {
    flex-grow: 0 !important;
  }

  .flex-xl-grow-1 {
    flex-grow: 1 !important;
  }

  .flex-xl-shrink-0 {
    flex-shrink: 0 !important;
  }

  .flex-xl-shrink-1 {
    flex-shrink: 1 !important;
  }

  .justify-content-xl-start {
    justify-content: flex-start !important;
  }

  .justify-content-xl-end {
    justify-content: flex-end !important;
  }

  .justify-content-xl-center {
    justify-content: center !important;
  }

  .justify-content-xl-between {
    justify-content: space-between !important;
  }

  .justify-content-xl-around {
    justify-content: space-around !important;
  }

  .align-items-xl-start {
    align-items: flex-start !important;
  }

  .align-items-xl-end {
    align-items: flex-end !important;
  }

  .align-items-xl-center {
    align-items: center !important;
  }

  .align-items-xl-baseline {
    align-items: baseline !important;
  }

  .align-items-xl-stretch {
    align-items: stretch !important;
  }

  .align-content-xl-start {
    align-content: flex-start !important;
  }

  .align-content-xl-end {
    align-content: flex-end !important;
  }

  .align-content-xl-center {
    align-content: center !important;
  }

  .align-content-xl-between {
    align-content: space-between !important;
  }

  .align-content-xl-around {
    align-content: space-around !important;
  }

  .align-content-xl-stretch {
    align-content: stretch !important;
  }

  .align-self-xl-auto {
    align-self: auto !important;
  }

  .align-self-xl-start {
    align-self: flex-start !important;
  }

  .align-self-xl-end {
    align-self: flex-end !important;
  }

  .align-self-xl-center {
    align-self: center !important;
  }

  .align-self-xl-baseline {
    align-self: baseline !important;
  }

  .align-self-xl-stretch {
    align-self: stretch !important;
  }
}

.container {
  max-width: calc(100% - 40px);
}

@media (min-width: 640px) {
  .container {
    max-width: calc(100% - 40px);
  }
}

@media (min-width: calc(1196px + 40px)) {
  .container {
    max-width: 1196px;
  }
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

@media (max-width: calc(1196px + 40px)) {
  .container--md {
    max-width: 100% !important;
  }
}

.container-full {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

.row {
  display: flex;
  flex-wrap: wrap;
  margin-right: 0;
  margin-left: 0;
}

@media (min-width: 640px) {
  .col-md-6--space {
    flex-basis: calc(50% - 6px);
    max-width: calc(50% - 6px);
  }
}

@media (min-width: calc(1196px + 40px)) {
  .col-xl-6--space {
    flex-basis: calc(50% - 6px);
    max-width: calc(50% - 6px);
  }
}

@media (min-width: 640px) {
  .col-md-4--space {
    flex-basis: calc(33.333333% - 26px);
    max-width: calc(33.333333% - 26px);
  }
}

@media (min-width: calc(1196px + 40px)) {
  .col-xl-4--space {
    flex-basis: calc(33.333333% - 26px);
    max-width: calc(33.333333% - 26px);
  }
}

@media (min-width: 640px) {
  .col-md-3--space {
    flex-basis: calc(25% - 9px);
    max-width: calc(25% - 9px);
  }
}

@media (min-width: calc(1196px + 40px)) {
  .col-xl-3--space {
    flex-basis: calc(25% - 9px);
    max-width: calc(25% - 9px);
  }
}

.footerAll {
  padding-bottom: 30px;
}

@media (min-width: 640px) {
  .footerAll {
    padding-bottom: 40px;
  }
}

.footerOtherLinks {
  margin-top: 20px;
  padding-bottom: 40px;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  border-bottom: 1px solid #525252;
}

@media (min-width: 640px) {
  .footerOtherLinks {
    justify-content: flex-start;
    padding-left: 40px;
  }
}

.footerOtherLinks__li {
  width: 50%;
  max-width: 114px;
  display: block;
  margin-left: 12%;
  margin-top: 20px;
}

@media (min-width: 640px) {
  .footerOtherLinks__li {
    width: 25%;
    max-width: 130px;
    margin-right: 35px;
    margin-left: 0;
  }
}

.footerOtherLinks__li > a {
  display: flex;
  justify-content: space-between;
  text-decoration: none;
}

@media (min-width: 640px) {
  .footerOtherLinks__li:hover {
    opacity: 0.6;
  }
}

.footerOtherLinks__txt {
  font-size: 10px;
  display: inline-block;
  line-height: 44px;
}

@media (min-width: 640px) {
  .footerOtherLinks__txt {
    font-size: 12px;
    line-height: 48px;
  }
}

.footerOtherLinks__logo {
  width: 44px;
  position: relative;
}

@media (min-width: 640px) {
  .footerOtherLinks__logo {
    width: 48px;
  }
}

.footerOtherLinks__logo > img {
  display: block;
  width: 100%;
  height: auto;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}

.footerPageLinks {
  margin-top: 20px;
  display: flex;
  flex-wrap: wrap;
}

@media (min-width: calc(1196px + 40px)) {
  .footerPageLinks {
    padding-left: 40px;
    flex-wrap: nowrap;
  }
}

.footerPageLinks__column {
  width: 50%;
}

@media (min-width: 640px) {
  .footerPageLinks__column {
    width: 25%;
  }
}

.footerPageLinks__linkBlock {
  display: block;
  margin-top: 16px;
}

.footerPageLinks__link {
  position: relative;
  color: #999;
  font-size: 10px;
  text-decoration: none;
  line-height: 1;
}

@media (min-width: 640px) {
  .footerPageLinks__link {
    font-size: 12px;
  }
}

.footerPageLinks__link:before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 1px;
  background-color: #999;
  position: relative;
  top: -1px;
  vertical-align: middle;
  margin-right: 4px;
  opacity: 0.6;
}

.footerPageLinks__link:hover {
  opacity: 0.6;
}

.footerCopy {
  margin-top: 80px;
  text-align: center;
  font-size: 10px;
}

@media (min-width: 640px) {
  .footerCopy {
    margin-top: 120px;
    font-size: 12px;
  }
}

.addBeforeBgFA {
  position: relative;
}

.addBeforeBgFA:before {
  content: "";
  width: 100%;
  height: 40px;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #fafafa;
  z-index: 0;
}

@media (min-width: 640px) {
  .addBeforeBgFA:before {
    height: 80px;
  }
}

.addBeforeBgWhite {
  position: relative;
}

.addBeforeBgWhite:before {
  content: "";
  width: 100%;
  height: 40px;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: white;
  z-index: 0;
}

@media (min-width: 640px) {
  .addBeforeBgWhite:before {
    height: 80px;
  }
}

.addAfterBgDark {
  position: relative;
}

.addAfterBgDark:after {
  content: "";
  width: 100%;
  height: 80px;
  display: block;
  position: absolute;
  top: auto;
  bottom: 0;
  background-color: #232323;
  z-index: 2;
}

.whiteBox {
  background-color: #fff;
  box-shadow: 0 0 7.5px rgba(0, 0, 0, 0.05);
  position: relative;
  z-index: 3;
}

@media (min-width: calc(1196px + 40px)) {
  .whiteBox {
    box-shadow: 0 0 15px rgba(0, 0, 0, 0.05);
  }
}

.pageTitle {
  position: relative;
  height: auto;
  overflow: hidden;
  width: 100%;
  background-image: url(/static/img/elements/headerSp.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  padding-bottom: 80px;
}

.pageTitle:before {
  content: "";
  background-image: url(https://www.tactinc.jp/static/img/parts/pageTitle/texture.png);
  background-repeat: repeat;
  background-size: 4px;
  opacity: 0.4;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 400px;
}

@media (min-width: 640px) {
  .pageTitle {
    padding-bottom: 100px;
  }
}

.pageTitle__ttlEN {
  padding-top: 60px;
  font-family: Montserrat, sans-serif;
  color: #232323;
  font-size: 14px;
  font-weight: 700;
  line-height: 1em;
  text-align: center;
}

@media (min-width: 640px) {
  .pageTitle__ttlEN {
    padding-top: 80px;
    font-size: 28px;
  }
}

.pageTitle__ttlJA {
  color: #232323;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.2;
  text-align: center;
  margin-top: 10px;
  letter-spacing: 0.4px;
}

@media (min-width: 640px) {
  .pageTitle__ttlJA {
    font-size: 48px;
  }
}

.pageTitle__ttlSub {
  color: #232323;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
  margin-top: 12px;
}

@media (min-width: 640px) {
  .pageTitle__ttlSub {
    font-size: 20px;
  }
}

@media (min-width: 640px) {
  .pageTitle--ai {
    background-image: url(/static/img/elements/headerPc.png);
  }
}

@media (min-width: 640px) {
  .pageTitle--rpa {
    background-image: url(/static/img/parts/pageTitle/bgPc--rpa.jpg);
  }
}

@media (min-width: 640px) {
  .pageTitle--callcenter {
    background-image: url(/static/img/parts/pageTitle/bgPc--callcenter.jpg);
  }
}

.pageTitle--small {
  padding-bottom: 40px;
}

@media (min-width: 640px) {
  .pageTitle--small {
    padding-bottom: 60px;
  }
}

.pageTitle--small .pageTitle__ttlEN {
  display: none;
}

.pageTitle--small .pageTitle__ttlJA {
  padding-top: 30px;
}

@media (min-width: 640px) {
  .pageTitle--small .pageTitle__ttlJA {
    padding-top: 50px;
  }
}

.blackBtn {
  position: relative;
  display: block;
  margin: 0 auto;
  background-color: #232323;
  color: #45e1e5;
  width: 100%;
  max-width: 160px;
  height: 44px;
  text-align: center;
  line-height: 44px;
  text-decoration: none;
  font-family: Montserrat, sans-serif;
  font-size: 12px;
  font-weight: 500;
  border: none;
  cursor: pointer;
}

@media (min-width: 640px) {
  .blackBtn {
    font-size: 15px;
    max-width: 184px;
    height: 48px;
    line-height: 48px;
  }
}

.blackBtn--dot {
  text-align: left;
  padding: 0 0 0 15px;
}

.blackBtn--dot:after {
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  background-color: #45e1e5;
  border-radius: 50%;
  position: absolute;
  top: 44%;
  right: 12px;
}

@media (min-width: 640px) {
  .blackBtn--dot:after {
    width: 4px;
    height: 4px;
    top: 46%;
    right: 14px;
  }
}

@media (min-width: 640px) {
  .blackBtn:hover {
    background-color: #45e1e5;
    color: #232323;
  }

  .blackBtn:hover:after {
    background-color: #232323;
  }
}

.blackBtn--simple {
  border: 1px solid #232323;
  background-color: transparent;
  color: #232323;
}

.blackBtn--simple:hover {
  background: transparent;
}

.blackBtn--inversion {
  background-color: #45e1e5;
  color: #232323;
}

.blackBtn--inversion:hover {
  background-color: #232323;
  color: #45e1e5;
}

.headingEN {
  font-family: Montserrat, sans-serif;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.5px;
  line-height: 1em;
}

@media (min-width: 640px) {
  .headingEN {
    font-size: 28px;
  }
}

.headingJA {
  font-size: 14px;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0.5px;
  line-height: 1em;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .headingJA {
    font-size: 16px;
    margin-top: 12px;
  }
}

.headerPcSpace {
  display: none;
  height: 104px;
}

@media (min-width: calc(1196px + 40px)) {
  .headerPcSpace {
    display: block;
  }
}

.headerPcArea {
  position: fixed;
  z-index: 49;
  top: 0;
  left: 0;
  display: none;
  width: 100%;
}

@media (min-width: calc(1196px + 40px)) {
  .headerPcArea {
    display: block;
  }
}

.headerPc {
  display: flex;
  height: 104px;
  background: white;
  justify-content: flex-end;
}

.headerPc__inner {
  display: flex;
  height: 100%;
  padding: 0 25px;
}

.headerPc:after {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  height: 104px;
  background-color: rgba(0, 0, 0, 0.5);
  pointer-events: none;
  content: "";
  opacity: 0;
  transition: opacity 0.3s;
}

.headerPc.isDim:after {
  opacity: 1;
  transition: opacity 0.3s;
}

.headerPcLink {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 0 20px 10px;
  border: none;
  outline: none;
  background-color: transparent;
  color: black;
  text-align: center;
  text-decoration: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  align-items: center;
  justify-content: center;
}

.headerPcLink--service {
  cursor: pointer;
}

.headerPcLink:visited {
  color: black;
}

.headerPcLink__en {
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.headerPcLink__ja {
  display: block;
  margin-top: 5px;
  font-size: 14px;
  font-weight: 400;
  line-height: 1;
}

.headerPcLink:after {
  position: absolute;
  bottom: 0;
  left: 50%;
  display: block;
  width: calc(100% - 60px);
  height: 2px;
  margin: auto;
  background-color: #45e1e5;
  content: "";
  transition: 0.4s ease-out;
  transform: translate(-50%, -26px) scale(0, 1);
  transform-origin: left;
}

.headerPcLink.isCurrent:after {
  transform: translate(-50%, -26px) scale(1, 1);
}

.headerPcLink:hover:after {
  transform: translate(-50%, -26px) scale(1, 1);
}

.headerPcService {
  display: none;
  padding: 40px;
  background: white;
}

.headerPcService__inner {
  display: flex;
  opacity: 0;
  justify-content: center;
}

.headerPcService.isOpen .headerPcService__inner {
  opacity: 1;
  transition: opacity 0.2s 0.3s;
}

.headerPcService__category {
  padding: 0 40px;
}

.headerPcService__categoryName {
  width: 220px;
  padding-bottom: 15px;
  border-bottom: 1px solid #b3b3b3;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.05em;
}

.headerPcService__linkWrap {
  display: block;
  margin-top: 18px;
}

.headerPcService__link {
  position: relative;
  display: inline-block;
  font-size: 14px;
  line-height: 1;
  color: black;
  text-decoration: none;
}

.headerPcService__link:visited {
  color: black;
}

.headerPcService__link:hover:after {
  transform: scale(1, 1);
}

.headerPcService__link:after {
  position: absolute;
  bottom: -9px;
  left: 0;
  display: block;
  width: 100%;
  height: 2px;
  margin: auto;
  background-color: #45e1e5;
  content: "";
  transition: transform 0.3s ease-out;
  transform: scale(0, 1);
  transform-origin: left;
}

.headerSpSpace {
  height: 58px;
}

@media (min-width: calc(1196px + 40px)) {
  .headerSpSpace {
    display: none;
  }
}

.headerSpBg {
  position: fixed;
  z-index: 49;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 58px;
  background-color: #fff;
}

@media (min-width: calc(1196px + 40px)) {
  .headerSpBg {
    display: none;
  }
}

.headerSpHamBtn {
  position: fixed;
  z-index: 70;
  top: 0;
  right: 25px;
  width: 32px;
  height: 58px;
  text-align: center;
  cursor: pointer;
}

@media (min-width: calc(1196px + 40px)) {
  .headerSpHamBtn {
    display: none;
  }
}

.headerSpHamBtn > span {
  position: absolute;
  display: block;
  width: 32px;
  height: 2px;
  background-color: #232323;
  transition: 0.35s ease-in-out;
}

.headerSpHamBtn > span:nth-child(1) {
  top: 24px;
}

.headerSpHamBtn > span:nth-child(2) {
  top: 34px;
}

.headerSpHamBtn.active > span:nth-child(1) {
  top: 31px;
  transform: rotate(-45deg);
}

.headerSpHamBtn.active > span:nth-child(2) {
  top: 31px;
  transform: rotate(45deg);
}

.headerSpMenu {
  position: fixed;
  z-index: 60;
  top: 0;
  left: 0;
  display: block;
  overflow: scroll;
  width: 100vw;
  padding: 60px 20px 120px;
  background-color: #fff;
  transition: transform 0.35s ease-in-out;
  transform: translateX(100vw);
}

.headerSpMenu.isOpen {
  transform: translateX(0);
}

.headerSpLink {
  position: relative;
  display: block;
  width: 100%;
  padding: 15px 0 15px 10px;
  border: none;
  border-top: 1px solid #b3b3b3;
  outline: none;
  background-color: transparent;
  color: black;
  text-align: left;
  text-decoration: none;
  letter-spacing: 0.05em;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.headerSpLink--service {
  position: relative;
  cursor: pointer;
}

.headerSpLink--service:after,
.headerSpLink--service:before {
  position: absolute;
  top: 32px;
  right: 0;
  width: 20px;
  height: 1px;
  background: #b3b3b3;
  content: "";
}

.headerSpLink--service:after {
  transform: rotate(90deg);
}

.headerSpLink--service.isOpen:after {
  transform: rotate(0deg);
}

.headerSpLink:visited {
  color: black;
}

.headerSpLink__en {
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
}

.headerSpLink__ja {
  display: block;
  margin-top: 7px;
  font-size: 15px;
  font-weight: 400;
  line-height: 1;
}

.headerSpService {
  display: none;
  letter-spacing: 0.05em;
}

.headerSpService.isOpen {
  display: block;
}

.headerSpService__category {
  padding: 15px 0 20px 10px;
  border-top: 1px solid #c7c7c7;
}

.headerSpService__categoryName {
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.headerSpService__link {
  display: block;
  margin-top: 20px;
  font-size: 14px;
  padding-left: 10px;
  line-height: 1;
  color: black;
  text-decoration: none;
}

.headerSpService__link:visited {
  color: black;
}

.movieSec {
  padding-bottom: 40px;
}

@media (min-width: 640px) {
  .movieSec {
    padding-bottom: 80px;
  }
}

.movieBox {
  margin-top: -30px;
  padding: 30px 7px;
}

@media (min-width: 640px) {
  .movieBox {
    padding: 30px 150px;
  }
}

.movieBox__movie {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  cursor: pointer;
  overflow: hidden;
}

.movieBox__iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.movieBox__img {
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: auto;
  transition: 0.2s ease;
}

.movieBox__img:hover {
  transform: scale(1.1);
}

.movie {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  cursor: pointer;
  overflow: hidden;
}

.movie__iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.movie__img {
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: auto;
  transition: 0.2s ease;
}

.movie__img:hover {
  transform: scale(1.1);
}

.footerContact {
  position: relative;
}

.footerContact__box {
  padding: 60px 30px;
}

@media (min-width: 640px) {
  .footerContact__box {
    padding: 40px 60px;
  }
}

.footerContact__txt {
  font-size: 14px;
  font-weight: 700;
  text-align: center;
}

@media (min-width: 640px) {
  .footerContact__txt {
    font-size: 20px;
  }
}

.footerContact__btn {
  margin-top: 10px;
}

@media (min-width: 640px) {
  .footerContact__btn {
    margin-top: 20px;
  }
}

.pointer {
  width: 1px;
  height: 40px;
  display: block;
  background-color: #45e1e5;
  position: absolute;
  right: 0;
  left: 0;
  margin: auto;
  z-index: 30;
}

.pointer--top {
  top: -20px;
  bottom: auto;
}

.pointer--bottom {
  bottom: -20px;
  top: auto;
}

.js-fade {
  opacity: 0;
  transition: all 1s ease;
}

.js-fade.show {
  opacity: 1;
  transform: none;
}

.js-fade--up {
  transform: translate(0, 100px);
}

.newsBox {
  margin-top: 20px;
  padding: 20px;
  color: #232323;
  text-decoration: none;
}

@media (min-width: 640px) {
  .newsBox {
    padding: 30px;
  }
}

@media (min-width: 640px) and (max-width: calc(1196px + 40px)) {
  .newsBox {
    flex-basis: calc(33.333333% - 9px);
    max-width: calc(33.333333% - 9px);
  }
}

.newsBox__link {
  display: block;
  position: relative;
  overflow: hidden;
  height: auto;
  clear: both;
  color: inherit;
  text-decoration: inherit;
}

.newsBox__link:hover {
  color: #999;
}

.newsBox__date {
  font-size: 12px;
  font-weight: 400;
  float: left;
}

@media (min-width: 640px) {
  .newsBox__date {
    font-size: 14px;
    clear: left;
  }
}

.newsBox__type {
  font-size: 12px;
  font-weight: 400;
  float: left;
  margin-left: 24px;
}

@media (min-width: 640px) {
  .newsBox__type {
    font-size: 14px;
    clear: left;
    margin-left: 0;
  }
}

.newsBox__type--news {
  color: #45e1e5;
}

.newsBox__type--blog {
  color: #d90368;
}

.newsBox__ttl {
  clear: both;
  padding-top: 10px;
  font-size: 15px;
  font-weight: 400;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

@media (min-width: 640px) {
  .newsBox__ttl {
    font-size: 16px;
    padding-top: 30px;
    -webkit-line-clamp: 4;
    height: 142px;
  }
}

.newsBox__more {
  padding-top: 10px;
  text-align: right;
  text-decoration: underline;
  font-size: 14px;
  font-weight: 400;
}

@media (min-width: 640px) {
  .newsBox__more {
    padding-top: 20px;
    font-size: 14px;
  }
}

.headerLogo {
  position: fixed;
  z-index: 50;
  width: 124px;
  height: 58px;
  background-color: #232323;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  top: 0;
  left: 0;
}

@media (min-width: calc(1196px + 40px)) {
  .headerLogo {
    width: 220px;
    height: 104px;
  }
}

.headerLogo > a {
  position: absolute;
  z-index: 43;
  top: 0;
  left: 0;
  display: block;
  width: inherit;
  height: inherit;
  text-decoration: none;
}

.headerLogo__rectangle {
  position: absolute;
  z-index: 42;
  top: 0;
  left: 0;
  display: block;
  width: inherit;
  height: inherit;
  background-color: #232323;
  background-image: url(https://www.tactinc.jp/static/img/elements/logo--rectangle.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
}

.headerLogo__square {
  position: absolute;
  z-index: 42;
  top: 0;
  left: 0;
  display: block;
  width: inherit;
  height: inherit;
  background-color: #232323;
  background-image: url(https://www.tactinc.jp/static/img/elements/logo--square.png);
  background-repeat: no-repeat;
  background-position: left top;
  background-size: contain;
  opacity: 0;
}

.headerLogo.smaller {
  width: 62px;
  height: 58px;
  transition: 0.3s ease all;
}

@media (min-width: calc(1196px + 40px)) {
  .headerLogo.smaller {
    width: 104px;
    height: 104px;
    background-image: url(/static/img/elements/logo--square.png);
  }
}

.smaller .headerLogo__rectangle {
  opacity: 0;
  transition: all 0.3s 0.2s ease;
}

.smaller .headerLogo__square {
  opacity: 1;
}

.top-Eyecatch {
  position: relative;
  overflow: hidden;
  height: 80vh;
  display: block;
}

@media (min-width: 640px) {
  .top-Eyecatch {
    height: auto;
  }
}

.top-Eyecatch:before {
  content: "";
  background-image: url(https://www.tactinc.jp/static/img/parts/pageTitle/texture.png);
  background-repeat: repeat;
  background-size: 4px;
  opacity: 0.4;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100%;
  z-index: 1;
}

.top-Eyecatch__video {
  min-height: 120%;
  width: auto;
  height: 100%;
  position: absolute;
  top: 50%;
  left: 15%;
  transform: translate(-50%, -50%);
}

@media (min-width: 640px) {
  .top-Eyecatch__video {
    width: 100%;
    display: block;
    position: relative;
    top: 0;
    left: 0;
    transform: translate(5%, 0) scale(1.1);
  }
}

.top-Eyecatch__img {
  width: 100%;
  height: auto;
}

.top-Eyecatch__leadbox {
  position: absolute;
  top: 32vw;
  bottom: 0;
  right: 0;
  left: 8.5%;
  padding: 0;
  display: block;
  width: 71%;
  max-height: 300px;
}

@media (min-width: 640px) {
  .top-Eyecatch__leadbox {
    top: 0;
    bottom: 0;
    margin: auto 0;
    max-height: 160px;
  }
}

.top-Eyecatch__EN {
  margin: 0;
  padding: 0;
  font-size: 32px;
  line-height: 1.4;
}

@media (min-width: calc(1196px + 40px)) {
  .top-Eyecatch__EN {
    font-size: 44px;
    line-height: 1.2;
  }
}

.top-Eyecatch__JA {
  margin: 0;
  padding: 0;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  margin-top: 20px;
}

@media (min-width: calc(1196px + 40px)) {
  .top-Eyecatch__JA {
    font-size: 20px;
  }
}

.top-sec01 {
  position: relative;
}

.top-sec01Title {
  padding-top: 80px;
  padding-bottom: 30px;
}

@media (min-width: 640px) {
  .top-sec01Title {
    padding-top: 120px;
    padding-bottom: 30px;
  }
}

.top-sec01Contents {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .top-sec01Contents {
    padding-bottom: 80px;
  }
}

.top-sec01Contents__box {
  padding: 20px 20px 60px;
  color: #232323;
}

@media (min-width: 640px) and (max-width: calc(1196px + 40px)) {
  .top-sec01Contents__box {
    padding: 60px 80px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .top-sec01Contents__box {
    padding: 40px 160px 80px;
  }
}

.top-sec01Contents__news {
  padding-top: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid #b3b3b3;
}

.top-sec01Contents__link {
  color: inherit;
  text-decoration: none;
  display: block;
  position: relative;
  overflow: hidden;
  height: auto;
}

.top-sec01Contents__link:hover {
  color: #999;
}

.top-sec01Contents__date {
  float: left;
  padding-right: 24px;
  font-size: 12px;
}

@media (min-width: 640px) {
  .top-sec01Contents__date {
    font-size: 14px;
    padding-right: 20px;
  }
}

.top-sec01Contents__category {
  float: left;
  width: auto;
  font-size: 12px;
  font-weight: 400;
}

@media (min-width: 640px) {
  .top-sec01Contents__category {
    font-size: 14px;
  }
}

.top-sec01Contents__category--news {
  color: #45e1e5;
}

.top-sec01Contents__category--blog {
  color: #d90368;
}

.top-sec01Contents__ttl {
  clear: both;
  width: 100%;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.8;
  padding-top: 10px;
}

@media (min-width: 640px) {
  .top-sec01Contents__ttl {
    font-size: 16px;
    padding-top: 16px;
  }
}

.top-sec01Contents__btnBox {
  margin-top: 40px;
}

.top-sec02 {
  padding-top: 60px;
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .top-sec02 {
    padding-top: 80px;
    padding-bottom: 160px;
  }
}

.top-sec02__mt {
  margin-top: 20px;
}

.top-sec02Title {
  padding-bottom: 30px;
}

@media (min-width: 640px) {
  .top-sec02Title {
    padding-bottom: 30px;
  }
}

.top-sec02Wrap {
  padding: 30px 30px 40px;
}

@media (min-width: 640px) {
  .top-sec02Wrap {
    padding: 30px 40px;
  }
}

.top-sec02Wrap__ttl {
  font-size: 16px;
  font-weight: 700;
}

@media (min-width: 640px) {
  .top-sec02Wrap__ttl {
    font-size: 20px;
  }
}

.top-sec02Wrap__txt {
  margin-top: 10px;
  font-size: 15px;
  font-weight: 400;
}

@media (min-width: 640px) {
  .top-sec02Wrap__txt {
    font-size: 16px;
  }
}

.top-sec02Wrap__btn {
  margin-top: 20px;
  margin-left: 0 !important;
}

.top-sec02ContentsTtl {
  position: relative;
  height: auto;
  overflow: hidden;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.top-sec02ContentsTtl:before {
  content: "";
  display: block;
  padding-top: 60.74%;
}

.top-sec02ContentsTtl__txt {
  position: relative;
  z-index: 2;
  text-align: center;
  font-size: 15px;
}

@media (min-width: 640px) {
  .top-sec02ContentsTtl__txt {
    font-size: 18px;
  }
}

.top-sec02ContentsTtl__bg {
  display: block;
  background-image: url(/static/img/elements/thumb--sp.jpg);
  background-size: cover;
  padding-top: 60.74%;
  width: 100%;
  height: 0;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}

.top-sec02ContentsTtl__bg:before {
  content: "";
  background-image: url(https://www.tactinc.jp/static/img/parts/pageTitle/texture.png);
  background-repeat: repeat;
  background-size: 4px;
  opacity: 0.4;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100%;
  z-index: 1;
}

@media (min-width: 640px) {
  .top-sec02ContentsTtl__bg {
    background-image: url(/static/img/elements/thumb.jpg);
  }
}

@media (min-width: 640px) {
  .top-sec02ContentsTtl__bg--1 {
    padding-top: 30.1%;
  }
}

.top-sec02ContentsTtl__bg--2 {
  background-image: url(/static/img/elements/thumb2--sp.jpg);
}

@media (min-width: 640px) {
  .top-sec02ContentsTtl__bg--2 {
    background-image: url(/static/img/elements/thumb2.jpg);
  }
}

.top-sec02ContentsTtl__bg--3 {
  background-image: url(/static/img/elements/thumb3--sp.jpg);
}

@media (min-width: 640px) {
  .top-sec02ContentsTtl__bg--3 {
    background-image: url(/static/img/elements/thumb3.jpg);
  }
}

@media (min-width: 640px) {
  .top-sec02ContentsTtl--1:before {
    padding-top: 30.1%;
  }
}

.news-sec01__ttl {
  margin-top: 40px;
}

@media (min-width: 640px) {
  .news-sec01__ttl {
    margin-top: 80px;
  }
}

.news-sec01__typeBtnArea {
  margin-top: 40px;
  display: flex;
  width: 100%;
  justify-content: space-between;
}

@media (min-width: 640px) {
  .news-sec01__typeBtnArea {
    margin-top: 70px;
    width: auto;
    justify-content: flex-start;
  }
}

.news-sec01__typeBtn {
  display: block;
  flex-grow: 1;
  font-size: 14px;
  color: black;
  border-bottom: 1px solid #b3b3b3;
  line-height: 2;
  text-decoration: none;
  margin-top: 10px;
  margin-right: 10px;
}

.news-sec01__typeBtn.isActive {
  border-color: black;
  border-width: 2px;
  pointer-events: none;
  cursor: unset;
}

@media (min-width: 640px) {
  .news-sec01__typeBtn {
    flex-grow: 0;
    font-size: 16px;
    width: 210px;
    letter-spacing: 0.05em;
    margin-right: 20px;
  }
}

.news-sec01__allView {
  margin-top: 20px;
}

@media (min-width: 640px) {
  .news-sec01__allView {
    margin-top: 40px;
  }
}

@media (min-width: 640px) {
  .news-sec01__wrap {
    margin-top: 20px;
  }
}

.news-page {
  padding-bottom: 120px;
}

@media (min-width: 640px) {
  .news-page {
    padding-bottom: 120px;
  }
}

.news-page__num {
  padding-top: 40px;
  text-align: center;
  color: #232323;
  text-decoration: none;
}

@media (min-width: 640px) {
  .news-page__num {
    padding-top: 80px;
  }
}

.news-page__num > a {
  font-family: inherit;
  color: inherit;
  text-decoration: inherit;
}

.news-page__num > a:hover {
  color: #999;
}

.news-page__disable {
  color: #999 !important;
  pointer-events: none;
}

@media (min-width: 640px) and (max-width: calc(1196px + 40px)) {
  .empty {
    flex-basis: calc(33.333333% - 9px);
    max-width: calc(33.333333% - 9px);
  }
}

.det-all {
  padding-top: 80px;
  padding-bottom: 80px;
}

@media (min-width: 640px) {
  .det-all {
    padding-top: 120px;
    padding-bottom: 120px;
  }
}

.det-detail__wrap {
  padding-top: 40px;
}

@media (min-width: 640px) {
  .det-detail__wrap {
    padding-top: 80px;
    max-width: 640px;
    margin: 0 auto;
  }
}

.det-detail__date {
  color: #232323;
  font-size: 16px;
  font-weight: 700;
  font-family: Montserrat, sans-serif;
}

@media (min-width: 640px) {
  .det-detail__date {
    font-size: 20px;
  }
}

.det-detail__type {
  color: #232323;
  font-size: 10px;
  font-weight: 700;
}

@media (min-width: 640px) {
  .det-detail__type {
    font-size: 14px;
  }
}

.det-detail__ttl {
  margin-top: 20px;
  color: #232323;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
}

@media (min-width: 640px) {
  .det-detail__ttl {
    margin-top: 40px;
    font-size: 28px;
  }
}

.det-detail__tag {
  color: #232323;
}

.det-detail__tag a {
  color: inherit;
  display: inline-block;
  margin-right: 1em;
}

.det-detail__document {
  font-size: 15px;
  margin-top: 40px;
  width: 100%;
}

@media (min-width: 640px) {
  .det-detail__document {
    margin-top: 80px;
  }
}

.det-detail__document p {
  color: #232323;
  font-size: inherit;
  font-weight: 400;
  margin-top: 20px;
  line-height: 2;
}

@media (min-width: 640px) {
  .det-detail__document p {
    font-size: 16px;
  }
}

.det-detail__document a {
  color: inherit;
  font-size: inherit;
  text-decoration: underline;
}

.det-detail__document strong {
  color: #232323;
}

.det-detail__document h2,
.det-detail__document h3,
.det-detail__document h4,
.det-detail__document h5,
.det-detail__document h6 {
  margin-top: 60px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}

@media (min-width: 640px) {
  .det-detail__document h2,
  .det-detail__document h3,
  .det-detail__document h4,
  .det-detail__document h5,
  .det-detail__document h6 {
    margin-top: 80px;
    font-size: 24px;
  }
}

.det-sns {
  position: relative;
  overflow: hidden;
  height: auto;
  margin-top: 60px;
}

@media (min-width: 640px) {
  .det-sns {
    margin-top: 80px;
  }
}

.det-sns__ttl {
  font-size: 14px;
  text-align: center;
  margin: 0 auto;
  letter-spacing: 1px;
}

@media (min-width: 640px) {
  .det-sns__ttl {
    font-size: 15px;
  }
}

.det-sns__ttl img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

.det-sns__wrap {
  margin-top: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.det-sns__btn {
  display: block;
  margin: 0 3%;
}

@media (min-width: 640px) {
  .det-sns__btn {
    margin: 0 16px;
  }
}

.det-sns__btn--f {
  width: 15px;
  height: 30px;
}

.det-sns__btn--tw {
  width: 27px;
  height: 22px;
}

.det-sns__btn--l {
  width: 30px;
  height: 28px;
}

.det-sns__btn svg {
  fill: #232323;
}

.det-sns__btn:hover svg {
  fill: #45e1e5;
}

.youtubeParent {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}

.youtubeParent iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.ai-whiteContainer {
  padding: 30px 20px;
}

@media (min-width: 640px) {
  .ai-whiteContainer {
    padding: 80px 20px 30px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .ai-whiteContainer {
    padding: 120px 100px 80px;
  }
}

.ai-client {
  padding-bottom: 80px;
}

@media (min-width: 640px) {
  .ai-client {
    padding-bottom: 120px;
  }
}

.ai-client__ttl {
  color: #232323;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  margin-bottom: 10px;
}

@media (min-width: 640px) {
  .ai-client__ttl {
    font-size: 16px;
    margin-bottom: 30px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .ai-client__wrap {
    max-width: 1106px;
    margin: 0 auto;
  }
}

.ai-client__link {
  display: block;
  text-decoration: none;
  margin-top: 10px;
}

.ai-client__link > img {
  display: block;
  width: 100%;
  height: auto;
}

.ai-client__link > small {
  display: block;
  width: 100%;
  font-size: 10px;
  text-align: center;
  color: #232323;
}

@media (min-width: calc(1196px + 40px)) {
  .ai-client__link > small {
    font-size: 12px;
    text-align: right;
    padding-right: 4em;
  }
}

.ai-client__link:hover {
  opacity: 0.6;
}

.ai-solution__ttl {
  padding-bottom: 40px;
}

.ai-solution__img {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
  padding-bottom: 10px;
}

@media (min-width: 640px) {
  .ai-solution__img {
    width: 100%;
    height: 130px;
    padding-bottom: 0;
  }
}

.ai-solution__img img {
  position: relative;
  display: block;
  width: 38%;
  max-width: 114px;
  height: auto;
  margin: auto;
}

@media (min-width: 640px) {
  .ai-solution__img img {
    width: 54%;
    min-width: 100px;
    max-width: 138px;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
  }
}

.ai-solution__caption {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  font-family: Montserrat, sans-serif;
  line-height: 1em;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .ai-solution__caption {
    font-size: 20px;
    font-weight: 400;
    margin-top: 20px;
  }
}

.ai-solution__txt {
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  line-height: 1.8;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .ai-solution__txt {
    font-size: 16px;
    margin-top: 20px;
  }
}

.ai-solution__detailLink {
  font-size: 16px;
  text-align: right;
  display: block;
  margin-top: 15px;
  color: inherit;
}

.ai-solution__detailLink:visited {
  color: inherit;
}

.ai-solution__col {
  margin-bottom: 40px;
}

@media (min-width: 640px) {
  .ai-solution__col {
    padding: 0 40px;
  }
}

.ai-functional {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .ai-functional {
    padding-bottom: 120px;
  }
}

.ai-functional__ttl {
  padding-top: 60px;
  padding-bottom: 40px;
}

@media (min-width: 640px) {
  .ai-functional__ttl {
    padding-top: 120px;
  }
}

.ai-functional__img {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
  padding-bottom: 10px;
}

@media (min-width: 640px) {
  .ai-functional__img {
    height: 102px;
    padding-bottom: 0;
  }
}

.ai-functional__img img {
  position: relative;
  display: block;
  width: 38%;
  max-width: 114px;
  margin: auto;
}

@media (min-width: 640px) {
  .ai-functional__img img {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    width: 52%;
    max-width: 138px;
    min-width: 80px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .ai-functional__img img {
    min-width: auto;
  }
}

.ai-functional__caption {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  line-height: 1em;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .ai-functional__caption {
    font-size: 16px;
    margin-top: 20px;
  }
}

.ai-functional__txt {
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  line-height: 1.8;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .ai-functional__txt {
    font-size: 16px;
    margin-top: 20px;
  }
}

.ai-functional__col {
  margin-bottom: 40px;
}

@media (min-width: 640px) {
  .ai-functional__col {
    padding: 0 40px;
  }
}

.ai-roughcost {
  padding-top: 80px;
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .ai-roughcost {
    padding-top: 120px;
    padding-bottom: 120px;
  }
}

.ai-roughcost__ttl {
  color: #232323;
  font-size: 14px;
  font-weight: 400;
  line-height: 1em;
  text-align: center;
  padding-bottom: 20px;
}

@media (min-width: 640px) {
  .ai-roughcost__ttl {
    font-size: 16px;
    padding-bottom: 40px;
  }
}

.ai-roughcost__img {
  width: 17%;
  max-width: 60px;
  display: block;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .ai-roughcost__img {
    width: 30%;
    max-width: 48px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .ai-roughcost__img {
    width: 17%;
    max-width: 60px;
  }
}

.ai-roughcost__caption {
  color: #232323;
  margin-top: 20px;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}

@media (min-width: 640px) {
  .ai-roughcost__caption {
    margin-top: 30px;
    font-size: 20px;
  }
}

.ai-roughcost__sub {
  color: #232323;
  margin-top: 10px;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
}

@media (min-width: 640px) {
  .ai-roughcost__sub {
    margin-top: 20px;
    font-size: 16px;
    font-weight: 700;
  }
}

.ai-roughcost__txt {
  color: #232323;
  margin-top: 10px;
  font-size: 15px;
  font-weight: 400;
  text-align: left;
}

@media (min-width: 640px) {
  .ai-roughcost__txt {
    margin-top: 20px;
    font-size: 16px;
  }
}

.ai-roughcost__col {
  margin-top: 20px;
  padding: 60px 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  align-content: space-between;
}

@media (min-width: 640px) {
  .ai-roughcost__col {
    padding: 40px 40px 60px;
  }
}

.ai-roughcost__colAlignTop {
  width: 100%;
}

.ai-roughcost__note {
  margin-top: 10px;
}

@media (min-width: 640px) {
  .ai-roughcost__note {
    margin-top: 20px;
  }
}

.ai-roughcost__note > p {
  color: #232323;
  font-size: 10px;
  font-weight: 400;
}

.ai-movieContact__ttl {
  font-size: 14px;
  font-weight: 400;
  text-align: center;
}

@media (min-width: 640px) {
  .ai-movieContact__ttl {
    font-size: 16px;
    padding-bottom: 20px;
  }
}

.ai-movieContact__wrap {
  padding: 30px 20px;
}

@media (min-width: 640px) {
  .ai-movieContact__wrap {
    padding: 60px 80px 0;
  }
}

.ai-movieContact__col {
  margin-top: 20px;
}

.con-title {
  padding-top: 40px;
}

@media (min-width: 640px) {
  .con-title {
    padding-top: 80px;
  }
}

.con-error {
  padding-top: 20px;
}

.con-error__ttl {
  color: red;
}

@media (min-width: 640px) {
  .con-error__ttl {
    font-size: 20px;
  }
}

.con-error__list {
  margin: 0;
  padding: 0;
}

.con-error__message {
  color: #232323;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.8;
}

@media (min-width: 640px) {
  .con-error__message {
    font-size: 15px;
  }
}

.con-lead {
  padding-top: 20px;
}

@media (min-width: 640px) {
  .con-lead {
    padding-top: 30px;
  }
}

.con-lead__txt {
  color: #232323;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.8;
}

@media (min-width: 640px) {
  .con-lead__txt {
    font-size: 16px;
    text-align: center;
    max-width: 894px;
    margin: 0 auto;
  }
}

.con-form {
  margin-top: 20px;
  padding: 20px 15px 40px;
}

@media (min-width: 640px) {
  .con-form {
    margin-top: 40px;
  }
}

@media (min-width: 640px) and (max-width: calc(1196px + 40px)) {
  .con-form {
    padding: 60px 9% 80px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .con-form {
    padding: 60px 100px 80px;
  }
}

.con-form__li {
  padding-top: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #f0f0f0;
}

@media (min-width: 640px) {
  .con-form__li {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

.con-form__li:last-of-type {
  border: none;
}

.con-form__label {
  font-size: 15px;
  font-weight: 400;
  display: block;
  line-height: 1em;
  color: #232323;
}

@media (min-width: 640px) {
  .con-form__label {
    margin-top: 10px;
    display: inline-block;
    width: 190px;
    vertical-align: top;
    font-size: 16px;
  }
}
.con-form__label2 {
  font-size: 15px;
  font-weight: 400;
  display: block;
  line-height: 1em;
  color: #232323;
}

@media (min-width: 640px) {
  .con-form__label2 {
    margin-top: 10px;
    display: inline-block;
    /* width: 190px; */
    vertical-align: top;
    font-size: 16px;
  }
}

.con-form__indispensable {
  margin-top: 20px;
  background-color: #45e1e5;
  color: #fff;
  font-size: 10px;
  line-height: 1em;
  font-weight: 700;
  display: inline-block;
  padding: 3px 6px;
}

@media (min-width: 640px) {
  .con-form__indispensable {
    margin-top: 6px;
    display: inline-block;
    width: 46px;
    height: 24px;
    line-height: 24px;
    margin-right: 10px;
    vertical-align: top;
    font-size: 12px;
    padding: 0;
    text-align: center;
  }
}

.con-form__optional {
  margin-top: 20px;
}

@media (min-width: 640px) {
  .con-form__optional {
    margin-top: 6px;
    display: inline-block;
    width: 46px;
    height: 24px;
    margin-right: 10px;
    vertical-align: top;
  }
}

.con-form__input {
  margin-top: 5px;
  display: block;
  width: 100%;
  height: 26px;
  line-height: 26px;
  background-color: #f0f0f0;
  box-shadow: none;
  border: none;
  padding-left: 1em;
  color: #232323;
  font-size: 10px;
}

@media (min-width: 640px) {
  .con-form__input {
    margin-top: 0;
    width: calc(100% - 266px);
    display: inline-block;
    vertical-align: top;
    height: 36px;
    font-size: 14px;
  }
}
.con-form__input2 {
  margin-top: 5px;
  display: block;
  width: 100%;
  height: 26px;
  line-height: 26px;
  background-color: #f0f0f0;
  box-shadow: none;
  border: none;
  padding-left: 1em;
  color: #232323;
  font-size: 10px;
}
@media (min-width: 640px) {
  .con-form__input2 {
    display: inline-block;
    vertical-align: top;
    height: 36px;
    font-size: 14px;
  }
}
.con-form__input_other {
  margin-top: 5px;
  margin-left: 2.3rem;
  display: block;
  width: 80%;
  /* height: 26px; */
  line-height: 26px;
  /* background-color: #f0f0f0; */
  box-shadow: none;
  border: none;
  border-bottom: 0.5px solid #232323;
  padding-left: 1em;
  color: #232323;
  font-size: 10px;
  outline: none;
}

@media (min-width: 640px) {
  .con-form__input_other {
    margin-top: 0;
    width: calc(100% - 266px);
    display: inline-block;
    vertical-align: top;
    /* height: 36px; */
    border-bottom: 1px solid #232323;
    font-size: 14px;
  }
}

.con-form__select {
  margin-top: 5px;
  display: block;
  width: 100%;
  height: 26px;
  line-height: 26px;
  background-color: #f0f0f0;
  box-shadow: none;
  border: none;
  padding-left: 1em;
  color: #232323;
  font-size: 10px;
}

@media (min-width: 640px) {
  .con-form__select {
    margin-top: 0;
    width: calc(100% - 266px);
    display: inline-block;
    vertical-align: top;
    font-size: 14px;
    height: 36px;
  }
}

.con-form__textarea {
  margin-top: 5px;
  display: block;
  width: 100%;
  height: 100px;
  line-height: 1.8;
  background-color: #f0f0f0;
  box-shadow: none;
  border: none;
  padding: 0.6em 1em;
  color: #232323;
  font-size: 10px;
}

@media (min-width: 640px) {
  .con-form__textarea {
    margin-top: 0;
    width: calc(100% - 266px);
    display: inline-block;
    vertical-align: top;
    font-size: 14px;
  }
}
.con-form__textarea2 {
  margin-top: 5px;
  display: block;
  width: 100%;
  height: 100px;
  line-height: 1.8;
  background-color: #f0f0f0;
  box-shadow: none;
  border: none;
  padding: 0.6em 1em;
  color: #232323;
  font-size: 10px;
}

@media (min-width: 640px) {
  .con-form__textarea2 {
    margin-top: 5px;
    display: inline-block;
    vertical-align: top;
    font-size: 14px;
  }
}
.con-form__checkbox {
  margin-top: 5px;
  display: block;
  width: 100%;
  line-height: 26px;
  padding-left: 1em;
  color: #232323;
  font-size: 10px;
}
@media (min-width: 640px) {
  .con-form__checkbox {
    margin-top: 10px;
    display: inline-block;
    vertical-align: top;
    font-size: 14px;
  }
}

.con-form__attention {
  margin-top: 30px;
  color: #232323;
  font-size: 12px;
}
@media (min-width: 640px) {
  .con-form__input {
    font-size: 14px;
  }
}

@media (min-width: 640px) {
  .con-form__attention {
    margin-top: 10px;
    font-size: 14px;
  }
}

.con-form__attention > a {
  color: inherit;
  text-decoration: none;
}

.con-form__attention > span {
  display: inline-block;
}

.con-form__btn {
  margin-top: 40px;
}

.con-complete {
  padding-top: 20px;
  padding-bottom: 120px;
}

@media (min-width: 640px) {
  .con-complete {
    padding-top: 40px;
    max-width: 894px;
    margin: 0 auto;
  }
}

.con-complete__ttl {
  color: #232323;
  font-size: 16px;
  font-weight: 700;
  text-align: left;
}

@media (min-width: 640px) {
  .con-complete__ttl {
    font-size: 20px;
  }
}

.con-complete__txt {
  margin-top: 20px;
  color: #232323;
  font-size: 15px;
  font-weight: 400;
  text-align: left;
}

@media (min-width: 640px) {
  .con-complete__txt {
    font-size: 16px;
  }
}

.call-whiteBox {
  padding: 40px 0;
}

@media (min-width: 640px) {
  .call-whiteBox {
    padding: 80px 8%;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .call-whiteBox {
    padding: 80px;
  }
}

.call-introduce {
  padding-bottom: 40px;
}

@media (min-width: 640px) {
  .call-introduce {
    padding-bottom: 80px;
  }
}

.call-introduce__title {
  padding-top: 60px;
  padding-bottom: 40px;
  font-size: 14px;
  font-weight: 400;
  text-align: center;
}

@media (min-width: 640px) {
  .call-introduce__title {
    padding-top: 120px;
    padding-bottom: 80px;
    font-size: 16px;
  }
}

.call-introduce__logo {
  display: block;
  width: 100%;
  height: auto;
  padding: 0 4%;
}

@media (min-width: 640px) {
  .call-introduce__logo {
    max-width: 280px;
    padding: 0 4%;
    margin: 0 auto;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .call-introduce__logo--left {
    margin: 0 0 0 auto;
  }
}

.call-introduce__logo--right {
  margin: auto 0 0;
}

.call-strengh {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .call-strengh {
    padding-bottom: 120px;
  }
}

.call-strengh__title {
  padding-top: 40px;
  padding-bottom: 30px;
}

@media (min-width: 640px) {
  .call-strengh__title {
    padding-top: 80px;
    padding-bottom: 60px;
  }
}

.call-strengh__col {
  padding: 20px;
}

@media (min-width: 640px) {
  .call-strengh__col {
    padding: 0 20px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .call-strengh__col {
    padding: 0 40px;
  }
}

.call-strengh__img {
  position: relative;
  height: auto;
  padding-bottom: 10px;
}

@media (min-width: 640px) {
  .call-strengh__img {
    height: 80px;
    padding-bottom: 0;
  }
}

.call-strengh__img img {
  position: relative;
  display: block;
  margin: auto;
  width: 27%;
  max-width: 160px;
}

@media (min-width: 640px) {
  .call-strengh__img img {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    min-width: 80px;
  }
}

.call-strengh__ttl {
  font-size: 16px;
  font-weight: 700;
  line-height: 1em;
  text-align: center;
  margin-top: 20px;
}

@media (min-width: 640px) {
  .call-strengh__ttl {
    font-size: 16px;
    line-height: 1.5;
  }
}

.call-strengh__txt {
  font-size: 15px;
  font-weight: 400;
  line-height: 1.8;
  text-align: left;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .call-strengh__txt {
    font-size: 16px;
  }
}

.call-cost {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .call-cost {
    padding-bottom: 120px;
  }
}

.call-cost__title {
  padding-top: 60px;
  padding-bottom: 10px;
  font-size: 14px;
  font-weight: 400;
  text-align: center;
}

@media (min-width: 640px) {
  .call-cost__title {
    padding-top: 120px;
    padding-bottom: 60px;
    font-size: 16px;
  }
}

.call-cost__col {
  margin-top: 20px;
  padding: 60px 20px;
}

@media (min-width: 640px) {
  .call-cost__col {
    padding: 40px;
  }
}

.call-cost__img {
  width: 17%;
  max-width: 60px;
  display: block;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .call-cost__img {
    width: 30%;
    max-width: 48px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .call-cost__img {
    width: 17%;
    max-width: 60px;
  }
}

.call-cost__note {
  display: block;
  margin-top: 10px;
  font-size: 12px;
  font-weight: 400;
  text-align: center;
}

@media (min-width: 640px) {
  .call-cost__note {
    font-size: 16px;
  }
}

.call-cost__ttl {
  margin-top: 10px;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
}

@media (min-width: 640px) {
  .call-cost__ttl {
    margin-top: 20px;
    font-size: 20px;
  }
}

.call-cost__sub {
  margin-top: 10px;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
  line-height: 1.5;
}

@media (min-width: 640px) {
  .call-cost__sub {
    font-size: 16px;
    font-weight: 700;
  }
}

.call-cost__txt {
  margin-top: 15px;
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  line-height: 1.5;
}

@media (min-width: 640px) {
  .call-cost__txt {
    margin-top: 20px;
    font-size: 16px;
  }
}

.rpa-overview {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .rpa-overview {
    padding-bottom: 120px;
  }
}

.rpa-overview__title {
  padding-top: 40px;
  padding-bottom: 30px;
}

.rpa-overview__whiteBox {
  padding: 60px 20px;
}

@media (min-width: 640px) {
  .rpa-overview__whiteBox {
    padding: 80px 60px;
  }
}

.rpa-organization {
  position: relative;
  height: auto;
  overflow: hidden;
  clear: both;
  width: 100%;
}

.rpa-organization__left {
  width: 100%;
  height: auto;
}

@media (min-width: 640px) {
  .rpa-organization__left {
    width: 42%;
    float: left;
  }
}

.rpa-organization__left img {
  display: block;
  width: 100%;
  max-width: 388px;
  margin: 0 auto;
}

.rpa-organization__right {
  width: 100%;
  height: auto;
}

@media (min-width: 640px) {
  .rpa-organization__right {
    width: 54%;
    float: right;
  }
}

.rpa-organization__def {
  color: #232323;
  font-family: Montserrat, sans-serif;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  margin-top: 30px;
}

@media (min-width: 640px) {
  .rpa-organization__def {
    margin-top: 40px;
    text-align: left;
    font-size: 20px;
  }
}

@media (min-width: 640px) {
  .rpa-organization__def:first-child {
    margin-top: 0;
  }
}

.rpa-organization__txt {
  color: #232323;
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .rpa-organization__txt {
    margin-top: 20px;
    font-size: 16px;
  }
}

.rpa-merit {
  position: relative;
  overflow: hidden;
  clear: both;
  width: 100%;
  height: auto;
}

@media (min-width: 640px) {
  .rpa-merit {
    max-width: 956px;
    margin: 0 auto;
  }
}

.rpa-merit__box {
  margin-top: 30px;
  width: 50%;
  float: left;
}

@media (min-width: 640px) {
  .rpa-merit__box {
    margin-top: 40px;
    width: 25%;
  }
}

.rpa-merit__img {
  position: relative;
  display: block;
  padding-bottom: 10px;
}

@media (min-width: 640px) {
  .rpa-merit__img {
    padding: 0;
    height: 98px;
  }
}

.rpa-merit__img img {
  position: relative;
  display: block;
  width: 80%;
  margin: auto auto 0;
}

@media (min-width: 640px) {
  .rpa-merit__img img {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    width: 38%;
    min-width: 68px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .rpa-merit__img img {
    max-width: 88px;
  }
}

.rpa-merit__txt {
  color: #232323;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
  line-height: 1.4;
  margin-top: 10px;
}

@media (min-width: 640px) {
  .rpa-merit__txt {
    font-size: 16px;
    font-weight: 700;
    margin: 20px auto 0;
    max-width: 96%;
  }
}

.rpa-cost {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .rpa-cost {
    padding-bottom: 120px;
  }
}

.rpa-cost__title {
  color: #232323;
  padding-top: 60px;
  padding-bottom: 10px;
  font-size: 14px;
  font-weight: 400;
  text-align: center;
}

@media (min-width: 640px) {
  .rpa-cost__title {
    padding-top: 120px;
    padding-bottom: 60px;
    font-size: 16px;
  }
}

.rpa-cost__whiteBox {
  margin-top: 20px;
  padding: 60px 20px;
}

@media (min-width: 640px) {
  .rpa-cost__whiteBox {
    margin-top: 0;
    display: flex;
    flex-wrap: wrap;
    align-content: space-between;
  }
}

.rpa-cost__upperwrap {
  height: auto;
}

@media (min-width: calc(1196px + 40px)) {
  .rpa-cost__upperwrap {
    min-height: 294px;
  }
}

@media (min-width: 640px) {
  .rpa-cost__bottomwrap {
    height: auto;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
  }
}

@media (min-width: 640px) {
  .rpa-cost__bottomwrap {
    min-height: 120px;
  }
}

.rpa-cost__num {
  width: 17%;
  max-width: 60px;
  display: block;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .rpa-cost__num {
    width: 30%;
    max-width: 48px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .rpa-cost__num {
    width: 17%;
    max-width: 60px;
  }
}

.rpa-cost__ttl {
  color: #232323;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
  margin-top: 20px;
}

@media (min-width: 640px) {
  .rpa-cost__ttl {
    font-size: 20px;
    font-weight: 700;
    margin-top: 30px;
  }
}

.rpa-cost__logo {
  width: 71%;
  margin: 10px auto 0;
}

@media (min-width: 640px) {
  .rpa-cost__logo {
    width: 66%;
    max-width: 220px;
    margin: 20px auto 0;
  }
}

.rpa-cost__txt {
  color: #232323;
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  margin-top: 10px;
  line-height: 1.8;
}

@media (min-width: 640px) {
  .rpa-cost__txt {
    font-size: 16px;
    margin-top: 20px;
  }
}

.rpa-cost__img {
  margin: 30px auto 0;
  width: 100%;
  display: block;
}

@media (min-width: 640px) {
  .rpa-cost__img {
    margin: auto auto 0;
  }
}

.rpa-cost__note {
  color: #232323;
  display: block;
  margin-top: 10px;
  font-size: 10px;
  font-weight: 400;
  text-align: left;
}

.about-bg {
  position: relative;
  padding-bottom: 40px;
}

@media (min-width: 640px) {
  .about-bg {
    padding-bottom: 80px;
  }
}

.about-bg:before {
  content: "";
  width: 100%;
  height: 120px;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #fafafa;
  z-index: 0;
}

@media (min-width: 640px) {
  .about-bg:before {
    height: 30%;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .about-bg:before {
    height: 424px;
  }
}

.about-message__title {
  padding-top: 40px;
  padding-bottom: 20px;
}

@media (min-width: 640px) {
  .about-message__title {
    padding-top: 80px;
    padding-bottom: 30px;
  }
}

.about-message__photo {
  margin: 0 auto;
  max-width: 894px;
  z-index: 2;
}

.about-message__col {
  max-width: 894px;
}

.about-message__lead {
  padding-top: 40px;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
}

@media (min-width: 640px) {
  .about-message__lead {
    padding-top: 80px;
    font-size: 28px;
  }
}

.about-message__text {
  padding-top: 20px;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.8;
}

@media (min-width: 640px) {
  .about-message__text {
    font-size: 16px;
  }
}

.about-message__text:first-of-type {
  padding-top: 40px;
}

.about-message__signBox {
  margin-top: 40px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

@media (min-width: 640px) {
  .about-message__signBox {
    margin-top: 60px;
  }
}

.about-message__namesign {
  width: 41%;
}

@media (min-width: 640px) {
  .about-message__namesign {
    width: 28%;
  }
}

.about-message__namesign > img {
  display: block;
}

.about-message__position {
  width: 50%;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.8;
}

@media (min-width: 640px) {
  .about-message__position {
    font-size: 16px;
  }
}

.about-company {
  padding-bottom: 40px;
}

@media (min-width: 640px) {
  .about-company {
    padding-bottom: 60px;
  }
}

.about-company__title {
  padding-top: 40px;
  padding-bottom: 10px;
}

@media (min-width: 640px) {
  .about-company__title {
    padding-top: 80px;
    padding-bottom: 30px;
  }
}

.about-company__table {
  width: 100%;
}

@media (min-width: 640px) {
  .about-company__table {
    max-width: 894px;
    margin: 0 auto;
  }
}

.about-table__list {
  position: relative;
}

.about-table__list:after {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, #45e1e5 40%, #b3b3b3 40%);
}

@media (min-width: 640px) {
  .about-table__list:after {
    background: linear-gradient(90deg, #45e1e5 180px, #b3b3b3 180px);
  }
}

.about-table__list:before {
  content: "";
  display: none;
}

@media (min-width: 640px) {
  .about-table__list:before {
    display: block;
    width: 180px;
    height: 1px;
    background-color: #45e1e5;
    position: absolute;
    bottom: -1px;
    top: auto;
    left: 0;
  }
}

.about-table__def {
  display: block;
  padding: 20px 4px;
}

@media (min-width: 640px) {
  .about-table__def {
    display: table;
    padding: 40px 4px;
  }
}

.about-table__dt {
  color: #232323;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 1px;
}

@media (min-width: 640px) {
  .about-table__dt {
    display: table-cell;
    font-size: 16px;
    width: 180px;
  }
}

.about-table__dd {
  color: #232323;
  padding-top: 10px;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 1px;
}

@media (min-width: 640px) {
  .about-table__dd {
    display: table-cell;
    font-size: 16px;
    width: calc(100% - 180px);
    padding-left: 72px;
    padding-top: 0;
  }
}

.about-table__dd h3 {
  margin-top: 20px;
}

.about-table__dd h3:first-of-type {
  margin-top: 10px;
}

@media (min-width: 640px) {
  .about-table__dd h3:first-of-type {
    margin-top: 0;
  }
}

.about-table__dd h3,
.about-table__dd p,
.about-table__dd a {
  color: inherit;
  font-weight: 400;
  font-size: inherit;
  text-decoration: none;
}

.about-access__title {
  padding-top: 40px;
  padding-bottom: 20px;
}

@media (min-width: 640px) {
  .about-access__title {
    padding-top: 80px;
    padding-bottom: 30px;
  }
}

.about-access__map {
  filter: grayscale(1);
  width: 100%;
  height: 185px;
}

@media (min-width: 640px) {
  .about-access__map {
    height: 380px;
  }
}

.about-access__col {
  width: 100%;
}

@media (min-width: 640px) {
  .about-access__col {
    max-width: 894px;
  }
}

.about-access__infoWrap {
  margin-top: 20px;
  padding: 0 20px 40px;
  position: relative;
  overflow: hidden;
  height: auto;
  clear: both;
}

@media (min-width: 640px) {
  .about-access__infoWrap {
    padding: 0 0 80px;
  }
}

.about-access__infoWrap--last {
  padding: 0 20px 60px;
}

@media (min-width: 640px) {
  .about-access__infoWrap--last {
    padding: 0 0 120px;
  }
}

.about-access__company {
  font-size: 16px;
  font-weight: 700;
  text-align: left;
}

@media (min-width: 640px) {
  .about-access__company {
    font-size: 24px;
  }
}

.about-access__address {
  margin-top: 10px;
  font-size: 15px;
  font-weight: 400;
  text-align: left;
}

@media (min-width: 640px) {
  .about-access__address {
    width: 40%;
    float: left;
    font-size: 16px;
  }
}

.about-access__address > li {
  padding: 0;
  font-size: inherit;
  font-weight: inhrit;
}

.about-access__directions {
  font-size: 15px;
  font-weight: 400;
  text-align: left;
}

@media (min-width: 640px) {
  .about-access__directions {
    width: 40%;
    float: left;
    font-size: 16px;
  }
}

.legal-all {
  padding-top: 80px;
  padding-bottom: 80px;
  color: #232323;
}

@media (min-width: 640px) {
  .legal-all {
    padding-top: 120px;
    padding-bottom: 120px;
  }
}

.legal-title {
  color: #232323;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  padding-top: 40px;
  padding-bottom: 40px;
  letter-spacing: 1px;
}

@media (min-width: 640px) {
  .legal-title {
    font-size: 28px;
  }
}

.legal-wrap {
  padding-bottom: 40px;
  font-size: 14px;
}

@media (min-width: 640px) {
  .legal-wrap {
    padding-bottom: 80px;
    font-size: 15px;
  }
}

.legal-wrap p,
.legal-wrap ol,
.legal-wrap ul,
.legal-wrap li {
  font-size: inherit;
  font-weight: 400;
  line-height: 1.8;
  opacity: 0.9;
}

.legal-wrap p {
  margin-bottom: 20px;
}

.legal-wrap ol,
.legal-wrap ul {
  margin: 1rem auto;
  width: 90%;
}

.legal-wrap li {
  list-style-position: outside;
  padding-left: 0.5rem;
}

.legal-wrap h3,
.legal-wrap h4,
.legal-wrap h5,
.legal-wrap h6 {
  color: #232323;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.5;
  padding-top: 30px;
  padding-bottom: 10px;
  letter-spacing: 1px;
}

@media (min-width: 640px) {
  .legal-wrap h3,
  .legal-wrap h4,
  .legal-wrap h5,
  .legal-wrap h6 {
    font-size: 16px;
  }
}

.legal-wrap a {
  color: inherit;
  font-size: inherit;
  text-decoration: underline;
}

#js-privacy {
  position: relative;
  top: -58px;
}

@media (min-width: 640px) {
  #js-privacy {
    top: -104px;
  }
}

.chatbot-sectionEndMargin {
  padding-bottom: 60px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-sectionEndMargin {
    padding-bottom: 120px;
  }
}

.chatbot-heading {
  margin: 60px auto 35px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-heading {
    margin: 120px auto 50px;
  }
}

.whiteBox--chatbot {
  padding: 25px 20px;
}

@media (min-width: calc(1196px + 40px)) {
  .whiteBox--chatbot {
    padding: 110px 40px;
  }
}

.whiteBox--chatbotSmallMargin {
  padding: 20px;
}

@media (min-width: calc(1196px + 40px)) {
  .whiteBox--chatbotSmallMargin {
    padding: 30px;
  }
}

.chatbot-video {
  width: 100%;
}

.chatbot-video video {
  display: block;
  width: 100%;
  max-width: 380px;
  margin: 0 auto;
}

.chatbot-featureBoxInner {
  max-width: 900px;
  margin: 0 auto;
}

.chatbot-feature {
  margin-top: 40px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-feature {
    margin-top: 0;
  }
}

.chatbot-feature__img {
  width: 115px;
  display: block;
  margin: 0 auto;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-feature__img {
    width: 130px;
  }
}

.chatbot-feature__text {
  font-size: 12px;
  text-align: center;
  margin-top: 17px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-feature__text {
    font-size: 18px;
  }
}

.chatbot-featureBox {
  background: #fafafa;
  padding: 25px 20px 40px;
  margin: 80px auto 0;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-featureBox {
    background: transparent;
    max-width: 900px;
    margin-top: 100px;
  }
}

.chatbot-featureBox h3 {
  font-size: 16px;
  line-height: 1.9;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-featureBox h3 {
    font-size: 24px;
    line-height: 2;
  }
}

.chatbot-featureBox p {
  margin-top: 10px;
  font-size: 12px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-featureBox p {
    font-size: 16px;
  }
}

.chatbot-featureBox img {
  display: block;
  margin: 30px auto 0;
  width: 240px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-featureBox img {
    width: 373px;
  }
}

.chatbot-useCase h3 {
  margin-top: 5px;
  font-size: 14px;
  color: #45e1e5;
  text-align: center;
}

@media (min-width: 640px) {
  .chatbot-useCase h3 {
    font-size: 20px;
    margin-top: 45px;
  }
}

.chatbot-useCase p {
  margin-top: 7px;
  font-size: 12px;
  text-align: center;
}

@media (min-width: 640px) {
  .chatbot-useCase p {
    font-size: 16px;
    margin-top: 25px;
  }
}

.chatbot-useCase img {
  display: block;
  margin-top: 20px;
}

@media (min-width: 640px) {
  .chatbot-useCase img {
    margin-top: 50px;
  }
}

.chatbot-useCase--second {
  margin-top: 20px;
}

@media (min-width: 640px) {
  .chatbot-useCase--second {
    margin-top: 0;
  }
}

@media (min-width: 640px) {
  .chatbot-useCase {
    margin: 0 15px;
  }
}

.whiteBox--chatbotStep {
  margin-bottom: 80px;
}

.chatbot-stepTitleBox {
  max-width: 500px;
  margin: 0 auto;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-stepTitleBox {
    display: flex;
    max-width: 1000px;
  }
}

.chatbot-stepTitleBox__step,
.chatbot-stepTitleBox__support {
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  line-height: 43px;
  height: 43px;
  display: block;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-stepTitleBox__step,
  .chatbot-stepTitleBox__support {
    line-height: auto;
    height: auto;
    padding: 20px;
  }
}

.chatbot-stepTitleBox__step {
  background: #eaeaea;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-stepTitleBox__step {
    width: 50%;
    font-size: 20px;
  }
}

.chatbot-stepTitleBox__support {
  display: none;
  background: #a5a5a5;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-stepTitleBox__support {
    display: block;
    width: 50%;
    color: white;
    font-size: 20px;
  }
}

.chatbot-step {
  margin: 60px auto 0;
  position: relative;
  max-width: 500px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-step {
    display: flex;
    align-items: stretch;
    margin-top: 70px;
    max-width: 1000px;
  }
}

.chatbot-step__name {
  background: #eaeaea;
  font-size: 12px;
  vertical-align: middle;
  height: 60px;
  line-height: 60px;
  padding-left: 70px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-step__name {
    width: 50%;
    font-size: 20px;
    text-align: center;
    padding: 0;
    line-height: auto;
    height: auto;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

.chatbot-step__support {
  background: #a5a5a5;
  color: white;
  padding: 15px 20px;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-step__support {
    width: 50%;
    font-size: 16px;
    padding: 40px 50px;
    line-height: 1.85;
  }
}

.chatbot-step__supportTitle {
  display: block;
  text-align: center;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-step__supportTitle {
    display: none;
  }
}

.chatbot-step__supportMain {
  display: block;
  padding-top: 8px;
}

.chatbot-step__num {
  position: absolute;
  top: 8px;
  left: 8px;
  font-family: Montserrat, sans-serif;
  display: block;
  width: 45px;
  height: 45px;
  line-height: 45px;
  border-radius: 50%;
  background: #2bccd8;
  color: white;
  font-size: 16px;
  font-weight: 700;
  vertical-align: middle;
  text-align: center;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-step__num {
    left: 50%;
    top: 50%;
    width: 60px;
    height: 60px;
    line-height: 60px;
    font-size: 24px;
    transform: translate(-50%, -50%);
  }
}

.chatbot-step:after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  transform: translate(-50%, 100%);
  bottom: -15px;
  border-style: solid;
  border-width: 31.2px 18px 0;
  border-color: #95f9f9 transparent transparent;
}

@media (min-width: calc(1196px + 40px)) {
  .chatbot-step:after {
    bottom: -20px;
  }
}

.chatbot-step:last-of-type {
  margin-bottom: 0;
}

.chatbot-step:last-of-type:after {
  display: none;
}

.chatbot-step:first-of-type {
  margin-top: 20px;
}

.chatbot-moreNews {
  margin-top: 40px;
}

@media (min-width: 640px) and (max-width: calc(1196px + 40px)) {
  .empty {
    flex-basis: calc(33.333333% - 9px);
    max-width: calc(33.333333% - 9px);
  }
}

.other-eyecatch img {
  display: block;
  width: 100%;
}

.other-sec01 {
  padding: 60px 0;
}

@media (min-width: 640px) {
  .other-sec01 {
    padding: 120px 0;
  }
}

.other-sec01__ttl {
  color: #1c9b97;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}

.other-sec01__ttl > img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .other-sec01__ttl > img {
    width: 480px;
  }
}

.other-sec01__text {
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  margin-top: 30px;
}

@media (min-width: 640px) {
  .other-sec01__text {
    margin-top: 60px;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
  }
}

.other-sec02 {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .other-sec02 {
    padding-bottom: 100px;
  }
}

.other-sec02__ttltopmargin {
  padding-top: 80px;
}

@media (min-width: 640px) {
  .other-sec02__ttltopmargin {
    padding-top: 120px;
  }
}

.other-sec02__ttlbottommargin {
  padding-bottom: 20px;
}

@media (min-width: 640px) {
  .other-sec02__ttlbottommargin {
    padding-bottom: 40px;
  }
}

.other-sec02__whiteBox {
  padding: 0;
}

@media (min-width: 640px) {
  .other-sec02__whiteBox {
    padding: 80px 130px;
  }
}

.other-sec02__whiteBox img {
  display: block;
}

.other-sec02__textBox {
  padding: 30px 15px;
}

@media (min-width: 640px) {
  .other-sec02__textBox {
    padding: 0 0 0 60px;
  }
}

@media (min-width: 640px) {
  .other-sec02__rowmt {
    margin-top: 80px;
  }
}

.other-sec02__ttl {
  font-size: 16px;
  font-weight: 700;
  text-align: left;
}

@media (min-width: 640px) {
  .other-sec02__ttl {
    font-size: 20px;
  }
}

.other-sec02__text {
  font-size: 15px;
  font-weight: 400;
  text-align: left;
  margin-top: 20px;
}

@media (min-width: 640px) {
  .other-sec02__text {
    font-size: 16px;
    margin-top: 30px;
  }
}

.other-sec02__note {
  font-size: 10px;
}

@media (min-width: 640px) {
  .other-sec02__note {
    font-size: 12px;
  }
}

.other-sec03 {
  padding-bottom: 60px;
}

@media (min-width: 640px) {
  .other-sec03 {
    padding-bottom: 120px;
  }
}

.other-sec03__ttltopmargin {
  padding-top: 80px;
}

@media (min-width: 640px) {
  .other-sec03__ttltopmargin {
    padding-top: 120px;
  }
}

.other-sec03__ttlbottommargin {
  padding-bottom: 20px;
}

@media (min-width: 640px) {
  .other-sec03__ttlbottommargin {
    padding-bottom: 40px;
  }
}

.other-sec03__whitebox {
  padding: 30px;
}

@media (min-width: 640px) {
  .other-sec03__whitebox {
    padding: 80px;
  }
}

@media (min-width: 640px) {
  .other-sec03__whitebox--left {
    margin-right: 20px;
  }
}

.other-sec03__whitebox--right {
  margin-top: 20px;
}

@media (min-width: 640px) {
  .other-sec03__whitebox--right {
    margin-top: 0;
    margin-left: 20px;
  }
}

.other-sec03__ttl {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}

@media (min-width: 640px) {
  .other-sec03__ttl {
    font-size: 20px;
  }
}

.other-sec03__img {
  display: block;
  height: 250px;
  width: auto;
  margin: 20px auto 0;
}

@media (min-width: 640px) {
  .other-sec03__img {
    margin: 30px auto 0;
    height: 246px;
  }
}

.other-sec03__text {
  margin-top: 25px;
  font-size: 15px;
  font-weight: 400;
  text-align: center;
}

@media (min-width: 640px) {
  .other-sec03__text {
    margin-top: 50px;
    font-size: 16px;
  }
}

.other-sec03__btn {
  margin-top: 20px;
}

@media (min-width: 640px) {
  .other-sec03__btn {
    margin-top: 30px;
  }
}

.recruit-eye {
  position: relative;
  width: 100%;
  height: auto;
}

.recruit-eye img {
  display: block;
  width: 100%;
  height: auto;
}

.recruit-top {
  position: relative;
  display: block;
  width: 100%;
  height: auto;
  z-index: 1;
  padding: 85px 0 40px;
}

@media (min-width: 640px) {
  .recruit-top {
    padding: 120px 55% 120px 0;
  }
}

.recruit-top:after {
  content: "";
  display: none;
}

@media (min-width: 640px) {
  .recruit-top:after {
    display: block;
    position: absolute;
    top: 120px;
    bottom: 120px;
    right: 0;
    left: auto;
    margin: auto;
    background-image: url(/static/img/recruit/pc/recruit_img01.png);
    background-repeat: no-repeat;
    background-size: 100%;
    width: 60%;
    z-index: -1;
  }
}

.recruit-top__ttl {
  font-size: 18px;
  font-weight: 700;
  line-height: 2.4;
  letter-spacing: 0.02em;
}

@media (min-width: 640px) {
  .recruit-top__ttl {
    font-size: 2.4vw;
    line-height: 2.1;
    margin-top: -0.4em;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .recruit-top__ttl {
    font-size: 28px;
    line-height: 2.1;
  }
}

.recruit-top__txt {
  padding: 40px 0 0;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.8;
}

@media (min-width: 640px) {
  .recruit-top__txt {
    font-size: 16px;
  }
}

.recruit-top__img {
  padding-bottom: 85px;
}

@media (min-width: 640px) {
  .recruit-top__img {
    padding-bottom: 0;
  }
}

.recruit-sec02 {
  padding-bottom: 90px;
}

@media (min-width: 640px) {
  .recruit-sec02 {
    padding-bottom: 120px;
  }
}

@media (min-width: 640px) {
  .recruit-sec02__row {
    justify-content: space-between;
  }
}

.recruit-sec02__wrap {
  margin-top: 50px;
}

@media (min-width: 640px) {
  .recruit-sec02__wrap {
    margin-top: 80px;
    max-width: calc(33.333333% - 39px);
    min-height: 334px;
  }
}

.recruit-sec02__icon {
  display: block;
  width: 75px;
  height: auto;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .recruit-sec02__icon {
    height: 75px;
    width: auto;
  }
}

.recruit-sec02__icon img {
  display: block;
  width: 100%;
  height: auto;
}

@media (min-width: 640px) {
  .recruit-sec02__icon img {
    width: 80px;
    height: auto;
    margin: 0 auto;
  }
}

.recruit-sec02__ttl {
  margin-top: 30px;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
  line-height: 1em;
}

@media (min-width: 640px) {
  .recruit-sec02__ttl {
    margin-top: 40px;
    font-size: 20px;
  }
}

.recruit-sec02__txt {
  margin-top: 30px;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.8;
}

@media (min-width: 640px) {
  .recruit-sec02__txt {
    font-size: 16px;
  }
}

.recruit-sec02__btn {
  margin: 60px auto 0;
}

@media (min-width: 640px) {
  .recruit-sec02__btn {
    margin: 80px auto 0;
  }
}

.recruit-fixedBg {
  width: 100%;
  height: auto;
  display: block;
  position: fixed;
  top: 58px;
  z-index: -1;
  opacity: 0;
  -webkit-animation: appear 2s ease 1s 1 normal forwards running;
  animation: appear 2s ease 1s 1 normal forwards running;
}

.recruit-fixedBg picture {
  width: 100%;
  height: auto;
  display: block;
}

.recruit-fixedBg img {
  width: 100%;
  display: block;
}

@media (min-width: 640px) {
  .recruit-fixedBg {
    top: 104px;
  }
}

@-webkit-keyframes appear {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

@keyframes appear {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

.recruit-bg {
  width: 100%;
  height: 382px;
  background-color: transparent;
}

@media (min-width: 640px) {
  .recruit-bg {
    height: 25vw;
    max-height: 360px;
  }
}

.recruit-sec03 {
  padding: 85px 0;
}

@media (min-width: 640px) {
  .recruit-sec03 {
    padding: 120px 0;
  }
}

.recruit-sec03__JAttl {
  margin-bottom: 60px;
}

@media (min-width: 640px) {
  .recruit-sec03__JAttl {
    margin-bottom: 80px;
  }
}

.recruit-sec03__dt {
  background-color: #f5f5f5;
  width: 100%;
  height: 64px;
  color: #45e1e5;
  font-size: 14px;
  font-weight: 700;
  line-height: 64px;
  text-align: center;
}

@media (min-width: 640px) {
  .recruit-sec03__dt {
    height: 140px;
    line-height: 140px;
    font-size: 24px;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .recruit-sec03__dt {
    height: 128px;
    line-height: 128px;
  }
}

.recruit-sec03__dd {
  background-color: #fafafa;
  width: 100%;
  height: auto;
  padding: 20px;
}

@media (min-width: 640px) {
  .recruit-sec03__dd {
    height: 140px;
    padding: 0 30px;
    display: flex;
    align-items: center;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .recruit-sec03__dd {
    height: 128px;
  }
}

.recruit-sec03__ddTxt {
  font-size: 12px;
  font-weight: 400;
  line-height: 1.8;
  text-align: left;
}

@media (min-width: 640px) {
  .recruit-sec03__ddTxt {
    font-size: 16px;
  }
}

.recruit-sec03__ddTxt a {
  color: #0031ff;
  text-decoration: underline;
}

.recruit-sec03__next {
  position: relative;
  padding: 20px 0;
}

@media (min-width: 640px) {
  .recruit-sec03__next {
    padding: 40px 0;
  }
}

.recruit-sec03__nextTxt {
  font-size: 12px;
  font-weight: 700;
  line-height: 1em;
  text-align: center;
}

@media (min-width: 640px) {
  .recruit-sec03__nextTxt {
    display: inline-block;
    position: relative;
    left: calc(50% + 36px);
    margin: auto;
    font-size: 20px;
  }
}

.recruit-sec03__nextTriangle {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 21px 12px 0;
  border-color: #000 transparent transparent;
  margin: 16px auto 0;
}

@media (min-width: 640px) {
  .recruit-sec03__nextTriangle {
    border-width: 28px 16px 0;
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
  }
}

.recruit-sec03__nextTriangle--noMargin {
  margin: 0 auto;
}

@media (min-width: 640px) {
  .recruit-sec03__nextTriangle--noMargin {
    margin: auto;
  }
}

.recruit-sec03__btn {
  margin: 60px auto 0;
}

@media (min-width: 640px) {
  .recruit-sec03__btn {
    margin: 80px auto 0;
  }
}

.recruit-btn {
  position: relative;
  display: block;
  background-color: #45e1e5;
  color: #232323;
  width: 100%;
  max-width: 180px;
  height: 50px;
  text-align: center;
  line-height: 50px;
  text-decoration: none;
  font-size: 12px;
  font-weight: 400;
}

@media (min-width: 640px) {
  .recruit-btn {
    font-size: 16px;
    max-width: 400px;
    height: 80px;
    line-height: 80px;
  }
}

@media (min-width: 640px) {
  .recruit-btn:hover {
    background-color: #232323;
    color: #45e1e5;
  }
}

.openfadeup {
  -webkit-animation-name: fadeUp;
  animation-name: fadeUp;
  -webkit-animation-duration: 0.6s;
  animation-duration: 0.6s;
  -webkit-animation-timing-function: ease-in;
  animation-timing-function: ease-in;
  -webkit-animation-delay: 0s;
  animation-delay: 0s;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  -webkit-animation-direction: normal;
  animation-direction: normal;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

@-webkit-keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translate3d(0, 10px, 0);
  }

  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translate3d(0, 10px, 0);
  }

  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}
.download-box__img {
  width: 100%;
  display: block;
  margin: 0 auto;
}

@media (min-width: 640px) {
  .download-box__img {
    width: 80%;
  }
}

@media (min-width: calc(1196px + 40px)) {
  .download-box__img {
    width: 65%;
  }
}
#download-box a {
  color: #0031ff;
}
#download-box a:hover {
  opacity: 0.7;
}
.download__caption {
  color: #232323;
  margin-top: 20px;
  font-size: 14px;
  font-weight: 700;
  text-align: center;
}

@media (min-width: 640px) {
  .download__caption {
    margin-top: 30px;
    font-size: 16px;
  }
}

.download__caption-a {
  text-decoration: none;
}
.download-contents__box {
  position: relative;
  z-index: 1;
}
.download-contents__box a {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  text-indent: -999px;
  z-index: 2;
}
.contact-section__input_radio {
  visibility: hidden;
  /* display: none; */
}
.contact-section__input_radio + label {
  padding-left: 25px;
  position: relative;
  margin-right: 20px;
  font-size: 10px;
}
@media (min-width: 640px) {
  .contact-section__input_radio + label {
    font-size: 14px;
  }
}

.contact-section__input_radio + label::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid #999;
  border-radius: 50%;
}
/* .contact-section__input_radio:checked + label{
    color: #d01137;
  } */
.contact-section__input_radio:checked + label::after {
  content: "";
  display: block;
  position: absolute;
  top: 3px;
  left: 3px;
  width: 11px;
  height: 11px;
  background: #333333;
  border-radius: 50%;
}
@media (min-width: 640px) {
  .form-content {
    width: 70%;
  }
}
