﻿
/* Scss Document */
@import url("css2-Robotowght900_swap.css");
@import url("css2-ShipporiMinchowght400600_swap.css");
html {
  font-size: 16px;
}

a {
  word-break: break-all;
}

img {
  image-rendering: -webkit-optimize-contrast;
}

.fadein {
  opacity: 0;
  transform: translate(0, 20px);
  transition: all .6s;
}

.fadein.show {
  opacity: 1;
  transform: translate(0, 0);
}

.brackets, .list_box_1 li {
  position: relative;
}

.brackets::before, .list_box_1 li::before,
.brackets::after,
.list_box_1 li::after {
  position: absolute;
  content: '';
  width: 3em;
  height: 3em;
}
@media only screen and (max-width: 540px) {
  .brackets::before, .list_box_1 li::before,
  .brackets::after,
  .list_box_1 li::after {
    width: 1.5em;
    height: 1.5em;
  }
}

.brackets::before, .list_box_1 li::before {
  top: 0;
  left: 0;
  border-top: 1px solid #555;
  border-left: 1px solid #555;
}

.brackets::after, .list_box_1 li::after {
  bottom: 0;
  right: 0;
  border-bottom: 1px solid #555;
  border-right: 1px solid #555;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
figure {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  line-height: 100%;
}

article,
header,
footer,
aside,
figure,
figcaption,
nav,
section {
  display: block;
}

body {
  line-height: 1;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  font-size: 1rem;
}

p,
li,
dd {
  font-size: 1rem;
}

ol,
ul {
  list-style: none;
  list-style-type: none;
}

ul.indent li {
  padding-left: 1em;
  text-indent: -1em;
}

.clearfix:after {
  content: " ";
  display: block;
  clear: both;
}

img {
  vertical-align: bottom;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

table {
  border-collapse: collapse;
}

small {
  font-size: 86%;
}

strong {
  font-weight: bold;
}

/* flort,clear
----------------------------------------------------*/
.fLeft {
  float: left;
}

.fRight {
  float: right;
}

.clear {
  clear: both;
}

/* img
---------------------------------------- */
.imgL {
  float: left;
  margin-right: 20px;
}

.imgLbtm {
  float: left;
  margin-right: 20px;
  margin-bottom: 20px;
}

.imgR {
  float: right;
  margin-left: 20px;
}

.imgRbtm {
  float: right;
  margin-left: 20px;
  margin-bottom: 20px;
}

.center {
  display: block;
  text-align: center;
  margin: 0 auto;
}

/* text
---------------------------------------- */
.tLeft {
  text-align: left;
}

.tRight {
  text-align: right;
}

.tCenter {
  text-align: center;
}

.bold {
  font-weight: 600;
}

a {
  text-decoration: none;
}

a:hover {
  transition: opacity 0.4s ease-in-out;
  transition: all 0.4s ease;
}

.dNone {
  display: none;
}

.positionR {
  position: relative;
}

/* flex
---------------------------------------- */
.flexW {
  display: flex;
  flex-wrap: wrap;
}

.flexSb {
  display: flex;
  justify-content: space-between;
}

.flexSbW {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.flexC {
  display: flex;
  justify-content: center;
}

.flexCW {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.flexCC {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flexCCW {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}

.flexSbC {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.flexE {
  display: flex;
  justify-content: flex-end;
}

.flex {
  display: flex;
}

.flexSAW {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
}

.flexRR {
  display: flex;
  flex-direction: row-reverse;
}

.flexRRW {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
}

.ai-center {
  align-items: center;
}

.ac-center {
  align-content: center;
}

.ai-st {
  align-items: stretch;
}

@media only screen and (min-width: 871px) {
  .flex-p {
    display: flex;
  }

  .flexW-p {
    display: flex;
    flex-wrap: wrap;
  }

  .flexSb-p {
    display: flex;
    justify-content: space-between;
  }

  .flexSbC-p {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .flexSbW-p {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  .flexC-p {
    display: flex;
    justify-content: center;
  }

  .flexCW-p {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }

  .flexCC-p {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .flexSA-p {
    display: flex;
    justify-content: space-around;
  }

  .flexSAW-p {
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
  }

  .flex-p {
    display: flex;
  }

  .flexRR-p {
    display: flex;
    flex-direction: row-reverse;
  }

  .flexRRW-p {
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: wrap;
  }

  #footer a[href^="tel:"] {
    pointer-events: none;
    text-decoration: none;
    color: #100313;
  }
}
/* space
---------------------------------------- */
.mt10 {
  margin-top: 10px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.m0 {
  margin: 0 !important;
}

.mt0 {
  margin-top: 0 !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.p20 {
  padding: 20px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt14em {
  padding-top: 14em !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.sp {
  display: none;
}

.tablet {
  display: none;
}

@media only screen and (max-width: 870px) {
  .tablet {
    display: block;
  }

  img.tablet {
    display: inline;
  }
}
.disp_ib {
  display: inline-block;
}

@media only screen and (max-width: 540px) {
  .disp_ib-s {
    display: inline-block;
  }

  .tablet,
  .pc {
    display: none !important;
  }

  .sp {
    display: block;
  }

  img.sp {
    display: inline;
  }
}
@font-face {
  font-family: 'Linearicons-Free';
  src: url("../font/Linearicons-Free.eot");
  src: url("../font/Linearicons-Free.eot") format("embedded-opentype"), url("../font/Linearicons-Free.woff2") format("woff2"), url("../font/Linearicons-Free.woff") format("woff"), url("../font/Linearicons-Free.ttf") format("truetype"), url("../font/Linearicons-Free.svg") format("svg");
  font-weight: normal;
  font-style: normal;
}
.lnr {
  font-family: 'Linearicons-Free';
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.lnr-home:before {
  content: "\e800";
}

.lnr-apartment:before {
  content: "\e801";
}

.lnr-pencil:before {
  content: "\e802";
}

.lnr-magic-wand:before {
  content: "\e803";
}

.lnr-drop:before {
  content: "\e804";
}

.lnr-lighter:before {
  content: "\e805";
}

.lnr-poop:before {
  content: "\e806";
}

.lnr-sun:before {
  content: "\e807";
}

.lnr-moon:before {
  content: "\e808";
}

.lnr-cloud:before {
  content: "\e809";
}

.lnr-cloud-upload:before {
  content: "\e80a";
}

.lnr-cloud-download:before {
  content: "\e80b";
}

.lnr-cloud-sync:before {
  content: "\e80c";
}

.lnr-cloud-check:before {
  content: "\e80d";
}

.lnr-database:before {
  content: "\e80e";
}

.lnr-lock:before {
  content: "\e80f";
}

.lnr-cog:before {
  content: "\e810";
}

.lnr-trash:before {
  content: "\e811";
}

.lnr-dice:before {
  content: "\e812";
}

.lnr-heart:before {
  content: "\e813";
}

.lnr-star:before {
  content: "\e814";
}

.lnr-star-half:before {
  content: "\e815";
}

.lnr-star-empty:before {
  content: "\e816";
}

.lnr-flag:before {
  content: "\e817";
}

.lnr-envelope:before {
  content: "\e818";
}

.lnr-paperclip:before {
  content: "\e819";
}

.lnr-inbox:before {
  content: "\e81a";
}

.lnr-eye:before {
  content: "\e81b";
}

.lnr-printer:before {
  content: "\e81c";
}

.lnr-file-empty:before {
  content: "\e81d";
}

.lnr-file-add:before {
  content: "\e81e";
}

.lnr-enter:before {
  content: "\e81f";
}

.lnr-exit:before {
  content: "\e820";
}

.lnr-graduation-hat:before {
  content: "\e821";
}

.lnr-license:before {
  content: "\e822";
}

.lnr-music-note:before {
  content: "\e823";
}

.lnr-film-play:before {
  content: "\e824";
}

.lnr-camera-video:before {
  content: "\e825";
}

.lnr-camera:before {
  content: "\e826";
}

.lnr-picture:before {
  content: "\e827";
}

.lnr-book:before {
  content: "\e828";
}

.lnr-bookmark:before {
  content: "\e829";
}

.lnr-user:before {
  content: "\e82a";
}

.lnr-users:before {
  content: "\e82b";
}

.lnr-shirt:before {
  content: "\e82c";
}

.lnr-store:before {
  content: "\e82d";
}

.lnr-cart:before {
  content: "\e82e";
}

.lnr-tag:before {
  content: "\e82f";
}

.lnr-phone-handset:before {
  content: "\e830";
}

.lnr-phone:before {
  content: "\e831";
}

.lnr-pushpin:before {
  content: "\e832";
}

.lnr-map-marker:before {
  content: "\e833";
}

.lnr-map:before {
  content: "\e834";
}

.lnr-location:before {
  content: "\e835";
}

.lnr-calendar-full:before {
  content: "\e836";
}

.lnr-keyboard:before {
  content: "\e837";
}

.lnr-spell-check:before {
  content: "\e838";
}

.lnr-screen:before {
  content: "\e839";
}

.lnr-smartphone:before {
  content: "\e83a";
}

.lnr-tablet:before {
  content: "\e83b";
}

.lnr-laptop:before {
  content: "\e83c";
}

.lnr-laptop-phone:before {
  content: "\e83d";
}

.lnr-power-switch:before {
  content: "\e83e";
}

.lnr-bubble:before {
  content: "\e83f";
}

.lnr-heart-pulse:before {
  content: "\e840";
}

.lnr-construction:before {
  content: "\e841";
}

.lnr-pie-chart:before {
  content: "\e842";
}

.lnr-chart-bars:before {
  content: "\e843";
}

.lnr-gift:before {
  content: "\e844";
}

.lnr-diamond:before {
  content: "\e845";
}

.lnr-linearicons:before {
  content: "\e846";
}

.lnr-dinner:before {
  content: "\e847";
}

.lnr-coffee-cup:before {
  content: "\e848";
}

.lnr-leaf:before {
  content: "\e849";
}

.lnr-paw:before {
  content: "\e84a";
}

.lnr-rocket:before {
  content: "\e84b";
}

.lnr-briefcase:before {
  content: "\e84c";
}

.lnr-bus:before {
  content: "\e84d";
}

.lnr-car:before {
  content: "\e84e";
}

.lnr-train:before {
  content: "\e84f";
}

.lnr-bicycle:before {
  content: "\e850";
}

.lnr-wheelchair:before {
  content: "\e851";
}

.lnr-select:before {
  content: "\e852";
}

.lnr-earth:before {
  content: "\e853";
}

.lnr-smile:before {
  content: "\e854";
}

.lnr-sad:before {
  content: "\e855";
}

.lnr-neutral:before {
  content: "\e856";
}

.lnr-mustache:before {
  content: "\e857";
}

.lnr-alarm:before {
  content: "\e858";
}

.lnr-bullhorn:before {
  content: "\e859";
}

.lnr-volume-high:before {
  content: "\e85a";
}

.lnr-volume-medium:before {
  content: "\e85b";
}

.lnr-volume-low:before {
  content: "\e85c";
}

.lnr-volume:before {
  content: "\e85d";
}

.lnr-mic:before {
  content: "\e85e";
}

.lnr-hourglass:before {
  content: "\e85f";
}

.lnr-undo:before {
  content: "\e860";
}

.lnr-redo:before {
  content: "\e861";
}

.lnr-sync:before {
  content: "\e862";
}

.lnr-history:before {
  content: "\e863";
}

.lnr-clock:before {
  content: "\e864";
}

.lnr-download:before {
  content: "\e865";
}

.lnr-upload:before {
  content: "\e866";
}

.lnr-enter-down:before {
  content: "\e867";
}

.lnr-exit-up:before {
  content: "\e868";
}

.lnr-bug:before {
  content: "\e869";
}

.lnr-code:before {
  content: "\e86a";
}

.lnr-link:before {
  content: "\e86b";
}

.lnr-unlink:before {
  content: "\e86c";
}

.lnr-thumbs-up:before {
  content: "\e86d";
}

.lnr-thumbs-down:before {
  content: "\e86e";
}

.lnr-magnifier:before {
  content: "\e86f";
}

.lnr-cross:before {
  content: "\e870";
}

.lnr-menu:before {
  content: "\e871";
}

.lnr-list:before {
  content: "\e872";
}

.lnr-chevron-up:before {
  content: "\e873";
}

.lnr-chevron-down:before {
  content: "\e874";
}

.lnr-chevron-left:before {
  content: "\e875";
}

.lnr-chevron-right:before {
  content: "\e876";
}

.lnr-arrow-up:before {
  content: "\e877";
}

.lnr-arrow-down:before {
  content: "\e878";
}

.lnr-arrow-left:before {
  content: "\e879";
}

.lnr-arrow-right:before {
  content: "\e87a";
}

.lnr-move:before {
  content: "\e87b";
}

.lnr-warning:before {
  content: "\e87c";
}

.lnr-question-circle:before {
  content: "\e87d";
}

.lnr-menu-circle:before {
  content: "\e87e";
}

.lnr-checkmark-circle:before {
  content: "\e87f";
}

.lnr-cross-circle:before {
  content: "\e880";
}

.lnr-plus-circle:before {
  content: "\e881";
}

.lnr-circle-minus:before {
  content: "\e882";
}

.lnr-arrow-up-circle:before {
  content: "\e883";
}

.lnr-arrow-down-circle:before {
  content: "\e884";
}

.lnr-arrow-left-circle:before {
  content: "\e885";
}

.lnr-arrow-right-circle:before {
  content: "\e886";
}

.lnr-chevron-up-circle:before {
  content: "\e887";
}

.lnr-chevron-down-circle:before {
  content: "\e888";
}

.lnr-chevron-left-circle:before {
  content: "\e889";
}

.lnr-chevron-right-circle:before {
  content: "\e88a";
}

.lnr-crop:before {
  content: "\e88b";
}

.lnr-frame-expand:before {
  content: "\e88c";
}

.lnr-frame-contract:before {
  content: "\e88d";
}

.lnr-layers:before {
  content: "\e88e";
}

.lnr-funnel:before {
  content: "\e88f";
}

.lnr-text-format:before {
  content: "\e890";
}

.lnr-text-format-remove:before {
  content: "\e891";
}

.lnr-text-size:before {
  content: "\e892";
}

.lnr-bold:before {
  content: "\e893";
}

.lnr-italic:before {
  content: "\e894";
}

.lnr-underline:before {
  content: "\e895";
}

.lnr-strikethrough:before {
  content: "\e896";
}

.lnr-highlight:before {
  content: "\e897";
}

.lnr-text-align-left:before {
  content: "\e898";
}

.lnr-text-align-center:before {
  content: "\e899";
}

.lnr-text-align-right:before {
  content: "\e89a";
}

.lnr-text-align-justify:before {
  content: "\e89b";
}

.lnr-line-spacing:before {
  content: "\e89c";
}

.lnr-indent-increase:before {
  content: "\e89d";
}

.lnr-indent-decrease:before {
  content: "\e89e";
}

.lnr-pilcrow:before {
  content: "\e89f";
}

.lnr-direction-ltr:before {
  content: "\e8a0";
}

.lnr-direction-rtl:before {
  content: "\e8a1";
}

.lnr-page-break:before {
  content: "\e8a2";
}

.lnr-sort-alpha-asc:before {
  content: "\e8a3";
}

.lnr-sort-amount-asc:before {
  content: "\e8a4";
}

.lnr-hand:before {
  content: "\e8a5";
}

.lnr-pointer-up:before {
  content: "\e8a6";
}

.lnr-pointer-right:before {
  content: "\e8a7";
}

.lnr-pointer-down:before {
  content: "\e8a8";
}

.lnr-pointer-left:before {
  content: "\e8a9";
}

.company_dlist {
  margin-right: 0;
  display: flex;
  flex-wrap: wrap;
  max-width: 80%;
}
.company_dlist dt,
.company_dlist dd {
  line-height: 1.6;
  margin-bottom: 1em;
}
.company_dlist dt {
  width: 24%;
  font-weight: bold;
  text-align: center;
  padding-right: 2em;
}
.company_dlist dd {
  width: 76%;
  border-left: 1px dotted;
  padding-left: 2em;
}
@media only screen and (max-width: 870px) {
  .company_dlist {
    width: 100%;
    margin-right: auto;
    max-width: 100%;
  }
  .company_dlist dt {
    padding-right: 0;
  }
}

.pageTtl {
  font-size: 2.5em;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  z-index: 1;
}
@media only screen and (max-width: 870px) {
  .pageTtl {
    width: 100%;
  }
}
.pageTtl span {
  font-size: 40%;
  font-family: "Times New Roman", Times, "serif";
  display: block;
  letter-spacing: 0.15em;
  margin-bottom: 1em;
}

.pageTtl_wrap {
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media only screen and (max-width: 870px) {
  .pageTtl_wrap {
    display: block;
  }
}
@media only screen and (min-width: 871px) {
  .pageTtl_wrap .pageTtl {
    width: 50%;
  }
}

.works_company {
  font-size: 0.8em;
  line-height: 1.4;
  padding: 1.5em 1em 0.6em;
}
@media only screen and (min-width: 871px) {
  .works_company {
    text-align: left;
  }
}
@media only screen and (max-width: 540px) {
  .works_company {
    font-size: 6vw;
  }
}

.pageTtl_img {
  overflow: hidden;
  filter: contrast(120%);
  z-index: 0;
  width: 100%;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
@media only screen and (min-width: 871px) {
  .pageTtl_img {
    height: 340px;
    width: 50%;
    margin-bottom: -50px;
  }
  .pageTtl_img img {
    min-height: 340px;
    object-fit: cover;
  }
}

.cont_wrap,
.container.cont_wrap {
  padding-top: 6em;
  padding-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  .cont_wrap,
  .container.cont_wrap {
    padding-top: 10%;
  }
}
@media only screen and (max-width: 870px) {
  .cont_wrap,
  .container.cont_wrap {
    padding-bottom: 10%;
  }
}
@media only screen and (min-width: 871px) {
  .cont_wrap h2.title_rl-p,
  .cont_wrap .title_rl-p,
  .container.cont_wrap h2.title_rl-p,
  .container.cont_wrap .title_rl-p {
    padding-right: 2em;
  }
}

@media only screen and (max-width: 540px) {
  .wp-block-spacer {
    height: auto;
  }
}
.company_about {
  padding: 4em 1em;
}
.company_about h3 a {
  font-size: 1.4em;
  font-weight: bold;
  border: 1px solid;
  padding: 0.8em 2em;
}
@media only screen and (max-width: 540px) {
  .company_about .btn_arwBox {
    width: 80%;
  }
}

.company_dl {
  margin: 1rem auto 4vw auto;
  background: #f5f5f5;
  padding: 1em 2em 0;
}
.company_dl dt,
.company_dl dd {
  margin-bottom: 0.6em;
  line-height: 1.4;
}
.company_dl dt {
  font-weight: 600;
  float: left;
  clear: both;
  padding-right: 0.5em;
}
.company_dl dd {
  display: inline-block;
}

#company_map {
  width: 100%;
  padding-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  #company_map {
    width: 100%;
    margin: 0 auto;
  }
}

.halfcont {
  margin: 6em auto 0;
  background: white;
}
.halfcont li {
  width: 50%;
  padding: 2em 3em 2em 8em;
  margin-bottom: 6em;
  position: relative;
}
@media only screen and (max-width: 870px) {
  .halfcont li {
    width: 100%;
  }
}
.halfcont li p {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-align: left;
  width: 100%;
  min-height: 6em;
}
.halfcont li h2 {
  position: absolute;
  top: -1.2em;
  left: 8%;
}
.halfcont li:first-child,
.halfcont li:last-child {
  background: #f5f5f5;
}
@media only screen and (max-width: 870px) {
  .halfcont li {
    background: #f5f5f5;
  }
}

.company .company_article h3 {
  font-size: 2em;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: 400;
  border-top: 1px dotted;
  border-bottom: 1px dotted;
  padding: 0.8em 0;
  margin-bottom: 1em;
}
.company .company_article h3 span {
  font-weight: 600;
}
.company .company_article h3.article_ttl_first {
  margin-top: 0;
}
.company .company_article h3.article_ttl_first + p {
  font-weight: bold;
  font-size: 1.1em;
}
.company .company_article h4 {
  font-size: 1.6em;
  margin: 1.5em auto 0.5em;
}

.company#history .bg-white {
  background-color: transparent;
}
.company#history .bg-white h3 {
  font-size: 1.1em;
  padding-left: 15px;
  border-left: 5px solid #ffe103;
}
.company#history .bg-white h4 {
  font-size: 1.6em;
  margin: 2em auto 0;
}
.company#history .bg-white p {
  padding: 3vw 0 1em;
}
.company#history .bg-white p + h3 {
  margin-top: 4vw;
}

.bg-white-gray {
  background: linear-gradient(-90deg, white 0%, white 50%, #f5f5f5 50%, #f5f5f5 100%);
}

.bg-gray-white {
  background: linear-gradient(-90deg, whitesmoke 0%, whitesmoke 50%, white 50%, white 100%);
}

#history .bg-gray-white,
#history .bg-white-gray {
  margin: 0 auto;
  position: relative;
  padding: 10vw 0;
}
@media only screen and (min-width: 871px) {
  #history .bg-gray-white .flexCC-p {
    flex-direction: row-reverse;
  }
  #history .bg-gray-white .bg-white {
    margin-left: -4.6vw;
    padding-right: 8vw;
    padding-left: 0;
  }
  #history .bg-gray-white .history_list_img {
    margin-left: -4.6vw;
  }
  #history .bg-white-gray .bg-white {
    margin-right: -4.6vw;
    padding-left: 8vw;
    padding-right: 0;
  }
  #history .bg-white-gray .history_list_img {
    margin-right: -4.6vw;
  }
}
@media only screen and (max-width: 870px) {
  #history .bg-white-gray {
    background: white;
  }
  #history .bg-gray-white {
    background: #f5f5f5;
  }
  #history h3 {
    margin-top: 2em;
  }
  #history h4 {
    margin: 1em auto;
  }
}

