@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

/*---------------------------------------
*   breake point
*---------------------------------------*/ /*---------------------------------------
*   media_query
*---------------------------------------*/ /*---------------------------------------
*   基本のstyleの指定
*---------------------------------------*/
body {
  color: #333;
  line-height: 1.8;
  font-family: "Noto Serif JP", "Noto Serif", sans-serif;
}
body * {
  box-sizing: border-box;
}

ul {
  list-style: none;
}

li {
  list-style: none;
}

a {
  color: #333;
  text-decoration: none;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

p {
  margin-bottom: 1.5em;
}
p:last-of-type {
  margin-bottom: 0;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
}

h2 {
  font-size: 1.5rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  h2 {
    font-size: 1.25rem;
  }
}

/*---------------------------------------
*   .blContainer(共通)
*---------------------------------------*/
.blContainer {
  max-width: 1280px;
  width: 92%;
  margin-right: auto;
  margin-left: auto;
}

section {
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  section {
    margin-bottom: 50px;
  }
}

h3 {
  color: #000;
  font-size: 1.5rem;
  font-style: normal;
  font-weight: 400;
}

h4 {
  font-size: 1.125rem;
  font-weight: 500;
}

/*--------------------------------------
    サイドバーレイアウト
----------------------------------------*/
.flexLayout {
  display: flex;
  gap: 50px;
  justify-content: space-around;
}
.flexLayout__main {
  flex: 1 1 auto;
}
.flexLayout__sidebar {
  flex: 0 0 250px;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .flexLayout__sidebar {
    display: none;
  }
}

.fa-line {
  color: #00B900;
  background-color: #ffffff;
  border-radius: 7px;
}

.btn {
  text-align: center;
}
.btn__wrapper {
  display: inline-block;
  text-align: center;
  border: 3px solid #4D6EB5;
  border-radius: 10px;
  background: linear-gradient(to top, #0B1026 0%, #1F3667 50%, #0B1026 100%);
}
.btn__wrapper:hover {
  cursor: pointer;
  transform: scale(1.05);
  transition: all ease 0.5s;
  background: linear-gradient(to top, #878788 0%, #1F3667 50%, #878788 100%);
}
.btn__text {
  color: #FFFFFF;
  padding: 0 30px;
  font-size: 0.875rem;
  font-weight: 100;
}
@media screen and (max-width: 575px) {
  .btn__text {
    font-size: 0.75rem;
    padding: 0 20px;
  }
}

.recruitBtn {
  text-align: center;
}
.recruitBtn__textWrap {
  margin-bottom: 20px;
}
.recruitBtn__catch {
  font-weight: 700;
}
@media screen and (max-width: 575px) {
  .recruitBtn__catch {
    font-size: 1rem;
  }
}
@media screen and (max-width: 400px) {
  .recruitBtn__catch {
    font-size: 0.875rem;
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 767px) {
  .recruitBtn__subCatch {
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 400px) {
  .recruitBtn__subCatch {
    font-size: 0.75rem;
  }
}
.recruitBtn__break1 {
  display: none;
}
@media screen and (max-width: 575px) {
  .recruitBtn__break1 {
    display: block;
  }
}
.recruitBtn__break2 {
  display: none;
}
@media screen and (max-width: 575px) {
  .recruitBtn__break2 {
    display: block;
  }
}
.recruitBtn__link {
  display: inline-block;
  background: #28008E;
  text-align: center;
  color: var(--white);
  width: 850px;
  border-radius: 40px;
  margin: 0 auto;
  padding-top: 15px;
  padding-bottom: 15px;
  font-size: 1.75rem;
  font-weight: bold;
  transition: all ease 0.2s;
}
.recruitBtn__link:hover {
  opacity: 0.8;
  transform: scale(1.05);
  cursor: pointer;
  transition: all ease 0.3s;
}
@media screen and (max-width: 1024px) {
  .recruitBtn__link {
    width: 700px;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 767px) {
  .recruitBtn__link {
    width: 550px;
    font-size: 1.25rem;
  }
}
@media screen and (max-width: 575px) {
  .recruitBtn__link {
    width: 350px;
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 400px) {
  .recruitBtn__link {
    width: 270px;
  }
}
@media screen and (max-width: 575px) {
  .recruitBtn__lineBtnText {
    font-size: 0.875rem;
  }
}

.page-numbers {
  background: #2B0097;
  color: var(--white);
  padding: 0.1em 0.4em;
  margin-right: 0.2em;
}
.page-numbers:hover {
  opacity: 0.7;
  cursor: pointer;
}

/*----------------------------------------
        Variables
----------------------------------------*/
:root {
  --red: #FF2A2A;
  --gray: #E8E8E8;
  --light_blue: #E9F1FB;
  --light_green: #6CEB78;
  --light-gray: #EEEEEE;
  --brown: #9a0413;
  --black: #333333;
  --white: #FFFFFF;
}

/*----------------------------------------
    header
----------------------------------------*/
#myCanvas {
  width: 100%;
  height: 100%;
  z-index: 1;
  margin-bottom: 100px;
}

.header {
  position: absolute;
  top: 10px;
  right: 0;
  left: 0;
  color: var(--white);
  display: flex;
}
.header__logoWrapper {
  z-index: 9999;
}
@media screen and (max-width: 400px) {
  .header__logoWrapper {
    width: 100px;
  }
}
.header__logo {
  width: 100%;
  height: 100%;
}
.header__nav {
  margin-top: auto;
  margin-bottom: auto;
  margin-left: auto;
  margin-right: 50px;
}
@media screen and (max-width: 767px) {
  .header__nav {
    display: none;
  }
}
.header__navList {
  font-size: 1rem;
  display: flex;
}
.header__navItem {
  margin-top: auto;
  margin-bottom: auto;
}
.header__navLink {
  text-decoration: none;
  display: inline-block;
  margin: 0 20px;
  color: var(--white);
  white-space: nowrap;
}
.header__navLink:hover {
  opacity: 0.5;
  cursor: pointer;
  transition: all ease 0.3s;
  transform: scale(1.05);
}
@media screen and (max-width: 767px) {
  .header__navLink:hover {
    opacity: 1;
    cursor: default;
    transition: none;
    transform: scale(1);
  }
}
@media screen and (max-width: 1024px) {
  .header__navLink {
    font-size: 0.75rem;
    margin: 0 10px;
  }
}
.header__navLine {
  display: flex;
  flex-direction: column;
  margin-left: 30px;
}
.header__navLineLink {
  text-align: center;
}
.header__iconDescription {
  font-size: 0.625rem;
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .header__iconDescription {
    font-size: 0.5rem;
  }
}

.spIcon {
  display: none;
}
@media screen and (max-width: 767px) {
  .spIcon {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 17px;
    right: 100px;
    z-index: 9997;
  }
}
.spIcon__navLineLink {
  text-align: center;
}
.spIcon__navLineLink:hover {
  opacity: 0.5;
  cursor: pointer;
  transition: all ease 0.3s;
  transform: scale(1.05);
}
@media screen and (max-width: 767px) {
  .spIcon__navLineLink:hover {
    opacity: 1;
    transform: scale(1);
    cursor: default;
    transition: none;
  }
}
.spIcon__iconDescription {
  font-size: 0.625rem;
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .spIcon__iconDescription {
    font-size: 0.5rem;
  }
}

/*-------------------------------------------------
*   スマホメニュー
*--------------------------------------------------*/
.hamburger {
  display: none;
  position: absolute;
  top: 10px;
  right: 15px;
  width: 52px;
  height: 50px;
  z-index: 9995;
  background: var(--white);
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .hamburger {
    display: block;
  }
}
.hamburger span {
  position: absolute;
  top: 50%;
  left: 8px;
  right: 8px;
  height: 2px;
  background: var(--black);
  transition: all ease 0.2s;
}
.hamburger::before {
  content: "";
  position: absolute;
  top: calc(50% - 10px);
  left: 8px;
  right: 8px;
  height: 2px;
  background: var(--black);
  transition: all ease 0.2s;
}
.hamburger::after {
  content: "";
  position: absolute;
  bottom: calc(50% - 12px);
  left: 8px;
  right: 8px;
  height: 2px;
  background: var(--black);
  transition: all ease 0.2s;
}

#menuToggle:checked ~ .spMenu {
  transform: translateX(0);
}

#menuToggle:checked ~ .hamburger span {
  left: 15px;
}
#menuToggle:checked ~ .hamburger::after {
  left: 25px;
}

#menuToggle {
  position: fixed;
  left: -100vw;
}
#menuToggle:focus-visible ~ .hamburger {
  box-shadow: 1px 1px 5px 0 rgb(0, 0, 0);
}

#menuToggle {
  position: fixed;
  left: -99999999vw;
}

