@charset "utf-8";
/* ==========================================================================
   Foundation
   ========================================================================== */
:root {
  --color-text: #282828;
  --color-link: #0071BC;
  --color-primary: #2a3bd1;
  --color-primary-light: #f0f1fc;
  --color-lightgray: #f4f4f4;
  --font: "Roboto", "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
  --font-en: "Montserrat", sans-serif;
  --font-mix: "Montserrat", "Noto Sans JP", "Roboto", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
}
/*!
 * Sanitize 13.0.0 (https://github.com/csstools/sanitize.css)
 * Licensed under the CC0 1.0 Universal.
 */
*,:after,:before{box-sizing:border-box}
:after,:before{text-decoration:inherit;vertical-align:inherit}
html{cursor:default;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-tap-highlight-color:rgba(0,0,0,0);-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;word-break:break-word}
body{margin:0}
h1{font-size:2em;margin:.67em 0}
dl dl,dl ol,dl ul,ol dl,ol ol,ol ul,ul dl,ul ol,ul ul{margin:0}
hr{height:0;overflow:visible}
main{display:block}
nav ol,nav ul{list-style:none;padding:0}
pre{font-family:monospace;font-size:1em}
a{background-color:transparent}
abbr[title]{text-decoration:underline;-webkit-text-decoration:underline;text-decoration:underline}
b,strong{font-weight:bolder}
code,kbd,samp{font-family:monospace;font-size:1em}
small{font-size:80%}
audio,canvas,iframe,img,svg,video{vertical-align:middle}
audio,video{display:inline-block}
audio:not([controls]){display:none;height:0}
iframe,img{border-style:none}
svg:not([fill]){fill:currentColor}
svg:not(:root){overflow:hidden}
table{border-collapse:collapse}
button,input,select{margin:0}
button{overflow:visible;text-transform:none}
[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}
fieldset{border:1px solid #a0a0a0;padding:.35em .75em .625em}
input{overflow:visible}
legend{color:inherit;display:table;max-width:100%;white-space:normal}
progress{display:inline-block;vertical-align:baseline}
select{text-transform:none}
textarea{margin:0;overflow:auto;resize:vertical}
[type=checkbox],[type=radio]{padding:0}
[type=search]{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
::-webkit-input-placeholder{color:inherit;opacity:.54}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
::-moz-focus-inner{border-style:none;padding:0}
:-moz-focusring{outline:1px dotted ButtonText}
:-moz-ui-invalid{box-shadow:none}
details,dialog{display:block}
dialog{background-color:#fff;border:solid;color:#000;height:-moz-fit-content;height:-webkit-fit-content;height:fit-content;left:0;margin:auto;padding:1em;position:absolute;right:0;width:-moz-fit-content;width:-webkit-fit-content;width:fit-content}
dialog:not([open]){display:none}
summary{display:list-item}
canvas{display:inline-block}
template{display:none}
[tabindex],a,area,button,input,label,select,summary,textarea{touch-action:manipulation}
[hidden]{display:none}
[aria-busy=true]{cursor:progress}
[aria-controls]{cursor:pointer}
[aria-disabled=true],[disabled]{cursor:not-allowed}
[aria-hidden="false"][hidden]{display:inline}
[aria-hidden="false"][hidden]:not(:focus){clip:rect(0,0,0,0);position:absolute}
body {
  position: relative;
  background: #fff;
  color: #282828;
  font-family: "Roboto", "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 1em;
  letter-spacing: 0.02em;
  line-height: 1.7;
}
html,
body {
  overflow-x: hidden;
}
a {
  color: #282828;
  -webkit-text-decoration: none;
  text-decoration: none;
}
.a {
  color: #0071BC;
  -webkit-text-decoration: underline;
  text-decoration: underline;
}
.a:hover {
    -webkit-text-decoration: none;
    text-decoration: none;
  }
/* Typography Base Setting */
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-weight: 600;
}
p,
ul,
ol {
  margin-top: 0;
  margin-bottom: 1em;
}
ul {
  padding-left: 1em;
}
ul li::marker {
  color: #ccc;
}
strong {
  font-weight: 600;
}
em {
  font-style: normal;
}
rp,
rt {
  line-height: 1;
  font-size: 0.688em;
}
sup,
sub {
  position: relative;
  font-size: 0.7em;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
table {
  empty-cells: show;
  font-size: 1em;
}
iframe {
  display: block;
  width: 100%;
}
img {
  height: auto;
}
img,
iframe,
button,
input,
select,
textarea {
  max-width: 100%;
}
figure {
  margin: 0;
}
textarea {
  height: auto;
  resize: vertical;
}
/* ==========================================================================
   Layout
   ========================================================================== */
body {
  position: relative;
  padding-top: 1px;
}
body::after {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  width: 100%;
  height: 100%;
  background: #fff;
  pointer-events: none;
  content: "";
}
.no-js body::after {
  opacity: 0;
}
.is-loaded body::after {
  opacity: 0;
  transition: opacity 0.5s 0.3s;
}
/* -----------------------------------
  Header / Navi
----------------------------------- */
.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 101;
  width: 100%;
  padding: 8px 3.8461% 6px;
  background: #fff;
}
.header__logo {
  width: 180px;
}
.header__logo img {
    display: block;
  }
.gnav-list-1,
.gnav-list-2,
.gnav-list-3 {
  margin: 0;
  padding: 0;
}
.gnav-list-1,
.gnav-list-2 {
  display: flex;
  flex-wrap: wrap;
  font-size: 0.875rem;
}
.gnav-list-1 li:nth-of-type(n+2)::before {
    display: inline-block;
    width: 0;
    height: 1em;
    margin: 0 1.2em;
    border-left: 1px solid;
    vertical-align: -0.1em;
    content: "";
  }
.gnav-list-2 {
  font-family: "Montserrat", sans-serif;
}
.gnav-list-2 > li {
    position: relative;
    margin-left: 1px;
  }
.gnav-list-2 > li > a,
  .gnav-list-2 .lang-btn {
    display: flex;
    align-items: center;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    height: 26px;
    line-height: 1;
    transition: background 0.2s;
  }
.gnav-list-2 > li > a {
    padding: 0.4em 0.8em 0.5em;
    background: #2a3bd1;
    color: #fff;
    font-size: 0.875rem;
  }
.gnav-list-2 > li > a:hover {
      background: #282828;
    }
.gnav-list-2 > li:first-of-type > a {
    border-radius: 0.4rem 0 0 0.4rem;
  }
.gnav-list-2 .lang-btn {
    padding: 0.5em 1em 0.5em 1em;
    border-radius: 0 0.4rem 0.4rem 0;
    border: none;
    background: #282828;
    color: #fff;
    font-size: 0.75rem;
  }
.gnav-list-2 .lang-btn::before {
      margin-right: 0.5em;
      color: #E3E3E3;
      font-family: "icomoon";
      content: "\e902";
    }
.gnav-list-2 .lang-btn::after {
      display: inline-block;
      transform: translateY(-25%) rotate(45deg);
      width: 0.4rem;
      height: 0.4rem;
      margin-left: 0.5em;
      border-right: 1px solid #999;
      border-bottom: 1px solid #999;
      content: "";
    }
.gnav-list-2 .lang-btn:hover {
      background: #2a3bd1;
    }
.gnav-list-3 a {
    display: block;
    height: 100%;
    font-weight: 600;
  }
.gnav-list-3 a small {
    margin-left: 1em;
    color: #ccc;
    font-size: 0.625em;
    font-weight: 400;
  }
.gnav-list-1 a,
.gnav-list-3 a {
  transition: color 0.2s;
}
.gnav-list-1 a:hover, .gnav-list-3 a:hover {
    color: #2a3bd1;
  }
.nav-child-list {
  margin: 0;
  padding: 0;
  font-size: 0.875rem;
  font-weight: 400;
}
.nav-child-list li {
    position: relative;
    padding-left: 1em;
  }
.nav-child-list li::before {
      position: absolute;
      top: 0.75em;
      left: 0;
      width: 0.6em;
      border-top: 1px solid;
      content: "";
    }
.dropdown-list {
  background: rgba(40, 40, 40, 0.95);
  color: #fff;
}
.dropdown-list > .nav-child-list > li {
    margin: 0.7em 1em;
    padding-bottom: 0.6em;
    border-bottom: 1px solid #3E3E3E;
  }
.dropdown-list > .nav-child-list > li:last-child {
      padding-bottom: 0;
      border-bottom: none;
    }
.dropdown-list a {
    display: block;
    color: inherit;
    font-weight: 400;
  }
#lang-menu {
  display: grid;
  grid-template-rows: 1fr;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 1;
  width: 100%;
  border-radius: 0.4rem;
  background: rgba(40, 40, 40, 0.95);
  color: #fff;
  transition: all 0.3s;
}
#lang-menu ul {
    overflow: hidden;
  }
#lang-menu a {
    display: block;
    padding: 0.25em 0.75em;
    border-top: 1px solid #DCDCDC;
    color: inherit;
    font-weight: 400;
    font-size: 0.875rem;
  }
#lang-menu a:hover {
    opacity: 0.8;
  }
#lang-menu[hidden] {
  grid-template-rows: 0fr;
}
/* -----------------------------------
  Main
----------------------------------- */
.wrap {
  overflow: hidden;
  padding-top: 70px;
}
.container {
  width: 87.6923vw;
  margin: 0 auto;
}
.container--wide {
  width: 92.31vw;
}
.main-header {
  margin-bottom: 60px;
}
.main-header__inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  width: 87.6923vw;
  height: 14.625rem;
  margin: 0 auto;
  padding-bottom: 10px;
}
.main-header__en {
  display: block;
  margin-bottom: 1em;
  color: #2a3bd1;
  font-family: "Montserrat", sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0;
}
.main-header__en::before {
    content: "[ ";
  }
.main-header__en::after {
    content: " ]";
  }
.main-header__title {
  position: relative;
  margin-bottom: 40px;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0;
}
.main-header__title small {
    display: inline-block;
    margin-bottom: 0.5rem;
    font-size: 0.58em;
  }
.main-header__breadcrumbs {
  position: absolute;
  right: 0;
  bottom: 0;
}
.main-header__movie {
  position: relative;
  width: 100%;
  height: 34.6153vw;
}
.main-header__movie img,
  .main-header__movie video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
