@charset "UTF-8";
/* !Base -------------------------------------------------------------- */
* {
  box-sizing: border-box;
}

/* !Base Fonts -------------------------------------------------------------- */
body {
  padding: 0;
  margin: 0;
  font-family: 'Noto Sans JP', sans-serif;
}

a {
  text-decoration: underline;
}

a:hover,
a:active,
a:focus {
  text-decoration: none;
}

.fwN {
  font-weight: normal;
}

.fwB {
  font-weight: bold;
}

.fzSS {
  font-size: 72%;
}

.fzS {
  font-size: 86%;
}

.fzM {
  font-size: 100%;
}

.fzL {
  font-size: 115%;
}

.fzLL {
  font-size: 129%;
}

.fzLLL {
  font-size: 143%;
}

sup {
  font-size: 78%;
  vertical-align: top;
}

sub {
  font-size: 78%;
  vertical-align: baseline;
}

/* テキストをノーマルに */
address {
  font-style: normal;
}

/* !Inline Align ------------------------------------------------------------ */
.taL, .alignLeft {
  text-align: left   !important;
}

.taC, .alignCenter {
  text-align: center !important;
}

.taR, .alignRight {
  text-align: right  !important;
}

.vaT {
  vertical-align: top    !important;
}

.vaM {
  vertical-align: middle !important;
}

.vaB {
  vertical-align: bottom !important;
}

.blockC {
  margin-right: auto;
  margin-left: auto;
  text-align: left;
}

* html .blockC {
  margin-right: 0;
  margin-left: 0;
}

.blockR {
  margin-left: auto;
  text-align: left;
}

* html .blockR {
  margin-left: 0;
}

@media screen and (min-width: 768px) {
  .alignRightPcOnly {
    text-align: right  !important;
  }
}

/* !Width ------------------------------------------------------------------- */
/* 960px Grid */
.w960 {
  width: 960px;
}

.w800 {
  width: 800px;
}

.w640 {
  width: 640px;
}

.w480 {
  width: 480px;
}

.w320 {
  width: 320px;
}

.w160 {
  width: 160px;
}

.wHalf {
  width: 48%;
}

.wTri {
  width: 33%;
}

.wQuart {
  width: 24%;
}

.wFull {
  width: 99.9%;
}

.wMax {
  width: 100%;
}

.w03per {
  width: 3%  !important;
}

.w05per {
  width: 5%  !important;
}

.w10per {
  width: 10% !important;
}

.w13per {
  width: 13% !important;
}

.w15per {
  width: 15% !important;
}

.w20per {
  width: 20% !important;
}

.w25per {
  width: 25% !important;
}

.w30per {
  width: 30% !important;
}

.w35per {
  width: 35% !important;
}

.w40per {
  width: 40% !important;
}

.w45per {
  width: 45% !important;
}

.w50per {
  width: 50% !important;
}

.w60per {
  width: 60% !important;
}

.w70per {
  width: 70% !important;
}

.w80per {
  width: 80% !important;
}

.w90per {
  width: 90% !important;
}

/* !Floats ------------------------------------------------------------------ */
.flL {
  display: inline;
  float: left;
}

.flR {
  display: inline;
  float: right;
}

.flImgL {
  display: inline;
  float: left;
  margin-right: 20px;
}

.flImgR {
  display: inline;
  float: right;
  margin-left: 20px;
}

.ftBox {
  overflow: hidden;
  *zoom: 1;
}

/* !Tools ------------------------------------------------------------------- */
.clear {
  clear: both;
}

.block {
  display: block;
}

.inlineBlock {
  display: inline-block;
}

.hide {
  display: none;
}

.bgN {
  background: none !important;
}

.tdU {
  text-decoration: underline;
}

.tdN {
  text-decoration: none;
}