.history_box {
  top: 0;
  bottom: 0;
}
.history_box div {
  flex-basis: 60%;
}

.history_list_img {
  z-index: 1;
}

.page-id-103 #top_contact {
  padding-top: 4vw;
}
.page-id-103 #top_contact .containerW.bg-white {
  display: none;
}

.bg-kv {
  overflow: hidden;
  background-image: url("../image/office.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-color: rgba(0, 0, 0, 0.3);
  background-blend-mode: multiply;
  height: 50vh;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  flex-wrap: wrap;
  padding: 8% 50% 4em 0;
}
.bg-kv .pageTtl {
  color: white;
}
@media only screen and (max-width: 870px) {
  .bg-kv {
    background-attachment: scroll;
    height: 30vh;
    padding: 1em;
  }
  .bg-kv .pageTtl {
    font-size: 2em;
  }
}
@media only screen and (max-width: 540px) {
  .bg-kv {
    background-attachment: scroll;
  }
}

.works .bg-kv {
  background-image: url("../image/office10.jpg");
  background-position: top 60% left;
}

.recruit .bg-kv {
  background-image: url("../image/0189.jpg");
  background-position: center center;
}

.service .bg-kv {
  background-image: url("../image/service.jpg");
}

.features .bg-kv {
  background-image: url("../image/office6.jpg");
  background-position: top 60% center;
}

.news-single .bg-kv {
  background-image: url("../image/img1.jpg");
}

.contact .bg-kv,
.post-193 .bg-kv,
.post-189 .bg-kv {
  background-image: url("../image/2020-05-08-15.06.02.jpg");
}

.blog-all {
  margin: 3em auto;
}
.blog-all .pageTtl {
  font-size: 2.6em;
  margin: 0 auto 2em;
  text-align: center;
}

.blog-thum {
  width: 38%;
  margin: 0 auto 6vw 0;
  height: 20vw;
  overflow: hidden;
}
@media only screen and (min-width: 871px) {
  .blog-thum {
    max-height: 196px;
  }
}

.blogTtl_wrap {
  position: relative;
}

.blogTtl_ttl {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translateX(-50%) translateY(-50%);
  font-size: 2.3vw;
  text-align: center;
  color: white;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-height: 1.6;
}

.blogTtl_img {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  filter: grayscale(100);
}

.blog-kv {
  width: 50%;
}

.blog-category, .blog-date, .blog-tag {
  margin-bottom: 0.8em;
  display: inline-block;
}
.blog-category a, .blog-date a, .blog-tag a {
  text-decoration: underline;
}
.blog-category a:hover, .blog-date a:hover, .blog-tag a:hover {
  text-decoration: none;
}

.top_blog_date,
.blog_update {
  font-size: 0.8em;
  padding: 0 0.8em;
  height: 2em;
  line-height: 2em;
  display: inline-block;
}

@media only screen and (max-width: 540px) {
  .blog-category {
    margin-right: 1em;
    margin-bottom: 0;
  }

  .blog-tag {
    margin-bottom: 0;
  }
}
.blog-single .pageTtl, .blog-page .pageTtl {
  margin: 0 auto;
  padding: 1.5em 0 2.5em;
}
.blog-single .cont_wrap {
  padding-top: 0;
  padding-bottom: 0;
  margin-top: -4em;
}
.blog-single h2 {
  margin-bottom: 1em;
}
@media only screen and (max-width: 870px) {
  .blog-single h2 {
    font-size: 1.6em;
  }
}
.blog-single .blog-date {
  text-align: right;
  margin-top: 1em;
  /* font-family: $fontMin; */
}
.blog-single #toc_container {
  padding: 2em;
  margin: 3em auto;
}
.blog #toc_container a {
  color: #006883;
  text-decoration: underline;
}
.blog #toc_container a:hover {
  text-decoration: none;
}
@media only screen and (max-width: 870px) {
  .blog-page .pageTtl {
    padding: 1em 0;
  }
}
@media only screen and (max-width: 540px) {
  .blog-page h2 {
    height: 0;
    overflow: hidden;
    margin: -10px auto;
  }
  .blog-page .blog-thum,
  .blog-page .blog-right {
    width: 100%;
    margin: 0 auto 8vw;
  }
  .blog-page .blog-thum {
    height: 50vw;
    margin-bottom: 1vw;
  }
}

.blog_main h2,
.blog_main h3,
.single-works .blog-sentence h2,
.single-works .blog-sentence h3,
.news-single h2,
.news-single h3,
.recruit_under h2,
.recruit_under h3 {
  line-height: 1.6;
}
.blog_main h2,
.blog_main h1.blog_main_title,
.single-works .blog-sentence h2,
.single-works .blog-sentence h1.blog_main_title,
.news-single h2,
.news-single h1.blog_main_title,
.recruit_under h2,
.recruit_under h1.blog_main_title {
  color: #006883;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  margin: 10% auto 5%;
  font-weight: 400;
  border-top: 1px dotted;
  border-bottom: 1px dotted;
  padding: 0.8em 0;
}
.blog_main h2 span,
.blog_main h1.blog_main_title span,
.single-works .blog-sentence h2 span,
.single-works .blog-sentence h1.blog_main_title span,
.news-single h2 span,
.news-single h1.blog_main_title span,
.recruit_under h2 span,
.recruit_under h1.blog_main_title span {
  font-weight: 400;
}
@media only screen and (min-width: 871px) {
  .blog_main h2,
  .blog_main h1.blog_main_title,
  .single-works .blog-sentence h2,
  .single-works .blog-sentence h1.blog_main_title,
  .news-single h2,
  .news-single h1.blog_main_title,
  .recruit_under h2,
  .recruit_under h1.blog_main_title {
    font-size: 1.8em;
    text-align: center;
  }
}
.blog_main p,
.blog_main li,
.blog_main dd,
.single-works .blog-sentence p,
.single-works .blog-sentence li,
.single-works .blog-sentence dd,
.news-single p,
.news-single li,
.news-single dd,
.recruit_under p,
.recruit_under li,
.recruit_under dd {
  font-size: 17px;
}
@media only screen and (max-width: 540px) {
  .blog_main p,
  .blog_main li,
  .blog_main dd,
  .single-works .blog-sentence p,
  .single-works .blog-sentence li,
  .single-works .blog-sentence dd,
  .news-single p,
  .news-single li,
  .news-single dd,
  .recruit_under p,
  .recruit_under li,
  .recruit_under dd {
    font-size: 4vw;
  }
}
.blog_main p,
.single-works .blog-sentence p,
.news-single p,
.recruit_under p {
  margin-bottom: 1em;
  line-height: 1.5;
}

.blog_main .blog_main_title,
.single-works .blog-sentence .blog_main_title,
.news-single .blog_main_title {
  margin: 0 auto 3em;
  font-size: 1.6em;
  line-height: 1.6;
}
.blog_main h3,
.single-works .blog-sentence h3,
.news-single h3 {
  padding: 0.5em 1em;
  letter-spacing: 0.1em;
  font-size: 1.3em;
  margin-bottom: 2em;
  font-weight: 600;
  position: relative;
  color: #006883;
  background: rgba(0, 104, 131, 0.1);
}
.blog_main h3 span,
.single-works .blog-sentence h3 span,
.news-single h3 span {
  font-weight: 600;
}
.blog_main .wp-block-group,
.single-works .blog-sentence .wp-block-group,
.news-single .wp-block-group {
  margin-bottom: 3em;
}
.blog_main table,
.single-works .blog-sentence table,
.news-single table {
  margin: 2vw auto 6vw;
}
.blog_main table th,
.single-works .blog-sentence table th,
.news-single table th {
  background: #fffce7;
  text-align: center;
}
.blog_main table th,
.blog_main table td,
.single-works .blog-sentence table th,
.single-works .blog-sentence table td,
.news-single table th,
.news-single table td {
  border: 1px solid #ccc;
  vertical-align: middle;
  padding: 0.8em;
  line-height: 1.4;
}
.blog_main .table-3 th:first-child,
.single-works .blog-sentence .table-3 th:first-child,
.news-single .table-3 th:first-child {
  width: 9em;
}

.wp-block-table td,
.wp-block-table th {
  padding: .8em .5em;
}

.blog-single .wp-block-table table {
  table-layout: auto;
  width: 100%;
}
@media only screen and (max-width: 540px) {
  .blog-single .wp-block-table table {
    overflow-x: scroll;
  }
  .blog-single .wp-block-table table td {
    min-width: 6em;
  }
}

@media only screen and (max-width: 540px) {
  .single-works .blog-sentence table:not(.table-3),
  .news-single table:not(.table-3) {
    width: 100%;
    display: flex;
    justify-content: center;
    border-top: 1px solid #ccc;
    border-left: 1px solid #ccc;
  }
  .single-works .blog-sentence table:not(.table-3) thead,
  .single-works .blog-sentence table:not(.table-3) tbody,
  .single-works .blog-sentence table:not(.table-3) td,
  .single-works .blog-sentence table:not(.table-3) th,
  .news-single table:not(.table-3) thead,
  .news-single table:not(.table-3) tbody,
  .news-single table:not(.table-3) td,
  .news-single table:not(.table-3) th {
    float: none;
    width: auto;
  }
  .single-works .blog-sentence table:not(.table-3) td,
  .single-works .blog-sentence table:not(.table-3) th,
  .news-single table:not(.table-3) td,
  .news-single table:not(.table-3) th {
    border: none;
  }
  .single-works .blog-sentence table:not(.table-3) thead,
  .news-single table:not(.table-3) thead {
    width: auto;
    white-space: nowrap;
  }
  .single-works .blog-sentence table:not(.table-3) tbody,
  .news-single table:not(.table-3) tbody {
    width: 100%;
    display: flex;
    justify-content: space-between;
  }
  .single-works .blog-sentence table:not(.table-3) tr,
  .news-single table:not(.table-3) tr {
    width: 100%;
  }
  .single-works .blog-sentence table:not(.table-3) th,
  .single-works .blog-sentence table:not(.table-3) td,
  .news-single table:not(.table-3) th,
  .news-single table:not(.table-3) td {
    display: block;
    border-bottom: 1px solid #ccc;
    border-right: 1px solid #ccc;
  }
}

.blog-main-thum {
  width: 100%;
  overflow: hidden;
  padding-top: 60%;
  position: relative;
  margin-bottom: -2em;
}
@media only screen and (min-width: 871px) {
  .blog-main-thum {
    margin-bottom: -5em;
  }
}
.blog-main-thum img {
  width: 100%;
  position: absolute;
  top: 0;
  object-fit: cover;
}

.ttl_num {
  padding-right: 1em;
  border-right: 1px solid;
  margin-right: 1em;
}