.main-header__movie .cover,
  .main-header__movie video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    transition: opacity 0.4s;
  }
.main-header__movie .cover.is-hidden {
    opacity: 0;
  }
.breadcrumbs ul {
    /* display: flex; */
    flex-wrap: wrap;
    justify-content: flex-end;
    font-size: 0.75rem;
    -webkit-hyphens: manual;
    hyphens: manual;
    word-break: break-all;
  }
.breadcrumbs li {
    display: inline;
  }
.breadcrumbs li + li::before {
    display: inline-block;
    transform: scaleX(0.9) rotate(45deg);
    width: 0.4rem;
    height: 0.4rem;
    margin: 0 0.8em;
    border-top: 1px solid #2a3bd1;
    border-right: 1px solid #2a3bd1;
    vertical-align: 0.1em;
    content: "";
  }
.breadcrumbs a {
    color: #ccc;
    -webkit-text-decoration: none;
    text-decoration: none;
    transition: color 0.2s;
  }
.breadcrumbs a:hover {
      color: #2a3bd1 !important;
    }
.main-content {
  /* フッター背景重なり対策 */
  position: relative;
  z-index: 1;
}
.section-lv1 {
  padding: min(15vw, 115px) 0;
}
.section-lv2 {
  padding-top: min(8vw, 65px);
}
.section-border {
  border-top: 1px solid #E6E6E6;
}
/* -----------------------------------
  Footer
----------------------------------- */
#pagetop {
  position: fixed;
  right: 5.5vw;
  bottom: 70px;
  z-index: 10;
}
.pagetop-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #2a3bd1;
  transition: background 0.2s;
}
.pagetop-link::before {
    display: block;
    color: #E3E3E3;
    font-family: "icomoon";
    font-size: 1.25rem;
    line-height: 1;
    content: "\e906";
  }
.pagetop-link:hover {
    background: #282828;
  }
/* アクセス・お問い合わせ */
.footer-group {
  margin-top: min(15vw, 150px);
  background: #f4f4f4;
}
.pagefoot-outer {
  position: relative;
  z-index: 0;
}
.pagefoot-outer::before {
    position: absolute;
    bottom: calc(100% - 80px);
    right: 0;
    left: 0;
    z-index: -1;
    height: 230px;
    background: linear-gradient(to top, #fff 50%, rgba(255, 255, 255, 0));
    content: "";
  }
.pagefoot-grid,
.pagefoot-tel {
  width: 90%;
  margin: 0 auto;
}
.pagefoot-grid {
  display: grid;
  grid-template-rows: repeat(2, 1fr);
  grid-row-gap: 48px;
}
.pagefoot__image {
  margin-bottom: 1.5em;
}
.pagefoot__image img {
    width: 100%;
    border-radius: 0.5rem;
  }
.pagefoot-title {
  margin-bottom: 0.66em;
  font-family: "Montserrat", sans-serif;
  font-size: 2.125em;
  text-align: center;
}
.pagefoot-lead {
  margin-bottom: 1em;
  padding: 0.8em;
  border-radius: 0.4em;
  background: #fff;
  font-weight: 600;
  text-align: center;
  line-height: 1.4;
}
.pagefoot-text {
  padding: 0 5%;
}
.pagefoot-text p,
  .pagefoot-text ul {
    margin-bottom: 20px;
  }
.pagefoot-text--columns2 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(13em, 1fr));
  grid-column-gap: 2rem;
}
.pagefoot__btns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16em, 1fr));
  grid-column-gap: 1rem;
  grid-row-gap: 0.5rem;
}
.pagefoot__btns .btn {
    width: 100%;
  }
.pagefoot-tel {
  margin-top: 2rem;
  padding: 1rem 0 1.25rem;
  border-top: 1px solid #DCDCDC;
  border-bottom: 1px solid #DCDCDC;
  text-align: center;
  line-height: 1.5;
}
.pagefoot-tel .tel {
    font-family: "Montserrat", sans-serif;
    font-size: 1.8125rem;
  }
.pagefoot-tel .tel a {
      font-size: 2.25rem;
    }
.pagefoot-tel .other {
    margin-top: 0.8rem;
    font-family: "Montserrat", sans-serif;
  }
.pagefoot-tel .other ul {
      list-style: none;
      margin: 0;
      padding: 0;
    }
.pagefoot-tel .small {
    font-size: 0.875rem;
  }
/* フッター */
.footer {
  margin-top: 50px;
  padding: 0 4% 4%;
}
.footer__container {
  overflow: hidden;
  position: relative;
  z-index: 0;
  border-radius: 0.5rem;
  color: #fff;
}
.footer__bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
}
.footer__bg::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.25);
    content: "";
  }
.footer__bg video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
.footer__logo {
  position: absolute;
  top: 0;
  left: 0;
  max-width: 40%;
  margin-bottom: 30px;
  padding: 0 1.25em 1em 0;
  border-radius: 0 0 0.5rem;
  background: #f4f4f4;
}
.footer__logo .round {
    overflow: hidden;
    position: absolute;
    width: 0.5rem;
    height: 0.5rem;
  }
.footer__logo .round::before {
      display: block;
      width: 1rem;
      height: 1rem;
      border-radius: 50%;
      box-shadow: 0 0 0 1em #fff;
      content: "";
    }
.footer__logo .round:first-of-type {
    top: 0;
    left: 100%;
  }
.footer__logo .round:last-of-type {
    top: 100%;
    left: 0;
  }
.footer__logo img {
    width: 240px;
  }
.footer__content {
  padding: 1.5rem;
}
.footer__nav {
  width: 52%;
  margin-left: auto;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.5;
}
.footer__nav ul {
    list-style: none;
    padding: 0;
  }
.footer__nav li {
    margin-bottom: 0.75rem;
  }
.footer__nav a {
    color: inherit;
  }
.footer__copyright {
  flex: 1 0 100%;
  font-size: 0.75rem;
}
/* ==========================================================================
   Object
   ========================================================================== */
/* Component
   ----------------------------------------------------------------- */