.atode {
  border: 2px solid #96c;
  padding: 100px 10px;
  text-align: center;
  background-color: #f9f;
  font-family: "ＭＳ ゴシック", "MS Gothic", "Osaka－等幅", Osaka-mono, monospace;
  font-size: 30px;
  color: #fff;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

.clearfix:before {
  content: "";
  display: block;
  clear: both;
}

.clearfix {
  display: block;
}

/* !Margin ------------------------------------------------------------------ */
.mgt00 {
  margin-top: 0   !important;
}

.mgt05 {
  margin-top: 5px !important;
}

.mgt10 {
  margin-top: 10px !important;
}

.mgt12 {
  margin-top: 12px !important;
}

.mgt15 {
  margin-top: 15px !important;
}

.mgt20 {
  margin-top: 20px !important;
}

.mgt25 {
  margin-top: 25px !important;
}

.mgt30 {
  margin-top: 30px !important;
}

.mgt35 {
  margin-top: 35px !important;
}

.mgt40 {
  margin-top: 40px !important;
}

.mgt45 {
  margin-top: 45px !important;
}

.mgt50 {
  margin-top: 50px !important;
}

.mgt1em, .mgtLine {
  margin-top: 1em !important;
}

.mgt2em {
  margin-top: 2em !important;
}

.mgt3em {
  margin-top: 3em !important;
}

.mgr00 {
  margin-right: 0   !important;
}

.mgr05 {
  margin-right: 5px !important;
}

.mgr10 {
  margin-right: 10px !important;
}

.mgr12 {
  margin-right: 12px !important;
}

.mgr15 {
  margin-right: 15px !important;
}

.mgr20 {
  margin-right: 20px !important;
}

.mgr25 {
  margin-right: 25px !important;
}

.mgr30 {
  margin-right: 30px !important;
}

.mgr35 {
  margin-right: 35px !important;
}

.mgr40 {
  margin-right: 40px !important;
}

.mgr45 {
  margin-right: 45px !important;
}

.mgr50 {
  margin-right: 50px !important;
}

.mgr1em, .mgrLine {
  margin-right: 1em !important;
}

.mgr2em {
  margin-right: 2em !important;
}

.mgr3em {
  margin-right: 3em !important;
}

.mgb00 {
  margin-bottom: 0   !important;
}

.mgb05 {
  margin-bottom: 5px !important;
}

.mgb10 {
  margin-bottom: 10px !important;
}

.mgb12 {
  margin-bottom: 12px !important;
}

.mgb15 {
  margin-bottom: 15px !important;
}

.mgb20 {
  margin-bottom: 20px !important;
}

.mgb25 {
  margin-bottom: 25px !important;
}

.mgb30 {
  margin-bottom: 30px !important;
}

.mgb35 {
  margin-bottom: 35px !important;
}

.mgb40 {
  margin-bottom: 40px !important;
}

.mgb45 {
  margin-bottom: 45px !important;
}

.mgb50 {
  margin-bottom: 50px !important;
}

.mgb1em, .mgbLine {
  margin-bottom: 1em !important;
}

.mgb2em {
  margin-bottom: 2em !important;
}

.mgb3em {
  margin-bottom: 3em !important;
}

.mgl00 {
  margin-left: 0   !important;
}

.mgl05 {
  margin-left: 5px !important;
}

.mgl10 {
  margin-left: 10px !important;
}

.mgl12 {
  margin-left: 12px !important;
}

.mgl15 {
  margin-left: 15px !important;
}

.mgl20 {
  margin-left: 20px !important;
}

.mgl25 {
  margin-left: 25px !important;
}

.mgl30 {
  margin-left: 30px !important;
}

.mgl35 {
  margin-left: 35px !important;
}

.mgl40 {
  margin-left: 40px !important;
}

.mgl45 {
  margin-left: 45px !important;
}

.mgl50 {
  margin-left: 50px !important;
}

.mgl1em, .mglLine {
  margin-left: 1em !important;
}

.mgl2em {
  margin-left: 2em !important;
}

.mgl3em {
  margin-left: 3em !important;
}

.mgLRAuto {
  margin-left: auto;
  margin-right: auto;
}

/* !Padding  ---------------------------------------------------------------- */
.pdt00 {
  padding-top: 0   !important;
}

.pdt05 {
  padding-top: 5px !important;
}

.pdt10 {
  padding-top: 10px !important;
}

.pdt12 {
  padding-top: 12px !important;
}

.pdt15 {
  padding-top: 15px !important;
}

.pdt20 {
  padding-top: 20px !important;
}

.pdt25 {
  padding-top: 25px !important;
}

.pdt30 {
  padding-top: 30px !important;
}

.pdt35 {
  padding-top: 35px !important;
}

.pdt40 {
  padding-top: 40px !important;
}

.pdt45 {
  padding-top: 45px !important;
}

.pdt50 {
  padding-top: 50px !important;
}

.pdt1em {
  padding-top: 1em !important;
}

.pdt2em {
  padding-top: 2em !important;
}

.pdr00 {
  padding-right: 0   !important;
}

.pdr05 {
  padding-right: 5px !important;
}

.pdr10 {
  padding-right: 10px !important;
}

.pdr12 {
  padding-right: 12px !important;
}

.pdr15 {
  padding-right: 15px !important;
}

.pdr20 {
  padding-right: 20px !important;
}

.pdr25 {
  padding-right: 25px !important;
}

.pdr30 {
  padding-right: 30px !important;
}

.pdr35 {
  padding-right: 35px !important;
}

.pdr40 {
  padding-right: 40px !important;
}

.pdr45 {
  padding-right: 45px !important;
}

.pdr50 {
  padding-right: 50px !important;
}

.pdr1em {
  padding-right: 1em !important;
}

.pdr2em {
  padding-right: 2em !important;
}

.pdb00 {
  padding-bottom: 0   !important;
}

.pdb05 {
  padding-bottom: 5px !important;
}

.pdb10 {
  padding-bottom: 10px !important;
}

.pdb12 {
  padding-bottom: 12px !important;
}

.pdb15 {
  padding-bottom: 15px !important;
}

.pdb20 {
  padding-bottom: 20px !important;
}

.pdb25 {
  padding-bottom: 25px !important;
}

.pdb30 {
  padding-bottom: 30px !important;
}

.pdb35 {
  padding-bottom: 35px !important;
}

.pdb40 {
  padding-bottom: 40px !important;
}

.pdb45 {
  padding-bottom: 45px !important;
}

.pdb50 {
  padding-bottom: 50px !important;
}

.pdb1em {
  padding-bottom: 1em !important;
}

.pdb2em {
  padding-bottom: 2em !important;
}

.pdl00 {
  padding-left: 0   !important;
}

.pdl05 {
  padding-left: 5px !important;
}

.pdl10 {
  padding-left: 10px !important;
}

.pdl12 {
  padding-left: 12px !important;
}

.pdl15 {
  padding-left: 15px !important;
}

.pdl20 {
  padding-left: 20px !important;
}

.pdl25 {
  padding-left: 25px !important;
}

.pdl30 {
  padding-left: 30px !important;
}

.pdl35 {
  padding-left: 35px !important;
}

.pdl40 {
  padding-left: 40px !important;
}

.pdl45 {
  padding-left: 45px !important;
}

.pdl50 {
  padding-left: 50px !important;
}

.pdl1em {
  padding-left: 1em !important;
}

.pdl2em {
  padding-left: 2em !important;
}

/* ---------------------------------------
　行間
--------------------------------------- */
/* 章 */
.sentence {
  margin-bottom: 4em !important;
}

/* 段落 */
.paragraph {
  margin-bottom: 2em !important;
}

/* 行 */
.mgbLine {
  margin-bottom: 1em !important;
}

.mgb3em {
  margin-bottom: 3em !important;
}

/* ---------------------------------------
　注釈
--------------------------------------- */
/* 本文中※ */
span.mkNote {
  position: relative;
  top: -0.4em;
  margin-left: 2px;
  font-size: 83%;
}

/* Zenkaku */
.note {
  padding-left: 1em;
  text-indent: -1em;
}

/* ※&nbsp; */
.noteKome {
  padding-left: 1.34em;
  text-indent: -1.34em !important;
}

/* ※1&nbsp; */
.noteNum1 {
  padding-left: 1.8em;
  text-indent: -1.8em;
}

/* ※10&nbsp; */
.noteNum2 {
  padding-left: 2.3em;
  text-indent: -2.3em;
}

/* *&nbsp; */
.notesAst {
  padding-left: 1.0em;
  text-indent: -0.85em;
}

/* ・ */
.notesZenkaku {
  padding-left: 1.0em;
  text-indent: -0.9em;
}

/* 1．*/
.notesNum {
  padding-left: 1.0em;
  text-indent: -1.2em;
}

/* 10．*/
.notesNum2Keta {
  padding-left: 1.58em;
  text-indent: -1.68em;
}

/* 1)&nbsp; */
.notesParentNum {
  padding-left: 1.35em;
  text-indent: -1.2em;
}

/* (1)&nbsp; */
.notesParent2Num {
  padding-left: 1.83em;
  text-indent: -1.50em;
}

/* 10)&nbsp; */
.notesParentNum2Keta {
  padding-left: 1.98em;
  text-indent: -1.7em;
}

/* (10)&nbsp; */
.notesParent2Num2Keta {
  padding-left: 2.48em;
  text-indent: -2.0em;
}

/* ※注)&nbsp; */
.notesParentAtten {
  padding-left: 3em;
  text-indent: -2.7em;
}

/* (注1)&nbsp; */
.notesParentAttenNum {
  padding-left: 3.0em;
  text-indent: -2.7em;
}

/* 電話番号 */
.is-eventNone {
  pointer-events: none;
}

/* -------------------------------------------------------------------
 表示
------------------------------------------------------------------- */
/* 非表示 */
.displayNone {
  display: none;
}

/* SP */
@media screen and (max-width: 767px) {
  .spDisNone,
  .pcOnly {
    display: none !important;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  .pcDisNone,
  .spOnly {
    display: none !important;
  }
}

/* -------------------------------------------------------------------
 画像
------------------------------------------------------------------- */
img {
  max-width: 100%;
  vertical-align: bottom;
}

body {
  box-sizing: border-box;
}

/* -------------------------------------------------------------------
 リスト
------------------------------------------------------------------- */
.discList {
  list-style-type: disc;
  padding-left: 1.5em;
  margin: 0;
}

.alphaList {
  list-style-type: lower-alpha;
  padding-left: 1.5em;
  margin: 0;
}

.alphaList > li {
  list-style-type: lower-alpha;
  margin: 0;
}

/* !Layout
---------------------------------------------------------- */
html {
  overflow-y: scroll;
  height: -webkit-fill-available;
}

body {
  min-height: 100vh;
  min-height: -webkit-fill-available;
  text-align: left;
}

@media print {
  html,
  html body {
    *zoom: 0.65;
  }
}

/* SP */
@media screen and (max-width: 767px) {
  body {
    line-height: 1.6;
    font-family: 'Noto Sans JP', sans-serif;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  body {
    line-height: 1.8;
  }
}

/* float */
.fr {
  float: right;
}

.fl {
  float: left;
}

/* !Header
---------------------------------------------------------- */
#header * {
  margin-top: 0;
  margin-bottom: 0;
}

#header a {
  text-decoration: none;
  font-weight: 500;
  color: #000;
}

.navUnder,
.navUnder a {
  color: #fff;
}

#gNaviList,
.navUnderList ul {
  list-style: none;
}

/* SP */
@media screen and (max-width: 1210px) {
  #contents {
    padding-top: 60px;
  }
  #header {
    position: relative;
  }
  #headerLogoWrap {
    width: 100%;
    height: 60px;
    background-color: #f9f9f9;
    padding: 15px 60px 15px 2.5%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 10;
  }
  #headerLogo {
    line-height: 60px;
  }
  #headerLogo img {
    height: 30px;
    width: auto;
    display: block;
  }
  #js-buttonHamburger {
    width: 60px;
    height: 60px;
    color: #fff;
    position: absolute;
    right: 0;
    bottom: 0;
  }
  /* バーガーメニュー */
  .c-button {
    position: relative;
    display: inline-block;
    text-decoration: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    background-color: transparent;
    cursor: pointer;
  }
  .p-hamburger {
    position: absolute;
    top: 0;
    right: 0;
    width: 22px;
    height: 22px;
    margin: auto;
    outline: none;
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
    z-index: 30;
  }
  .p-hamburger_line {
    position: absolute;
    top: 30px;
    right: 0;
    left: 0;
    margin: auto;
    width: 22px;
    height: 2px;
    background-color: #1d2088;
    -webkit-transition: inherit;
    transition: inherit;
    z-index: 30;
  }
  .p-hamburger_line::before,
  .p-hamburger_line::after {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    background-color: #1d2088;
    content: '';
    -webkit-transition: inherit;
    transition: inherit;
  }
  .p-hamburger_line::before {
    top: -8px;
  }
  .p-hamburger_line::after {
    top: 8px;
  }
  .active .p-hamburger_line {
    background-color: transparent;
  }
  .active .p-hamburger_line::before,
  .active .p-hamburger_line::after {
    top: 0;
    background-color: #1d2088;
  }
  .active .p-hamburger_line::before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .active .p-hamburger_line::after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  .u-visuallyHidden {
    position: absolute;
    white-space: nowrap;
    width: 1px;
    height: 1px;
    overflow: hidden;
    border: 0;
    padding: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    margin: -1px;
  }
  #gNavi {
    width: 100%;
    background-color: #3538a9;
    color: #fff;
    position: fixed;
    left: 0;
    top: 60px;
    transition: 0.3s ease-out;
    opacity: 0;
    z-index: -10;
  }
  #gNavi.active {
    top: 60px;
    opacity: 1;
    z-index: 10;
  }
  #gNaviList,
  .navUnderList ul {
    padding-left: 0;
  }
  #gNaviList {
    height: calc(100vh - 60px);
    padding: 20px 5%;
    overflow-y: scroll;
    font-size: 0.88rem;
  }
  #gNaviList .sp-acc-trigger {
    display: block;
    font-weight: 500;
    font-size: 0.94rem;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
    position: relative;
    cursor: pointer;
  }
  #gNaviList .sp-acc-trigger::after {
    content: '';
    display: block;
    width: 0.75em;
    height: 0.75em;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(135deg);
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  #gNaviList .sp-acc-trigger.open::after {
    transform: rotate(-45deg);
  }
  #gNaviList > li {
    border-bottom: #7f81cc 1px solid;
    padding: 1em 0;
  }
  #gNaviList a {
    display: block;
    color: #fff;
  }
  .navUnder {
    padding-left: 1em;
    display: none;
  }
  .gNavIndexLink + .navUnderList {
    margin-top: 0.5em !important;
  }
  .navUnderList > ul > li {
    margin-bottom: 0.5em !important;
  }
  .navUnderList > ul > li:last-child {
    margin-bottom: 0 !important;
  }
  #gNavRecruitment a {
    position: relative;
  }
  #gNavRecruitment a::after {
    content: '';
    display: block;
    width: 0.75em;
    height: 0.75em;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  #gNavContact {
    border-bottom: none !important;
    text-align: center;
  }
  #gNavContact a {
    display: inline-block;
    width: 90%;
    background-color: #fff;
    border-radius: 2em;
    color: #1d2088;
    font-weight: 500;
    padding: 1em 0;
  }
  #gNavContact a span {
    padding-left: 1.5em;
    position: relative;
  }
  #gNavContact a span::before {
    content: '';
    background-color: #1d2088;
    display: block;
    width: 1.25em;
    height: 1.25em;
    -webkit-mask-image: url("/img/common/ic_mail.svg");
    mask-image: url("/img/common/ic_mail.svg");
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: right center;
    mask-position: right center;
    -webkit-mask-size: 100% auto;
    mask-size: 100% auto;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
}