.blog-date {
  text-align: left;
  margin-top: 0;
  display: inline-block;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.blog_content_first {
  display: inline-block;
  vertical-align: middle;
  max-width: 20em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.search-field {
  padding: 0.5em;
}

.search_results {
  margin: 2vw auto 4vw;
  display: flex;
}
.search_results .serach_thum {
  width: 24%;
  margin-right: 2em;
}
.search_results h3 {
  font-size: 1.2em;
}

h2.search_title {
  font-size: 1.4em;
}

.article p {
  margin-bottom: 6vw;
}
.article h2 {
  font-size: 1.6em;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  text-align: left;
  margin-bottom: 1em;
}
@media only screen and (max-width: 540px) {
  .article h2 {
    font-size: 5vw;
    line-height: 1.3;
    margin-bottom: 0.5em;
  }
}
.article h2 a {
  font-weight: normal;
}
.article h2 a:hover {
  opacity: 0.7;
}
.article h3 {
  font-size: 1.4em;
  margin-bottom: 3vw;
  margin-top: 6vw;
}
.article h3:first-child {
  margin-top: 0;
}
.article h4 {
  font-size: 1.2em;
  margin-bottom: 1em;
}
.article .flexSb-p {
  position: relative;
}
.article figure {
  filter: saturate(70%) contrast(90%) brightness(130%);
  z-index: 0;
}
.article .fLeft {
  width: 60%;
  margin-right: -10%;
  z-index: 1;
}
.article .fRight {
  width: 50%;
  z-index: 0;
}

.list_box_1 {
  margin: 6vw auto;
  font-size: 1.3em;
}
.list_box_1 li {
  width: 60%;
  margin: 0 auto 4vw;
  min-width: 460px;
  font-weight: bold;
  padding: 3em;
  text-align: center;
  line-height: 1;
}
@media only screen and (max-width: 540px) {
  .list_box_1 li {
    width: 90%;
    padding: 1em;
    margin-bottom: 8vw;
    min-width: 90%;
    font-size: 4vw;
  }
}

.blog-sentence {
  margin: 3em auto;
}
.blog-sentence a {
  color: #006883;
  text-decoration: underline;
}
.blog-sentence a:hover {
  text-decoration: none;
}

.blog-right {
  width: 60%;
  margin-bottom: 8vw;
}

.news-single .pageTtl {
  font-size: 2.6em;
  margin: 0 2em;
}
.news-single .article {
  margin: 1em auto 6em auto;
}
.news-single h1.blog_main_title {
  margin: 1em auto;
}
.news-single .cont_wrap {
  padding-top: 0;
}

.works-sentence {
  padding-left: 2em;
}
.works-sentence h2 {
  font-size: 1.6em;
  margin-bottom: 1em;
}

.noImage {
  background: #eee;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.news_list p {
  margin-bottom: 3em;
}
.news_list h2 {
  font-size: 2em;
}

.newsAll_list {
  margin-top: 2em;
}
.newsAll_list a {
  color: #006883;
  text-decoration: underline;
}
.newsAll_list a:hover {
  text-decoration: none;
}

.post-categories li {
  display: inline-block;
}
.post-categories li a {
  font-size: 12px;
  background: #100313;
  color: white;
  padding: 0.3em 0.6em;
  text-decoration: none;
}
.post-categories li a:hover {
  opacity: 0.7;
}

.blog-tag {
  font-size: 12px;
}
.blog-tag a {
  color: #006883;
  text-decoration: underline;
}
.blog-tag a:hover {
  text-decoration: none;
}

.tagcloud {
  margin-bottom: 1em;
}
.tagcloud a:not(:last-child):after {
  content: "/";
}

.features {
  padding-bottom: 8vw;
}
.features .feature_ttl {
  margin-top: 6em;
}
@media only screen and (max-width: 870px) {
  .features .feature_ttl {
    margin-top: 10%;
  }
}
.features .feature_ttl .titleMin span {
  background: #ffe103;
  text-align: center;
  font-size: 1.5em;
  border-radius: 1em;
  height: 1.6em;
  width: 1.6em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.2em;
  margin-right: 1em;
  margin-bottom: 0.5em;
}
@media only screen and (max-width: 540px) {
  .features .feature_ttl .titleMin span {
    font-size: 1.2em;
    margin-right: auto;
  }
  .features .feature_ttl .titleMin span:after {
    content: "\A";
    white-space: pre;
  }
}
.features .feature_ttl h3 {
  text-align: center;
  margin-bottom: 5%;
  font-size: 2.2em;
}
.features p {
  font-size: 18px;
}

.features_intro .btn_arwBox {
  margin: 3vw auto;
}

.features_problem {
  display: flex;
  align-items: center;
  background: #f5f5f5;
  padding: 2em 2em 1em;
  margin-bottom: 2em;
}
.features_problem h4 {
  font-size: 1.2em;
  margin-right: 3em;
  white-space: nowrap;
}
.features_problem li {
  font-size: 1.2em;
  min-width: 33%;
  margin-bottom: 1em;
  line-height: 1.6;
}
.features_problem li:before {
  content: "\e855";
  font-family: 'Linearicons-Free';
  padding-right: 0.3em;
}
@media only screen and (max-width: 540px) {
  .features_problem {
    display: block;
  }
  .features_problem h4 {
    margin: 0 auto 1em;
    text-align: center;
  }
}

.basic-page {
  padding-bottom: 4em;
}
@media only screen and (min-width: 871px) {
  .basic-page .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
    padding: 0 8% 0 0;
  }
}
.basic-page h2 strong {
  font-size: 1.4em;
  font-weight: bold;
}
.basic-page .blog_main h3 {
  margin-top: 3em;
}
.basic-page .wp-block-media-text {
  margin-bottom: 1em;
}
.basic-page .pageTtl {
  color: white;
}
@media only screen and (max-width: 540px) {
  .basic-page .wp-block-media-text__media {
    margin-bottom: 1em;
  }
}
@media only screen and (max-width: 540px) {
  .basic-page .wp-block-media-text .wp-block-media-text__content {
    padding: 0;
  }
}
.basic-page strong a {
  font-weight: bold;
}
.basic-page .wp-block-columns {
  margin: 1em auto 2em;
  align-items: stretch;
}
.basic-page .wp-block-columns p {
  line-height: 1.4;
  font-size: 1em;
}
.basic-page .wp-block-columns p a {
  text-decoration: underline;
  color: #006883;
}
.basic-page .wp-block-columns p a:hover {
  text-decoration: none;
}
.basic-page .wp-block-columns figure.wp-block-image {
  overflow: hidden;
}
.basic-page .wp-block-columns figure.wp-block-image img {
  min-width: 100%;
  max-width: 105%;
}
.basic-page .wp-block-columns h4 {
  font-size: 1.1em;
}
.basic-page .wp-block-columns h4 a {
  font-weight: bold;
  color: #006883;
}
.basic-page .wp-block-columns h4.has-text-align-center strong {
  font-size: 1.3em;
}

.ls-1 {
  letter-spacing: -2px;
}

h3 span.subtxt {
  font-size: 80%;
  font-weight: normal;
  display: inline-block;
  line-height: 1.5;
}
@media only screen and (min-width: 871px) {
  h3 span.subtxt {
    padding-left: 2.5em;
  }
}

.basic-page.basic_2 h2,
.basic-page.basic_2 h3 {
  text-align: center;
}
@media only screen and (max-width: 540px) {
  .basic-page.basic_2 h3 {
    margin: 1em auto 0.5em;
    letter-spacing: normal;
    font-feature-settings: "palt";
    font-size: 4.5vw;
  }
}

.basic-page.basic_3 h2,
.basic-page.basic_3 h3 {
  clear: both;
}
@media only screen and (max-width: 540px) {
  .basic-page.basic_3 h2,
  .basic-page.basic_3 h3 {
    font-feature-settings: "palt";
  }
}

.bgNone {
  background: none !important;
}

h3.bgNone {
  padding: 0;
  font-size: 1.6em;
  margin-bottom: 1em;
  color: #100313;
}

.bg_num {
  position: relative;
}
.bg_num:after {
  content: "";
  text-align: center;
  font-family: "Roboto", sans-serif;
  color: #f5f5f5;
  font-size: 30em;
  position: absolute;
  left: 10%;
  top: 0;
  line-height: 1;
  z-index: -1;
}
@media only screen and (max-width: 540px) {
  .bg_num:after {
    left: 50%;
    transform: translateX(-50%);
    top: 240px;
  }
}
.bg_num._1:after {
  content: "1";
}
.bg_num._2:after {
  content: "2";
}
.bg_num._3:after {
  content: "3";
}
@media only screen and (max-width: 540px) {
  .bg_num .imgR {
    width: 100%;
    float: none;
    display: block;
  }
}

.bg-eyecatch {
  position: relative;
  width: 100%;
  height: 290px;
  overflow: hidden;
  display: flex;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.3);
}
@media only screen and (max-width: 540px) {
  .bg-eyecatch {
    height: 200px;
  }
}

.bg-eyecatch-img {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: -1;
}
.bg-eyecatch-img img {
  min-width: 100%;
  max-width: 10000px;
  min-height: 290px;
}
@media only screen and (max-width: 870px) {
  .bg-eyecatch-img img {
    height: 100%;
    width: auto;
  }
}

@media only screen and (max-width: 540px) {
  .chara_img img {
    max-width: 200px;
    text-align: center;
    margin: auto;
    display: block;
  }
}
.seminar .pageTtl {
  color: white;
}

.bg-seminar {
  background: rgba(0, 0, 0, 0.4) url("../image/DSC_0142.jpg") no-repeat 50% 50%;
  background-size: cover;
  background-blend-mode: multiply;
}

.seminar_main h1 {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: 400;
  border-top: 1px dotted;
  border-bottom: 1px dotted;
  padding: 0.8em 0;
  margin: 2em auto 0;
  font-size: 1.6em;
  line-height: 1.6;
}
.seminar_main h1 span {
  font-weight: 400;
}
@media only screen and (min-width: 871px) {
  .seminar_main h1 {
    font-size: 1.8em;
    text-align: center;
  }
}
.seminar_main h2 {
  font-size: 1.6em;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  margin: 4em auto 1em;
  border-left: 4px solid #ccc;
  padding-left: 0.5em;
}
@media only screen and (max-width: 540px) {
  .seminar_main h2 {
    margin: 3em auto 1em;
  }
}
.seminar_main h3 {
  font-weight: bold;
  font-size: 1.4em;
  margin: 2em auto 1em;
  background: #f5f5f5;
  padding: 1em;
}
.seminar_main p,
.seminar_main li,
.seminar_main dd {
  font-size: 1.14em;
}
.seminar_main p strong,
.seminar_main li strong,
.seminar_main dd strong {
  font-weight: bold;
  background: linear-gradient(transparent 70%, #ffe103 70%);
}
.seminar_main #contactform1 {
  margin-top: 3em;
}
.seminar_main #contactform1 p {
  font-size: 1em;
}

.for-test {
  display: none;
}

body.page-id-1996 .for-test {
  display: block;
}

.post br {
  display: none !important;
}

.sidebar {
  margin-top: 6em;
  width: 100%;
  padding-bottom: 8vw;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media only screen and (max-width: 870px) {
  .sidebar {
    margin-top: 10%;
  }
}
.sidebar h3 {
  color: white;
  background: #100313;
  padding: 0.5em 1em;
  margin-bottom: 1em;
  font-size: 1rem;
}
.sidebar ul {
  margin-bottom: 1em;
}
.sidebar a {
  color: #006883;
  text-decoration: underline;
}
.sidebar a:hover {
  text-decoration: none;
}
.sidebar li {
  position: relative;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sidebar li br {
  display: none !important;
}
.sidebar li.cat-item-29 {
  display: none;
}
.sidebar li#custom-post-type-recent-posts-2 > ul li {
  white-space: nowrap;
}
.sidebar li#custom-post-type-tag-cloud-2 {
  white-space: normal;
}

.blog_sidebar .sidebar > li {
  width: 48%;
}
@media only screen and (max-width: 540px) {
  .blog_sidebar .sidebar > li {
    width: 100%;
  }
}

.seminar_sidebar .sidebar > li a {
  padding-left: 6em;
}
.seminar_sidebar .sidebar > li .post-date {
  position: absolute;
  left: 0;
  top: 0.5em;
}

@media only screen and (max-width: 540px) {
  li.widget_recent_entries {
    width: 100%;
  }
}
.blog_main {
  margin: 0 auto;
}

@media only screen and (min-width: 541px) {
  .widget.widget_search .search-field {
    width: calc(100% - 5em);
    max-width: 430px;
  }
}
.privacy-policy .post-964 ol li {
  list-style: decimal;
  text-indent: -1em;
  margin-left: 1em;
  list-style-position: inside;
}
.privacy-policy .post-964 h2 {
  font-size: 1.4em;
  margin-top: 2em;
  margin-bottom: 1em;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-weight: 600;
}
.privacy-policy .post-964 p a:hover {
  text-decoration: underline;
}
.privacy-policy .post-964 p {
  margin-bottom: 2em;
}

.navigation.pagination .page-numbers {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  border: 1px solid #100313;
  padding: 0.2em 0.6em;
}
.navigation.pagination .page-numbers:hover, .navigation.pagination .page-numbers.current {
  background: #100313;
  color: white;
}

.imgL {
  margin-right: 20px;
}

.imgR {
  margin-left: 20px;
}

.imgR,
.imgL {
  width: 48%;
  margin-bottom: 20px;
}
.imgR + p:after,
.imgL + p:after {
  content: " ";
  display: block;
  clear: both;
}
@media only screen and (max-width: 540px) {
  .imgR,
  .imgL {
    float: none;
    margin: 20px auto;
    width: 100%;
  }
}

figure,
.blog-sentence {
  clear: both;
}

.blocks-gallery-caption,
.wp-block-embed figcaption,
.wp-block-image figcaption {
  text-align: left;
}

.works_illust {
  margin: 4vw auto;
}
.works_illust figure + p,
.works_illust h3 {
  display: inline-block;
  width: calc(100% - 130px);
  vertical-align: middle;
}
@media only screen and (max-width: 540px) {
  .works_illust figure + p,
  .works_illust h3 {
    width: calc(100% - 16vw);
  }
}
.works_illust igure.wp-block-image.is-resized {
  width: 100px;
  display: inline-block;
  vertical-align: middle;
  margin-right: 16px;
}
@media only screen and (max-width: 540px) {
  .works_illust igure.wp-block-image.is-resized {
    width: 14vw;
  }
}
.works_illust h3 {
  font-size: 1.8em;
}
@media only screen and (max-width: 540px) {
  .works_illust h3 {
    font-size: 4.6vw;
  }
}
.works_illust figure.wp-block-image.is-resized {
  display: inline-block;
}

.single-works #toc_container {
  margin: 3em auto;
  padding: 1em;
}

#toc_container .toc_list li {
  line-height: 1.5;
  margin-bottom: 0.8em;
}
#toc_container .toc_list li a + ul {
  margin-top: 0.8em;
}

.single-works p,
.single-works h2,
.single-works h3,
.single-works div,
.single-works figure {
  clear: both;
}

.works_top_info_ttl {
  padding: 0.5em 1em;
  letter-spacing: 0.1em;
  font-size: 1.3em;
  margin-bottom: 1em;
  font-weight: 600;
  position: relative;
  background: #f5f5f5;
}

p.wi {
  padding-top: 2em;
  padding-bottom: 2em;
}

p.wi + figure.wp-block-image {
  margin-bottom: 4em;
}

p.wi:before {
  display: block;
  width: 120px;
  margin-top: -1em;
  float: left;
}

p.wi_1:before {
  content: url("/wp-content/themes/primenumbers/images/works/ill_1.png");
}

p.wi_2:before {
  content: url("/wp-content/themes/primenumbers/images/works/ill_2.png");
}

p.wi_3:before {
  content: url("/wp-content/themes/primenumbers/images/works/ill_3.png");
}

p.wi_4:before {
  content: url("/wp-content/themes/primenumbers/images/works/ill_4.png");
}

.works_bottom_info {
  margin: 4vw auto;
  padding: 1em;
  border: 1px solid;
}

.blocks-gallery-caption,
.wp-block-embed figcaption,
.wp-block-image figcaption {
  line-height: 1.3;
}

.article .yarpp-related h3,
.news-single .yarpp-related h3 {
  margin: 0;
  padding: 10px 0;
}