/*------------------------------------*\
    Icons
\*------------------------------------*/
@font-face {
  font-family: 'icomoon';
  src:
    url('fonts/icomoon.ttf?g1k70a') format('truetype'),
    url('fonts/icomoon.woff?g1k70a') format('woff'),
    url('fonts/icomoon.svg?g1k70a#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-feature-settings: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-tel:before {
  content: "\e90c";
}
.icon-zoom:before {
  content: "\e90b";
}
.icon-language:before {
  content: "\e902";
}
.icon-external:before {
  content: "\e909";
}
.icon-circle-arrow-next:before {
  content: "\e907";
}
.icon-circle-arrow-prev:before {
  content: "\e908";
}
.icon-arrow-down:before {
  content: "\e903";
}
.icon-arrow-next:before {
  content: "\e904";
}
.icon-arrow-prev:before {
  content: "\e905";
}
.icon-arrow-up:before {
  content: "\e906";
}
.icon-download:before {
  content: "\e900";
}
.icon-mail:before {
  content: "\e901";
}
.icon-map:before {
  content: "\e90a";
}
/*------------------------------------*\
    Typography
\*------------------------------------*/
/* 見出し */
.heading {
  position: relative;
  margin-bottom: 40px;
  font-family: "Montserrat", sans-serif;
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.47;
  letter-spacing: 0;
}
.heading[data-en-before]::before,
.heading[data-en-after]::after {
  display: block;
  font-family: "Montserrat", sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0;
  content: "[ " attr(data-en-before) " ]";
}
.heading[data-en-before]::before {
  margin-bottom: 2em;
}
.heading[data-en-after]::after {
  margin-top: 2em;
}
.h2 {
  margin-bottom: 1.5em;
  font-size: 1.375rem;
  font-weight: 600;
  line-height: 1.5;
}
.h2--line {
  position: relative;
  padding-bottom: 1em;
  border-bottom: 1px solid #E6E6E6;
}
.h2--line::before {
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100px;
    border-bottom: 1px solid #2a3bd1;
    content: "";
  }
.h2--marker {
  position: relative;
  padding-left: 1rem;
}
.h2--marker::before {
    position: absolute;
    top: 0.3em;
    left: 0;
    height: 1em;
    border-left: 3px solid #2a3bd1;
    content: "";
  }
.h3,
.h4 {
  margin-bottom: 1em;
  font-size: 1.25rem;
  font-weight: 600;
}
.lead {
  margin-bottom: 1rem;
  font-size: 1.375rem;
  line-height: 1.4;
}
.lead__bg {
  display: inline-block;
  border-radius: 4px;
  padding: 0.4em 0.5em;
  background: #2a3bd1;
  color: #fff;
  font-size: 0.8em;
  line-height: 1.33;
}
/* リスト */
.list-inline,
.list-note,
.list-nostyle {
  list-style: none;
  padding: 0;
}
.list-inline > li {
    display: inline-block;
    margin-right: 1em;
  }
.list-inline > li:last-child {
    margin-right: 0;
  }
.list-note > li {
    padding-left: 1em;
    text-indent: -1em;
  }
.list-note > li::before {
    margin-right: 0.5em;
    content: "*";
  }
/*------------------------------------*\
    Flexbox Grid
    http://flexboxgrid.com/
\*------------------------------------*/
:root {
  --gutter-width: 1.5rem;
  --gutter-compensation: calc((var(--gutter-width) * 0.5) * -1);
  --half-gutter-width: calc((var(--gutter-width) * 0.5));
}
.row {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin-right: calc((1.5rem * 0.5) * -1);
  margin-left: calc((1.5rem * 0.5) * -1);
}
.row.reverse {
  flex-direction: row-reverse;
}
.col,
.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-offset-0,
.col-offset-1,
.col-offset-2,
.col-offset-3,
.col-offset-4,
.col-offset-5,
.col-offset-6,
.col-offset-7,
.col-offset-8,
.col-offset-9,
.col-offset-10,
.col-offset-11,
.col-offset-12 {
  box-sizing: border-box;
  flex: 0 0 auto;
  padding-right: calc((1.5rem * 0.5));
  padding-left: calc((1.5rem * 0.5));
}
.col {
  flex-grow: 1;
  flex-basis: 0;
  max-width: 100%;
}
.col-1 {
  flex-basis: 8.33333333%;
  max-width: 8.33333333%;
}
.col-2 {
  flex-basis: 16.66666667%;
  max-width: 16.66666667%;
}
.col-3 {
  flex-basis: 25%;
  max-width: 25%;
}
.col-4 {
  flex-basis: 33.33333333%;
  max-width: 33.33333333%;
}
.col-5 {
  flex-basis: 41.66666667%;
  max-width: 41.66666667%;
}
.col-6 {
  flex-basis: 50%;
  max-width: 50%;
}
.col-7 {
  flex-basis: 58.33333333%;
  max-width: 58.33333333%;
}
.col-8 {
  flex-basis: 66.66666667%;
  max-width: 66.66666667%;
}
.col-9 {
  flex-basis: 75%;
  max-width: 75%;
}
.col-10 {
  flex-basis: 83.33333333%;
  max-width: 83.33333333%;
}
.col-11 {
  flex-basis: 91.66666667%;
  max-width: 91.66666667%;
}
.col-12 {
  flex-basis: 100%;
  max-width: 100%;
}
.col-offset-0 {
  margin-left: 0;
}
.col-offset-1 {
  margin-left: 8.33333333%;
}
.col-offset-2 {
  margin-left: 16.66666667%;
}
.col-offset-3 {
  margin-left: 25%;
}
.col-offset-4 {
  margin-left: 33.33333333%;
}
.col-offset-5 {
  margin-left: 41.66666667%;
}
.col-offset-6 {
  margin-left: 50%;
}
.col-offset-7 {
  margin-left: 58.33333333%;
}
.col-offset-8 {
  margin-left: 66.66666667%;
}
.col-offset-9 {
  margin-left: 75%;
}
.col-offset-10 {
  margin-left: 83.33333333%;
}
.col-offset-11 {
  margin-left: 91.66666667%;
}
.start {
  justify-content: flex-start;
}
.center {
  justify-content: center;
}
.end {
  justify-content: flex-end;
}
.around {
  justify-content: space-around;
}
.between {
  justify-content: space-between;
}
.top {
  align-items: flex-start;
}
.middle {
  align-items: center;
}
.bottom {
  align-items: flex-end;
}
/*------------------------------------*\
    Tables
\*------------------------------------*/
.table {
  width: 100%;
  /* line-height: 1.625; */
}
.table :where(th, td) {
    padding: 0.75em 0;
    border-bottom: 1px solid #DCDCDC;
  }
.table :where(th) {
    font-weight: 600;
    text-align: inherit;
  }
.table--bordered,
.table--data {
  border-top: 1px solid #DCDCDC;
  border-left: 1px solid #DCDCDC;
}
.table--bordered :where(th, td), .table--data :where(th, td) {
    padding: 1em 0;
    border-right: 1px solid #DCDCDC;
    border-bottom: 1px solid #DCDCDC;
  }
.table--bordered :where(th, td) {
    padding: 0.66em 1em;
  }
.table--bordered tbody th {
    background: #f0f1fc;
  }
.table--data {
  font-size: 0.875rem;
  line-height: 1.5714;
}
.table--data :where(th, td) {
    padding: 0.4em 1em;
  }
.table--data thead th {
    background: #f0f1fc;
    text-align: center;
  }
.table--data tbody th {
    background: #f4f4f4;
  }
.table--guide1 .col1 {
    background: #F4F5FD;
  }
.table--guide1 .col2 {
    background: #FEF6F6;
  }
.table--guide1 .col3 {
    background: #FFFDEB;
  }
.table--guide1 thead th {
    --bg: var(--color-primary-light);
    background: var(--bg);
  }
.table--guide1 tbody td ul {
      margin-bottom: 0;
    }
.table--guide1 tbody td a {
      color: #0071BC;
      -webkit-text-decoration: underline;
      text-decoration: underline;
    }
.table--guide1 tbody td a:hover {
        -webkit-text-decoration: none;
        text-decoration: none;
      }
.table--guide2 .col1 {
    width: 18%;
  }
.table--guide2 .col2 {
    width: 13%;
  }
.table--guide2 .col3 {
    width: 17%;
  }
.table--guide2 .col4 {
    width: 17%;
    background: #FEF6F6;
  }
.table--guide2 .col5 {
    width: 14%;
    background: #E9F8F1;
  }
.table--guide2 .col6 {
    width: 21%;
    background: #E9F8F1;
  }
.table--guide2 thead th {
    --bg: var(--color-primary-light);
    background: var(--bg);
  }
/* レスポンシブ */
/*------------------------------------*\
    Buttons
\*------------------------------------*/
.btn {
  display: inline-flex;
  align-items: center;
  position: relative;
  max-width: 100%;
  height: 3.6em;
  border-radius: 2em;
  border: none;
  padding: 0.625rem 1rem;
  box-shadow: 0 1px 0 rgba(20, 20, 114, 0.15);
  border: 1px solid transparent;
  background: #f0f1fc;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.333;
  -webkit-text-decoration: none;
  text-decoration: none;
  transition: all 0.2s ease-out;
  vertical-align: middle;
  cursor: pointer;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.btn .prefix {
    margin-right: 0.5rem;
  }
.btn .text {
    padding-right: 0.5em;
  }
.btn .suffix {
    margin-left: auto;
  }
.btn .circle-icon {
    flex: 0 0 1.5em;
    background: #2a3bd1;
    color: #fff;
    transition: all 0.2s;
  }
.btn:hover {
    box-shadow: none;
    background: #2a3bd1;
    color: #fff;
  }
.btn:hover .circle-icon {
    background: #fff;
    color: #2a3bd1;
  }
.btn--small {
  height: 2.875em;
}
.btn--white {
  background-color: #fff;
}
.btn--fixed {
  width: 270px;
}
/* リンク用アイコン */
.circle-icon {
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5em;
  height: 1.5em;
  padding-left: 0.0625em;
  border-radius: 50%;
  background: #2a3bd1;
  color: #fff;
  line-height: 1;
  text-align: center;
  transition: all 0.2s;
}
.link .circle-icon {
  margin-right: 0.5rem;
}
:where(.link, a):hover .circle-icon {
  background: #282828;
}
:where(.link, a):hover .icon-arrow-next::before {
  animation: arrowNext .3s ease-out alternate both;
}
:where(.link, a):hover .icon-arrow-prev::before {
  animation: arrowPrev .3s ease-out alternate both;
}
@keyframes arrowNext {
	0% {
		transform: translateX(0);
	}
	50% {
		transform: translateX(100%);
	}
	51% {
		transform: translateX(-100%);
	}
	100% {
		transform: translateX(0);
	}
}
@keyframes arrowPrev {
	0% {
		transform: translateX(0);
	}
	50% {
		transform: translateX(-100%);
	}
	51% {
		transform: translateX(100%);
	}
	100% {
		transform: translateX(0);
	}
}
/*------------------------------------*\
    Pagination
\*------------------------------------*/
.pagination {
  margin-top: 80px;
}
.pagination-list {
  list-style: none;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 0.5rem;
  margin: 0;
  padding: 0;
}
.pagination-list li {
    padding: 5px;
  }
.pagination-list a {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 6px;
    background: #282828;
    color: #fff;
    font-family: "Montserrat", sans-serif;
    font-size: 1.125rem;
    text-align: center;
    -webkit-text-decoration: none;
    text-decoration: none;
    transition: background 0.2s;
  }
.pagination-list a::before {
      color: inherit;
    }
.pagination-list a.arrow,
    .pagination-list a:hover {
      background: #2a3bd1;
    }
.pagination-list a.arrow:hover {
      background: #282828;
    }
.pagination-list a[aria-current],
    .pagination-list a.is-current {
      background: #f4f4f4;
      color: #282828;
    }
/* Project
   ----------------------------------------------------------------- */
/*------------------------------------*\
  共通
\*------------------------------------*/
/* アニメーション設定 */
.js .anim-mask {
	display: inline-block;
	-webkit-clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
	clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
  vertical-align: top;
}
.js .anim-mask.inview {
	--duration: 0.8s;
	--delay: 0.1s;
	-webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	transition: -webkit-clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay);
	transition: clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay);
	transition: clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay), -webkit-clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay);
}
/* 画像 */
.img-rounded {
  overflow: hidden;
  border-radius: 6px;
}
/* 画像拡大 */
.js-zoom {
  display: inline-block;
  position: relative;
}
.js-zoom::after{
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    right: 8px;
    bottom: 8px;
    width: 1.125rem;
    height: 1.125rem;
    border-radius: 50%;
    background: #fff;
    color: #2a3bd1;
    font-family: "icomoon";
    font-size: 0.625rem;
    content: "\e90b";
  }
/* パララックス */
.parallax {
  overflow: hidden;
  width: 100%;
  height: 34.615vw;
}
.parallax img {
    width: 100%;
    height: auto;
  }
.bg-lightgray {
  background: #f4f4f4;
}
/*------------------------------------*\
  加工材質ガイド
\*------------------------------------*/
/* 検索グループ */
.materials-group {
  overflow: hidden;
  border-radius: 0.375rem;
}
.materials-group {
  margin-bottom: 20px;
}
.materials-group__heading {
  flex: 0 0 9.6em;
  display: flex;
  align-items: center;
  padding: 0.2em 1em;
  background: #2a3bd1;
  color: #fff;
  font-size: 1.375rem;
  line-height: 1.5;
}
.materials-group__body {
  flex: 1;
  padding: 1.5rem;
  background: #F2F2F2;
}
.materials-group-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.materials-group-list > li {
    padding: 4px 0;
  }
.materials-group-list .btn {
    width: 100%;
  }
.image-group {
  overflow: hidden;
}
.image-group .image {
    overflow: hidden;
    position: relative;
  }
.image-group .image:first-child {
      border-top-left-radius: 0.5rem;
      border-top-right-radius: 0.5rem;
    }
.image-group .image:last-child {
      border-bottom-right-radius: 0.5rem;
      border-bottom-left-radius: 0.5rem;
    }
.image-group .image + .image {
    margin-top: 1px;
  }
.image-group .image__label {
    position: absolute;
    top: 8px;
    left: 8px;
    font-size: 0.875rem;
    line-height: 1.5;
  }