/* タブレットのみ */
@media screen and (min-width: 767px) and (max-width: 1210px) {
  #gNaviList .pcOnly {
    display: none;
  }
}

/* PC */
@media print, screen and (min-width: 1211px) {
  #js-buttonHamburger,
  .sp-acc-trigger {
    display: none !important;
  }
  #contents {
    padding-top: 100px;
  }
  #header {
    width: 100%;
  }
  #headerWrap {
    width: 100%;
    height: 100px;
    background-color: #f9f9f9;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 10;
  }
  #headerIn {
    width: 90%;
    max-width: 1520px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  #gNaviList {
    display: flex;
    justify-content: flex-end;
  }
  #gNaviList > li {
    height: 100px;
    margin-right: 40px;
    display: flex;
    align-items: center;
  }
  #gNaviList > li:last-child {
    margin-right: 0;
  }
  #gNaviList > li > a {
    display: block;
    line-height: 1;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
  }
  .navUnder {
    width: 100%;
    position: fixed;
    left: 0;
    top: 100px;
    background-color: #3538a9;
    color: #fff;
  }
  .haveLower > a {
    padding-right: 1.5em;
    position: relative;
  }
  .haveLower > a::after {
    content: '';
    display: block;
    width: 0.5em;
    height: 0.5em;
    border-top: #1d2088 2px solid;
    border-right: #1d2088 2px solid;
    transform: rotate(135deg);
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  #gNavContact a {
    background-color: #1f2289;
    border: #fff 2px solid;
    color: #fff;
    padding-left: 1.25em;
    padding-right: 1.25em;
    border-radius: 2em;
  }
  .navUnder {
    visibility: hidden;
    opacity: 0;
    transform: translateY(-10%);
  }
  .navUnder a {
    color: #fff !important;
  }
  .navUnderInner {
    width: 90%;
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
    padding-top: 20px;
    padding-bottom: 20px;
    display: flex;
  }
  .navUnderInner .gNavIndexLink {
    width: 280px;
  }
  .navUnderInner .gNavIndexLink a {
    font-size: 1.25rem;
    padding-right: 1em;
    position: relative;
  }
  .navUnderInner .gNavIndexLink a::after {
    content: '';
    display: block;
    width: 0.5em;
    height: 0.5em;
    border-top: #fff 2px solid;
    border-right: #fff 2px solid;
    transform: rotate(45deg);
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .navUnderInner .navUnderList {
    width: calc(100% - 280px);
    padding-left: 30px;
    padding-top: 0.25em;
    padding-bottom: 0.25em;
    border-left: #6467e3 1px solid;
  }
  .navUnderInner .navUnderList ul {
    column-count: 3;
    padding-left: 0;
  }
  .navUnderInner .navUnderList ul > li {
    margin-bottom: 0.75em !important;
  }
}

@media (hover: hover) {
  .haveLower .navUnder {
    transition: 0.4s;
    transition-delay: 0.2s;
  }
  .haveLower > a::after {
    transition: 0.3s;
  }
  .haveLower:hover > .navUnder {
    visibility: visible;
    opacity: 1;
    transform: translateY(0);
  }
  .haveLower:hover > a::after {
    transform: rotate(-45deg);
  }
  #gNavContact a {
    transition: 0.3s;
  }
  #gNavContact a:hover {
    background-color: #fff;
    color: #1f2289;
    border: #1f2289 2px solid;
  }
}

/* !Footer
---------------------------------------------------------- */
.pageTop {
  border-radius: 50%;
  background-color: #6467e3;
  position: fixed;
  z-index: 5;
}

.pageTop a {
  display: block;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
}

.pageTop a::before {
  content: '';
  display: block;
  width: 2px;
  height: 18px;
  background-color: #fff;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.pageTop a::after {
  content: '';
  display: block;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(-45deg);
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}

#footer * {
  margin-top: 0;
}

#footer {
  background: #3538a9;
  background: linear-gradient(90deg, #3538a9 0%, #3538a9 12%, #1d2088 50%, #3538a9 88%, #3538a9 100%);
}

#footer a {
  text-decoration: none;
  color: #fff;
}

#footer #copyright {
  text-align: center;
  color: #fff;
}

.footerLinksDl {
  page-break-inside: avoid;
  break-inside: avoid;
}

.footerLinksDl > dt {
  font-weight: 500;
}

.footerLinksDl > dd {
  margin-left: 0;
  font-weight: 300;
}

.footerLinks1st {
  font-weight: 500;
}

/* SP */
@media screen and (max-width: 767px) {
  .pageTop {
    width: 40px;
    height: 40px;
    right: 15px;
    bottom: 15px;
  }
  .pageTop a {
    width: 40px;
    height: 40px;
  }
  .pageTop a::after {
    width: 10px;
    height: 10px;
    top: 10px;
  }
  .gNaviOpen .pageTop {
    z-index: -1;
  }
  #footer {
    padding: 25px 5%;
  }
  #footerLogo {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
  }
  #footerLinks {
    column-count: 2;
    font-size: 0.88rem;
    padding-bottom: 1.5em;
  }
  #footerLinks .footerLinks1st {
    font-size: 0.94rem;
    padding-bottom: 0.25em;
  }
  .footerLinksDl {
    margin-bottom: 1em;
  }
  .footerLinksDl > dt {
    margin-bottom: 0.5em;
  }
  .footerLinksDl > dd p {
    margin-bottom: 0.5em;
  }
  .footerLinksDl > dd p:last-child {
    margin-bottom: 0;
  }
  p.footerLinks1st {
    margin-bottom: 1em;
  }
  #copyright {
    font-size: 0.81rem;
    padding: 0 5%;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  .pageTop {
    width: 54px;
    height: 54px;
    right: 30px;
    bottom: 30px;
  }
  .pageTop a {
    width: 54px;
    height: 54px;
  }
  .pageTop a::after {
    width: 14px;
    height: 14px;
    top: 18px;
  }
  #footer {
    padding: 40px 0;
  }
  #footerIn {
    display: flex;
    width: 90%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 40px;
  }
  #footerLogo {
    width: 400px;
  }
  #footerLinks {
    width: calc(100% - 400px);
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 30px;
    border-left: #6467e3 1px solid;
    column-count: 3;
  }
  .footerLinksDl {
    margin-bottom: 1.5em;
  }
  .footerLinksDl > dt {
    margin-bottom: 0.5em;
  }
  p.footerLinks1st {
    margin-bottom: 1.5em;
  }
  #copyright {
    font-size: 0.88rem;
  }
}