.contact .w3eden a.btn {
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-size: 16px;
  background: black;
  border: none;
}
.contact .wpdm-download-link.btn.btn-primary {
  border-radius: 0;
}
.contact .link-template-default .package-title {
  line-height: 1.6;
}
.contact .w3eden .text-muted {
  color: black !important;
}
.contact .w3eden .card h3 {
  margin-bottom: 0.5em;
  font-size: 20px;
}
.contact .w3eden .card h3 a {
  color: black;
}
@media only screen and (max-width: 540px) {
  .contact .w3eden .card,
  .contact .w3eden .media {
    display: block;
    width: 100%;
  }
  .contact .w3eden .card img {
    float: left;
  }
  .contact .w3eden .media-body {
    margin-bottom: 1em;
    width: 100%;
  }
  .contact .w3eden a.btn {
    width: 100%;
  }
  .contact .w3eden .card h3 {
    margin-left: 1em;
  }
  .contact .w3eden .text-muted {
    margin-bottom: 1em;
    font-size: 1em;
    text-align: right;
  }
}

.author-wrap.wp-block-media-text {
  display: flex;
  align-items: flex-end;
  margin: 3em auto;
}
@media only screen and (max-width: 540px) {
  .author-wrap.wp-block-media-text {
    display: block;
  }
}
.author-wrap.wp-block-media-text .wp-block-media-text__media {
  width: 14em;
  height: 14em;
  border-radius: 100%;
  overflow: hidden;
}
@media only screen and (max-width: 540px) {
  .author-wrap.wp-block-media-text .wp-block-media-text__media {
    margin: 0 auto;
    text-align: center;
  }
}
@media only screen and (min-width: 871px) {
  .author-wrap.wp-block-media-text .wp-block-media-text__media {
    margin-left: 1em;
  }
}
.author-wrap.wp-block-media-text .wp-block-media-text__media img {
  width: 100%;
}
.author-wrap.wp-block-media-text .wp-block-media-text__content {
  padding: 6% 0 0 0;
}
@media only screen and (min-width: 871px) {
  .author-wrap.wp-block-media-text .wp-block-media-text__content {
    flex: 1;
    padding: 0 4%;
  }
}
.author-wrap.wp-block-media-text.has-media-on-the-right .wp-block-media-text__content {
  padding: 6% 0 0 0;
}

@media only screen and (max-width: 870px) {
  .commentball {
    position: relative;
    background: #FFFFFF;
    padding: 10px;
    border: 2px solid #006883;
    border-radius: 1em;
  }
  .commentball:after, .commentball:before {
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    bottom: 100%;
    left: 50%;
  }
  .commentball:after {
    border-color: rgba(255, 255, 255, 0);
    border-top-width: 10px;
    border-bottom-width: 10px;
    border-left-width: 10px;
    border-right-width: 10px;
    margin-left: -10px;
    border-bottom-color: #FFFFFF;
  }
  .commentball:before {
    border-color: rgba(161, 255, 97, 0);
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-left-width: 12px;
    border-right-width: 12px;
    margin-left: -12px;
    margin-bottom: 2px;
    border-bottom-color: #006883;
  }
}
@media only screen and (min-width: 871px) {
  .commentball {
    position: relative;
    background: #FFFFFF;
    padding: 1em;
    text-align: left;
    border: 3px solid #006883;
    border-radius: 1em;
  }
  .commentball:after, .commentball:before {
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    right: 100%;
    top: 70%;
  }
  .commentball:after {
    border-color: rgba(255, 255, 255, 0);
    border-top-width: 10px;
    border-bottom-width: 10px;
    border-left-width: 21px;
    border-right-width: 21px;
    margin-top: -10px;
    border-right-color: #FFFFFF;
  }
  .commentball:before {
    border-top-width: 12px;
    border-bottom-width: 12px;
    border-left-width: 23px;
    border-right-width: 23px;
    margin-top: -12px;
    margin-right: 2px;
    border-right-color: #006883;
  }
}
@media only screen and (min-width: 871px) {
  .wp-block-media-text__content .commentball {
    margin-right: -2em;
  }
}
.wp-block-media-text.has-media-on-the-right {
  flex-direction: row-reverse;
}
@media only screen and (min-width: 871px) {
  .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content .commentball {
    margin-right: auto;
  }
  .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content .commentball:after, .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content .commentball:before {
    transform: rotate(180deg);
    right: -47px;
  }
  .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content .commentball:after {
    margin-right: 7px;
  }
  .wp-block-media-text.has-media-on-the-right .wp-block-media-text__content .commentball:before {
    margin-right: 0;
  }
}

.wp-block-quote.quote {
  font-style: normal;
  background-color: #f5f5f5;
  border-left: none;
  position: relative;
  padding: 2em;
}
.wp-block-quote.quote cite {
  text-align: right;
  display: block;
  padding-right: 1em;
  z-index: 1;
  position: relative;
}
.wp-block-quote.quote p {
  z-index: 1;
  position: relative;
}
.wp-block-quote.quote:before, .wp-block-quote.quote:after {
  color: #DCDCDC;
  position: absolute;
  z-index: 0;
}
.wp-block-quote.quote:before {
  content: url("/wp-content/themes/tn-child/images/quote_1.png");
  top: -1em;
  left: 0;
}
.wp-block-quote.quote:after {
  bottom: -1em;
  right: 0;
  text-align: right;
  display: block;
  content: url("/wp-content/themes/tn-child/images/quote_2.png");
}

.b_messe {
  text-align: center;
  font-size: 2em;
  font-weight: bold;
  margin: 2em auto;
}
@media only screen and (max-width: 540px) {
  .b_messe {
    font-size: 5vw;
  }
}
.b_messe span {
  opacity: 0.4;
  font-weight: bold;
}

.bgNone {
  background: none !important;
}

h3.bgNone {
  padding: 0;
  font-size: 1.6em;
  margin-bottom: 1em;
  color: #100313;
}

/*wp-pagenavi base*/
.wp-pagenavi {
  clear: both;
  text-align: center;
}

.wp-pagenavi a,
.wp-pagenavi span {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  border: 1px solid #100313;
  padding: 0.2em 0.6em;
  text-align: center;
  text-decoration: none;
  margin: 0 2px;
}

.wp-pagenavi a:hover {
  background: #100313;
  color: white;
}

.wp-pagenavi span.current {
  background: #100313;
  color: white;
}

.recruitFaq dt {
  display: flex;
  align-content: center;
  line-height: 1.4;
  counter-increment: item;
  font-size: 126%;
  margin-bottom: 0.5em;
  font-weight: 600;
  padding: 1em 0 4vw 4em;
  position: relative;
}
.recruitFaq dt::before {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: 400;
  content: "Q" counter(item);
  background-color: #ffe103;
  border-radius: 1.5em;
  height: 3em;
  width: 3em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: absolute;
  margin-right: 1em;
  left: 0;
  top: 0;
}
.recruitFaq dt:empty {
  display: none;
}
.recruitFaq dt.countReset_1 {
  counter-increment: item 3;
}
.recruitFaq dt.countReset_2 {
  counter-increment: item 6;
}
.recruitFaq dt.countReset_3 {
  counter-increment: item 8;
}
.recruitFaq dd {
  background: #f5f5f5;
  padding: 2em;
  margin: 0 auto 4vw;
  text-align: justify;
}
.recruitFaq dd:empty {
  display: none;
}
.recruitFaq h2 {
  margin: 1em auto;
}
@media only screen and (max-width: 540px) {
  .recruitFaq .staff_main_L,
  .recruitFaq .staff_main ._img {
    width: 100%;
  }
}

.bg-kv_img {
  position: absolute;
  object-fit: cover;
  left: 50%;
  transform: translateX(-50%);
  min-width: 980px;
  width: 100%;
  filter: contrast(90%) brightness(70%);
}

.recruit_staff .bg-kv {
  background-image: none;
  background-color: #100313;
}

.staff_main {
  padding-top: 1em;
  padding-bottom: 1em;
}
.staff_main.bg-bk {
  color: white;
}
.staff_main h2 {
  margin-bottom: 1em;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-size: 1.6em;
  font-weight: 600;
}
@media only screen and (max-width: 540px) {
  .staff_main h2 {
    font-size: 1.4em;
  }
}
.staff_main ._img {
  overflow: hidden;
  width: 45%;
  height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.staff_main ._nameField {
  line-height: 1.4;
  display: inline-block;
}

.staff_main_L {
  width: 50%;
}

#staff_face {
  position: relative;
}
#staff_face ._img {
  width: 180px;
  height: 220px;
  position: absolute;
  right: 1em;
  bottom: 0;
}
@media only screen and (max-width: 540px) {
  #staff_face ._img {
    position: static;
  }
}
#staff_face ._img img {
  height: 240px;
  max-width: 200%;
}
#staff_face .staff_main_L {
  width: calc(100% - 200px);
}

.container.recruit_otherstaff {
  padding-top: 6vw;
}

.recruit_image {
  margin: 0 auto 4vw;
}

.timeschedule {
  margin: 2vw auto;
}
.timeschedule li {
  display: flex;
  align-items: center;
  line-height: 1.4;
  position: relative;
  font-weight: 600;
  margin-bottom: 2em;
  font-size: 1.12em;
}
.timeschedule li > span:not(.lnr) {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  text-align: right;
  width: 2.4em;
}
.timeschedule li:not(.timeschedule_end):after {
  border-left: 5px dotted #ccc;
  position: absolute;
  bottom: -1.8em;
  content: "";
  height: 1.8em;
  left: 1em;
}
.timeschedule span.lnr {
  margin: 0 0.8em;
  background: #ffe103;
  width: 1.8em;
  height: 1.8em;
  border-radius: 1em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.recruit_workList {
  border: 1px solid #ccc;
  padding: 1.2em 2em 1px;
  margin: 0 auto 1vw auto;
  text-indent: -1.5em;
}
.recruit_workList li {
  line-height: 1.6;
  padding-left: 1em;
  margin-bottom: 1em;
}
.recruit_workList li:before {
  content: "・";
  padding-right: 0.5em;
}

.recruit_list {
  border: 1px solid #ccc;
  padding: 1.2em 2em 1px;
  margin: 0 auto 1vw auto;
}

.recruit_work.container {
  padding-top: 6vw;
  padding-bottom: 6vw;
}

.recruit_work p {
  font-size: 18px;
}
@media only screen and (max-width: 540px) {
  .recruit_work p {
    font-size: 1em;
  }
}
.recruit_work p strong {
  font-weight: 600;
}
.recruit_work h3 {
  margin: 1em auto 8vw;
  position: relative;
  font-size: 1.6em;
  text-align: center;
}
.recruit_work h3:after {
  content: "";
  display: block;
  position: absolute;
  border-bottom: 2px solid #100313;
  width: 2em;
  left: 50%;
  transform: translateX(-50%);
  bottom: -1em;
}
.recruit_work p + p {
  margin-top: 2em;
}
.recruit_work h4 {
  font-size: 1.2em;
}

@media only screen and (min-width: 871px) {
  .recruit_job p, .recruit_job li, .recruit_job .toc_list li {
    font-size: 1.2rem;
  }
}
.recruit_job .toc_number {
  display: none;
}
.recruit_job p strong {
  font-weight: 600;
}
.recruit_job h3 {
  padding-top: 1em;
  margin: 0.5em auto 3em;
  position: relative;
  font-size: 2.3em;
  text-align: center;
}
.recruit_job h3:after {
  content: "";
  display: block;
  position: absolute;
  border-bottom: 2px solid #100313;
  width: 2em;
  left: 50%;
  transform: translateX(-50%);
  bottom: -0.5em;
}
.recruit_job h3 .number {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  margin-right: 0.5em;
  padding: 0.2em 0.5em;
  font-size: 90%;
}
.recruit_job p + p {
  margin-top: 2em;
}
.recruit_job div > h4 {
  font-size: 1.6em;
  margin: 1em auto;
  border-left: 5px solid #ffe103;
  padding-left: 0.6em;
}
.recruit_job .container {
  padding-bottom: 3em;
}
.recruit_job div.bg-gray {
  padding: 2em 0;
}
.recruit_job p.bg-gray {
  padding: 1em;
}
.recruit_job h5 {
  font-size: 1.4em;
  font-weight: bold;
  border-bottom: 1px dotted;
  margin-top: 2.4em;
  padding-bottom: 0.5em;
}
.recruit_job .wp-block-image .alignright {
  margin: 0 0 2em 2em;
}
.recruit_job .wp-block-image .alignleft {
  margin: 0 2em 2em 0;
}
@media only screen and (max-width: 540px) {
  .recruit_job h3 {
    font-size: 2em;
  }
  .recruit_job div > h4 {
    font-size: 1.5em;
  }
  .recruit_job .wp-block-image .alignright, .recruit_job .wp-block-image .alignleft {
    float: none;
    margin: 0 auto 2em;
  }
}
.recruit_job #toc_container {
  margin: 3em auto 0;
  padding: 1em;
}

.ttl_dot {
  font-family: "游明朝",YuMincho,"Hiragino Mincho ProN W3","ヒラギノ明朝 ProN W3","ＭＳ Ｐ明朝","ＭＳ 明朝",serif;
  margin: 7% auto 5%;
  font-weight: 400;
  border-top: 1px dotted;
  border-bottom: 1px dotted;
  padding: .8em 0;
  text-align: center;
}

.recruit_under p {
  font-size: 1.2em;
}
.recruit_under h2 {
  margin: 5em auto 2em;
}
.recruit_under h3 {
  margin: 3em auto 2em;
  font-size: 1.8em;
  position: relative;
  font-size: 1.6em;
  text-align: center;
}
.recruit_under h3:after {
  content: "";
  display: block;
  position: absolute;
  border-bottom: 2px solid #100313;
  width: 2em;
  left: 50%;
  transform: translateX(-50%);
  bottom: -0.7em;
}
.recruit_under h4 {
  font-size: 1.2em;
}

.recruit_work_ttl {
  position: relative;
  border-bottom: 1px solid;
  width: 100%;
  text-align: center;
  margin: 0 auto 6vw;
}
.recruit_work_ttl h3 {
  font-size: 1.6em;
  margin-bottom: -0.8em;
  display: inline-block;
  background-color: white;
  padding: 0 1em;
}
.recruit_work_ttl h4 {
  font-size: 1.2em;
}

.recruit_work_schedule {
  margin: 8vw auto 3vw;
  padding: 1em 2em;
  background: white;
}
@media only screen and (max-width: 540px) {
  .recruit_work_schedule {
    margin: 12vw auto 4vw;
  }
}

h4.recruit_work_schedule_ttl {
  margin: -2.5em auto 1em;
  text-align: center;
  padding: 0.6em 1em;
  background: #100313;
  color: white;
  min-width: 240px;
}
@media only screen and (min-width: 871px) {
  h4.recruit_work_schedule_ttl {
    width: 50%;
  }
}

span.sub-title {
  font-size: 0.7em;
  margin-top: 0.5em;
}
@media only screen and (max-width: 870px) {
  span.sub-title {
    margin-left: 0.5em;
  }
}
span.sub-title:before, span.sub-title:after {
  content: "－";
}
@media only screen and (max-width: 540px) {
  span.sub-title {
    display: block;
  }
}

#recruit_top p {
  text-align: justify;
}
#recruit_top p.center {
  text-align: center;
}
#recruit_top h2 {
  margin-bottom: 1em;
}
@media only screen and (max-width: 870px) {
  #recruit_top h2 {
    text-align: center;
  }
}
@media only screen and (min-width: 871px) {
  #recruit_top .containerW {
    padding-right: 3em;
  }
}
#recruit_top .cont_wrap {
  padding-bottom: 0;
}
#recruit_top .cont_wrap.bg-gray {
  position: relative;
  z-index: 0;
}
@media only screen and (min-width: 871px) {
  #recruit_top .cont_wrap.bg-gray {
    margin-bottom: 14em;
  }
}
@media only screen and (max-width: 870px) {
  #recruit_top .cont_wrap.bg-gray {
    padding-bottom: 8vw;
  }
}
#recruit_top .containerW.bg-white {
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 870px) {
  #recruit_top .containerW.bg-white {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
}
@media screen and (min-width: 871px) {
  #recruit_top h2.title_rl-p.pr-p {
    width: 2.5em;
    padding-right: 0;
  }
}

@media only screen and (max-width: 870px) {
  #recruit_top_staff {
    padding-top: 8vw;
  }
}

.recruit_top_img {
  width: 100%;
  max-height: 400px;
  overflow: hidden;
  position: relative;
  z-index: 2;
}
@media only screen and (min-width: 871px) {
  .recruit_top_img {
    width: 56%;
    max-width: 500px;
    margin-bottom: -4vw;
  }
}
@media only screen and (max-width: 870px) {
  .recruit_top_img {
    margin: 0 auto 4vw;
  }
}