.image-group .image__label span {
      border-radius: 3px;
      padding: 0.2em 0.5em;
      box-shadow: 1px 1px 0 rgba(0, 0, 0, 0.15);
      background: #fff;
      box-decoration-break: clone;
      -webkit-box-decoration-break: clone;
    }
/*------------------------------------*\
  ニュース
\*------------------------------------*/
.news-date {
  display: inline-block;
  margin-right: 0.5em;
  font-family: "Montserrat", sans-serif;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  vertical-align: middle;
}
.news-category {
  display: inline-block;
  min-width: 7.4em;
  margin-right: 1em;
  padding: 0 0.8em;
  border-radius: 2px;
  border: 1px solid #E6E6E6;
  background: #fff;
  font-size: 0.625rem;
  text-align: center;
  vertical-align: middle;
}
.news-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid #EBEBEB;
}
.news-list>li {
    border-bottom: 1px solid #EBEBEB;
  }
.news-list-item {
  display: flex;
  justify-content: space-between;
  position: relative;
  padding: 1em 2em 1em 0;
}
.news-list-item::after {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    color: #CCC;
    font-family: "icomoon";
    font-size: 1.5em;
    content: "\e904";
    transition: color 0.2s;
  }
.news-list-item:hover::after {
    color: #2a3bd1;
  }
.news-list-item__thumb {
  flex: 0 0 110px;
  position: relative;
}
.news-list-item__thumb .news-view {
    position: absolute;
    top: 0;
    left: 0;
    padding-right: 0.5em;
    border-radius: 0 0 3px;
    background: #fff;
    font-family: "Montserrat", sans-serif;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1.5;
  }
.news-list-item__thumb img {
    width: 100%;
    border-radius: 6px;
  }
.news-list-item__body {
  flex: 1 1 auto;
  max-width: calc(100% - 120px);
}
.news-list-item__body .news-title {
    font-weight: 600;
  }
.news-list-item__body .news-title span {
      overflow: hidden;
      display: block;
      max-width: 100%;
      text-overflow: ellipsis;
      white-space: nowrap;
    }
.news-card-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.news-card-list > li {
    margin-bottom: 2em;
  }
.news-card {
  display: block;
}
.news-card__thumb {
  overflow: hidden;
  border-radius: 6px;
  margin-bottom: 1rem;
}
.news-card__thumb img {
    width: 100%;
    aspect-ratio: 1.579;
    -o-object-fit: cover;
    object-fit: cover;
  }
.news-card__body {
  position: relative;
}
.news-card__body .news-category {
    position: absolute;
    top: 0;
    right: 0;
    margin: 0;
  }
.news-card__body .news-title {
    font-weight: 600;
    line-height: 1.66;
  }
/* ニュースカテゴリ */
.news-category-list a:hover, .news-category-list2 a:hover {
    color: #2a3bd1;
  }
.news-category-list .is-current::marker {
  color: #2a3bd1;
}
.news-category-list2 {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 2em;
  padding: 0;
}
.news-category-list2 li {
    flex: 0 1 32%;
  }
.news-category-list2 a {
    display: block;
    padding: 0 0.5em;
    border: 1px solid #E6E6E6;
    background: #fff;
    font-size: 0.875rem;
    text-align: center;
  }
.news-category-list2 .is-current a {
    background: #2a3bd1;
    color: #fff;
  }
/* ニュース詳細 */
.article__header {
  padding-top: 50px;
  padding-bottom: 40px;
  border-top: 1px solid #EBEBEB;
}
.article__header .news-view {
    display: inline-block;
    padding: 0 0.5em;
    border-radius: 4px;
    background: #2a3bd1;
    color: #fff;
    font-family: "Montserrat", sans-serif;
    font-size: 0.75rem;
  }
.article__header .news-title {
    margin-top: 0.5em;
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.47;
    letter-spacing: 0.025em;
  }
.article__content :where(h2) {
    margin-bottom: 1.5rem;
    font-size: 1.375rem;
  }
.article__content :where(p) {
    margin-bottom: 1.5rem;
  }
.article__content .image,
  .article__content .text {
    margin: 2.5em 0;
  }
.article__content .image img {
    width: 100%;
  }
.article__content > :first-child {
    margin-top: 0;
  }
.article__recommend {
  margin-top: min(15vw, 100px);
  border-top: 1px solid #EBEBEB;
  padding-top: 20px;
}
/*------------------------------------*\
  トップ精工とは
\*------------------------------------*/
.vision-movie {
  overflow: hidden;
  width: 92.3077vw;
  margin: min(70px, 10vw) auto min(30px, 2vw);
  border-radius: 6px;
}
.vision-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.vision-list > li {
    margin-bottom: 2px;
  }
.vision-item {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border-radius: 6px;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  margin-left: 10vw;
  padding-left: 5vw;
}
.vision-item .icon {
    position: absolute;
    top: 50%;
    left: -12vw;
    transform: translateY(-50%);
    z-index: 0;
  }
.vision-item .icon img {
      width: 20vw;
    }
.vision-item .icon::before {
      position: absolute;
      top: 50%;
      left: 50%;
      z-index: -1;
      transform: translate(-50%, -50%);
      border-radius: 50%;
      width: 25vw;
      height: 25vw;
      background: #fff;
      content: "";
    }
.vision-item--1 {
  background-image: url("../../about/images/vision01.jpg");
}
.vision-item--2 {
  background-image: url("../../about/images/vision02.jpg");
}
.vision-item--3 {
  background-image: url("../../about/images/vision03.jpg");
}
.vision-item--4 {
  background-image: url("../../about/images/vision04.jpg");
}
/* 強み */
.strength__image {
  position: relative;
  padding-left: 2.1875rem;
}
.strength__content {
  border-top: 1px solid #E6E6E6;
}
.strength-selector {
  display: grid;
  align-items: center;
  grid-template-columns: 4.25rem auto;
  counter-increment: strength;
  grid-gap: 1.5rem;
  padding: 2em 0;
  border-bottom: 1px solid #E6E6E6;

}
.strength-selector .number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4.25rem;
    height: 4.25rem;
    background: #2a3bd1;
    color: #fff;
    font-family: "Montserrat", sans-serif;
    font-size: 1.375rem;
    font-weight: 600;
  }
.strength-selector strong {
    font-size: 1.5em;
    font-weight: 600;
    line-height: 1.2;
  }