@media (hover: hover) {
  .pageTop a {
    transition: 0.3s;
  }
  .pageTop a:hover {
    opacity: 0.7;
  }
}

/* !Contents
---------------------------------------------------------- */
#contents {
  background-color: #f9f9f9;
  background-image: url("/img/common/body_bg_l.svg"), url("/img/common/body_bg_r.svg");
  background-repeat: no-repeat, no-repeat;
  background-position: left top, right top;
}

/* カテゴリータイトル */
#categoryTtlWrap {
  width: 100%;
  background: #1d2088;
  background: linear-gradient(90deg, #1d2088 0%, #3538a9 90%, #3538a9 100%);
  color: #fff;
  font-weight: 700;
}

.categoryTtl {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  line-height: 1;
}

.ttlH02 {
  background-color: #22258e;
  color: #fff;
  font-weight: 700;
  text-align: center;
  padding: 0.5em;
  margin-bottom: 0.75em;
}

/* パンくず */
#breadcrumbWrap {
  background-color: #ececec;
  margin: 0;
}

#breadcrumbList {
  margin: 0 auto;
  list-style: none;
  padding-left: 0;
  letter-spacing: -0.4em;
}

#breadcrumbList > li {
  letter-spacing: normal;
  display: inline-block;
  vertical-align: bottom;
  line-height: 1.4;
  position: relative;
}

#breadcrumbList > li a {
  text-decoration: none;
  color: #1d2087;
}

#breadcrumbList > li::after {
  content: '\003E';
  display: inline-block;
  vertical-align: middle;
  position: absolute;
  top: 0;
  bottom: 0;
}

#breadcrumbList > li:last-child {
  font-weight: 700;
}

#breadcrumbList > li:last-child::after {
  content: none;
}

/* 製品情報 */
.pageTtl, .mainCatch, .grnBoxTtl {
  text-align: center;
  font-weight: 700;
  position: relative;
}

.pageTtl::after, .mainCatch::after, .grnBoxTtl::after {
  content: '';
  display: block;
  width: 60px;
  height: 4px;
  background-color: #1d2088;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.contentsInner {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
}

/* 詳しくはこちらbtn */
.forDetailsBtn {
  text-align: right;
  margin-top: 1em;
}

.forDetailsBtn a {
  font-weight: 700;
  color: #1d2088;
  text-decoration: none;
  line-height: 1;
  position: relative;
}