.recruit_top_right {
  width: 40%;
}
@media only screen and (max-width: 870px) {
  .recruit_top_right {
    width: 100%;
  }
}

.btn_arwBox.btn_mynb {
  width: 100%;
}

#recruit_top_list {
  margin: 4vw auto;
}
#recruit_top_list li {
  margin-bottom: 4vw;
  width: 310px;
}
@media screen and (max-width: 660px) {
  #recruit_top_list li {
    width: 100%;
  }
}
#recruit_top_list li a:hover img {
  transform: scale(1.1);
  transition: all .2s;
}
#recruit_top_list dl {
  position: relative;
}
#recruit_top_list dl dt {
  overflow: hidden;
  z-index: 1;
  height: 280px;
}
#recruit_top_list dl dt img {
  height: 100%;
  max-width: 110%;
  object-fit: cover;
}
#recruit_top_list dl dd {
  position: absolute;
  width: 100%;
  height: 5em;
  background: rgba(0, 0, 0, 0.7);
  color: white;
  padding: 0.6em 1em;
  bottom: 0;
  z-index: 2;
}
#recruit_top_list dl dd p {
  line-height: 1.3;
  font-size: 0.9em;
}
#recruit_top_list dl dd h3 {
  font-size: 1.2em;
}

.container.recruit_btns {
  padding-top: 4vw;
  padding-bottom: 8vw;
}
@media only screen and (max-width: 540px) {
  .container.recruit_btns {
    display: block;
  }
}

.page-id-185 .recruit_image {
  height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}
@media only screen and (max-width: 870px) {
  .page-id-185 .recruit_image {
    height: 30vw;
  }
}
.page-id-185 .recruit_work .wp-block-table table {
  width: 100%;
  margin: 0 auto;
  border-top: 1px dotted #ccc;
}
.page-id-185 .recruit_work .wp-block-table table td:first-child {
  background: #f5f5f5;
  vertical-align: middle;
  width: 20vw;
  text-align: center;
  font-weight: 600;
}
@media only screen and (max-width: 540px) {
  .page-id-185 .recruit_work .wp-block-table table td:first-child {
    width: 8em;
    padding: 1em;
  }
}
.page-id-185 .recruit_work .wp-block-table table td {
  line-height: 1.6;
  padding: 1em 2em;
  border: none;
  border-bottom: 1px dotted #ccc;
}
.page-id-185 .recruit_work .wp-block-table table + h3 {
  margin-top: 6vw;
}

.recruit_work_list li {
  min-width: 20em;
}
@media only screen and (min-width: 541px) {
  .recruit_work_list li {
    width: 45%;
  }
}
.recruit_work_list li:before {
  content: "・";
}

.recruit_table {
  table-layout: auto;
  width: 100%;
  margin: 2vw auto 2vw;
}
.recruit_table th, .recruit_table td {
  line-height: 1.4;
  padding: 1em 2em;
  border: 1px solid #ccc;
  vertical-align: middle;
}
.recruit_table th, .recruit_table td {
  text-align: center;
  min-width: 10em;
}
.recruit_table th {
  background: #ddd;
}
.recruit_table td {
  background: white;
}
@media only screen and (max-width: 540px) {
  .recruit_table th, .recruit_table td {
    min-width: 3em;
    max-width: 10em;
    padding: 1em 0.2em;
  }
}

.recruit_table_2 {
  font-size: 0.8em;
  table-layout: auto;
}
.recruit_table_2 th {
  background: #ddd;
}
.recruit_table_2 th, .recruit_table_2 td {
  line-height: 1.4;
  padding: 1em 2em;
  border: 1px solid #ccc;
  vertical-align: middle;
}
.recruit_table_2 td:last-child {
  width: 50%;
}
.recruit_table_2 td {
  padding: 0.5em;
}

/* Scss Document */
.contact_dl_ttl {
  font-size: 2em;
  margin-bottom: 0.6em;
}

.contact_dl_box {
  margin-bottom: 8vw;
}

.contact_dl_boxL {
  margin-left: 2em;
  width: calc(100% - 290px);
}
@media only screen and (max-width: 540px) {
  .contact_dl_boxL {
    margin: 8vw auto 16vw;
    width: 100%;
  }
}
.contact_dl_boxL .btn_arwBox {
  margin-top: 2em;
}

.contact_dl_img {
  width: 240px;
  height: 240px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.contact_dl_img img {
  height: 240px;
  width: auto;
  max-width: none;
}
@media only screen and (max-width: 540px) {
  .contact_dl_img {
    margin: 8vw auto;
  }
}

#contactform1 {
  width: 100%;
  margin: 2vw auto;
}
#contactform1 input[type=text],
#contactform1 input[type=email],
#contactform1 textarea {
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-size: 1em;
  padding: 0.6em 1em;
  outline-style: none;
  border: 1px solid #666;
  vertical-align: top;
  width: 100%;
  -webkit-appearance: none;
}
@media only screen and (min-width: 871px) {
  #contactform1 input[type=text],
  #contactform1 input[type=email],
  #contactform1 textarea {
    width: 60%;
    display: inline-block;
  }
}
@media only screen and (max-width: 540px) {
  #contactform1 input[type=text],
  #contactform1 input[type=email],
  #contactform1 textarea {
    font-size: 18px;
  }
}
#contactform1 input[type=checkbox] {
  width: 1.4em;
  height: 1.4em;
  vertical-align: middle;
}
#contactform1 input[type=submit] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
#contactform1 input[type="submit"]::-webkit-search-decoration,
#contactform1 input[type="button"]::-webkit-search-decoration {
  display: none;
}
#contactform1 input[type="submit"]::focus,
#contactform1 input[type="button"]::focus {
  outline-offset: -2px;
}
#contactform1 div.wpcf7 .ajax-loader {
  display: none;
}
#contactform1 :focus::placeholder {
  color: white;
}
#contactform1 ::placeholder {
  color: #CCCCCC;
}
#contactform1 p {
  margin-bottom: 1.2em;
}
#contactform1 p:not(.wpcf7-list-item) label {
  padding-top: 0.6em;
}
@media only screen and (min-width: 871px) {
  #contactform1 p:not(.wpcf7-list-item) label {
    width: 30%;
    display: inline-block;
    text-align: right;
    padding-right: 1em;
  }
}
#contactform1 p label {
  width: 100%;
  line-height: 1;
  display: inline-block;
  vertical-align: middle;
}
#contactform1 p a {
  text-decoration: underline;
  color: #006883;
}
#contactform1 p a:hover {
  text-decoration: none;
}
#contactform1 input[type=submit] {
  cursor: pointer;
  padding: 1.2em;
  background: #100313;
  color: white;
  width: 15em;
  margin: 3em auto;
  border: 1px solid;
}
#contactform1 input[type=submit]:hover {
  background: white;
  color: #100313;
}
#contactform1 p a {
  text-decoration: underline;
}
#contactform1 p a:hover {
  text-decoration: none;
}
#contactform1 p.checkbox {
  line-height: 1;
  font-size: 16px;
}
#contactform1 .mwform-checkbox-field.horizontal-item {
  display: inline;
}
#contactform1 p label.radio {
  padding: 1em;
}
#contactform1 .mwform-radio-field.vertical-item > label,
#contactform1 .mwform-checkbox-field.horizontal-item > label {
  width: auto;
}

@media only screen and (max-width: 870px) {
  input {
    font-size: 16px;
  }
}
.mw_wp_form .vertical-item {
  display: inline !important;
  vertical-align: super;
}

.mw_wp_form .error {
  text-align: right;
  padding-top: 10px;
}

.contact .cont_wrap p.contact_tel {
  margin: 2vw auto;
  font-size: 1.6em;
  text-align: center;
}
.contact .cont_wrap p.contact_tel span.small {
  display: inline-block;
  font-size: .6em;
}
@media only screen and (max-width: 540px) {
  .contact .cont_wrap p.contact_tel {
    font-size: 6vw;
  }
}

.container.contactform {
  margin: 4vw auto;
}

.required {
  display: inline !important;
  color: #E14F51;
}

span.wpcf7-not-valid-tip {
  text-align: right;
  font-size: 12px;
  padding-top: 0.4em;
}

.topTitle {
  font-size: 3em;
  padding-top: 2em;
  text-align: center;
  font-weight: bold;
}
.topTitle small {
  display: block;
  font-size: 0.7em;
  padding-bottom: 1em;
}

.download_eyecatch {
  max-width: 100%;
  text-align: center;
  margin: 0 auto 1em;
  background-color: #fafafa;
  padding: 2em;
}
.download_eyecatch img {
  max-width: 400px;
  width: 100%;
  box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.3);
}

.box_bdr_gray {
  border: 3px solid #eee;
  padding: 1em;
  margin: 1em auto;
}

p.txtTtl {
  font-size: 1.2em;
  font-weight: bold;
}

.bg-lgray-p1 {
  background-color: #f5f5f5;
  padding: 1em 2em;
  margin-bottom: 1em;
}
.bg-lgray-p1 p {
  line-height: 1.4;
}

.material-icons {
  vertical-align: middle;
}

.cont_left {
  margin-bottom: 3em;
}

@media only screen and (min-width: 871px) {
  .cont_right {
    margin-left: 3em;
  }
}

div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing {
  border: none;
  background: #ffe103;
  line-height: 1.2;
  text-align: center;
}

.wpcf7-mail-sent-ok {
  display: none !important;
}

.page-id-6342 #breadCrumb {
  display: none;
}

h3 {
  font-size: 2em;
}
@media only screen and (max-width: 540px) {
  h3 {
    font-size: 1.4em;
  }
}

#top_21-1 {
  position: relative;
  background: url(../image/2020-05-08-15.26.35.jpg) no-repeat top center;
  background-size: cover;
  padding-top: 4em;
  padding-bottom: 9em;
  z-index: 0;
}
@media only screen and (max-width: 540px) {
  #top_21-1 {
    padding-top: 3em;
    padding-bottom: 7em;
  }
}
#top_21-1:before {
  width: 100%;
  height: 100%;
  content: "";
  position: absolute;
  filter: brightness(65%);
  z-index: -1;
  background: inherit;
  top: 0;
}
#top_21-1 h2 {
  color: white;
}
#top_21-1 .btn_arwBox {
  width: 30%;
}

#top_kv_window {
  margin: 1em auto 3em auto;
  box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.16);
  width: 500px;
  background-color: white;
  border-radius: 6px;
}
#top_kv_window li {
  font-size: 1.1em;
  line-height: 1;
  margin: 0;
  padding: 0.8em 1em;
}
#top_kv_window li strong {
  font-weight: bold;
  padding-left: 1em;
}
#top_kv_window li:hover {
  background-color: #ddd;
}
#top_kv_window li .lnr {
  padding-right: 0.6em;
}
#top_kv_window li:first-child {
  border-radius: 6px 6px 0 0;
}
#top_kv_window li:first-child img {
  height: 1em;
  padding-right: 0.6em;
}
#top_kv_window li:last-child {
  border-radius: 0 0 6px 6px;
}
@media only screen and (max-width: 540px) {
  #top_kv_window {
    width: 80%;
  }
  #top_kv_window li {
    padding: 0.6em 1em;
  }
}

.top_kv_logo {
  text-align: center;
  max-width: 300px;
}

#top_21-3 {
  background: white;
  margin-top: -6em;
  position: relative;
  z-index: 1;
  padding: 3em;
}
@media only screen and (max-width: 540px) {
  #top_21-3 {
    width: 90%;
    padding: 2em 10px;
  }
}
#top_21-3 h2 {
  line-height: 0.8;
  text-align: center;
  margin-bottom: 1em;
}
#top_21-3 h2 strong {
  font-weight: bold;
  font-size: 120%;
}
#top_21-3 .lnr-pencil {
  font-size: 1.6em;
  padding-left: 4em;
}
@media only screen and (max-width: 540px) {
  #top_21-3 .lnr-pencil {
    padding-left: 1.8em;
  }
}

#top_nayami {
  margin: 0 auto;
  justify-content: center;
}
#top_nayami li {
  font-size: 1.1em;
  width: 45%;
  margin-bottom: 1em;
  line-height: 1;
}
@media only screen and (min-width: 871px) {
  #top_nayami li {
    padding-left: 3em;
  }
}
@media only screen and (max-width: 540px) {
  #top_nayami li {
    width: 80%;
  }
}
#top_nayami li:before {
  content: "";
  display: inline-block;
  height: 1em;
  width: 1em;
  border: 1px solid;
  margin-right: 0.6em;
  vertical-align: baseline;
}

#top_21-2 .containerW {
  background: url(/wp-content/themes/primenumbers/images/top/bg_senryaku.png) no-repeat top 3em center;
  background-size: contain;
}
#top_21-2 h2.top_Ttl {
  text-align: center;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-weight: bold;
  margin: 1em auto;
  line-height: 1.4;
}
#top_21-2 p {
  font-size: 1.1rem;
}
@media only screen and (max-width: 540px) {
  #top_21-2 p {
    font-size: 1em;
  }
}
#top_21-2 h3 {
  font-weight: bold;
  margin: 0.5em auto 1em;
  text-align: center;
}
#top_21-2 .top_mainBox_R {
  margin: -0.5em -3em -0.5em auto;
  text-align: right;
}
@media only screen and (max-width: 540px) {
  #top_21-2 .top_mainBox_R {
    text-align: left;
    margin: 0 auto -1em 3em;
  }
}
#top_21-2 .top_mainBox_R h3 {
  transform: rotate(-3deg);
  background-color: #100313;
  color: white;
  padding: 0.3em 0.5em;
  display: inline-block;
  margin: 0;
}
#top_21-2 .top_mainBox {
  border: 1px solid;
  padding: 1px 2em;
  margin: 2em auto;
}
@media only screen and (max-width: 540px) {
  #top_21-2 .top_mainBox {
    padding: 1px 1em;
  }
}
#top_21-2 .top_mainBox p {
  margin-bottom: 0;
}
@media only screen and (max-width: 540px) {
  #top_21-2 .top_mainBox p {
    line-height: 1.5;
  }
}
#top_21-2 p strong {
  font-weight: bold;
  font-size: 1.4em;
}
#top_21-2 h2.top_mainTtl {
  text-align: center;
  font-size: 6em;
  margin: 10px auto 0.5em;
}
@media only screen and (max-width: 870px) {
  #top_21-2 h2.top_mainTtl {
    font-size: 10vw;
    font-feature-settings: "palt";
  }
}
@media only screen and (max-width: 540px) {
  #top_21-2 h2.top_mainTtl {
    font-size: 3.5em;
    white-space: nowrap;
    margin-left: -0.3em;
  }
}
#top_21-2 h2.top_mainTtl .small {
  font-size: 40%;
}
#top_21-2 .top_main_List {
  margin: 0 auto 3em;
}
@media only screen and (max-width: 540px) {
  #top_21-2 .top_main_List {
    margin: 0 auto 2em;
  }
}
#top_21-2 .top_main_List li {
  font-size: 1.2em;
  font-weight: bold;
  text-indent: -.5em;
  margin-left: 1em;
}
#top_21-2 .top_main_List li span {
  font-size: 1.5em;
  vertical-align: text-bottom;
  display: inline-block;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
@media only screen and (max-width: 540px) {
  #top_21-2 .top_main_List li {
    font-size: .9em;
    line-height: 1.4;
    margin-bottom: 1em;
    margin-right: 1em;
  }
}
#top_21-2 .btn_arwBox {
  margin-bottom: 1em;
}

#top_fuki_ani {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media only screen and (max-width: 540px) {
  #top_fuki_ani {
    margin-bottom: -2em;
  }
}
#top_fuki_ani li {
  width: calc(100% / 4.5);
  margin: 1em auto 0;
}
@media only screen and (max-width: 540px) {
  #top_fuki_ani li {
    width: 30%;
    margin: 0 auto 10px;
  }
}
#top_fuki_ani li img {
  width: 100%;
}

.sa.sa--scaleUp-up {
  transform: scale(0.3) translate(0, 100px);
  transition: all 0.5s cubic-bezier(0.59, 0.01, 0.49, 1.44);
}

.space_t {
  padding: 6em 0 1px;
}

.space_b {
  padding: 0 0 6em;
}

.space_tb {
  padding: 6em 0;
}
@media only screen and (max-width: 540px) {
  .space_tb {
    padding: 6vw 0;
  }
}

#top_serviceAll {
  padding-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  #top_serviceAll {
    padding-bottom: 10%;
  }
}