.strength .swiper-pagination {
  position: absolute;
  top: 0;
  left: 0;
}
.strength .swiper-pagination-bullet {
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  width: 2.0625rem;
  height: 2.0625rem;
  margin: 0 0 1px !important;
  border-radius: 0;
  background: #98A0E9;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 0.6875rem;
  font-weight: 600;
  transition: all 0.3s;
}
.strength .swiper-pagination-bullet-active {
  width: 4.75rem;
  height: 4.75rem;
  background: #2a3bd1;
  font-size: 1.625rem;
}
/*------------------------------------*\
  コア技術
\*------------------------------------*/
.core-intro {
  padding-top: min(15vw, 140px);
  background: linear-gradient(to bottom, #f4f4f4 50%, #fff 100%);
}
.core-intro__lead {
  margin-bottom: 1rem;
  font-size: 1.66rem;
  font-weight: 400;
  line-height: 1.4;
}
.core-intro__en {
  margin-bottom: 2rem;
  color: #B3B3B3;
  font-family: "Montserrat", sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.714;
}
.core-intro__image {
  margin-top: 40px;
}
.core-intro__shape {
  overflow: hidden;
  margin: 2em 0;
  border-radius: 6px;
  background: #fff;
}
.core-intro__shape dt {
    padding: 0.5em 1rem;
    background: #000;
    color: #fff;
    font-weight: 600;
  }
.core-intro__shape dd {
    margin: 0;
    padding: 1rem;
    font-size: 0.875rem;
  }
.advantage {
  margin-top: 50px;
}
.advantage__label {
  display: inline-block;
  margin-bottom: 1rem;
  padding: 0 1em;
  border-radius: 4px;
  background: #2a3bd1;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0;
}
.advantage__text {
  line-height: 1.6;
}
.advantage__text h3 {
  margin-bottom: 1rem;
  font-size: 1.75rem;
  font-weight: 400;
  line-height: 1.5;
}
.advantage__image {
  margin-top: 30px;
}
.advantage__image img {
  width: 100%;
}
/* 対応業界例 */
.technology-field {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  margin: 0 -0.5em;
  padding: 0;
}
.technology-field li {
    flex: 0 0 50%;
    padding: 0 0.5em;
    margin-bottom: 1.5em;
    text-align: center;
  }
.technology-field .icon {
    display: inline-block;
    width: 100%;
    margin-bottom: 0.5em;
    border-radius: 4px;
    background: linear-gradient(60deg, #2A3BD1, #282828)
  }
.technology-field img {
    width: 100%;
  }
/* 保有技術例 */
.technology-list {
  list-style: none;
  margin: 25px 0 0;
  padding: 0;
}
.technology-list li {
    margin-bottom: 1em;
  }
.technology-list .btn {
    width: 100%;
  }
.technology-list + .technology-list {
  padding-top: 25px;
  border-top: 1px solid #E6E6E6;
}
.technology-index__image {
  margin-top: 40px;
}
.technology-index__image img {
    width: 100%;
  }
/* 形状加工／3D加工の事例 */
.tech-sample-works {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  grid-gap: 26px 28px;
  margin: 0;
  padding: 0;
}
.tech-sample-work {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100%;
  border-radius: 6px;
  background: #F4F4F4;
}
.tech-sample-work__image img {
    width: 100%;
  }
.tech-sample-work__text {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 20px 24px;
}
.tech-sample-work__title {
  margin-bottom: 0.5rem;
  font-size: 1.25rem;
  line-height: 1.54;
}
/* 難削材の3D加工について */
.tech01 {
  position: relative;
}
.tech01__circle {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: -1;
  transform: translate(-50%, -50%);
}
.tech01__circle circle {
  offset-path: path("M330,10c176.73,0,320,143.27,320,320s-143.27,320-320,320S10,506.73,10,330,153.27,10,330,10");
  animation: move 40s linear infinite;
}
.tech01__circle circle:nth-of-type(2) {
  animation-delay: -20s;
}
.tech01-section {
  margin-bottom: 50px;
}
.tech01-section__image {
  margin-top: 30px;
}
.tech01-section__image img {
    width: 100%;
  }
@keyframes move {
  to {
    offset-distance: 100%;
  }
}
/* tech02 */
.tech-dl dt {
    font-size: 1.125rem;
    font-weight: 600;
  }
.tech-dl dd {
    margin: 0;
    font-size: 0.9375rem;
  }
/* tech03 */
.tech-images {
  list-style: none;
  display: grid;
  grid-gap: 23px;
  margin: 0;
  padding: 0;
}
.tech-images img {
    width: 100%;
    margin-bottom: 0.5rem;
  }
.tech-images--3cols {
  grid-template-columns: repeat(2, 1fr);
}
/*------------------------------------*\
  tech05 熱拡散接合
\*------------------------------------*/
.worry-list {
  list-style: none;
  position: relative;
  display: grid;
  grid-gap: 40px;
  grid-template-columns: repat(1, 1fr);
  margin: 0 0 3rem;
  padding: 0 0 7.5rem;
}
.worry-list::after {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%) scaleY(0.8) rotate(45deg);
    width: 3.75rem;
    height: 3.75rem;
    border: 0.8rem solid #2a3bd1;
    border-top-color: transparent;
    border-left-color: transparent;
    content: "";
  }
.worry-item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 2.5rem 2rem;
  border-radius: 6px;
  background: linear-gradient(-150deg, #282828, #2A3BD1);
  color: #fff;
  font-weight: 500;
  text-align: center;
}
.worry-item::before {
    position: absolute;
    top: 100%;
    left: 2.5rem;
    width: 0;
    height: 0;
    border-width: 12px 10px;
    border-style: solid;
    border-color: #2a3bd1 #2a3bd1 transparent transparent;
    content: "";
  }
.worry-item mark {
    background-color: transparent;
    background-image: linear-gradient(#fff, #fff);
    background-size: 0 1px;
    background-position: bottom left;
    background-repeat: no-repeat;
    color: inherit;
  }
.worry-lead {
  font-size: 1.125rem;
  text-align: center;
}
.worry-lead strong {
    display: inline-block;
    font-size: 1.375rem;
    line-height: 1.5;
  }
.tech05-news__header {
  margin-bottom: 2rem;
}
/*------------------------------------*\
  素材別加工事例
\*------------------------------------*/
/* 一覧画面 */
.works-index {
  margin-top: 60px;
}
.works-index .h2 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 40px;
}
.works-index-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.works-index-item {
  margin-bottom: 40px;
}
.works-title {
  margin-top: 0.75em;
  margin-bottom: 0.5em;
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.2;
}
.textlabel {
  display: inline-block;
  padding: 0.1em 0.4em 0.2em;
  border-radius: 3px;
  border: 1px solid;
  font-size: 0.875rem;
  line-height: 1.2;
}
/* 素材概要 */
.works-outline__image {
  margin-bottom: 1em;
}
.works-outline__image img {
    width: 100%;
  }
.works-outline__content .text {
    margin-top: 1.75em;
    padding: 1.5em 1.75em;
    border-radius: 6px;
    background: #F2F2F2;
  }
/* 事例詳細 */
.works-detail__image {
  margin-bottom: 2.5rem;
}
.works-detail__image img {
    width: 100%;
  }
.works-detail__content {
  /* max-width: 490px; */
  margin: 0 auto;
}
.works-detail__content th {
    width: 6.5em;
    /* white-space: nowrap; */
  }
/* 加工事例一覧 */
.sample-works {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: 20px;
  grid-row-gap: 40px;
  margin: 0;
  padding: 0;
}
.sample-works__image {
  overflow: hidden;
  margin-bottom: 1em;
  border-radius: 6px;
}
.sample-works__image img {
    width: 100%;
    transition: transform 0.3s ease-out;
  }
a:hover .sample-works__image img {
    transform: scale(1.1);
  }
/* 企業情報 */
.greeting-image1 {
  margin-bottom: 30px;
}
.greeting-image1 figcaption {
    display: block;
    margin-top: 1em;
    font-size: 0.9375rem;
    text-align: right;
  }
.greeting-image1 .u-font-en {
    font-size: 0.75rem;
  }
.greeting-lead {
  margin-bottom: 1.5em;
}
.philosophy__image {
  display: flex;
  justify-content: space-between;
  margin-bottom: 5vw;
}
.philosophy__image div {
    flex: 0 0 29.25%;
  }
.philosophy__image .philosophy-image2 {
    margin-top: 5.8%;
  }
.philosophy__image .philosophy-image3 {
    margin-top: 11.6%;
  }
.philosophy__inner,
.quality-policy__inner {
  overflow: hidden;
  position: relative;
  padding-bottom: 1.25em;
  border-bottom: 1px solid;
}
.philosophy__inner .h4, .quality-policy__inner .h4 {
    margin-bottom: 0.5em;
    letter-spacing: 0.1em;
  }
.philosophy__inner .h4 span, .quality-policy__inner .h4 span {
      position: relative;
      padding-right: 0.5em;
    }
.philosophy__inner .h4 span::after, .quality-policy__inner .h4 span::after {
        position: absolute;
        left: 100%;
        top: 50%;
        width: 100vw;
        border-top: 1px solid;
        content: "";
      }
.philosophy__inner {
  margin-top: 3em;
}
.company-row__content {
  margin-bottom: 40px;
}
.company-row__image {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}
.quality-policy {
  margin-top: 20px;
  padding: 48vw 1.5em 1.5em;
  border-radius: 6px;
  background: #000 url("../../company/images/quality01.jpg") no-repeat left top / 100%;
  color: #fff;
}
.quality-policy ol {
    list-style: none;
    margin: 0;
    padding: 0;
  }
.quality-policy li {
    display: flex;
    gap: 0.5em;
    margin-top: 0.5em;
  }
.quality-policy .number {
    flex: 0 0 1.625rem;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    position: relative;
    top: 0.2em;
    width: 1.625rem;
    height: 1.625rem;
    background: #2a3bd1;
    color: #fff;
    font-size: 0.75rem;
  }
/*------------------------------------*\
  開発サポート
\*------------------------------------*/
.cooperation01 {
  padding-bottom: 20%;
}
.cooperation01__text {
  margin-bottom: 40px;
}
.cooperation01__image {
  position: relative;
}
.cooperation01__image img:first-child {
    width: 88.18%;
  }
.cooperation01__image img:last-child {
    position: absolute;
    right: -40px;
    bottom: -20%;
    width: 45.89%;
  }
.cooperation02 {
  list-style: none;
  margin: 0 0 40px;
  padding: 0;
}
.cooperation02 > li {
    margin-bottom: 40px;
  }
.cooperation02__image {
  position: relative;
  margin-bottom: 2.5rem;
}
.cooperation02__image img {
    width: 100%;
  }
.cooperation02__image .u-font-en {
    position: absolute;
    right: 0;
    bottom: -0.5em;
    color: #2a3bd1;
    font-size: 1.625rem;
    font-weight: 500;
    line-height: 1;
  }
.cooperation03__text {
  margin-bottom: 40px;
}
/* ご依頼の流れ */
.flow-list {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}
.flow-list::before {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    width: 1.75rem;
    background: linear-gradient(to bottom, #e1e1e1, #2A3BD1);
    content: "";
  }
.flow-list > li {
    position: relative;
    padding: 1rem 1rem 1rem 2.75rem;
  }
.flow-list > li:nth-of-type(n+2) {
    border-top: 1px solid #F4F4F4;
  }
.flow-list__en {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 1.75rem;
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 0.625rem;
  font-weight: 500;
  text-align: center;
  line-height: 2.8;
  writing-mode: vertical-rl;
}
.flow-list__heading {
  font-size: 1.375rem;
  font-weight: 600;
  line-height: 1.6;
}
.flow__image {
  margin-top: 40px;
}
.flow__image .image {
    height: 50vw;
  }
.flow__image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: left 60%;
    object-position: left 60%;
    border-radius: 6px;
  }
/* よくあるご質問 */
.faq {
  border-top: 1px solid #DCDCDC;
}
.faq-item {
  padding: 1.875rem 0;
  border-bottom: 1px solid #DCDCDC;
}
.faq-item dt,
  .faq-item dd {
    display: grid;
    grid-template-columns: 2.5rem 1fr;
    grid-gap: 1.125rem;
  }
.faq-item dt::before, .faq-item dd::before {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 2.5rem;
      height: 2.5rem;
      color: #fff;
      font-family: "Montserrat", sans-serif;
      font-size: 1rem;
      font-weight: 500;
      content: "";
    }
.faq-item dt span, .faq-item dd span {
      align-self: center;
    }
.faq-item dt {
    margin-bottom: 10px;
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.6;
  }
.faq-item dt::before {
    background: #2a3bd1;
    content: "Q";
  }
.faq-item dd {
    margin: 0;
  }
.faq-item dd::before {
    background: #282828;
    content: "A";
  }
/* Utility
   ----------------------------------------------------------------- */
/* Responsive */
.video {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}
.video iframe,
.video video {
  position: absolute;
  outline: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/* Display */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(0px 0px 99.9% 99.9%);
  clip-path: inset(0px 0px 99.9% 99.9%);
  border: 0;
}
.u-none {
  display: none;
}
.u-block {
  display: block;
}
.u-inline {
  display: inline;
}
.u-inline-block {
  display: inline-block;
}
.u-flex {
  display: flex;
}
/* Text Align & Font style */
.u-text-left {
  text-align: left !important;
}
.u-text-center {
  text-align: center !important;
}
.u-text-right {
  text-align: right !important;
}
.u-text-indent {
  padding-left: 1.5em;
  text-indent: -1.5em;
}
ul.u-text-indent {
  list-style: none;
}
.u-align-items-center {
  align-items: center;
}
.u-align-self-start {
  align-self: flex-start;
}
.u-align-self-center {
  align-self: center;
}
.u-align-self-end {
  align-self: flex-end;
}
/* widths */
.u-w100 {
  width: 100%;
}
.u-w90 {
  width: 90%;
}
.u-w80 {
  width: 80%;
}
.u-w75 {
  width: 75%;
}
.u-w70 {
  width: 70%;
}
.u-w66 {
  width: 66%;
}
.u-w60 {
  width: 60%;
}
.u-w50 {
  width: 50%;
}
.u-w40 {
  width: 40%;
}
.u-w33 {
  width: 33%;
}
.u-w30 {
  width: 30%;
}
.u-w25 {
  width: 25%;
}
.u-w20 {
  width: 20%;
}
.u-w10 {
  width: 10%;
}
.u-w-auto {
  width: auto;
}
/* Margins */
.u-mt-0 {
  margin-top: 0 !important;
}
.u-mb-0 {
  margin-bottom: 0 !important;
}
.u-mr-0 {
  margin-right: 0 !important;
}
.u-ml-0 {
  margin-left: 0 !important;
}
.u-mt-1 {
  margin-top: 10px !important;
}
.u-mr-1 {
  margin-right: 10px !important;
}
.u-mb-1 {
  margin-bottom: 10px !important;
}
.u-ml-1 {
  margin-left: 10px !important;
}
.u-mt-2 {
  margin-top: 20px !important;
}
.u-mr-2 {
  margin-right: 20px !important;
}
.u-mb-2 {
  margin-bottom: 20px !important;
}
.u-ml-2 {
  margin-left: 20px !important;
}
.u-mt-3 {
  margin-top: 40px !important;
}
.u-mr-3 {
  margin-right: 40px !important;
}
.u-mb-3 {
  margin-bottom: 40px !important;
}
.u-ml-3 {
  margin-left: 40px !important;
}
.u-mt-4 {
  margin-top: 60px !important;
}
.u-mr-4 {
  margin-right: 60px !important;
}
.u-mb-4 {
  margin-bottom: 60px !important;
}
.u-ml-4 {
  margin-left: 60px !important;
}
.u-mt-5 {
  margin-top: 100px !important;
}
.u-mr-5 {
  margin-right: 100px !important;
}
.u-mb-5 {
  margin-bottom: 100px !important;
}
.u-ml-5 {
  margin-left: 100px !important;
}
.u-mr-auto,
.u-mx-auto {
  margin-right: auto !important;
}
.u-ml-auto,
.u-mx-auto {
  margin-left: auto !important;
}
/* Paddings */
.u-pt-0 {
  padding-top: 0 !important;
}
.u-pb-0 {
  padding-bottom: 0 !important;
}
.u-pr-0 {
  padding-right: 0 !important;
}
.u-pl-0 {
  padding-left: 0 !important;
}
.u-pt-1 {
  padding-top: 10px !important;
}
.u-pr-1 {
  padding-right: 10px !important;
}
.u-pb-1 {
  padding-bottom: 10px !important;
}
.u-pl-1 {
  padding-left: 10px !important;
}
.u-pt-2 {
  padding-top: 20px !important;
}
.u-pr-2 {
  padding-right: 20px !important;
}
.u-pb-2 {
  padding-bottom: 20px !important;
}
.u-pl-2 {
  padding-left: 20px !important;
}
.u-pt-3 {
  padding-top: 40px !important;
}
.u-pr-3 {
  padding-right: 40px !important;
}
.u-pb-3 {
  padding-bottom: 40px !important;
}
.u-pl-3 {
  padding-left: 40px !important;
}
.u-pt-4 {
  padding-top: 60px !important;
}
.u-pr-4 {
  padding-right: 60px !important;
}
.u-pb-4 {
  padding-bottom: 60px !important;
}
.u-pl-4 {
  padding-left: 60px !important;
}
.u-pt-5 {
  padding-top: 100px !important;
}
.u-pr-5 {
  padding-right: 100px !important;
}
.u-pb-5 {
  padding-bottom: 100px !important;
}
.u-pl-5 {
  padding-left: 100px !important;
}
/* Text Styles */
.u-font-l {
  font-size: 1.2rem;
}
.u-font-m {
  font-size: 1.125rem;
}
.u-font-s {
  font-size: 0.875rem;
}
.u-weight-b {
  font-weight: 600;
}
.u-color-primary {
  color: #2a3bd1;
}
.u-color-error {
  color: var(--color-error);
}
.u-font-en {
  font-family: "Montserrat", sans-serif;
}
@media (max-width: 40em) {
  html {
    font-size: 3.73333vw;
  }
  .footer__lead {
    position: absolute;
    top: 5rem;
    left: 0;
    width: 40%;
    text-align: center;
  }
    .footer__lead img {
      width: 66%;
    }
  .table-bock-sm {
    display: block;
    width: 100%;
  }
    .table-bock-sm :where(tbody, tr, th, td) {
      display: block;
      width: 100%;
    }
    .table-bock-sm thead {
      display: none;
    }
    .table-bock-sm th {
      padding-bottom: 0;
      border-bottom: none;
    }
    .vision-item .text {
      width: 40vw;
    }
  .sample-works {
    font-size: 0.875rem;
  }
  .greeting-image1 {
    margin-bottom: 0;
  }
    .greeting-image1 figcaption {
      text-align: center;
    }
}
@media (min-width: 40.001em) {
  .footer__logo {
    max-width: 230px;
    padding: 0 32px 28px 0;
  }
  .footer__content {
    padding: 100px 40px 20px 20px;
  }
  .footer__nav {
    width: calc(100% - 250px);
    margin-left: auto;
    padding-bottom: 30px;
    -moz-columns: 2;
    columns: 2;
    -moz-column-gap: 1em;
    column-gap: 1em;
  }
  .footer__lead {
    flex-basis: 190px;
    padding-bottom: 40px;
    text-align: center;
  }
    .footer__lead img {
      width: 75%;
    }
  .vision-list {
    display: flex;
    gap: 2px;
  }
    .vision-list > li {
      flex: 1;
      padding-top: 14vw;
    }
  .vision-item {
    flex-direction: column;
    margin-left: 0;
    padding-left: 0;
    padding-top: 5vw;
  }
    .vision-item .icon {
      top: -7vw;
      left: 50%;
      transform: translate(-50%, 0);
    }
      .vision-item .icon::before {
        width: 20vw;
        height: 20vw;
        transform: translate(-50%, -60%);
      }
    .technology-field li {
      flex-basis: 33%;
    }
  .technology-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 15px;
  }
    .technology-list li {
      flex: 0 0 50%;
      margin-bottom: 5px;
    }
  .worry-lead {
    font-size: 1.5rem;
  }
    .worry-lead strong {
      font-size: 2.125rem;
    }
  .works-index-item {
    display: flex;
    gap: 40px;
  }
  .works-index-item__thumb {
    flex: 0 0 38.8888%;
  }
  .works-index-item__content {
    flex: 1;
    display: flex;
    flex-direction: column;
  }
    .works-index-item__content .works-more {
      margin-top: auto;
      padding-top: 1rem;
    }
  .works-title {
    margin-top: 0;
    margin-bottom: 1em;
  }
  .greeting {
    display: grid;
    grid-template-columns: 20% 1fr 35%;
    grid-gap: 40px 6.7%;
  }
  .greeting-text1 {
    grid-column: span 3 / span 2;
  }
  .greeting-text2 {
    grid-column: span 2 / span 2;
    grid-row-start: 2;
  }
  .greeting-image1 {
    grid-column-start: 3;
    grid-row-start: 2;
  }
  .greeting-image2 {
    grid-column: span 3 / span 3;
    grid-row-start: 3;
  }
  .faq-item {
    padding: 1.875rem;
  }
    .faq-item dt,
    .faq-item dd {
      grid-template-columns: 3.5625rem 1fr;
    }
      .faq-item dt::before, .faq-item dd::before {
        width: 3.5625rem;
        height: 3.5625rem;
      }
    .faq-item dt {
      font-size: 1.375rem;
    }
  .u-md-text-left {
    text-align: left !important;
  }
  .u-md-text-center {
    text-align: center !important;
  }
  .u-md-text-right {
    text-align: right !important;
  }}