.forDetailsBtn a::before {
  content: '';
  background-color: #fff;
  border: #1d2088 2px solid;
  border-radius: 50%;
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.forDetailsBtn a::after {
  content: '';
  background-color: #1d2088;
  display: block;
  -webkit-mask-image: url("/img/common/ar_r.svg");
  mask-image: url("/img/common/ar_r.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: right center;
  mask-position: right center;
  -webkit-mask-size: 100% auto;
  mask-size: 100% auto;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
}

.productOverviewTxt + .forDetailsBtn {
  padding-top: 1em;
  border-top: #ddd 1px solid;
}

/* カラーバリエーション凡例 */
.usageGuideWrap {
  background-color: #fff;
  padding: 1.5em;
  border: #b5bbbf 1px solid;
  display: none;
}

.usageGuide > dt {
  font-weight: 700;
}

.usageGuide > dd {
  margin: 0;
}

.usageGuideList {
  list-style: none;
  padding-left: 0;
  margin: 0;
  letter-spacing: -0.4em;
}

.usageGuideList > li {
  letter-spacing: normal;
  display: inline-block;
  vertical-align: top;
  margin-right: 10px;
  margin-top: 2px;
  margin-bottom: 2px;
}

.usageGuideList > li:last-child {
  margin-right: 0;
}

/* H3 */
.productBlockTtl {
  font-weight: 700;
  margin-bottom: 1.25em;
}

/* list */
.bluDotList {
  margin: 0;
  padding-left: 0;
  list-style: none;
}

.bluDotList > li {
  padding-left: 1em;
  position: relative;
}

.bluDotList > li::before {
  content: '';
  display: block;
  width: 0.8em;
  height: 0.8em;
  border-radius: 50%;
  background-color: #6467e3;
  position: absolute;
  left: 0;
  top: 0.55em;
}

/* Table */
.productSpecTable {
  border-collapse: collapse;
}

.productSpecTable th {
  background-color: #1d2088;
  color: #fff;
  font-weight: 700;
  text-align: center;
  border: #b5bbbf 1px solid;
}

.productSpecTable td {
  background-color: #fff;
  border: #b5bbbf 1px solid;
  text-align: center;
}

.productSpecTable.split-2-8 th:nth-child(1),
.productSpecTable.split-2-8 td:nth-child(1) {
  width: 20%;
}

.productSpecTable.split-2-8 th:nth-child(2),
.productSpecTable.split-2-8 td:nth-child(2) {
  width: 80%;
}

.productSpecTable.split-3-7 th:nth-child(1),
.productSpecTable.split-3-7 td:nth-child(1) {
  width: 30%;
}

.productSpecTable.split-3-7 th:nth-child(2),
.productSpecTable.split-3-7 td:nth-child(2) {
  width: 70%;
}

/* お問い合わせbtn */
.contactBtnWrap {
  width: 90%;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.contactBtn a {
  display: block;
  text-decoration: none;
  line-height: 1;
  background-color: #fff;
  color: #1d2088;
  font-weight: 700;
  border-radius: 4em;
  border: #1d2088 3px solid;
  padding: 0.5em 4em;
  position: relative;
}

.contactBtn a::before {
  content: '';
  background-color: #1d2088;
  display: block;
  width: 1.5em;
  height: 1.5em;
  -webkit-mask-image: url("/img/common/ic_mail.svg");
  mask-image: url("/img/common/ic_mail.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: right center;
  mask-position: right center;
  -webkit-mask-size: 100% auto;
  mask-size: 100% auto;
  position: absolute;
  left: 1.5em;
  top: 0;
  bottom: 0;
  margin: auto;
}

/* SP */
@media screen and (max-width: 767px) {
  #contents {
    background-size: 32% auto;
  }
  #contents p, #contents ul, #contents ol, #contents dl {
    font-size: 0.88rem;
  }
  .categoryTtl {
    width: 100%;
    height: 80px;
    display: flex;
    align-items: center;
    padding: 0 5%;
    font-size: 1.56rem;
  }
  .ttlH02 {
    font-size: 1.75rem;
  }
  /* 横スクロールTable */
  .spScrollTableWrap {
    overflow-x: scroll;
    padding-bottom: 10px;
    margin-bottom: 10px;
  }
  .spScrollTableWrap table {
    border-collapse: collapse;
    white-space: nowrap;
  }
  /* パンくず */
  #breadcrumbWrap {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  #breadcrumbList {
    width: 90%;
    font-size: 0.88rem;
  }
  #breadcrumbList > li {
    padding-right: 1.5em;
  }
  #breadcrumbList > li::after {
    right: 0.25em;
  }
  /* 製品情報 */
  .pageTtl, .mainCatch, .grnBoxTtl {
    margin-top: 20px;
    margin-bottom: 20px;
    font-size: 1.5rem;
    padding-bottom: 20px;
  }
  .contentsInner {
    width: 90%;
    padding-bottom: 50px;
  }
  .productOverview {
    margin-bottom: 15px;
  }
  .productOverview .photo {
    margin-bottom: 1em;
  }
  .productOverview .productOverviewTxt {
    font-size: 0.88rem;
  }
  .col2Quarter1-3 .photo {
    margin-bottom: 1em;
  }
  .col2Quarter1-3 .photo img {
    display: block;
    margin-left: auto;
    margin-right: auto;
  }
  .col2Quarter1-3 .photo .cap {
    margin-top: 1em;
  }
  .forDetailsBtn a {
    display: inline-block;
    padding-right: 40px;
    height: 30px;
    line-height: 30px;
  }
  .forDetailsBtn a::before, .forDetailsBtn a::after {
    width: 30px;
    height: 30px;
  }
  /* カラーバリエーション凡例 */
  .usageGuideWrap {
    margin-bottom: 30px;
  }
  .usageGuide {
    font-size: 0.88rem;
  }
  .usageGuide > dt {
    margin-bottom: 0.5em;
  }
  .usageGuideList > li > img {
    height: 26px;
    width: auto;
  }
  .productBlock,
  .leadImgWrap {
    margin-bottom: 30px;
  }
  /* H3 */
  .productBlockTtl .ttl {
    display: block;
    padding: 0.25em 0 0.25em 0.5em;
    border-left: #1d2088 4px solid;
    font-size: 1.25rem;
    margin-bottom: 0.5em;
  }
  .productBlockTtl .sub {
    display: block;
    font-size: 0.94rem;
  }
  .bluDotList {
    font-size: 0.88rem;
  }
  /* Table */
  .productSpecTable {
    width: 100%;
  }
  .productSpecTable th, .productSpecTable td {
    padding: 0.25em 0.5em;
  }
  .productSpecTable th:nth-child(5),
  .productSpecTable td:nth-child(5) {
    width: 300px;
    white-space: nowrap;
  }
  .productSpecTable td {
    font-size: 0.88rem;
  }
  .productSpecTable.tableCell3 {
    width: 400px;
  }
  .productSpecTable.tableCell3 th, .productSpecTable.tableCell3 td {
    width: auto;
  }
  .spScrollTableWrap .productSpecTable {
    width: 800px;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  /* カテゴリータイトル */
  #categoryTtlWrap {
    position: relative;
    overflow: hidden;
  }
  .categoryTtl {
    max-width: 1200px;
    height: 120px;
    display: flex;
    align-items: center;
    font-size: 2.5rem;
    position: relative;
    z-index: 1;
  }
  .categoryTtl::after {
    display: block;
    font-size: 6.25rem;
    font-family: 'Roboto', sans-serif;
    font-weight: 900;
    color: #272a9a;
    position: absolute;
    right: 60px;
    bottom: -0.15em;
    z-index: -1;
  }
  .cat-product .categoryTtl::after {
    content: 'Products';
  }
  .cat-company .categoryTtl::after {
    content: 'About Us';
  }
  .cat-environmental .categoryTtl::after {
    content: 'Environment';
  }
  .cat-news .categoryTtl::after {
    content: 'News';
  }
  .cat-contact .categoryTtl::after {
    content: 'Contact';
  }
  .cat-recruitment .categoryTtl::after {
    content: 'Recruit';
  }
  .ttlH02 {
    font-size: 2rem;
  }
  /* パンくず */
  #breadcrumbWrap {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  #breadcrumbList {
    width: 90%;
    max-width: 1200px;
  }
  #breadcrumbList > li {
    padding-right: 3em;
  }
  #breadcrumbList > li::after {
    right: 1em;
  }
  /* 製品情報 */
  .pageTtl, .mainCatch, .grnBoxTtl {
    margin-top: 60px;
    margin-bottom: 60px;
    font-size: 2.25rem;
    padding-bottom: 40px;
  }
  .contentsInner {
    max-width: 1080px;
    padding-bottom: 100px;
  }
  .productOverview {
    display: flex;
    margin-bottom: 40px;
  }
  .productOverview .photo {
    width: 27.5%;
  }
  .productOverview .txtBlock {
    width: 72.5%;
    padding-left: 50px;
  }
  .col2Quarter1-3 {
    display: flex;
  }
  .col2Quarter1-3 .photo {
    width: 23%;
  }
  .col2Quarter1-3 .txtBlock {
    width: 77%;
    padding-left: 50px;
  }
  .photo p + .cap {
    margin-top: 1em;
  }
  .forDetailsBtn a {
    display: inline-block;
    padding-right: 50px;
    height: 40px;
    line-height: 40px;
  }
  .forDetailsBtn a::before, .forDetailsBtn a::after {
    width: 40px;
    height: 40px;
  }
  /* カラーバリエーション凡例 */
  .usageGuideWrap {
    margin-bottom: 60px;
  }
  .usageGuide {
    display: flex;
  }
  .usageGuide > dt {
    padding-right: 1em;
  }
  .productBlock,
  .leadImgWrap {
    margin-bottom: 60px;
  }
  /* H3 */
  .productBlockTtl {
    display: flex;
    align-items: center;
    font-size: 1.88rem;
    padding: 0.25em 0 0.25em 0.5em;
    border-left: #1d2088 4px solid;
    margin-bottom: 1.25em;
  }
  .productBlockTtl .sub {
    padding-left: 1em;
    font-size: 1.13rem;
  }
  /* Table */
  .productSpecTable {
    width: 100%;
  }
  .productSpecTable th, .productSpecTable td {
    width: 20%;
    padding: 0.5em 0.75em;
  }
  .productSpecTable th {
    font-size: 1.13rem;
  }
  .productSpecTable.tableCell8 th, .productSpecTable.tableCell8 td {
    width: 10.2%;
  }
  .productSpecTable.tableCell8 th:nth-child(1),
  .productSpecTable.tableCell8 td:nth-child(1),
  .productSpecTable.tableCell8 th:nth-child(4),
  .productSpecTable.tableCell8 td:nth-child(4) {
    width: 19.4%;
  }
  .productSpecTable.tableCell7 th, .productSpecTable.tableCell7 td {
    width: 10%;
  }
  .productSpecTable.tableCell7 th:nth-child(3),
  .productSpecTable.tableCell7 td:nth-child(3) {
    width: 25%;
  }
  .productSpecTable.tableCell7 th:nth-child(5),
  .productSpecTable.tableCell7 td:nth-child(5) {
    width: 22%;
  }
  .productSpecTable.tableCell7 th:nth-child(6),
  .productSpecTable.tableCell7 td:nth-child(6) {
    width: 13%;
  }
  .productSpecTable.tableCell6 th, .productSpecTable.tableCell6 td {
    width: 12%;
  }
  .productSpecTable.tableCell6 th:nth-child(3),
  .productSpecTable.tableCell6 td:nth-child(3),
  .productSpecTable.tableCell6 th:nth-child(5),
  .productSpecTable.tableCell6 td:nth-child(5) {
    width: 26%;
  }
  .productSpecTable.tableCell3 th, .productSpecTable.tableCell3 td {
    width: calc(100% / 3);
  }
  .productSpecTable.tableCell3.split-1-6-3 td:nth-child(1) {
    width: 10%;
  }
  .productSpecTable.tableCell3.split-1-6-3 td:nth-child(2) {
    width: 60%;
  }
  .productSpecTable.tableCell3.split-1-6-3 td:nth-child(3) {
    width: 30%;
  }
  /* お問い合わせbtn */
  .contactBtnWrap {
    margin-top: 60px;
    text-align: center;
  }
  .contactBtnWrap .contactBtn {
    display: inline-block;
    min-width: 440px;
  }
  .contactBtnWrap .contactBtn a {
    font-size: 1.75rem;
  }
}

@media (hover: hover) {
  .forDetailsBtn a,
  .contactBtn a,
  .contactBtn a::before,
  .forDetailsBtn a::before,
  .forDetailsBtn a::after {
    transition: 0.3s;
  }
  .forDetailsBtn a:hover {
    text-decoration: underline;
  }
  .forDetailsBtn a:hover::before {
    background-color: #1d2088;
  }
  .forDetailsBtn a:hover::after {
    background-color: #fff;
  }
  .contactBtn a:hover {
    background-color: #1d2088;
    color: #fff;
  }
  .contactBtn a:hover::before {
    background-color: #fff;
  }
}

/* 製品情報 ＞ その他取扱製品 */
.photo3col,
.photo4col {
  list-style: none;
  padding-left: 0;
}

.photo + .cap,
.photo + .indexCap {
  margin-top: 1em;
  text-align: center;
  font-weight: 700;
}

.photo + .cap .sub {
  display: block;
  font-weight: 500;
}

.cap.normal {
  text-align: left;
  font-weight: normal;
}

.forDetailsBtnPdf {
  margin-bottom: 1.5em;
  text-align: right;
}

.forDetailsBtnPdf a {
  display: inline-block;
  height: 2em;
  line-height: 2em;
  text-decoration: none;
  color: #1d2088;
  font-weight: 700;
  padding-right: 3em;
  position: relative;
}