#top_serviceBtm h3 {
  text-align: center;
  margin: 3em auto 1em;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

#top_service_list_icn {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 3em;
  border-bottom: 1px solid;
}
#top_service_list_icn li {
  text-align: center;
  font-feature-settings: "palt";
  padding: 1em 5px;
  line-height: 1.2;
  width: calc(100%/2);
  font-weight: bold;
  border-top: 1px solid;
  border-left: 1px solid;
}
@media only screen and (min-width: 541px) {
  #top_service_list_icn li {
    width: calc(100%/5);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    flex-wrap: wrap;
  }
  #top_service_list_icn li:nth-child(5n) {
    border-right: 1px solid;
  }
}
@media only screen and (max-width: 540px) {
  #top_service_list_icn li:nth-child(2n) {
    border-right: 1px solid;
  }
}
#top_service_list_icn li .icn {
  width: 148px;
  padding: 0 2em;
  display: block;
  margin: 0 auto 1em auto;
}
@media only screen and (max-width: 540px) {
  #top_service_list_icn li .icn {
    width: 60%;
    margin: 0 auto 10px;
  }
}
#top_service_list_icn li p {
  margin-bottom: 0;
}
#top_service_list_icn a:hover object.icn {
  opacity: 0.5;
}
#top_service_list_icn a:hover {
  color: #006883;
  opacity: 0.7;
}
#top_service_list_icn p {
  line-height: 1.2;
  font-size: 14px;
  display: flex;
  justify-content: center;
  align-items: center;
}

#top_recruit2 {
  background: url("../image/01891.jpg") no-repeat center;
  background-size: cover;
  padding-top: 6em;
  padding-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  #top_recruit2 {
    padding-top: 10%;
  }
}
@media only screen and (max-width: 870px) {
  #top_recruit2 {
    padding-bottom: 10%;
  }
}

#top_voice_list_2 {
  justify-content: center;
  margin: 0 -1% 3em;
}
@media only screen and (min-width: 871px) {
  #top_voice_list_2 {
    flex-wrap: nowrap;
  }
}
#top_voice_list_2 li {
  width: 45%;
  margin: 0 1%;
  max-width: 410px;
}
@media only screen and (max-width: 540px) {
  #top_voice_list_2 li {
    width: 100%;
  }
}
#top_voice_list_2 .top_voice_img {
  position: relative;
  z-index: 0;
  aspect-ratio: 16 / 9;
  max-height: 230px;
  overflow: hidden;
}
#top_voice_list_2 .listOnBox {
  margin: -1em auto 1em;
  padding: 1em;
  width: 90%;
  position: relative;
}
#top_voice_list_2 .listOnBox dt {
  line-height: 1.4;
  font-weight: bold;
  font-size: 1.2em;
  border-bottom: 1px solid;
  padding-bottom: 0.5em;
  margin-bottom: 1em;
}
#top_voice_list_2 .listOnBox dd {
  line-height: 1.4;
}

.top_blog_list_2 {
  margin-bottom: 3em;
}
.top_blog_list_2 > li {
  max-width: 100%;
  background: white;
  margin-bottom: 2em;
}
@media only screen and (min-width: 541px) {
  .top_blog_list_2 > li {
    width: 31%;
  }
}
.top_blog_list_2 dl {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.top_blog_list_2 dd {
  padding: 0 1em 3px;
}
.top_blog_list_2 .top_tag {
  position: static;
  display: block;
}
.top_blog_list_2 .blog-category,
.top_blog_list_2 .blog-date,
.top_blog_list_2 .blog-tag {
  margin-bottom: 0;
}
.top_blog_list_2 .top_blog_date,
.top_blog_list_2 .blog_update {
  padding: 0 1em 0 0;
}

h2.title_bb {
  text-align: center;
  position: relative;
  margin: 1px auto 2em;
}
h2.title_bb:after {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  content: "";
  border-bottom: 1px solid;
  width: 3em;
  bottom: -0.2em;
}

.topContact_box {
  width: 48%;
  max-width: 400px;
  background-color: white;
  text-align: center;
  margin-top: 3em;
}
.topContact_box h3 {
  font-size: 1.2em;
  padding-top: 1em;
}
.topContact_box p {
  line-height: 1.5;
  padding: 0.5em 1em;
}
.topContact_box .btn_arwBox {
  width: calc(100% + 2px);
  margin: 1em -1px 0;
}
@media only screen and (max-width: 870px) {
  .topContact_box {
    margin: 3em auto 0;
  }
}
@media only screen and (max-width: 540px) {
  .topContact_box {
    width: 100%;
  }
}

#top_reason .reason_box {
  max-width: 430px;
  text-align: center;
  margin: 0 auto 3em;
}
#top_reason .reason_box h3 {
  margin-bottom: 0.2em;
}
#top_reason .reason_box p {
  text-align: left;
  line-height: 1.4;
}
#top_reason .reason_box .icn {
  width: 25%;
  margin: 0 auto 1em;
}

#top_news ul#top_news_list {
  margin: 0 auto 3em;
  margin-left: auto;
}
@media only screen and (min-width: 871px) {
  #top_news ul#top_news_list {
    width: max-content;
  }
}

.blog-category,
.blog-tag {
  width: 94%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

h2.blog-title-toppage-wrap {
  display: flex;
  align-items: center;
  height: 3em;
  font-size: 18px;
}
@media only screen and (max-width: 540px) {
  h2.blog-title-toppage-wrap {
    font-size: 5vw;
    margin-bottom: 0.2em;
  }
}

.blog-title-toppage {
  line-height: 1.4;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.faq_list dt,
.faq_list dd {
  display: table;
}
.faq_list dt span:first-child,
.faq_list dd span:first-child {
  font-weight: bold;
  /* font-family: $fontRobot; */
  font-family: Impact;
  padding-right: 0.3em;
  font-size: 2rem;
  display: table-cell;
}
@media only screen and (max-width: 540px) {
  .faq_list dt span:first-child,
  .faq_list dd span:first-child {
    font-size: 1.4rem;
  }
}
.faq_list dt {
  font-weight: bold;
  line-height: 1.6;
  margin-bottom: 1em;
  font-size: 1.2em;
}
.faq_list dt span:first-child {
  color: #100313;
}
.faq_list dd {
  margin-bottom: 2em;
  line-height: 1.6;
}
.faq_list dd span:first-child {
  color: #006883;
}

.basic-page .blog_main table.operations_tbl {
  width: max-content;
  margin: 2vw auto;
}
.basic-page .blog_main table.operations_tbl td {
  padding: 10px 2em;
  border: none;
  vertical-align: top;
  line-height: 1.6;
}
.basic-page .blog_main table.operations_tbl td strong {
  border: 1px solid;
  padding: 0.2em 1em;
  margin-bottom: 0.3em;
  display: inline-block;
}
@media only screen and (max-width: 540px) {
  .basic-page .blog_main table.operations_tbl {
    width: 100%;
    zoom: 0.4;
    table-layout: auto;
  }
  .basic-page .blog_main table.operations_tbl td {
    padding: 0;
  }
  .basic-page .blog_main table.operations_tbl td strong {
    white-space: nowrap;
    font-size: 2vw;
  }
  .basic-page .blog_main table.operations_tbl td.operations_tbl_td_1 {
    vertical-align: bottom !important;
    padding-bottom: 1em;
  }
  .basic-page .blog_main table.operations_tbl td:nth-child(1) {
    width: 32%;
  }
  .basic-page .blog_main table.operations_tbl td:nth-child(2) {
    width: 32%;
    padding-right: 10px;
  }
}
.basic-page .borderBox {
  border: 1px solid;
  padding: 1em;
}
.basic-page .blog_main table.service_tbl {
  width: 100%;
  margin: 3em auto;
}
.basic-page .blog_main table.service_tbl td {
  padding: 10px 0 10px 1em;
  border: none;
  border-bottom: 1px solid #006883;
  vertical-align: top;
  font-weight: bold;
  line-height: 1.4;
}
@media only screen and (max-width: 540px) {
  .basic-page .blog_main table.service_tbl td {
    font-size: 3vw;
  }
}
.basic-page .blog_main table.service_tbl td.ttl {
  background-color: rgba(179, 218, 236, 0.2);
}
.basic-page .blog_main table.service_tbl td:last-child {
  width: 54%;
  font-weight: normal;
}
@media only screen and (max-width: 540px) {
  .basic-page .blog_main table.service_tbl td:last-child {
    width: 40%;
  }
}
.basic-page .blog_main table.service_tbl th {
  border: none;
  vertical-align: middle;
  text-align: center;
  font-weight: bold;
  width: 28%;
  padding: 0 0.5em 2em;
  line-height: 1.6;
  font-size: 1.2em;
  background: #006883 url("../image/bg_arw.png") no-repeat bottom center;
  background-size: 100% auto;
  color: white;
}
@media only screen and (max-width: 540px) {
  .basic-page .blog_main table.service_tbl th {
    font-size: 3vw;
  }
}
.basic-page .blog_main table.service_tbl tr.service_tbl_ttl td {
  text-align: center;
  font-weight: bold;
  color: #006883;
}
.basic-page .blog_main table th {
  background-color: #e5f0f2;
}

#top_voice.basic-page {
  padding-top: 1px;
}
#top_voice.basic-page #top_voice_list_2 .listOnBox {
  font-size: 0.9em;
}
#top_voice.basic-page #top_voice_list_2 .listOnBox dd {
  font-size: 1em;
}
@media only screen and (min-width: 871px) {
  #top_voice.basic-page #top_voice_list_2 .top_voice_img {
    aspect-ratio: 16 / 9;
  }
}

.blog_main p.ttl_txt {
  text-align: center;
  font-weight: bold;
  font-size: 1.5em;
  margin: 2em auto;
}
@media only screen and (max-width: 540px) {
  .blog_main p.ttl_txt {
    font-size: 1.4em;
  }
}

.service_list {
  margin-bottom: 2em;
}
.service_list li {
  font-size: 1.2em;
  margin-left: 1.5em;
}
.service_list li::before {
  margin-left: -1.2em;
  content: "";
  display: inline-block;
  height: 0.8em;
  width: 0.8em;
  border-radius: 100%;
  background-color: #006883;
  margin-right: 0.4em;
}
@media only screen and (max-width: 540px) {
  .service_list li {
    font-size: 1.1em;
    line-height: 1.6;
  }
}

.maxContent {
  width: max-content;
  margin: auto;
}
.maxContent li {
  font-size: 1.3em;
}
@media only screen and (max-width: 540px) {
  .maxContent {
    width: auto;
  }
  .maxContent li {
    font-size: 1.1em;
  }
}

.img_center {
  width: 500px;
  margin: 1em auto;
}
@media only screen and (max-width: 540px) {
  .img_center {
    width: 100%;
  }
}

.service_tbl_bt {
  border-top: 3px solid #006883;
}

#servicePage .blog_main table th {
  min-width: 15em;
}
@media only screen and (max-width: 540px) {
  #servicePage .blog_main table th {
    min-width: 6em;
  }
}
#servicePage.service_other #top_serviceAll {
  display: none;
}
#servicePage.service_other .service_other_list h2.title_bb {
  display: none;
}
#servicePage .bg-kv {
  background-image: url(../image/service.jpg);
  height: 290px;
}
@media only screen and (max-width: 540px) {
  #servicePage .bg-kv {
    height: 30vh;
  }
}

.dictionary_main h2 {
  font-size: 5em;
  margin: 1em auto;
}
.dictionary_main .read {
  margin: 1em auto;
}
.dictionary_main .read li {
  width: 50%;
}
.dictionary_main .read li p {
  font-size: 1.4em;
}
.dictionary_main .read h3 {
  font-size: 1.2em;
}

.dictionary-page .pageTtl {
  margin: 0 auto;
  padding: 1.5em 0 2.5em;
}

.dictionary_list {
  margin-bottom: 1em;
}
.dictionary_list li a {
  color: #006883;
  text-decoration: underline;
}
.dictionary_list li a:hover {
  text-decoration: none;
}

.at-label {
  font-size: 32px;
  line-height: 32px;
  height: 32px;
}

.at-resp-share-element .at-share-btn {
  background-color: white !important;
}

.at-resp-share-element .at-share-btn .at-label {
  display: none !important;
}

.at-resp-share-element .at-share-btn .at-icon-wrapper,
.at-svc-lineme .at-icon-lineme.at-icon,
.at-svc-twitter .at-icon-twitter.at-icon,
.at-svc-facebook .at-icon-facebook.at-icon {
  line-height: 32px !important;
  height: 32px !important;
  width: 32px !important;
  background-color: white !important;
}

.at-svc-lineme .at-icon-lineme.at-icon,
.at-svc-twitter .at-icon-twitter.at-icon,
.at-svc-facebook .at-icon-facebook.at-icon {
  border-radius: 50% !important;
  padding: 0.5em;
  border: 1px solid #999999 !important;
  fill: #999999;
}

.at-svc-facebook .at-icon-facebook.at-icon:hover {
  fill: #3b5998;
}

.at-svc-twitter .at-icon-twitter.at-icon:hover {
  fill: #00acee;
}

.at-svc-lineme .at-icon-lineme.at-icon:hover {
  fill: #00b900;
}

#atrsb2 {
  margin: 0 auto;
  text-align: center;
}
#atrsb2:before {
  content: "SHARE";
  text-align: center;
  display: block;
  font-weight: bold;
  color: #999;
  font-size: 18px;
  height: 22px;
  padding-top: 0.5em;
}
#atrsb2 .at-resp-share-element.at-style-responsive.addthis-smartlayers.addthis-animated.at4-show {
  padding-top: 30px !important;
}

body {
  color: #100313;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-size: 1rem;
}
@media only screen and (max-width: 870px) {
  body {
    font-size: 0.8125rem;
  }
}
@media only screen and (max-width: 540px) {
  body {
    font-size: 3.4vw;
  }
}

img,
figure {
  height: auto;
  max-width: 100%;
  object-fit: contain;
}

a:hover img {
  opacity: 0.7;
}

strong {
  font-weight: bold;
}

p,
li,
dd {
  font-size: 1em;
  line-height: 2;
}
p.small,
p small,
li.small,
li small,
dd.small,
dd small {
  font-size: 70%;
  line-height: 1.1;
}

.container {
  width: 100%;
  margin: 0 auto;
  max-width: 980px;
}
@media screen and (max-width: 980px) {
  .container {
    padding: 0 1rem;
  }
}

.container._Small {
  max-width: 840px;
}

.containerW {
  width: 1340px;
  margin: 0 auto;
}
@media screen and (max-width: 1340px) {
  .containerW {
    width: 100%;
    padding: 0 1rem;
  }
  .containerW .container {
    padding: 0;
  }
}

h3,
h4 {
  font-weight: 600;
  line-height: 1.5;
}

h2 {
  line-height: 1.5;
  font-weight: normal;
}
h2 a {
  text-decoration: none !important;
}

a {
  color: #100313;
  text-decoration: none;
}

.text-yellow {
  color: #ffe103;
}

.text-red {
  color: #EF3636;
}

.bg-gray {
  background-color: #f5f5f5;
}

.bg-bk {
  background-color: #100313;
}

.bg-white {
  background-color: white;
}

.box-shadow {
  filter: drop-shadow(0px 2px 3px rgba(0, 0, 0, 0.3));
  z-index: 10;
}

.box-shadow-w {
  filter: drop-shadow(0px 0 4px white);
  z-index: 10;
}

.box-shadowW {
  text-shadow: white 2px 0px 0px, white -2px 0px 0px, white 0px -2px 0px, white 0px 2px 0px, white 2px 2px 0px, white -2px 2px 0px, white 2px -2px 0px, white -2px -2px 0px, white 1px 2px 0px, white -1px 2px 0px, white 1px -2px 0px, white -1px -2px 0px, white 2px 1px 0px, white -2px 1px 0px, white 2px -1px 0px, white -2px -1px 0px, white 1px 1px 0px, white -1px 1px 0px, white 1px -1px 0px, white -1px -1px 0px;
}

.underM, .company_dl dt {
  background: linear-gradient(transparent 90%, #ffe103 90%);
}

:focus::-webkit-input-placeholder,
:focus:-moz-placeholder,
:focus::-moz-placeholder,
:focus::placeholder {
  color: white;
}

@media only screen and (min-width: 871px) {
  .menu-btn {
    display: none;
  }
}
#header {
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background: white;
  box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.16);
  width: 100%;
  z-index: 100;
  position: fixed;
}
@media only screen and (min-width: 871px) {
  #header a {
    text-decoration: none;
  }
}
@media only screen and (max-width: 870px) {
  #header {
    font-size: 1.5vw;
  }
}