@media (max-width: 48em) {
  .table-responsive-md {
    display: block;
    width: 100%;
    overflow-x: auto;
  }
    .table-responsive-md table {
      min-width: 45em;
    }
    .image-group .image__label {
      font-size: 0.75rem;
    }}
@media (min-width: 48.001em) {
  .main-header__en {
    font-size: 0.875rem;
  }
  .main-header__title {
    font-size: 2.5rem;
  }
    .main-header__title[data-en]::before {
      font-size: 0.875rem;
    }
  .pagefoot-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: repeat(1, 1fr);
    grid-row-gap: 0;
    grid-column-gap: 48px;
  }
  .pagefoot {
    display: flex;
    flex-direction: column;
  }
    .pagefoot:first-of-type::after {
      position: absolute;
      top: 22vw;
      left: 50%;
      bottom: 0;
      width: 0;
      margin: 0;
      border-right: 1px solid #DCDCDC;
      content: "";
    }
  .pagefoot__btns {
    margin-top: auto;
  }
  .col-md,
  .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-offset-0,
  .col-md-offset-1,
  .col-md-offset-2,
  .col-md-offset-3,
  .col-md-offset-4,
  .col-md-offset-5,
  .col-md-offset-6,
  .col-md-offset-7,
  .col-md-offset-8,
  .col-md-offset-9,
  .col-md-offset-10,
  .col-md-offset-11,
  .col-md-offset-12 {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding-right: calc((1.5rem * 0.5));
    padding-left: calc((1.5rem * 0.5));
  }

  .col-md {
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
  }

  .col-md-1 {
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }

  .col-md-2 {
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }

  .col-md-3 {
    flex-basis: 25%;
    max-width: 25%;
  }

  .col-md-4 {
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }

  .col-md-5 {
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }

  .col-md-6 {
    flex-basis: 50%;
    max-width: 50%;
  }

  .col-md-7 {
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }

  .col-md-8 {
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }

  .col-md-9 {
    flex-basis: 75%;
    max-width: 75%;
  }

  .col-md-10 {
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }

  .col-md-11 {
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }

  .col-md-12 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col-md-offset-0 {
    margin-left: 0;
  }

  .col-md-offset-1 {
    margin-left: 8.33333333%;
  }

  .col-md-offset-2 {
    margin-left: 16.66666667%;
  }

  .col-md-offset-3 {
    margin-left: 25%;
  }

  .col-md-offset-4 {
    margin-left: 33.33333333%;
  }

  .col-md-offset-5 {
    margin-left: 41.66666667%;
  }

  .col-md-offset-6 {
    margin-left: 50%;
  }

  .col-md-offset-7 {
    margin-left: 58.33333333%;
  }

  .col-md-offset-8 {
    margin-left: 66.66666667%;
  }

  .col-md-offset-9 {
    margin-left: 75%;
  }

  .col-md-offset-10 {
    margin-left: 83.33333333%;
  }

  .col-md-offset-11 {
    margin-left: 91.66666667%;
  }

  .start-md {
    justify-content: flex-start;
  }

  .center-md {
    justify-content: center;
  }

  .end-md {
    justify-content: flex-end;
  }

  .around-md {
    justify-content: space-around;
  }

  .between-md {
    justify-content: space-between;
  }

  .top-md {
    align-items: flex-start;
  }

  .middle-md {
    align-items: center;
  }

  .bottom-md {
    align-items: flex-end;
  }
  .materials-group {
    margin-bottom: 2.25rem;
  }
  .materials-group-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, 300px);
    grid-column-gap: 18px;
    grid-row-gap: 8px;
    justify-content: center;
  }
    .materials-group-list > li {
      padding: 0;
    }
    .materials-group-list .btn {
      width: 100%;
    }
    .materials-group__body .materials-group-list {
      grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    }
  .news-list-item {
    padding-left: 1em;
  }
  .news-list-item__thumb {
    flex: 0 0 138px;
  }
  .news-list-item__body {
    max-width: calc(100% - 160px);
  }
    .news-list-item__body .news-title {
      font-size: 1.125rem;
    }
  .news-card-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 1.5rem;
  }
    .news-card-list > li {
      margin-bottom: 0;
    }
    .news-category-list2 li {
      flex-basis: calc(20% - 8px);
    }
  .article__header .news-title {
    font-size: 1.875rem;
  }
  .strength {
    display: flex;
    justify-content: space-between;
  }
  .strength__image {
    width: 51.8421%;
    padding-top: 1.875rem;
  }
  .strength__content {
    width: 41.49%;
  }
  .tech-sample-works {
    grid-template-columns: repeat(2, 1fr);
  }
  .tech01-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .tech01-section__text {
    flex: 0 0 50%;
  }
  .tech01-section__image {
    flex: 0 0 44.56%;
    margin-top: 0;
  }
    .tech01-section:nth-of-type(odd) .tech01-section__image {
      margin-right: -6.1539vw;
    }
  .tech01-section:nth-of-type(even) {
    flex-direction: row-reverse;
  }
    .tech01-section:nth-of-type(even) .tech01-section__image {
      margin-left: -6.1539vw;
    }
  .tech-images {
    grid-template-columns: repeat(2, 1fr);
  }
  .tech-images--3cols {
    grid-template-columns: repeat(3, 1fr);
  }
  .worry-list {
    grid-template-columns: repeat(2, 1fr);
    gap-row: 28px;
  }
  .works-outline {
    display: flex;
    justify-content: space-between;
  }
  .works-outline__image {
    flex: 0 0 57.6576%;
    margin-bottom: 0;
  }
  .works-outline__content {
    flex: 0 0 38.1981%;
  }
  .sample-works {
    grid-template-columns: repeat(3, 1fr);
  }
  .cooperation02 {
    display: flex;
    justify-content: space-between;
    gap: 30px;
    margin-bottom: 0;
  }
    .cooperation02 > li {
      flex: 1;
    }
    .cooperation02 > li:nth-of-type(2) {
      margin-top: 33px;
    }
    .cooperation02 > li:nth-of-type(3) {
      margin-top: 66px;
    }
  .cooperation03 {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
  }
  .cooperation03__text {
    flex: 0 0 50%;
    margin-bottom: 0;
  }
  .cooperation03__image {
    flex: 0 0 42.98%;
  }
  .flow-list {
    display: flex;
    flex-direction: column;
  }
    .flow-list > li {
      display: flex;
      align-items: center;
      min-height: 6.375rem;
    }
  .flow-list__heading {
    flex: 0 0 12em;
    padding-bottom: 0.25em;
  }
  .u-md-none {
    display: none !important;
  }
  .u-md-block {
    display: block !important;
  }
  .u-md-inline {
    display: inline !important;
  }
  .u-md-inline-block {
    display: inline-block !important;
  }
  .u-md-flex {
    display: flex !important;
  }}