.spMenu {
  transform: translateX(-200vw);
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9990;
  padding: 30px;
  background: linear-gradient(180deg, #333333 0%, #D9D9D9 100%);
  color: var(--white);
  display: grid;
  place-content: center;
  transition: all ease 0.3s;
}
.spMenu__item {
  padding-bottom: 20px;
  text-align: center;
}
.spMenu__item:hover {
  opacity: 0.5;
  cursor: pointer;
  transition: all ease 0.3s;
  transform: scale(1.05);
}
@media screen and (max-width: 767px) {
  .spMenu__item:hover {
    opacity: 1;
    transform: scale(1);
    cursor: default;
    transition: none;
  }
}
.spMenu__link {
  display: block;
  color: var(--white);
}

.keyVisual {
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  color: white;
  transform: translate(-50%, -50%);
}
.keyVisual__title {
  font-size: 2rem;
  padding: 0px;
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .keyVisual__title {
    font-size: 1.5rem;
  }
}
@media screen and (max-width: 767px) {
  .keyVisual__title {
    font-size: 1.125rem;
  }
}
.keyVisual__descriptionEn {
  white-space: nowrap;
}
@media screen and (max-width: 400px) {
  .keyVisual__descriptionEn {
    font-size: 0.75rem;
  }
}
.keyVisual__descriptionJp {
  font-size: 1.875rem;
  margin-bottom: 30px;
  white-space: nowrap;
}
@media screen and (max-width: 400px) {
  .keyVisual__descriptionJp {
    font-size: 1.25rem;
  }
}
.keyVisual__break {
  display: none;
}
@media screen and (max-width: 1024px) {
  .keyVisual__break {
    display: block;
  }
}

/*----------------------------------------
    about
----------------------------------------*/
.aboutTop__title {
  text-align: center;
  margin-bottom: 80px;
}
@media screen and (max-width: 1024px) {
  .aboutTop__title {
    margin-bottom: 50px;
  }
}
.aboutTop__contentsWrapper {
  display: flex;
  gap: 80px;
}
@media screen and (max-width: 1024px) {
  .aboutTop__contentsWrapper {
    flex-direction: column;
  }
}
@media screen and (max-width: 575px) {
  .aboutTop__contentsWrapper {
    gap: 30px;
  }
}
.aboutTop__imgWrapper {
  flex: 1 1 auto;
}
.aboutTop__textWrapper {
  flex: 1 1 600px;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 1024px) {
  .aboutTop__textWrapper {
    flex: 1 1 auto;
  }
}
.aboutTop__img {
  width: 100%;
  height: 100%;
}
.aboutTop__catch {
  margin-bottom: 20px;
  text-align: center;
}
.aboutTop__text {
  padding-bottom: 20px;
  font-size: 0.875rem;
}
@media screen and (max-width: 1024px) {
  .aboutTop__text {
    text-align: center;
    padding-bottom: 0;
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 767px) {
  .aboutTop__text {
    text-align: left;
  }
}
.aboutTop__break1 {
  display: block;
}
@media screen and (max-width: 767px) {
  .aboutTop__break1 {
    display: none;
  }
}

/*----------------------------------------
    column
----------------------------------------*/
.columnTop__title {
  text-align: center;
  margin-bottom: 80px;
}
@media screen and (max-width: 1024px) {
  .columnTop__title {
    margin-bottom: 50px;
  }
}
@media screen and (max-width: 767px) {
  .columnTop__contentsWrapper {
    margin-bottom: 50px;
  }
}
.columnTop__list {
  display: flex;
  gap: 50px;
  justify-content: center;
  margin-bottom: 80px;
}
@media screen and (max-width: 1200px) {
  .columnTop__list {
    flex-wrap: wrap;
  }
}
.columnTop__listItem {
  width: 30%;
  display: flex;
  align-items: center;
  flex-direction: column;
  border-radius: 10px;
  box-shadow: 5px 5px 10px 5px var(--light-gray);
}
@media screen and (max-width: 767px) {
  .columnTop__listItem {
    width: 45%;
  }
}
@media screen and (max-width: 575px) {
  .columnTop__listItem {
    width: 80%;
  }
}
.columnTop__listItem:hover {
  cursor: pointer;
  transform: scale(1.05);
  transition: all ease 0.3s;
}
@media screen and (max-width: 767px) {
  .columnTop__listItem:hover {
    transform: scale(1);
    cursor: default;
    transition: none;
  }
}
.columnTop__cardLink {
  display: flex;
  flex-direction: column;
}
.columnTop__imgWrap {
  width: 100%;
  height: 200px;
}
@media screen and (max-width: 767px) {
  .columnTop__imgWrap {
    height: 150px;
  }
}
.columnTop__img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.columnTop__articleTextWrap {
  padding: 10px;
  display: flex;
  flex-direction: column;
  height: 200px;
}
@media screen and (max-width: 767px) {
  .columnTop__articleTextWrap {
    height: auto;
  }
}
.columnTop__date {
  margin-top: 15px;
  font-size: 0.875rem;
}
@media screen and (max-width: 767px) {
  .columnTop__date {
    font-size: 0.625rem;
  }
}
.columnTop__articleTitle {
  margin-top: 5px;
  font-size: 0.9375rem;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .columnTop__articleTitle {
    font-size: 0.875rem;
  }
}
.columnTop__excerpt {
  font-size: 0.875rem;
  margin-top: auto;
  padding-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .columnTop__excerpt {
    font-size: 0.75rem;
    margin-top: 10px;
    padding-bottom: 0;
  }
}

.wp-post-image {
  width: 100%;
  height: 100%;
  padding: 10px;
  -o-object-fit: cover;
     object-fit: cover;
}

.archiveColumn__title {
  text-align: center;
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .archiveColumn__title {
    margin-bottom: 30px;
  }
}
.archiveColumn__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 80px;
  place-content: center;
  margin-bottom: 50px;
}
@media screen and (max-width: 1200px) {
  .archiveColumn__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .archiveColumn__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .archiveColumn__list {
    grid-template-columns: repeat(1, 1fr);
    width: 80%;
    margin: 0 auto;
  }
}
.archiveColumn__listItem {
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  border-radius: 10px;
  box-shadow: 5px 5px 10px 5px var(--light-gray);
}
.archiveColumn__listItem:hover {
  cursor: pointer;
  transform: scale(1.05);
  transition: all ease 0.3s;
}
@media screen and (max-width: 767px) {
  .archiveColumn__listItem:hover {
    cursor: default;
    transform: scale(1);
    transition: none;
  }
}
.archiveColumn__cardLink {
  display: flex;
  flex-direction: column;
}
.archiveColumn__imgWrap {
  width: 100%;
  height: 200px;
}
.archiveColumn__img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.archiveColumn__articleTextWrap {
  padding: 10px;
  display: flex;
  flex-direction: column;
  height: 200px;
}
.archiveColumn__date {
  margin-top: 15px;
  font-size: 0.875rem;
}
@media screen and (max-width: 575px) {
  .archiveColumn__date {
    margin-top: 10px;
  }
}
.archiveColumn__articleTitle {
  margin-top: 5px;
  font-size: 0.9375rem;
  font-weight: 600;
}
.archiveColumn__excerpt {
  font-size: 0.75rem;
  margin-top: auto;
  padding-bottom: 10px;
}
@media screen and (max-width: 575px) {
  .archiveColumn__excerpt {
    margin-top: 15px;
  }
}

@media screen and (max-width: 575px) {
  .nav-links {
    text-align: center;
  }
}

/*--------------------------------------
    カテゴリー一覧とタグ一覧ページのレイアウト
----------------------------------------*/
.category__title {
  font-size: 1rem;
  margin-bottom: 20px;
}

.tag__title {
  font-size: 1rem;
  margin-bottom: 20px;
}

/*----------------------------------------
    business
----------------------------------------*/
.businessTop__title {
  margin-bottom: 50px;
  text-align: center;
}
.businessTop__catch {
  margin-bottom: 50px;
  text-align: center;
  background: var(--gray);
}
@media screen and (max-width: 1024px) {
  .businessTop__catch {
    font-size: 1, 25rem;
  }
}
@media screen and (max-width: 767px) {
  .businessTop__catch {
    font-size: 0.875rem;
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 400px) {
  .businessTop__catch {
    font-size: 0.625rem;
  }
}
.businessTop__contentsWrap {
  display: flex;
  gap: 20px;
  margin-bottom: 80px;
}
@media screen and (max-width: 1024px) {
  .businessTop__contentsWrap {
    flex-direction: column;
    margin-bottom: 80px;
  }
}
.businessTop__imgWrap {
  flex: 1 1 auto;
}
@media screen and (max-width: 1024px) {
  .businessTop__imgWrap {
    height: 300px;
  }
}
.businessTop__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.businessTop__textWrap {
  flex: 1 1 600px;
  text-align: center;
  margin: 0 auto;
}
@media screen and (max-width: 1024px) {
  .businessTop__textWrap {
    flex: 1 1 auto;
  }
}
.businessTop__subTitle {
  font-weight: 700;
  margin-bottom: 30px;
}
@media screen and (max-width: 1024px) {
  .businessTop__subTitle {
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 767px) {
  .businessTop__subTitle {
    text-align: left;
  }
}
.businessTop__text {
  font-size: 0.875rem;
}
@media screen and (max-width: 767px) {
  .businessTop__text {
    text-align: left;
    padding-bottom: 0;
    font-size: 0.75rem;
  }
}
.businessTop__btn {
  margin-top: 50px;
}
.businessTop__break1 {
  display: block;
}
@media screen and (max-width: 767px) {
  .businessTop__break1 {
    display: none;
  }
}

.business__reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 1024px) {
  .business__reverse {
    flex-direction: column;
  }
}

/*----------------------------------------
    recruit
----------------------------------------*/
.recruitTop__title {
  margin-bottom: 50px;
  text-align: center;
}
.recruitTop__imgWrapper {
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .recruitTop__imgWrapper {
    margin-bottom: 50px;
  }
}
.recruitTop__img {
  width: 100%;
  height: 100%;
}
.recruitTop__textWrapper {
  text-align: center;
  margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .recruitTop__textWrapper {
    text-align: left;
  }
}
.recruitTop__catch {
  font-weight: 700;
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  .recruitTop__catch {
    font-size: 0.875rem;
  }
}
.recruitTop__text {
  font-size: 0.875rem;
}
@media screen and (max-width: 767px) {
  .recruitTop__text {
    font-size: 0.75rem;
  }
}
.recruitTop__break1 {
  display: block;
}
@media screen and (max-width: 767px) {
  .recruitTop__break1 {
    display: none;
  }
}

.recruitSystem__title {
  text-align: center;
  margin-bottom: 50px;
}
.recruitSystem__list {
  display: grid;
  place-content: center;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
  gap: 50px;
}
@media screen and (max-width: 1024px) {
  .recruitSystem__list {
    grid-template-columns: repeat(2, 1fr);
    width: 700px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .recruitSystem__list {
    width: 500px;
  }
}
@media screen and (max-width: 575px) {
  .recruitSystem__list {
    display: flex;
    flex-direction: column;
    width: 300px;
  }
}
.recruitSystem__listItem {
  padding: 30px 25px 30px;
  background: #260c68;
  text-align: center;
}
.recruitSystem__imgWrap {
  display: block;
  margin: 0 auto;
  margin-bottom: 10px;
  width: 90%;
  height: 200px;
}
.recruitSystem__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.recruitSystem__cardTitle {
  margin-bottom: 20px;
  color: var(--white);
}
.recruitSystem__description {
  align-items: center;
  font-size: 0.875rem;
  color: var(--white);
}

.recruitFlow {
  grid-column: span 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.recruitFlow__title {
  text-align: center;
  padding-top: 20px;
  margin-bottom: 30px;
}
.recruitFlow__itemWrapper {
  margin-bottom: 20px;
  display: flex;
  justify-content: center;
  gap: 100px;
}
@media screen and (max-width: 767px) {
  .recruitFlow__itemWrapper {
    gap: 50px;
  }
}
@media screen and (max-width: 575px) {
  .recruitFlow__itemWrapper {
    gap: 20px;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 400px) {
  .recruitFlow__itemWrapper {
    gap: 10px;
    margin-bottom: 40px;
  }
}
.recruitFlow__itemInner {
  text-align: center;
}
.recruitFlow__numberWrap {
  width: 50px;
  height: 50px;
  margin-bottom: 10px;
  text-align: center;
  border-radius: 100%;
}
.recruitFlow__term {
  font-size: 0.75rem;
}
.recruitFlow__number {
  display: grid;
  place-content: center;
  padding-top: 10px;
}
.recruitFlow__text {
  text-align: center;
  font-size: 0.75rem;
  line-height: 1.3;
}
.step1,
.step5 {
  background: #50A7FF;
}

.step2,
.step3,
.step4 {
  background: #CCE9FF;
}

.president__title {
  margin-bottom: 50px;
  text-align: center;
}
.president__contentsWrap {
  display: flex;
  align-items: center;
  gap: 50px;
  margin-bottom: 100px;
}
@media screen and (max-width: 767px) {
  .president__contentsWrap {
    flex-direction: column;
    margin-bottom: 80px;
  }
}
.president__imgWrap {
  flex: 1 0 350px;
  height: 500px;
}
@media screen and (max-width: 767px) {
  .president__imgWrap {
    width: 92%;
    height: 500px;
    margin: 0 auto;
  }
}
.president__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center 15%;
     object-position: center 15%;
}
.president__textWrap {
  flex: 1 1 600px;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .president__textWrap {
    flex: 1 1 auto;
    font-size: 0.875rem;
  }
}
.president__catch {
  font-size: 1.25rem;
  font-weight: 500;
  margin-bottom: 20px;
}
.president__text {
  font-size: 0.875rem;
}
@media screen and (max-width: 767px) {
  .president__text {
    text-align: center;
    padding-bottom: 0;
    font-size: 0.75rem;
  }
}

/*----------------------------------------
    footer
----------------------------------------*/
.footer {
  background: linear-gradient(90deg, #D9D9D9 0%, #333 100%);
}
@media screen and (max-width: 575px) {
  .footer {
    padding-top: 50px;
  }
}
.footer__navWrapper {
  display: flex;
  justify-content: space-evenly;
  padding: 100px 0 100px;
}
@media screen and (max-width: 575px) {
  .footer__navWrapper {
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 575px) {
  .footer__navWrapper {
    position: relative;
  }
}
@media screen and (max-width: 575px) {
  .footer__logoWrapper {
    position: absolute;
    top: 10px;
    left: 5px;
  }
}
.footer__nav {
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 575px) {
  .footer__nav {
    gap: 10px;
    padding-top: 50px;
  }
}
.footer__navList {
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 767px) {
  .footer__navList {
    flex-direction: column;
    gap: 20px;
  }
}
.footer__navListInner {
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 1024px) {
  .footer__navListInner {
    flex-direction: column;
    justify-content: flex-start;
  }
}
@media screen and (max-width: 767px) {
  .footer__navListInner {
    height: auto;
    gap: 20px;
  }
}
@media screen and (max-width: 1024px) {
  .footer__navItem {
    height: 100px;
  }
}
@media screen and (max-width: 767px) {
  .footer__navItem {
    height: auto;
  }
}
.footer__navLink {
  font-size: 0.875rem;
  font-weight: bold;
  color: var(--white);
}
.footer__navLink:hover {
  transition: all ease 0.3s;
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .footer__navLink:hover {
    transition: none;
    opacity: 1;
  }
}
@media screen and (max-width: 575px) {
  .footer__navLink {
    font-size: 0.75rem;
  }
}
.footer__subLinkWrap {
  display: flex;
  flex-direction: column;
  padding-left: 20px;
}
.footer__subLink {
  font-size: 0.75rem;
  color: var(--white);
  white-space: nowrap;
  position: relative;
}
.footer__subLink::before {
  content: "";
  width: 10px;
  height: 10px;
  border-left: 1px dotted var(--white);
  border-bottom: 1px dotted var(--white);
  position: absolute;
  left: -15px;
}
.footer__subLink:hover {
  transition: all ease 0.3s;
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .footer__subLink:hover {
    transition: none;
    opacity: 1;
  }
}
@media screen and (max-width: 575px) {
  .footer__subLink {
    font-size: 0.625rem;
  }
}
.footer__lineWrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .footer__lineWrap {
    padding-top: 20px;
    justify-content: flex-start;
  }
}
@media screen and (max-width: 575px) {
  .footer__lineWrap {
    position: absolute;
    top: 22px;
    right: 20px;
  }
}
.footer__lineLink {
  text-align: center;
}
.footer__lineLink:hover {
  transform: scale(1.05);
  transition: all ease 0.3s;
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .footer__lineLink:hover {
    transform: scale(1);
    transition: none;
    opacity: 1;
  }
}
@media screen and (max-width: 575px) {
  .footer__lineIcon {
    font-size: 2rem;
    margin-bottom: 10px;
  }
}
.footer__lineDescription {
  color: var(--white);
  font-size: 0.75rem;
  white-space: nowrap;
}
@media screen and (max-width: 575px) {
  .footer__lineDescription {
    font-size: 0.625rem;
  }
}
.footer__copyWrap {
  text-align: center;
}
.footer__copy {
  font-size: 0.625rem;
  color: var(--white);
}

/*----------------------------------------
    company
----------------------------------------*/
.company__title {
  text-align: center;
  margin-bottom: 50px;
}
.company__table {
  width: 80%;
  margin: 0 auto;
  border-collapse: separate;
  border-spacing: 0 30px;
}
@media screen and (max-width: 575px) {
  .company__table {
    width: 90%;
  }
}
@media screen and (max-width: 575px) {
  .company__tableRow {
    display: flex;
    flex-direction: column;
  }
}
.company__tableHeader {
  padding-left: 20%;
  -moz-text-align-last: left;
       text-align-last: left;
  border-bottom: 1px solid var(--gray);
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .company__tableHeader {
    font-size: 0.75rem;
  }
}
@media screen and (max-width: 575px) {
  .company__tableHeader {
    border-bottom: none;
    padding-left: 15%;
  }
}
.company__tableData {
  width: 100%;
  border-bottom: 1px solid var(--gray);
  padding-left: 40%;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .company__tableData {
    font-size: 0.75rem;
    padding-left: 35%;
  }
}
@media screen and (max-width: 575px) {
  .company__tableData {
    padding-left: 40%;
  }
}
@media screen and (max-width: 400px) {
  .company__tableData {
    padding-left: 30%;
  }
}
.company__btn {
  margin-top: 30px;
}

/*-------------------------------------------
    サイドバー
    .sidebar(サイドバーのレイアウト)
--------------------------------------------*/
@media screen and (max-width: 1024px) {
  .sidebar {
    display: none;
  }
}
.sidebar__term {
  font-size: 1rem;
  font-weight: bold;
  margin-top: 25px;
  margin-bottom: 10px;
  padding-left: 20px;
  background: var(--light-gray);
}
.sidebar__description {
  font-size: 0.875rem;
  font-weight: 500;
  padding-left: 40px;
  margin-bottom: 15px;
  border-bottom: 1px solid var(--light-gray);
}
.sidebar__description:last-child {
  margin-bottom: 0;
}
.sidebar__description:hover {
  opacity: 0.5;
  transform: scale(1.05);
  transition: all ease 0.5s;
}
@media screen and (max-width: 767px) {
  .sidebar__description:hover {
    opacity: 1;
    transform: scale(1);
    transition: none;
  }
}
.sidebar__middleHeading {
  color: var(--black);
  font-weight: bold;
  font-size: 0.75rem;
  margin-top: 20px;
  margin-left: 25px;
  margin-bottom: 15px;
}
.sidebar__tagInner {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding-left: 40px;
}
.sidebar__descriptionTags {
  border: 1px solid var(--red);
  border-radius: 20px;
  font-size: 0.75rem;
  padding: 0.1em 0.4em;
}
.sidebar__descriptionTags:hover {
  transform: scale(1.05);
  opacity: 0.5;
  transition: all ease 0.5s;
}
@media screen and (max-width: 767px) {
  .sidebar__descriptionTags:hover {
    transform: scale(1);
    opacity: 1;
    transition: none;
  }
}

/*-------------------------------------------
    投稿記事ページ
--------------------------------------------*/
.single {
  margin-bottom: 50px;
}
.single__date {
  margin-bottom: 10px;
}
@media screen and (max-width: 575px) {
  .single__date {
    font-size: 0.875rem;
  }
}
.single__title {
  margin-bottom: 10px;
}
@media screen and (max-width: 575px) {
  .single__title {
    font-size: 0.875rem;
  }
}
.single__imgWrap {
  margin-bottom: 10px;
}
.single__category {
  margin-bottom: 10px;
  font-weight: 500;
  font-size: 0.875rem;
}
.single__category__category a {
  opacity: 0.7;
}
@media screen and (max-width: 575px) {
  .single__category {
    font-size: 0.75rem;
  }
}
.single__tag {
  margin-bottom: 50px;
  font-weight: 500;
  font-size: 0.875rem;
}
@media screen and (max-width: 575px) {
  .single__tag {
    font-size: 0.75rem;
  }
}
.single__tag > a {
  border: 1px solid var(--red);
  border-radius: 20px;
  font-size: 0.75rem;
  padding: 0.1em 0.4em;
}
.single__tag > a:hover {
  transform: scale(1.05);
}
@media screen and (max-width: 767px) {
  .single__tag > a:hover {
    transform: scale(1);
  }
}
.single__category > a, .single__tag > a {
  display: inline-block;
}
.single__category > a:hover, .single__tag > a:hover {
  transition: all ease 0.5s;
  opacity: 0.5;
}
@media screen and (max-width: 767px) {
  .single__category > a:hover, .single__tag > a:hover {
    transform: none;
    opacity: 1;
  }
}
.single__text {
  font-size: 0.875rem;
  margin-bottom: 80px;
}
@media screen and (max-width: 575px) {
  .single__text {
    font-size: 0.625rem;
  }
}
/*# sourceMappingURL=style.css.map */