#header_logo,
#header_logo_top {
  height: auto;
  width: 280px;
  text-align: left;
}
@media only screen and (max-width: 870px) {
  #header_logo,
  #header_logo_top {
    padding: 1rem 0;
    width: 30vw;
  }
}
@media only screen and (max-width: 540px) {
  #header_logo,
  #header_logo_top {
    width: 45vw;
  }
}

#header_logo_top {
  display: none;
}

p.header_tel {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  padding: 10px 0;
  margin-right: 1em;
  line-height: 1;
  font-size: 1.2em;
}
p.header_tel .small {
  font-size: 0.6em;
}
@media only screen and (max-width: 540px) {
  p.header_tel {
    font-size: 3.6vw;
  }
}

.nav {
  justify-content: center;
}
.nav > li {
  margin: 0 1em;
  color: #CCCCCC;
}

#header_nav .nav > li {
  line-height: 1.2;
  white-space: nowrap;
  font-size: 0.9375rem;
  position: relative;
}
@media only screen and (max-width: 870px) {
  #header_nav .nav > li {
    margin-bottom: 1.2em;
  }
}
@media only screen and (max-width: 540px) {
  #header_nav .nav > li {
    font-size: 4vw;
    margin: 0 0.7em 1em;
    text-align: left;
  }
}
#header_nav .nav > li a {
  position: relative;
  color: #100313;
}
#header_nav .nav > li a:after {
  position: absolute;
  bottom: -6px;
  left: 0;
  opacity: 0;
  width: 0;
  display: block;
  content: "";
  height: 2px;
  background: white;
  background: linear-gradient(90deg, #ffed00 0%, #ffed00 92%);
  background-size: 100% 0.2em;
  background-repeat: no-repeat;
  background-position: bottom center;
}
#header_nav .nav > li a:hover:after, #header_nav .nav > li a.active:after {
  opacity: 1;
  width: 100%;
  transition: all 0.3s ease;
}
#header_nav .nav {
  justify-content: center;
}
#header_nav .nav .dropdown-btn {
  position: relative;
  padding: 1em 0;
  cursor: pointer;
}
@media only screen and (max-width: 540px) {
  #header_nav .nav .dropdown-btn {
    padding: 0.5em 0;
  }
}
#header_nav .nav .header_nav_sub {
  transition: .2s all;
  z-index: 1000;
  background: rgba(0, 0, 0, 0.8);
  position: absolute;
  left: 0;
  top: 2.6em;
  padding: 0 2em;
  height: 0;
  text-align: left;
}
#header_nav .nav .header_nav_sub li {
  margin-bottom: 1em;
  display: none;
}
#header_nav .nav .header_nav_sub li a {
  color: white;
}
#header_nav .nav .open {
  padding: 1em 2em 0;
  height: auto;
  transition: .4s all;
}
@media only screen and (max-width: 540px) {
  #header_nav .nav .open {
    padding: 1em 1em 0;
  }
}
#header_nav .nav .open li {
  display: block;
}
#header_nav .nav .close {
  transition: .4s all;
  display: block;
}

@media screen and (max-width: 1100px) {
  #header_nav .nav {
    display: block;
  }
  #header_nav .nav > li {
    color: #626262;
  }
  #header_nav .nav > li a {
    color: white;
  }

  .menu-btn {
    z-index: 200;
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #100313;
  }
  .menu-btn:hover {
    cursor: pointer;
  }
  .menu-btn li {
    line-height: 0.2;
    font-size: 40px;
  }

  .menu {
    position: fixed;
    top: 50px;
    right: 0;
    z-index: 10;
    width: 13em;
    min-width: 200px;
    height: 100vh;
    padding-top: 2em;
    background: rgba(0, 0, 0, 0.85);
    transform: translateX(100vw);
    transition: all .5s;
  }

  .menu__item {
    width: 100%;
    height: auto;
    padding: .5em 2em;
    text-align: center;
    color: #fff;
  }

  .menu.is-active {
    transform: translateX(0);
  }
  .menu.is-active .nav .flexCC-p {
    justify-content: flex-start;
    text-align: left;
  }

  .header_tel {
    position: absolute;
    right: 60px;
  }
}
#side_nav {
  position: fixed;
  top: 12.5rem;
  right: 1em;
  z-index: 5;
}
#side_nav li {
  margin-bottom: 1em;
}
#side_nav li a {
  background: #100313;
  color: white;
  width: 6em;
  height: 6em;
  font-size: 0.8em;
  flex-wrap: wrap;
  border-radius: 3em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  align-content: center;
}
#side_nav li a span {
  font-size: 2em;
  display: block;
  width: 100%;
  margin-bottom: 0.2em;
}
#side_nav li a:hover {
  background: #ffe103;
  color: #100313;
}
@media only screen and (max-width: 870px) {
  #side_nav {
    bottom: 7em;
    top: auto;
    font-size: 14px;
  }
}

@media only screen and (max-width: 540px) {
  #side_nav {
    bottom: 0;
    left: 1em;
    z-index: 100;
  }
  #side_nav ul {
    font-size: 2.8vw;
    display: flex;
    justify-content: space-between;
  }
  #side_nav li {
    width: 31%;
  }
  #side_nav li a {
    width: 100%;
    border-radius: 0;
    height: auto;
    padding: 0.5em 0;
  }
  #side_nav li a br {
    display: none;
  }
  #side_nav li a span {
    display: inline;
    width: auto;
    padding-right: 0.6em;
  }
  #side_nav .side_nav_icon {
    text-align: right;
    position: absolute;
    right: 1em;
    bottom: 8.5vw;
  }

  #footer .copyright {
    margin-top: 0;
  }
}
.si_bnr {
  max-width: 320px;
  width: 90%;
  margin: 10px auto 0;
}
@media only screen and (max-width: 870px) {
  .si_bnr {
    margin: 2em auto 1.4em;
  }
}

.side_nav_icon {
  text-align: center;
}
.side_nav_icon p {
  font-size: 1.5rem;
  display: inline-block;
}
.side_nav_icon a:hover {
  opacity: 0.7;
}
.side_nav_icon a .icon-facebook2 {
  color: #3c5a99;
}
.side_nav_icon a .icon-twitter {
  color: #1da1f2;
  padding-left: 0.1em;
}

#main {
  padding-top: 50px;
  position: relative;
}

h2 {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 2.5em;
}
h2 small {
  font-size: 40%;
  font-family: "Times New Roman", Times, "serif";
  display: block;
  letter-spacing: 0.15em;
  font-weight: normal;
}
@media only screen and (max-width: 540px) {
  h2 {
    font-size: 5.6vw;
  }
}
h2.min {
  font-weight: normal;
}

.min {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

h1.title_rl-p,
h1.title_rl {
  font-size: 2.5em;
  line-height: 1.4;
}

#topMain {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
  height: 100vh;
}
@media only screen and (max-width: 870px) {
  #topMain {
    height: 80vh;
  }
}
@media only screen and (max-width: 540px) {
  #topMain {
    padding-top: 2em;
    display: block;
  }
}
#topMain h2,
#topMain h2 span {
  line-height: 2;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  z-index: 2;
}
#topMain h2.title_rl {
  margin: auto;
}
#topMain h2.title_rl .sa {
  transition: all 2s ease;
}

#top_bodytext p {
  height: 42vh;
  margin: auto 3em;
  text-align: left;
}
@media only screen and (min-width: 871px) {
  #top_bodytext {
    flex-wrap: nowrap;
  }
}
@media only screen and (max-width: 870px) {
  #top_bodytext {
    width: 90%;
    margin: 0 auto;
    margin: auto;
  }
  #top_bodytext p {
    margin-right: 4em;
    margin-top: 3em;
    line-height: 1.8;
  }
}
@media only screen and (max-width: 540px) {
  #top_bodytext p {
    line-height: 1.5;
    font-size: 1.6vh;
    margin: 2em auto;
    padding-right: 1em;
    padding-bottom: 30px;
  }
}

.title_rl,
.text_rl {
  writing-mode: vertical-rl;
  font-feature-settings: normal;
  text-orientation: upright;
}

@media screen and (min-width: 871px) {
  .title_rl-p,
  .text_rl-p {
    writing-mode: vertical-rl;
    font-feature-settings: normal;
  }

  .title_rl-p.pr-p {
    padding-right: 2em;
  }
}
.title_rl-p {
  margin-bottom: 1em;
}

.btn_arwBox {
  margin: 1em auto;
  min-width: 15em;
  width: 40%;
  background: white;
}
@media only screen and (max-width: 540px) {
  .btn_arwBox {
    width: 70%;
  }
}
.btn_arwBox a {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  border: 1px solid #100313;
  padding: 1em 3em 1em 2em;
  position: relative;
  color: #100313;
  text-decoration: none;
}
.btn_arwBox a:after {
  content: url("/wp-content/themes/primenumbers/images/lnr-arrow-right.svg");
  display: block;
  position: absolute;
  right: 1em;
  width: 1em;
  top: 50%;
  transform: translateY(-50%);
}
.btn_arwBox a:hover {
  color: white;
  background: #100313;
}
.btn_arwBox a:hover:after {
  content: url("/wp-content/themes/primenumbers/images/lnr-arrow-rightw.svg");
}
.btn_arwBox._white {
  background: transparent;
}
.btn_arwBox._white a {
  border: 1px solid white;
  color: white;
}
.btn_arwBox._white a:after {
  content: url("/wp-content/themes/primenumbers/images/lnr-arrow-rightw.svg");
}
.btn_arwBox._white a:hover {
  background: white;
  color: #100313;
}
.btn_arwBox._white a:hover:after {
  content: url("/wp-content/themes/primenumbers/images/lnr-arrow-right.svg");
}

.btn_arw {
  width: 1.5em;
  height: 1.5em;
  padding: 0.2em;
  background: #100313;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  margin: 0 0 auto auto;
}

.btn_arwBox._Long {
  width: 26em;
}

h2#footer_logo {
  width: 380px;
  margin-bottom: 8px;
  font-size: 0.8em;
  line-height: 2;
  font-weight: normal;
}
@media only screen and (max-width: 540px) {
  h2#footer_logo {
    width: 80%;
  }
}

#footer {
  position: relative;
  z-index: 0;
  padding: 4em 0 0 0;
}
#footer .copyright {
  background: #100313;
  color: white;
  font-size: 0.76em;
  margin: 1em auto 0;
  padding: 0.6em;
  text-align: center;
}
#footer a {
  text-decoration: underline;
  color: #006883;
}
#footer a:hover {
  text-decoration: none;
}
#footer .box_right li {
  color: #CCCCCC;
  margin-left: 0.5em;
}
#footer .box_right li:after {
  content: "/";
  padding-left: 0.5em;
}
#footer .box_right li:last-child {
  content: none;
}
@media only screen and (max-width: 870px) {
  #footer .box_right li {
    margin-right: 0.5em;
    margin-left: 0;
    line-height: 1.6;
  }
}
#footer .footer_tel {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 1.2em;
}

.wrap_footerR {
  padding-top: 2em;
}

h2.title {
  margin-bottom: 1em;
  text-align: center;
}

.title_rl-p {
  text-align: left;
}
@media only screen and (max-width: 870px) {
  .title_rl-p {
    text-align: center;
  }
}

.title_icon {
  margin: 0 auto 0.2em;
  display: block;
  width: 1.6em;
}

h3.title_mid {
  font-size: 1.6em;
  margin-bottom: 0.5em;
  margin-top: 1em;
}

.titleMin {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.box_left {
  width: 46%;
}

.box_right {
  width: 50%;
}

@media only screen and (max-width: 870px) {
  .box_left,
  .box_right {
    width: 100%;
  }
}
#top_problem {
  z-index: 20;
  margin-bottom: 6em;
  background: linear-gradient(90deg, transparent 0%, transparent 50%, #f5f5f5 50%, #f5f5f5 100%);
}
@media only screen and (max-width: 870px) {
  #top_problem {
    margin-bottom: 10%;
  }
}
#top_problem .bg-bk {
  color: white;
  padding: 0.5em 2em;
  margin-bottom: 1em;
}
#top_problem h2 {
  border-top: 3px double;
  border-bottom: 3px double;
  padding: 0.3em 0;
  margin-bottom: 1.4em;
  text-align: center;
}
#top_problem h3 {
  font-size: 1.8em;
  margin-bottom: 1em;
  text-align: center;
}
#top_problem h3 strong {
  background: linear-gradient(transparent 80%, #ffe103 80%);
}
#top_problem li {
  font-size: 1.2em;
  margin-bottom: 1.2em;
  min-width: 33%;
}
#top_problem li:before {
  content: "\e855";
  font-family: 'Linearicons-Free';
  padding-right: 0.3em;
}
#top_problem p strong {
  font-weight: bold;
  font-size: 1.2em;
}
#top_problem .containerW {
  padding-top: 4em;
  padding-bottom: 2em;
}
@media only screen and (max-width: 540px) {
  #top_problem .containerW {
    padding-top: 10%;
  }
}

.marker {
  background: linear-gradient(transparent 70%, #ffe103 70%);
}

#top_service {
  margin-top: -6em;
  padding-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  #top_service {
    padding-bottom: 10%;
  }
}
@media only screen and (min-width: 871px) {
  #top_service h2 {
    margin-right: 2em;
  }
}
@media only screen and (max-width: 540px) {
  #top_service {
    margin-top: 0;
    padding-top: 2em;
  }
}

#top_service_list {
  background: white;
  color: #100313;
  padding: 2em;
  font-size: 1.2em;
  max-width: 980px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (min-width: 871px) {
  #top_service_list li {
    width: 50%;
  }
}
@media only screen and (max-width: 870px) {
  #top_service_list {
    padding: 1em;
    display: flex;
    flex-wrap: wrap;
  }
  #top_service_list li {
    margin-right: 1em;
  }
}
@media only screen and (max-width: 540px) {
  #top_service_list {
    width: 100%;
  }
}
#top_service_list li:before {
  content: "●";
  color: #ffe103;
  padding-right: 1em;
}
#top_service_list li a {
  text-decoration: underline;
  color: #006883;
}
#top_service_list li a:hover {
  text-decoration: none;
}
#top_service_list h3 {
  border-bottom: 1px solid;
  padding-bottom: 0.5em;
  margin-bottom: 1em;
  text-align: center;
}

#top_voice {
  padding-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  #top_voice {
    padding-bottom: 10%;
  }
}
@media screen and (max-width: 414px) {
  #top_voice {
    padding-bottom: 4em;
  }
}

#top_voice_list {
  width: 100%;
  margin: 0 auto;
}
#top_voice_list li {
  display: flex;
  justify-content: space-between;
  position: relative;
  margin-bottom: 6em;
  width: 100%;
}
@media only screen and (max-width: 870px) {
  #top_voice_list li {
    margin-bottom: 10%;
  }
}
#top_voice_list li h2 {
  font-size: 1em;
  margin-top: 1em;
  margin-bottom: 1em;
}
#top_voice_list li .top_voice_img {
  z-index: 0;
  max-width: 640px;
  text-align: right;
}
@media only screen and (max-width: 870px) {
  #top_voice_list li .top_voice_img {
    position: static;
    width: 100%;
    max-width: 100%;
  }
}
#top_voice_list li a {
  z-index: 1;
}
#top_voice_list li dl {
  margin: 2em 0 auto -2em;
  background: white;
}
@media only screen and (min-width: 871px) {
  #top_voice_list li dl {
    box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.16);
    min-width: 400px;
  }
}
@media only screen and (max-width: 870px) {
  #top_voice_list li dl {
    position: static;
    width: 100%;
    margin: 0em auto;
  }
}
#top_voice_list li dt {
  line-height: 1.4;
  font-weight: bold;
  font-size: 1.2em;
  border-bottom: 1px solid;
  padding-bottom: 0.5em;
  margin-bottom: 1em;
}
@media only screen and (min-width: 871px) {
  #top_voice_list li:nth-child(odd) {
    flex-direction: row-reverse;
  }
  #top_voice_list li:nth-child(odd) dl {
    margin: 2em -2em auto auto;
  }
}
@media only screen and (max-width: 870px) {
  #top_voice_list li {
    margin-bottom: 3em;
    display: block;
  }
}

.listOnBox {
  background: white;
  padding: 2em;
  max-width: 420px;
  z-index: 1;
}
@media only screen and (max-width: 870px) {
  .listOnBox {
    max-width: 100%;
    padding: 1em;
  }
}