@media (max-width: 60em) {
    .footer__nav .nav-child-list {
      display: none;
    }
  .footer__columns {
    display: contents;
  }
    .footer__columns .column {
      display: contents;
    }
    .tech-dl > div {
      position: relative;
      padding: 1em 0;
      border-top: 1px solid #DCDCDC;
    }
      .tech-dl > div::before {
        content: "";
        position: absolute;
        left: 0;
        top: -1px;
        width: 5em;
        border-top: 1px solid #2a3bd1;
      }}
@media (min-width: 60.001em) {
  .pagefoot-grid,
  .pagefoot-tel {
    width: 87.69%;
  }
  .pagefoot-text {
    padding: 0 8%;
  }
      .pagefoot-tel .other ul {
        display: flex;
        justify-content: center;
      }
      .pagefoot-tel .other li:first-of-type::after {
        display: inline-block;
        width: 0;
        height: 1em;
        margin: 0 1.5em;
        border-left: 1px solid #DCDCDC;
        vertical-align: middle;
        content: "";
      }
  .footer__content {
    padding-top: 40px;
  }
  .footer__lead {
    padding-top: 60px;
  }
  .footer__columns {
    display: flex;
    justify-content: space-between;
    gap: 4em;
  }
    .footer__columns .column {
      flex: 1;
    }
      .footer__columns .column > ul {
        margin-bottom: 0;
      }
      .footer__columns .column .nav-child-list {
        margin: 0.5em 0;
      }
        .footer__columns .column .nav-child-list li {
          margin-bottom: 0.25em;
        }
    .footer__columns .column:nth-of-type(n+2) {
      padding-top: 2.25em;
    }
  .footer__nav {
    -moz-columns: 1;
    columns: 1;
    width: 70%;
  }
  .news-card-list {
    gap: 1.875rem;
  }
    .news-card__body .news-title {
      font-size: 1.125rem;
    }
  .core-intro .container {
    display: flex;
    justify-content: space-between;
  }
  .core-intro__text {
    flex: 0 0 43.51%;
  }
  .core-intro__image {
    flex: 0 0 50%;
    margin-top: 0;
  }
  .core-intro__text2 {
    flex: 0 0 37.98%;
  }
  .core-intro__text3 {
    flex: 0 0 40.3508%;
  }
  .core-intro__image2 {
    flex: 0 0 53.94%;
  }
  .advantage {
    display: flex;
    align-items: center;
  }
    .advantage:nth-of-type(even) {
      flex-direction: row-reverse;
    }
  .advantage__text,
  .advantage__image {
    flex: 1;
  }
  .advantage__text .text-bg {
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    display: inline;
    padding: 0em 0.3em;
    background-color: #fff;
  }
  .advantage__image {
    margin-top: 0;
  }
    .advantage__image .image {
      position: relative;
      z-index: -1;
      width: 122%;
    }
  .advantage:nth-of-type(odd) .advantage__image {
    direction: rtl;
  }
  .advantage:nth-of-type(odd) .advantage__image .image {
    margin-right: -5.2%;
    margin-left: auto;
  }
  .advantage:nth-of-type(even) .advantage__image .image {
    margin-left: -5.2%;
  }
  .technology-field {
    margin-right: -13px;
    margin-left: -13px;
  }
    .technology-field li {
      flex-basis: 25%;
      padding: 0 13px;
    }
  .technology-index {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
  .technology-index__text {
    flex: 0 0 48.68%;
  }
  .technology-index__image {
    flex: 0 0 42.98%;
    margin-top: 0;
  }
  .tech-sample-work {
    flex-direction: row;
  }
  .tech-sample-work__image {
    flex: 0 0 41.72%;
  }
    .tech-sample-work__image img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }
  .tech-sample-work__text {
    flex: 1 0 58.28%;
  }
    .tech-dl > div {
      display: flex;
    }
    .tech-dl dt {
      flex: 0 0 14em;
      padding: 1em 0;
      border-top: 1px solid #2a3bd1;
    }
    .tech-dl dd {
      flex: 1 1 auto;
      padding: 1.2em 1em;
      border-top: 1px solid #DCDCDC;
    }
  .cooperation01 {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding-bottom: 140px;
  }
  .cooperation01__text {
    flex: 0 0 41.57%;
    margin-bottom: 0;
  }
  .cooperation01__image {
    flex: 0 0 51.22%;
  }
  .cooperation02 {
    gap: 46px;
  }
  .flow {
    display: flex;
    justify-content: space-between;
  }
  .flow__text {
    flex: 0 0 64.91%;
  }
  .flow__image {
    flex: 0 0 30.26%;
    height: auto;
  }
    .flow__image .image {
      width: calc(100% + 6.153vw);
      height: 100%;
      margin-right: -6.153vw;
      border-radius: 6px 6px 0 0;
    }
  .u-lg-text-left {
    text-align: left !important;
  }
  .u-lg-text-center {
    text-align: center !important;
  }
  .u-lg-text-right {
    text-align: right !important;
  }}