.forDetailsBtnPdf a::after {
  content: '';
  background-color: #1d2088;
  display: block;
  width: 2em;
  height: 2em;
  -webkit-mask-image: url("/img/common/ic_pdf.svg");
  mask-image: url("/img/common/ic_pdf.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: right center;
  mask-position: right center;
  -webkit-mask-size: 100% auto;
  mask-size: 100% auto;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}

.productBlockTtl + .forDetailsBtnPdf,
.productBlockTtl + .col2half .txtBlock .forDetailsBtnPdf {
  margin-top: -1.5em;
}

.productBlockSTtl + .forDetailsBtnPdf {
  margin-top: -0.75em;
}

.productBlockSTtl {
  font-size: 700;
  margin-bottom: 1em;
}

.productBlock p + .productBlockSTtl,
.photo4col + .productBlockSTtl {
  margin-top: 2.5em;
}

.photo3col > li > a {
  text-decoration: none;
}

/* SP */
@media screen and (max-width: 767px) {
  .photo4col,
  .photo3col {
    display: flex;
    flex-wrap: wrap;
  }
  .photo4col > li,
  .photo3col > li {
    width: 48%;
    margin-right: 4%;
    margin-top: 2em;
  }
  .photo4col > li:nth-child(2n),
  .photo3col > li:nth-child(2n) {
    margin-right: 0;
  }
  .photo4col > li:nth-child(-n + 2),
  .photo3col > li:nth-child(-n + 2) {
    margin-top: 0;
  }
  .col2half .photo:first-child,
  .col2half .txtBlock:first-child {
    margin-bottom: 1em;
  }
  .productBlockSTtl {
    font-size: 1.25rem;
    margin-top: 1.5em;
  }
  .txtBlock p + .productBlockTtl {
    margin-top: 30px;
  }
  .indexCap {
    font-size: 1.13rem;
  }
  .productBlock .col2half.spOrderReverse {
    display: flex;
    flex-direction: column;
  }
  .productBlock .col2half.spOrderReverse .photo {
    order: 2;
  }
  .productBlock .col2half.spOrderReverse .txtBlock {
    order: 1;
    margin-bottom: 1em;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  .photo3col,
  .photo4col {
    display: flex;
    flex-wrap: wrap;
  }
  .photo3col > li {
    width: 31.4%;
    margin-right: 2.9%;
    margin-top: 30px;
  }
  .photo3col > li:nth-child(3n) {
    margin-right: 0;
  }
  .photo3col > li:nth-child(-n + 3) {
    margin-top: 0;
  }
  .photo4col > li {
    width: 23%;
    margin-right: 2.6%;
    margin-top: 30px;
  }
  .photo4col > li:nth-child(4n) {
    margin-right: 0;
  }
  .photo4col > li:nth-child(-n + 4) {
    margin-top: 0;
  }
  .col2half {
    display: flex;
    justify-content: space-between;
  }
  .col2half > .photo,
  .col2half > .txtBlock {
    width: 48%;
  }
  .productBlockSTtl {
    font-size: 1.5rem;
    margin-top: 30px;
  }
  .txtBlock p + .productBlockTtl {
    margin-top: 60px;
  }
  .indexCap {
    font-size: 1.25rem;
  }
  /* 印刷バンド */
  .usageGuideWrap.col2half .txtBlock:first-child .usageGuide {
    justify-content: flex-end;
  }
}

@media (hover: hover) {
  .forDetailsBtnPdf a,
  .photo3col > li > a {
    transition: 0.3s;
  }
  .forDetailsBtnPdf a:hover,
  .photo3col > li > a:hover {
    opacity: 0.7;
  }
}

/* 企業情報 */
.companyIndexTtl {
  margin-bottom: 1em;
}

.companyIndex .companyIndexTtlWrap {
  border-bottom: #ddd 1px solid;
  padding-bottom: 1em;
  margin-bottom: 1em;
}

/* SP */
@media screen and (max-width: 767px) {
  .companyIndexWrap {
    padding-top: 20px;
  }
  .companyIndex {
    margin-bottom: 30px;
  }
  .companyIndex .txtBlock {
    margin-bottom: 1em;
  }
  .companyIndex .photo {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  .companyIndexTtlWrap .companyIndexTtl {
    font-size: 1.3rem;
  }
  .companyIndexTtlWrap .txt {
    font-size: 0.88rem;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  .companyIndexWrap {
    max-width: 1080px;
    margin-top: 60px;
  }
  .companyIndex {
    width: 100%;
    display: flex;
    justify-content: space-between;
    margin-bottom: 80px;
  }
  .companyIndex:last-child {
    margin-bottom: 0;
  }
  .companyIndex:nth-child(even) .txtBlock {
    order: 2;
  }
  .companyIndex:nth-child(even) .photo {
    order: 1;
  }
  .companyIndex .txtBlock {
    width: 38.9%;
    padding-top: 60px;
  }
  .companyIndex .photo {
    width: 55.6%;
  }
  .companyIndex .companyIndexTtl {
    font-size: 2.25rem;
  }
}

/* 会社概要 */
.leadCatch {
  text-align: center;
  margin-bottom: 1.5em;
}

.contentsBlock:last-child {
  margin-bottom: 0;
}

ul.photo2col {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

/* Table */
.profileTable {
  width: 100%;
  border-collapse: collapse;
  border-top: #b5bbbf 1px solid;
}

.profileTable th {
  font-weight: 700;
  background-color: #f0f0f0;
  border-left: #b5bbbf 1px solid;
  border-bottom: #b5bbbf 1px solid;
  vertical-align: top;
}

.profileTable td {
  background-color: #fff;
  border-right: #b5bbbf 1px solid;
  border-bottom: #b5bbbf 1px solid;
  vertical-align: top;
}

.profileTable .noBorderBtm th, .profileTable .noBorderBtm td {
  border-bottom: none;
}

.officerList {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}

.officerList > dt {
  width: 9em;
  white-space: nowrap;
  margin: 0;
}

.officerList > dd {
  width: calc(100% - 9em);
  margin: 0;
}

.ymd {
  display: flex;
}

.ymd > span {
  display: block;
}

.ymd .year {
  width: 10em;
  white-space: nowrap;
}

.gMap a {
  display: inline-block;
  text-decoration: none;
  color: #1d2088;
  font-weight: 700;
  line-height: 1;
  padding: 0.5em 1.5em 0.5em 3.5em;
  border: #1d2088 2px solid;
  border-radius: 4em;
  position: relative;
}

.gMap a::before {
  content: '';
  display: block;
  width: 1.5em;
  height: 1.5em;
  background-color: #1d2088;
  -webkit-mask-image: url("/img/common/ic_gmap_pin.svg");
  mask-image: url("/img/common/ic_gmap_pin.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: right center;
  mask-position: right center;
  -webkit-mask-size: 100% auto;
  mask-size: 100% auto;
  position: absolute;
  left: 1.5em;
  top: 0;
  bottom: 0;
  margin: auto;
}

/* SP */
@media screen and (max-width: 767px) {
  .leadCatch,
  #contents .leadCatch p {
    font-size: 1.37rem;
  }
  .contentsInner.index {
    padding-top: 20px;
  }
  .contentsBlock {
    margin-bottom: 30px;
    margin-top: 20px;
  }
  .photo2col > li {
    margin-bottom: 1em;
  }
  .photo2col > li:last-child {
    margin-bottom: 0;
  }
  .profileTable th, .profileTable td {
    display: block;
    padding: 1em;
    font-size: 0.88rem;
  }
  .profileTable th {
    border-right: #b5bbbf 1px solid;
  }
  .profileTable td {
    border-left: #b5bbbf 1px solid;
  }
  .profileTable .noBorderBtm td {
    border-bottom: #b5bbbf 1px solid;
  }
  .gMap {
    margin-top: 0.5em;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  .leadCatch {
    font-size: 2rem;
  }
  .contentsInner.index {
    padding-top: 60px;
  }
  .contentsBlock {
    margin-bottom: 60px;
    margin-top: 60px;
  }
  .photo2col {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
  }
  .photo2col > li {
    width: 48%;
    margin-right: 4%;
    margin-top: 20px;
  }
  .photo2col > li:nth-child(2n) {
    margin-right: 0;
  }
  .photo2col > li:nth-child(-n + 2) {
    margin-top: 0;
  }
  .profileTable th, .profileTable td {
    padding: 1em 2em;
  }
  .profileTable th {
    width: 300px;
  }
  .profileTable .md {
    width: calc(100% - 10em);
    text-align: right;
  }
  .officeAddressWrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

@media (hover: hover) {
  .gMap a,
  .gMap a::before {
    transition: 0.3s;
  }
  .gMap a:hover {
    background-color: #1d2088;
    color: #fff;
  }
  .gMap a:hover::before {
    background-color: #fff;
  }
}

/* サンエイポリマーの強み */
.strengthsNumList > dd {
  margin-left: 0;
}

.strengthsNumList > dt {
  margin-bottom: 0.75em;
}

.strengthsNumList > dt .num {
  font-family: 'Roboto', sans-serif;
  font-weight: 700;
  color: #1d2088;
  display: block;
  line-height: 1;
  margin-bottom: 0.25em;
}

.strengthsNumList > dt .ttl {
  font-weight: 700;
  display: block;
}

/* SP */
@media screen and (max-width: 767px) {
  .strengthsNumList > dt .num {
    font-size: 3.5rem;
  }
  .strengthsNumList > dt .ttl {
    font-size: 1.6rem;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  .strengthsNumList > dt .num {
    font-size: 4rem;
  }
  .strengthsNumList > dt .ttl {
    font-size: 1.88rem;
  }
}

/* 環境への取り組み */
.grnBox {
  background-color: #e6f0e9;
}

.grnBox .grnBoxTtl:first-child {
  margin-top: 0;
}

.grnBoxTtl::after {
  background-color: #0f9b40;
}

/* SP */
@media screen and (max-width: 767px) {
  .leadImgWrap .txtBlock {
    margin-bottom: 1em;
  }
  .leadImgWrap .photo {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  .grnBox {
    padding: 1em;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  .leadImgWrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .leadImgWrap .txtBlock {
    width: 39.8%;
  }
  .leadImgWrap .photo {
    width: 55.6%;
  }
  .grnBox {
    padding: 60px;
  }
}

/* 環境負荷低減に貢献する製品開発 */
.movWrap {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.movWrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Step Num List */
ol.stepNumList {
  list-style: none;
  counter-reset: number;
  padding-left: 0;
  margin: 0;
}

ol.stepNumList > li .photo {
  margin-bottom: 0.75em;
}

ol.stepNumList > li .txt {
  padding-left: 3em;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  position: relative;
}

ol.stepNumList > li .txt::before {
  content: counter(number) "";
  counter-increment: number;
  display: block;
  width: 2em;
  height: 2em;
  line-height: 2em;
  font-weight: 700;
  font-size: 125%;
  text-align: center;
  border-radius: 100%;
  box-sizing: border-box;
  background: #1d2088;
  color: #fff;
  position: absolute;
  left: 0;
  top: 0;
}

.figArrow {
  background-color: #ececec;
  border-radius: 2em;
}

/* SP */
@media screen and (max-width: 767px) {
  ol.stepNumList > li {
    margin-bottom: 2em;
  }
  ol.stepNumList > li:last-child {
    margin-bottom: 0;
  }
  .figArrow {
    padding: 1em;
  }
}

/* PC */
@media print, screen and (min-width: 768px) {
  ol.stepNumList {
    display: flex;
    flex-wrap: wrap;
  }
  ol.stepNumList > li {
    width: 31.2%;
    margin-right: 3.2%;
    margin-top: 20px;
  }
  ol.stepNumList > li:nth-child(3n) {
    margin-right: 0;
  }
  ol.stepNumList > li:nth-child(-n + 3) {
    margin-top: 0;
  }
  .figArrow {
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

/* 採用情報 */
#contents .noteTxt {
  font-size: 88%;
}

.noteRed {
  color: #e50012;
}

/* お知らせ一覧・詳細 */
.cat-news li {
  list-style-type: none;
}

@media screen and (max-width: 767px) {
  .filter {
    margin-bottom: 8px;
  }
}

.filter-list {
  display: flex;
  border-bottom: 1px solid #1b2088;
  padding-left: 0;
  margin: 0;
}

@media screen and (max-width: 767px) {
  .filter-list {
    flex-wrap: wrap;
  }
}

.filter-list li {
  position: relative;
  border: 1px solid #1b2088;
  border-radius: 8px 8px 0 0;
  border-bottom: 0;
  color: #1d2088;
  font-weight: bold;
  text-align: center;
  cursor: pointer;
  z-index: 1;
  background-color: #fff;
}

@media screen and (min-width: 768px) {
  .filter-list li {
    padding: 10px;
    width: 200px;
  }
  .filter-list li:not(:first-child) {
    margin-left: 10px;
  }
}

@media screen and (max-width: 767px) {
  .filter-list li {
    width: 49%;
    padding: 5px;
  }
  .filter-list li:nth-child(2n+1) {
    margin-right: 2%;
  }
  .filter-list li.full {
    width: 100%;
    border-right: none;
  }
}

.filter-list li.is-active {
  color: #fff;
  background-color: #1d2089;
}

.filter-list li:hover {
  color: #fff;
  background-color: #1d2089;
}

.filter-content {
  margin-top: -1px;
}

.filter-item {
  display: none;
  opacity: 0;
  padding: 0;
}

@media screen and (max-width: 767px) {
  .filter-item {
    padding: 8px 0 20px;
  }
}

.filter-item.is-active {
  display: block;
  opacity: 1;
  animation-name: displayAnime;
  animation-duration: .5s;
  animation-fill-mode: forwards;
}

.filter-item-list {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding-left: 20px;
}

.filter-item li {
  padding: 20px 0;
}

@media screen and (max-width: 767px) {
  .filter-item li {
    width: 50%;
    padding: 10px 7px 0;
  }
}

.filter-item li a {
  text-decoration: none;
  font-weight: bold;
}

.filter-item li.current-cat a {
  border-bottom: 2px solid #1d2088;
  padding-bottom: 5px;
}

.filter-item.yearly li {
  width: 100px;
}

@media screen and (max-width: 767px) {
  .filter-item.yearly li {
    width: 25%;
  }
}

.filter-item.category li {
  width: 12%;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .filter-item.category li {
    width: 33%;
    padding-left: 0;
  }
}

.filter-item.category .filter-item-list {
  padding-left: 0;
}

.news-heading {
  background-color: #1d2087;
  padding: 20px 30px;
  color: #fff;
  font-size: 1.6rem;
}

@media screen and (max-width: 767px) {
  .news-heading {
    padding: 10px 20px;
    font-size: 1.4rem;
  }
}

.newsList {
  padding: 0;
}

.newsList li {
  width: 100%;
  padding: 2em 0 2em 2em;
  border-bottom: #dddddd 1px solid;
}

@media screen and (max-width: 767px) {
  .newsList li {
    padding: 2em 0;
  }
}

.newsList li .date {
  color: #1d2088;
  font-weight: 700;
  width: 7em;
  display: inline-block;
  white-space: nowrap;
  float: left;
}

.newsList li .category {
  width: 9em;
  color: #1d2088;
  background-color: #fff;
  font-weight: 700;
  float: left;
  white-space: nowrap;
  border: 2px solid #1d2088;
  border-radius: 20px;
  padding: 0 2px;
  text-align: center;
  margin-right: 1em;
}

.newsList li .ttl {
  margin-left: 8em;
}

@media screen and (max-width: 767px) {
  .newsList li .ttl {
    margin-left: 0;
    padding-top: 10px;
    clear: both;
  }
}

.newsList li .ttl a {
  display: block;
  text-decoration: none;
  color: #000;
  position: relative;
}

.newsList li .ttl a::after {
  content: '';
  display: block;
  width: 0.75em;
  height: 0.75em;
  border-top: #1d2088 2px solid;
  border-right: #1d2088 2px solid;
  transform: rotate(45deg);
  position: absolute;
  right: 1em;
  top: 0.5em;
}

.newsList li .ttl a:hover {
  text-decoration: underline;
}

@media screen and (max-width: 767px) {
  .newsList li .ttl a span {
    padding-right: 1em;
  }
}

.tablenav {
  clear: both;
  margin-top: 30px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .tablenav {
    font-size: 1.1rem;
  }
}

.tablenav a, .tablenav span {
  margin: 0 8px;
  display: inline-block;
  min-width: 40px;
  height: 40px;
  line-height: 35px;
  letter-spacing: normal;
  background: #eeeeee;
  vertical-align: top;
  text-align: center;
  text-decoration: none;
  border-radius: 50%;
  color: #21248d;
  padding: 0;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .tablenav a, .tablenav span {
    min-width: 30px;
    height: 30px;
    line-height: 25px;
    margin: 0 4px;
  }
}

.tablenav .prev, .tablenav .next {
  padding-left: 12px;
  padding-right: 12px;
  background-color: #fff;
}

@media screen and (max-width: 767px) {
  .tablenav .prev, .tablenav .next {
    padding-left: 5px;
    padding-right: 5px;
  }
}

.tablenav a {
  background-color: #fff;
  border: #21248d 2px solid;
}

.tablenav span {
  background-color: #21248d;
  border: #21248d 1px solid;
  color: #fff;
}

.tablenav span.dots {
  background-color: #fff;
  color: #21248d;
  border-color: #fff;
}

.postNews .postTitle {
  font-size: 2.2rem;
  border-bottom: 1px solid #dedede;
  padding-bottom: 20px;
}

@media print, screen and (max-width: 767px) {
  .postNews .postTitle {
    font-size: 1.8rem;
    text-wrap: auto;
  }
}

.postNews .postInfo {
  margin: 20px auto;
}

.postNews .postTime {
  color: #1b2088;
  font-weight: 700;
  float: left;
}

.postNews .postCategory {
  width: 9em;
  color: #1d2088;
  background-color: #fff;
  font-weight: 700;
  float: right;
  white-space: nowrap;
  border: 2px solid #1d2088;
  border-radius: 20px;
  padding: 0 2px;
  text-align: center;
  margin-right: 1em;
}

.postNews .postMain {
  clear: both;
  margin: 70px auto 50px;
}

.postNews .postMain h2.wp-block-heading {
  display: flex;
  align-items: center;
  font-size: 1.88rem;
  padding: 0.25em 0 0.25em 0.5em;
  border-left: #1d2088 4px solid;
  margin-bottom: 1.25em;
}

.postNews .postMain h3.wp-block-heading {
  font-size: 1.4rem;
  margin-bottom: 1.25em;
}

.postNews .postMain ul {
  margin: 1.25em 0 2em;
  padding-left: 0;
  list-style: none;
}

.postNews .postMain ul li {
  padding-left: 1em;
  position: relative;
}

.postNews .postMain ul li:before {
  content: '';
  display: block;
  width: 0.8em;
  height: 0.8em;
  border-radius: 50%;
  background-color: #6467e3;
  position: absolute;
  left: 0;
  top: 0.55em;
}

.postNews .postMain p {
  margin-bottom: 20px;
}

.postNews .postMain .wp-block-table {
  padding: 0;
  margin: 20px auto;
}

@media print, screen and (max-width: 767px) {
  .postNews .postMain .wp-block-table {
    overflow-x: scroll;
    padding-bottom: 10px;
    margin-bottom: 10px;
  }
}

.postNews .postMain .wp-block-table table {
  width: 100%;
  border-collapse: collapse;
}

@media print, screen and (max-width: 767px) {
  .postNews .postMain .wp-block-table table {
    width: 800px;
    border-collapse: collapse;
    white-space: nowrap;
  }
}

.postNews .postMain .wp-block-table table th {
  background-color: #1d2088;
  color: #fff;
  font-weight: 700;
  text-align: center;
  border: #b5bbbf 1px solid;
}

@media print, screen and (min-width: 768px) {
  .postNews .postMain .wp-block-table table th {
    width: 20%;
    padding: 0.5em 0.75em;
    font-size: 1.13rem;
  }
}

.postNews .postMain .wp-block-table table td {
  background-color: #fff;
  border: #b5bbbf 1px solid;
  text-align: center;
}

@media print, screen and (min-width: 768px) {
  .postNews .postMain .wp-block-table table td {
    width: 20%;
    padding: 0.5em 0.75em;
  }
}

.postNews .postMain .wp-block-image {
  margin: 40px auto;
  text-align: center;
}

.postNews .postMain .wp-block-image figure {
  margin: 0;
}

.postNews .postMain .wp-block-image img {
  border-radius: 12px;
  height: auto;
}

.postNews .postMain a {
  font-weight: 700;
  color: #1d2088;
  position: relative;
  text-decoration: none;
}

.postNews .postMain a:hover {
  text-decoration: underline;
}

.postNews .postMain a[href$=".pdf"]:after {
  content: '';
  background-color: #1d2088;
  display: block;
  width: 2em;
  height: 2em;
  -webkit-mask-image: url("/img/common/ic_pdf.svg");
  mask-image: url("/img/common/ic_pdf.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: right center;
  mask-position: right center;
  -webkit-mask-size: 100% auto;
  mask-size: 100% auto;
  position: absolute;
  right: -3em;
  top: 0;
  bottom: 0;
  margin: auto;
}

.tolistBtnWrap {
  width: 90%;
  text-align: center;
  margin: 30px auto;
}

@media print, screen and (min-width: 768px) {
  .tolistBtnWrap {
    margin-top: 60px;
    text-align: center;
  }
}

@media print, screen and (min-width: 768px) {
  .tolistBtn {
    display: inline-block;
    min-width: 300px;
  }
}

.tolistBtn a {
  display: block;
  text-decoration: none;
  line-height: 1;
  background-color: #fff;
  color: #1d2088;
  font-weight: 700;
  border-radius: 4em;
  border: #1d2088 3px solid;
  padding: 0.5em 4em;
  position: relative;
}

@media print, screen and (min-width: 768px) {
  .tolistBtn a {
    font-size: 1.75rem;
  }
}

.tolistBtn a::after {
  content: '';
  display: block;
  width: 0.5em;
  height: 0.5em;
  border-top: #1d2088 2px solid;
  border-right: #1d2088 2px solid;
  transform: rotate(45deg);
  position: absolute;
  right: 1em;
  top: 0.8em;
}

.tolistBtn a:hover {
  background-color: #1d2088;
  color: #fff;
}

.tolistBtn a:hover::before {
  background-color: #fff;
}

.tolistBtn a:hover::after {
  border-top: #fff 2px solid;
  border-right: #fff 2px solid;
}

.contactHead {
  margin: 0 auto 60px;
  text-align: center;
}

@media print, screen and (max-width: 767px) {
  .contactHead {
    margin: 0 auto 30px;
    text-align: left;
  }
}

.contactForm {
  background-color: #fff;
  border: 1px solid #dddddd;
  padding: 60px;
  border-radius: 16px;
}

@media print, screen and (max-width: 767px) {
  .contactForm {
    padding: 30px;
  }
}

.contactItem dt {
  font-weight: 700;
  margin-bottom: 10px;
}

.contactItem .contactMust {
  font-style: normal;
  color: #e60012;
}

.contactItem dd {
  line-height: 2.2;
  margin-left: 0;
  margin-bottom: 20px;
}

.contactItem dd input {
  background-color: #f9f9f9;
  border: 1px solid #ddd;
  border-radius: 8px;
  width: 100%;
  padding: 10px;
}

.contactItem dd textarea {
  background-color: #f9f9f9;
  border: 1px solid #ddd;
  border-radius: 8px;
  width: 100%;
  height: 160px;
  line-height: 1.4;
  padding: 10px;
}

.contactItem .mwform-tel-field {
  font-weight: bold;
}

.contactItem .mwform-tel-field input {
  font-weight: normal;
  width: 20% !important;
}

@media print, screen and (max-width: 767px) {
  .contactItem .mwform-tel-field input {
    width: 29% !important;
  }
}

.contactItem .mwform-tel-field input:not(:last-child) {
  margin-right: 1%;
}

.contactItem .mwform-tel-field input:not(:first-child) {
  margin-left: 1%;
}

.contactBtn {
  width: 90%;
  text-align: center;
  margin: 30px auto;
}

@media print, screen and (min-width: 768px) {
  .contactBtn {
    margin-top: 30px;
    text-align: center;
  }
}

@media print, screen and (max-width: 767px) {
  .contactBtn {
    width: 100%;
  }
}

.contactBtn input {
  display: block;
  text-decoration: none;
  line-height: 1;
  background-color: #1d2088;
  color: #fff;
  font-weight: 700;
  border-radius: 4em;
  border: #1d2088 3px solid;
  padding: 0.5em 4em;
  position: relative;
  cursor: pointer;
}

@media print, screen and (min-width: 768px) {
  .contactBtn input {
    display: inline-block;
    min-width: 300px;
    font-size: 1.75rem;
  }
}

@media print, screen and (max-width: 767px) {
  .contactBtn input {
    width: 100%;
    margin: 0 auto 20px;
  }
}

.contactBtn input.hover:hover {
  background-color: #fff;
  color: #1d2088;
}

.mw_wp_form .error {
  color: #e60012 !important;
}