#top_about {
  background: white url("/wp-content/themes/primenumbers/images/img_1.jpg") no-repeat right 6em fixed;
  background-size: cover;
  margin-top: 6vw;
}
@media only screen and (max-width: 870px) {
  #top_about {
    background: white url("/wp-content/themes/primenumbers/images/img_1_sp.jpg") no-repeat;
    background-size: cover;
  }
}
#top_about .containerW {
  position: relative;
  padding-bottom: 6em;
  padding-top: 6em;
}
@media only screen and (max-width: 870px) {
  #top_about .containerW {
    padding-bottom: 10%;
  }
}
@media only screen and (max-width: 870px) {
  #top_about .containerW {
    padding-top: 10%;
  }
}
#top_about h2 {
  position: absolute;
  top: -3em;
  font-size: 3em;
}
@media only screen and (max-width: 870px) {
  #top_about h2 {
    position: static;
    margin: -3.4em 0 auto auto;
    font-size: 2.5rem;
    padding-bottom: 1em;
  }
}
@media only screen and (max-width: 540px) {
  #top_about h2 {
    font-size: 6vw;
  }
}

.about_feature {
  margin: 0 auto 6em;
}
@media only screen and (max-width: 870px) {
  .about_feature {
    padding: 0 1rem;
  }
}
@media screen and (max-width: 980px) and (min-width: 540px) {
  .about_feature {
    width: 80%;
  }
}
.about_feature dl {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.about_feature dt {
  font-weight: bold;
  font-size: 1.2em;
  line-height: 1.4;
  margin-bottom: 1em;
  text-align: center;
  width: 100%;
}
.about_feature dd {
  font-size: 1.1em;
}
.about_feature li {
  background: rgba(255, 255, 255, 0.85);
  width: 48%;
  margin: 0 auto 3em;
  padding: 3em 2em;
}
@media only screen and (max-width: 870px) {
  .about_feature li {
    width: 100%;
    padding: 2em;
    margin: 0 auto 1em;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .about_feature li h3.titleMin {
    width: 20%;
    margin-bottom: 0;
  }
  .about_feature li dl {
    width: 80%;
  }
}
@media only screen and (max-width: 540px) {
  .about_feature li dl {
    width: 70%;
  }
}
@media only screen and (max-width: 870px) {
  .about_feature ol.flexSb {
    justify-content: center;
    flex-wrap: wrap;
  }
}
.about_feature .titleMin {
  text-align: center;
  margin-bottom: 2em;
  font-size: 1.4em;
}
.about_feature .titleMin span {
  background: #ffe103;
  text-align: center;
  font-size: 1.5em;
  border-radius: 1em;
  height: 2em;
  width: 2em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 0.2em;
}
@media only screen and (max-width: 540px) {
  .about_feature .titleMin span {
    margin-left: 0;
  }
}

#top_blog {
  padding-top: 6em;
  padding-bottom: 6em;
  z-index: 0;
}
@media only screen and (max-width: 870px) {
  #top_blog {
    padding-top: 10%;
  }
}
@media only screen and (max-width: 540px) {
  #top_blog {
    padding-bottom: 6em;
  }
}

.top_blog_list {
  margin-bottom: 4em;
}
@media only screen and (min-width: 871px) {
  .top_blog_list {
    margin-right: 2em;
  }
}
.top_blog_list > li {
  width: 100%;
  background: white;
  margin-bottom: 2em;
}
@media only screen and (max-width: 640px) {
  .top_blog_list > li {
    max-width: 100%;
    width: 100%;
  }
}
.top_blog_list > li dl {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media only screen and (max-width: 640px) {
  .top_blog_list > li dl {
    display: block;
  }
  .top_blog_list > li dl h3 {
    display: none;
  }
}
.top_blog_list > li dt {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  height: 160px;
  width: 310px;
}
@media only screen and (max-width: 870px) {
  .top_blog_list > li dt img {
    height: 180px;
    width: auto;
    max-width: 150%;
  }
}
@media only screen and (max-width: 640px) {
  .top_blog_list > li dt {
    width: 100%;
    height: auto;
  }
  .top_blog_list > li dt img {
    height: auto;
    width: 100%;
  }
}
.top_blog_list > li a:hover {
  opacity: 0.7;
}
.top_blog_list > li a:hover img {
  transform: scale(1.05);
  transition: all .2s;
}
.top_blog_list > li dd {
  padding: 1.8em 1.5em 1em;
  position: relative;
  width: calc(100% - 310px);
}
@media only screen and (min-width: 871px) {
  .top_blog_list > li dd {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }
}
@media only screen and (max-width: 640px) {
  .top_blog_list > li dd {
    width: 100%;
  }
}
.top_blog_list > li dd .top_blog_date,
.top_blog_list > li dd .blog_update {
  position: absolute;
  top: 0;
  text-align: right;
}
.top_blog_list > li dd .top_blog_date {
  background: #ffe103;
  right: 0;
}
.top_blog_list > li dd .blog_update {
  right: 7em;
}
.top_blog_list > li dd h3 {
  width: 100%;
  font-size: 1.4em;
  font-weight: 600;
  line-height: 1.4;
  text-align: left;
  padding-bottom: 1em;
}
@media only screen and (max-width: 540px) {
  .top_blog_list > li dd h3 {
    padding-bottom: 0.5em;
  }
}

@media only screen and (min-width: 871px) {
  .top_tag {
    position: absolute;
    left: 1.5em;
    bottom: 0;
    display: flex;
    align-items: center;
  }
  .top_tag .blog-category {
    margin-right: 1em;
  }
}

#top_news .containerW {
  padding-top: 6em;
  margin-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  #top_news .containerW {
    padding-top: 10%;
  }
}
@media only screen and (max-width: 870px) {
  #top_news .containerW {
    margin-bottom: 10%;
  }
}
#top_news ul {
  margin-left: 10vw;
}
@media only screen and (max-width: 870px) {
  #top_news ul {
    margin-left: 0;
    margin-top: 2em;
  }
}
#top_news ul li {
  line-height: 1.6;
  margin-bottom: 1em;
}
#top_news ul li p {
  line-height: 1.6;
}
#top_news ul li span {
  font-family: "Shippori Mincho", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
#top_news ul li a {
  text-decoration: underline;
  color: #006883;
}
#top_news ul li a:hover {
  text-decoration: none;
}

.news_day {
  width: 8.5em;
}

#top_recruit {
  padding-top: 6em;
  padding-bottom: 6em;
  z-index: 1;
}
@media only screen and (max-width: 870px) {
  #top_recruit {
    padding-top: 10%;
  }
}
@media only screen and (max-width: 870px) {
  #top_recruit {
    padding-bottom: 10%;
  }
}
#top_recruit h3.bg-bk {
  padding: 0.2em 1em;
  color: white;
  margin-top: 6em;
  margin-bottom: 3em;
  font-size: 1.24em;
}
@media only screen and (max-width: 870px) {
  #top_recruit h3.bg-bk {
    margin-top: 10%;
  }
}

.top_recruit_ceo {
  flex-wrap: wrap;
  justify-content: space-between;
}
.top_recruit_ceo p {
  max-height: 340px;
}
@media only screen and (max-width: 870px) {
  .top_recruit_ceo {
    justify-content: space-around;
  }
  .top_recruit_ceo p {
    height: 18vh;
    margin-bottom: 4vw;
  }
}
@media only screen and (max-width: 540px) {
  .top_recruit_ceo p {
    height: 24vh;
  }
}

p.title_disc {
  font-size: 1.2em;
  font-weight: bold;
  line-height: 1.4;
  margin-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  p.title_disc {
    margin-bottom: 10%;
  }
}

h3.title_rl {
  font-size: 1.9em;
  font-weight: bold;
}

.title_bdr {
  border-top: 1px solid;
  border-bottom: 1px solid;
  padding: 1em;
  margin: 5vw auto 3vw;
  font-size: 1.2em;
}

#topStaffInterview p._nameField {
  padding-top: 1vw;
  line-height: 1.4;
  text-align: left;
}

#topStaffInterview {
  margin-bottom: 3em;
}
#topStaffInterview > li {
  width: 310px;
  position: relative;
  margin: 0 auto 1em;
  background-image: url("/wp-content/themes/tn-child/images/bal_1.svg");
  background-repeat: no-repeat;
  background-position: top left;
  background-size: 94% auto;
}
@media only screen and (max-width: 540px) {
  #topStaffInterview > li {
    width: 100%;
    background-size: auto 180px;
    background-position: top center;
  }
}
#topStaffInterview > li:nth-child(2) {
  background-image: url("/wp-content/themes/tn-child/images/bal_2.svg");
}
#topStaffInterview > li:nth-child(3) {
  background-image: url("/wp-content/themes/tn-child/images/bal_3.svg");
}
#topStaffInterview a:hover img {
  transform: scale(1.05);
  transition: all .2s;
}
@media only screen and (max-width: 540px) {
  #topStaffInterview a:hover img {
    transform: none;
  }
}
#topStaffInterview a:hover img {
  opacity: 1;
}
#topStaffInterview .bal_1 p {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  text-align: left;
  line-height: 1.4;
  font-size: 1.1em;
  padding: 0 3em 0.6em;
  height: 180px;
}
@media only screen and (max-width: 870px) {
  #topStaffInterview .bal_1 p {
    font-size: 14px;
  }
}
@media only screen and (max-width: 540px) {
  #topStaffInterview .bal_1 p {
    padding: 0 4em 0.6em;
  }
}

.top_recruit_staff {
  height: 220px;
  overflow: hidden;
}
.top_recruit_staff img {
  max-width: 110%;
  object-fit: cover;
}

.bal_1 {
  z-index: 2;
}
.bal_1 img {
  height: 11em;
  width: auto;
  margin-bottom: -1em;
  position: relative;
}

#top_contact {
  z-index: -1;
  padding-top: 6vw;
  padding-bottom: 6em;
}
#top_contact p {
  margin-bottom: 1em;
}
@media only screen and (max-width: 870px) {
  #top_contact {
    padding-bottom: 10%;
  }
}
@media screen and (max-width: 414px) {
  #top_contact {
    padding-bottom: 4em;
  }
}
#top_contact .containerW.bg-white {
  height: 6em;
  margin-bottom: 6em;
}
@media only screen and (max-width: 870px) {
  #top_contact .containerW.bg-white {
    margin-bottom: 10%;
  }
}

.bg_bk h2 {
  color: white;
}

.home #top_contact .containerW.bg-white {
  background: #f5f5f5;
  height: 1px;
}

.contact_listBox li {
  width: calc(96% / 3);
  max-width: 18.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.contact_listBox li a {
  text-align: center;
  background: white;
  width: 100%;
  padding: 2em 1em 1em;
}
.contact_listBox li a:hover {
  background: #ffe103;
}
.contact_listBox li .lnr {
  font-size: 4em;
  display: block;
  margin-top: 1rem;
}
@media only screen and (max-width: 870px) {
  .contact_listBox {
    justify-content: space-around;
  }
}
@media screen and (max-width: 600px) {
  .contact_listBox li {
    width: 100%;
    margin-bottom: 1em;
  }
}

#gmap {
  margin-left: 3em;
  margin-bottom: 3em;
  border: 5px solid white;
}
@media only screen and (max-width: 870px) {
  #gmap {
    margin: 1em auto 3em;
  }
  #gmap iframe {
    width: 100%;
  }
}

.link_box_bb a {
  border: #5682b5 2px solid;
  padding: 0.5em 1em;
  display: block;
  text-align: center;
}
.link_box_bb a:hover {
  color: white;
  background-color: #5682b5;
}

#activity {
  background-image: url("/wp-content/themes/primenumbers/images/bg_01_top.svg"), url("/wp-content/themes/primenumbers/images/bg_01_btm.svg");
  background-position: top center, bottom center;
  background-repeat: no-repeat, no-repeat;
  background-color: #f1f4f7;
}
#activity .title {
  border-left-color: #1EAA39;
}
#activity .imgIllust {
  border-color: #cfe5ce;
}

.sa {
  opacity: 0;
  transition: all .5s ease;
}

.sa.show {
  opacity: 1;
  transform: none;
}

.ani-down {
  position: absolute;
  background-color: white;
  display: block;
  z-index: 1;
  width: 20px;
  height: 120%;
  bottom: 0;
  left: -10px;
}

.ani-up {
  position: absolute;
  background-color: white;
  display: block;
  z-index: 1;
  width: 100%;
  height: 100%;
  top: -100px;
  left: 0;
  opacity: 1;
}

.ani-down.sa {
  opacity: 1;
}

.ani-down.sa.show {
  opacity: 1;
  transition: all 1s ease;
  height: 1%;
}

.ani-up.sa.show {
  transition: all 0.6s ease;
  height: 0%;
  top: 0;
}

.sa--scaleUp {
  transform: scale(0.5);
}

.sa--scaleDown {
  transform: scale(1.1);
}

.sa--up {
  transform: translate(0, 30px);
}

.sa--down {
  transform: translate(0, -30px);
}

._gray {
  background-color: #f1f4f7;
}

.kvarea {
  animation: animate 200s infinite running linear;
}

.area {
  width: 100%;
  overflow-x: hidden;
  z-index: -1;
}

.circles {
  z-index: -1;
  position: absolute;
  overflow: hidden;
  top: 50px;
  left: 0;
  width: 100%;
  height: 200vh;
}
@media only screen and (max-width: 540px) {
  .circles {
    height: 100vh;
  }
}

.circles li {
  width: 150%;
  height: 120%;
  position: absolute;
  display: block;
  opacity: 0.5;
  background: url("/wp-content/themes/primenumbers/images/bg_kv.png") no-repeat left top;
  background-size: cover;
  animation: animate 200s infinite running linear alternate;
  top: -10%;
  left: -20%;
}
@media only screen and (max-width: 870px) {
  .circles li {
    animation: animate 50s infinite running linear alternate;
  }
}

@keyframes animate {
  0% {
    transform: translateX(-10%) rotate(0) translateY(-10%);
  }
  100% {
    transform: translateX(15%) rotate(-20deg) translateY(-5%);
  }
}
@font-face {
  font-family: 'icomoon';
  src: url("../font/icomoon.eot");
  src: url("../font/icomoon.eot") format("embedded-opentype"), url("../font/icomoon.ttf") format("truetype"), url("../font/icomoon.woff") format("woff"), url("../font/icomoon.svg") 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;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-facebook2:before {
  content: "\ea91";
}

.icon-twitter:before {
  content: "\ea96";
}

#breadCrumb {
  z-index: 10;
  font-size: 0.7em;
  position: absolute;
  top: 60px;
  left: 1em;
  color: white;
  text-shadow: 1px 1px 2px black;
}
#breadCrumb strong {
  font-weight: normal;
}
#breadCrumb a {
  text-decoration: underline;
  color: white;
}
#breadCrumb a:hover {
  text-decoration: none;
}
#breadCrumb a,
#breadCrumb .current {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 10em;
}

.breadcrumbs .current-item {
  display: inline-block;
  vertical-align: middle;
  max-width: 20em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

body.home #breadCrumb {
  display: none;
}

@media only screen and (max-width: 540px) {
  .grecaptcha-badge {
    display: none;
  }
}
.bg_bk {
  background-color: #100313;
}

.borderBox {
  border: 1px solid #100313;
  padding: 1em;
}

.fit-content {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}

.list {
  border: 1px solid;
  padding: 1em;
  margin-bottom: 2em;
}
.list li {
  font-size: 1.2em;
  margin-left: 1.5em;
}
.list li::before {
  margin-left: -1.2em;
  content: "";
  display: inline-block;
  height: 0.8em;
  width: 0.8em;
  border-radius: 100%;
  background-color: #006883;
  margin-right: 0.4em;
}
@media only screen and (max-width: 540px) {
  .list li {
    font-size: 1.1em;
    line-height: 1.6;
  }
}

mark {
  background: linear-gradient(transparent 50%, #FFF44B 0%);
}

.blog_main p,
.blog_main li {
  font-size: 17px;
  line-height: 180%;
}
@media only screen and (min-width: 871px) {
  .blog_main p,
  .blog_main li {
    font-size: 20px;
  }
}
.blog_main .container._Small {
  max-width: 720px;
}

.blog_main h3 {
  margin-top: 4em;
  margin-bottom: 2em;
}
.blog_main h2 {
  text-align: left;
  border-top: none;
  border-bottom: 1px solid #999999;
}