@media (max-width: 70em) {
  .header {
    height: 70px;
  }
  .navi-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: fixed;
    top: 5px;
    right: 10px;
    z-index: 100;
    width: 60px;
    height: 60px;
    padding: 0;
    border: 0;
    background: none;
    cursor: pointer;
    transition: all 0.3s ease-out;
  }
    .navi-btn > .icon {
      display: block;
      position: absolute;
      top: 50%;
      left: 50%;
      width: 40px;
      height: 1px;
      background: #2a3bd1;
      margin-left: -20px;
      transition: all 0.3s ease-out;
    }
      .navi-btn > .icon::before,
      .navi-btn > .icon::after {
        display: block;
        position: absolute;
        left: 0;
        width: 40px;
        height: 1px;
        background: #2a3bd1;
        transition: all 0.2s ease-out;
        content: "";
      }
      .navi-btn > .icon::before {
        top: -8px;
      }
      .navi-btn > .icon::after {
        bottom: -8px;
      }
  .gnav {
    position: fixed;
    top: 70px;
    bottom: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    width: 100%;
    background: #fff;
    opacity: 0;
    visibility: hidden;
  }
      .navi-open .navi-btn > .icon {
        background: transparent;
      }
        .navi-open .navi-btn > .icon::before {
          top: 0;
          transform: rotate(-45deg);
        }
        .navi-open .navi-btn > .icon::after {
          bottom: 0;
          transform: rotate(45deg);
        }
    .navi-open .gnav {
      opacity: 1;
      visibility: visible;
      transition: all 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), visibility 0s;
    }
  .gnav__second {
    padding-top: 10px;
  }
  .gnav__main {
    margin-top: auto;
    margin-bottom: auto;
  }
  .gnav-list-1,
  .gnav-list-2 {
    margin: 1rem  3.8461% !important;
  }
    .gnav-list-2 > li > a,
    .gnav-list-2 .lang-btn {
      display: flex;
      align-items: center;
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;
      height: 2rem;
      line-height: 1;
      transition: background 0.2s;
    }
  .gnav-list-3 {
    padding: 1em 3.8461%;
    font-size: max(1.125rem, min(4.5vw, 2rem));
  }
    .gnav-list-3 > li {
      margin-bottom: 1em;
    }
  .dropdown-list {
    display: none;
  }
  .table-responsive {
    display: block;
    width: 100%;
    overflow-x: auto;
  }
    .table-responsive table {
      min-width: 60em;
    }
  .news-category-list {
    display: flex;
    flex-wrap: wrap;
  }
    .news-category-list > li:nth-last-of-type(n+2) {
      margin-right: 2.5em;
    }}
@media (min-width: 70.001em) {
  .header {
    display: flex;
    justify-content: space-between;
    height: 140px;
    padding: 40px 3.8461% 5px;
  }
  .header__logo {
    flex: 0 0 224px;
    width: 224px;
  }
  .navi-btn {
    display: none;
  }
  .gnav {
    display: flex;
    flex-wrap: wrap;
  }
  .gnav__main,
  .gnav__second {
    flex: 1 0 100%;
  }
  .gnav__second,
  .gnav-list-1,
  .gnav-list-2,
  .gnav-list-3 {
    display: flex;
    justify-content: flex-end;
  }
  .gnav-list-2 {
    padding-left: 1.2em;
  }
  .gnav-list-3 {
    margin-top: 1em;
  }
    .gnav-list-3 > li {
      position: relative;
      margin-left: 2em;
    }
    .gnav-list-3 > li > a small {
      display: block;
      margin-left: 0;
      text-align: center;
    }
    .gnav-list-3 li:hover .dropdown-list {
      grid-template-rows: 1fr;
    }
    .gnav-list-3 .dropdown-list {
      display: grid;
      grid-template-rows: 0fr;
      position: absolute;
      top: 100%;
      left: calc(1em + 50%);
      transform: translateX(-50%);
      width: 15.25rem;
      border-radius: 0.4rem;
      transition: all 0.3s;
    }
      .gnav-list-3 .dropdown-list .nav-child-list {
        overflow: hidden;
      }
      .gnav-list-3 .dropdown-list a:hover {
        color: #ddd;
      }
      .gnav-list-3 .dropdown-list.wide {
        overflow: hidden;
        width: 30.5rem;
      }
        .gnav-list-3 .dropdown-list.wide::before {
          position: absolute;
          top: 0;
          bottom: 0;
          left: 50%;
          border-left: 1px solid #3E3E3E;
          content: "";
        }
        .gnav-list-3 .dropdown-list.wide > .nav-child-list {
          padding-left: 50%;
        }
        .gnav-list-3 .dropdown-list.wide > .nav-child-list > li:first-child {
          position: absolute;
          left: 0;
          top: 0;
          width: 45%;
        }
  .wrap {
    padding-top: 140px;
  }
  .container--narrow {
    width: 69.2307vw;
  }
    .main-header .parallax {
      margin-bottom: min(8vw, 140px);
    }
  .main-header__title {
    font-size: 3rem;
  }
  .section-inner {
    padding-left: 30px;
  }
  .heading {
    font-size: 2.75rem;
  }
  .h2,
  .lead {
    font-size: 1.75rem;
  }
  .h3 {
    font-size: 1.5rem;
  }
  .col-lg,
  .col-lg-1,
  .col-lg-2,
  .col-lg-3,
  .col-lg-4,
  .col-lg-5,
  .col-lg-6,
  .col-lg-7,
  .col-lg-8,
  .col-lg-9,
  .col-lg-10,
  .col-lg-11,
  .col-lg-12,
  .col-lg-offset-0,
  .col-lg-offset-1,
  .col-lg-offset-2,
  .col-lg-offset-3,
  .col-lg-offset-4,
  .col-lg-offset-5,
  .col-lg-offset-6,
  .col-lg-offset-7,
  .col-lg-offset-8,
  .col-lg-offset-9,
  .col-lg-offset-10,
  .col-lg-offset-11,
  .col-lg-offset-12 {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding-right: calc((1.5rem * 0.5));
    padding-left: calc((1.5rem * 0.5));
  }

  .col-lg {
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
  }

  .col-lg-1 {
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }

  .col-lg-2 {
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }

  .col-lg-3 {
    flex-basis: 25%;
    max-width: 25%;
  }

  .col-lg-4 {
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }

  .col-lg-5 {
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }

  .col-lg-6 {
    flex-basis: 50%;
    max-width: 50%;
  }

  .col-lg-7 {
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }

  .col-lg-8 {
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }

  .col-lg-9 {
    flex-basis: 75%;
    max-width: 75%;
  }

  .col-lg-10 {
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }

  .col-lg-11 {
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }

  .col-lg-12 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col-lg-offset-0 {
    margin-left: 0;
  }

  .col-lg-offset-1 {
    margin-left: 8.33333333%;
  }

  .col-lg-offset-2 {
    margin-left: 16.66666667%;
  }

  .col-lg-offset-3 {
    margin-left: 25%;
  }

  .col-lg-offset-4 {
    margin-left: 33.33333333%;
  }

  .col-lg-offset-5 {
    margin-left: 41.66666667%;
  }

  .col-lg-offset-6 {
    margin-left: 50%;
  }

  .col-lg-offset-7 {
    margin-left: 58.33333333%;
  }

  .col-lg-offset-8 {
    margin-left: 66.66666667%;
  }

  .col-lg-offset-9 {
    margin-left: 75%;
  }

  .col-lg-offset-10 {
    margin-left: 83.33333333%;
  }

  .col-lg-offset-11 {
    margin-left: 91.66666667%;
  }

  .start-lg {
    justify-content: flex-start;
  }

  .center-lg {
    justify-content: center;
  }

  .end-lg {
    justify-content: flex-end;
  }

  .around-lg {
    justify-content: space-around;
  }

  .between-lg {
    justify-content: space-between;
  }

  .top-lg {
    align-items: flex-start;
  }

  .middle-lg {
    align-items: center;
  }

  .bottom-lg {
    align-items: flex-end;
  }
  .materials-group {
    display: flex;
  }
  .news-category-list2 {
    display: block;
  }
    .news-category-list2 li {
      margin-bottom: 5px;
    }
    .news-category-list2 a {
      width: 11rem;
    }
  .article__header .news-title {
    font-size: 2.125rem;
  }
    .article__content :where(h2) {
      font-size: 1.5rem;
    }
  .core-intro__lead {
    font-size: 2.5rem;
  }
  .tech-sample-work__title {
    font-size: 1.375rem;
  }
  .worry-list {
    grid-template-columns: repeat(3, 1fr);
    -moz-column-gap: 4.2%;
    column-gap: 4.2%;
    row-gap: 54px;
  }
  .tech05-news {
    display: flex;
  }
  .tech05-news__header {
    flex: 0 0 25%;
  }
  .tech05-news__content {
    flex: 0 0 72.28%;
  }
  .works-index .h3 {
    margin-bottom: 50px;
  }
  .works-index-list {
    padding-left: 30px;
  }
  .works-index-item {
    margin-bottom: 50px;
  }
  .works-title {
    font-size: 1.625rem;
  }
  .works-detail {
    max-width: 72.28%;
    margin: 0 auto;
  }
  .works-detail__image {
    margin-bottom: 3.5rem;
  }
  .sample-works {
    grid-template-columns: repeat(4, 1fr);
    -moz-column-gap: 33px;
    column-gap: 33px;
  }
  .greeting {
    grid-template-columns: 16.66% 27.19% 1fr 27.72%;
    gap: 80px 6.7%;
  }
  .greeting-text2 {
    grid-column-start: 3;
    grid-row-start: 2;
  }
  .greeting-image1 {
    grid-column-start: 4;
    grid-row-start: 1;
  }
  .greeting-image2 {
    grid-column: span 2 / span 2;
    grid-column-start: 1;
    grid-row-start: 2;
  }
  .philosophy {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
  }
  .philosophy__heading {
    flex: 0 0 60.26%;
  }
  .philosophy__content {
    flex: 0 0 32.89%;
    position: relative;
    left: -30px;
  }
  .philosophy__image {
    position: relative;
    left: -30px;
  }
  .company-row {
    display: flex;
    justify-content: space-between;
  }
  .company-row__content {
    flex: 0 0 53.5088%;
    margin-bottom: 0;
  }
  .company-row__image {
    flex: 0 0 40.5263%;
    max-width: auto;
    margin: 0;
    text-align: left;
  }
    .company-row__image .image-fit {
      overflow: hidden;
      border-radius: 6px 0 0 6px;
      width: calc(100% + 6vw);
    }
  .quality-policy {
    padding: 60px 50px 60px 52%;
    background-size: auto 100%;
  }
  .u-lg-none {
    display: none !important;
  }
  .u-lg-block {
    display: block !important;
  }
  .u-lg-inline {
    display: inline !important;
  }
  .u-lg-inline-block {
    display: inline-block !important;
  }
  .u-lg-flex {
    display: flex !important;
  }}
@media (min-width: 90.001em) {
  .tech-dl {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 26px 28px;
  }}
/*# sourceMappingURL=maps/main.css.map */
