@charset "UTF-8";

/*reset*/
/*
  Josh W. Comeau's Custom CSS Reset
  www.joshwcomeau.com
*/
/* 1. ボックスモデルの修正：余白や境界線が幅を壊さないようにする */
*,
*:hover,
*::before,
*::after {
 box-sizing: border-box;
}
/* 2. デフォルトの余白を削除 */
* {
 margin: 0;
}
/* 3. 本文の行間を整え、フォントのレンダリングを滑らかにする */
body {
 line-height: 1.5;
 /* -webkit-font-smoothing: antialiased; */
}
/* 4. メディア要素（画像など）がはみ出さないようにし、ブロック要素化する */
img,
picture,
video,
canvas,
svg {
 display: block;
 max-width: 100%;
}
/* 5. フォーム要素が親のフォント設定を無視するのを防ぐ */
input,
button,
textarea,
select {
 font: inherit;
}
/* 6. 長い単語が画面からはみ出して横スクロールが出るのを防ぐ */
p,
h1,
h2,
h3,
h4,
h5,
h6 {
 overflow-wrap: break-word;
}
/* 7. ルート（#rootや#__nextなど）にスタック文脈を作成する（Reactなどのフレームワーク用） */
#root,
#__next {
 isolation: isolate;
}
/*reset_end*/



/*all*/
@media screen and (max-width:768px) {
 .sp_none {
  display: none;
 }
}
@media screen and (max-width:1100px) {
 .tb_none {
  display: none;
 }
 .tb_block {
  display: block;
 }
}
@media screen and (min-width:769px) {
 .pc_none {
  display: none;
 }
}
@media screen and (min-width: 1101px) {
 .tb_block {
  display: none;
 }
}

body {
 font-size: 16px;
 line-height: 30px;
}
body a {
 text-decoration: none;
 color: inherit;
}
ul,
li {
 margin: 0;
 padding: 0;
 list-style: none;
}
.section_inner {
 width: 100%;
 max-width: 1000px;
 margin: 0 auto;
}
@media screen and (min-width: 769px) and (max-width: 1100px) {
 .section_inner {
  width: 90%;
 }
}
@media screen and (max-width:768px) {
 body {
  font-size: 14px;
 }
 .section_inner {
  width: 90%;
 }
}
/* fadeup */
.js-fade-up {
 opacity: 0;
 transform: translateY(48px);
 transition:
  opacity 1.4s ease-out,
  transform 1.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.js-fade-up.is-visible {
 opacity: 1;
 transform: translateY(0);
}

/*btn_slide*/
.btn_slide {
 position: relative;
 box-shadow: inset 0 0 0 1px transparent;
 border-radius: 99em;
 margin: 2em auto 0;
 font-size: 1.2em;
 color: #fff;
 background: linear-gradient(to right,
   #8EA8D2 0%,
   #86A2CE 40%,
   #7193C7 100%);
 overflow: hidden;
 letter-spacing: 0.15em;
}
.btn_slide a {
 position: relative;
 z-index: 2;
 display: flex;
 justify-content: space-between;
 align-items: center;
 padding: 1em 1.2em 1em 2em;
 color: inherit;
 text-decoration: none;
}
.btn_slide::before {
 border-radius: 99em;
 content: "";
 position: absolute;
 inset: 0;
 background: #fff;
 opacity: 0;
 transition: opacity .4s ease;
 z-index: 1;
 box-shadow: inset 0 0 0 1px #516EA1;
}

.arrow_static {
 position: absolute;
 top: 54%;
 right: 1em;
 transform: translateY(-50%);
 z-index: 3;
}
.arrow_static .icon_arrow {
 color: #fff;
 background-color: #fff;
 width: 1.5em;
 height: 1.5em;
}

.circle_arrow {
 position: absolute;
 top: 50%;
 right: 100%;
 height: 100%;
 aspect-ratio: 1;
 border-radius: 50%;
 background: linear-gradient(to right, #7192C7, #0D3D82);
 transform: translate(50%, -50%);
 opacity: 0;
 z-index: 2;
 pointer-events: none;
}
.icon_arrow {
 display: inline-block;
 position: relative;
 left: 0.05em;
 mask-image: url("../img/ico_arrow2.svg");
 mask-repeat: no-repeat;
 mask-position: center;
 mask-size: contain;
 -webkit-mask-image: url("../img/ico_arrow2.svg");
 -webkit-mask-repeat: no-repeat;
 -webkit-mask-position: center;
 -webkit-mask-size: contain;
}
.btn_slide .circle_arrow {
 height: 100%;
 aspect-ratio: 1;
 display: flex;
 justify-content: center;
 align-items: center;
}
.btn_slide .icon_arrow {
 color: #fff;
 background-color: #fff;
 width: 1.5em;
 height: 1.5em;
}

@keyframes slideCircle {
 0% {
  right: 100%;
  opacity: 0;
 }
 30% {
  opacity: 0;
 }
 55% {
  opacity: 0.1;
 }
 85% {
  opacity: 0.3;
 }
 100% {
  right: 0;
  transform: translate(0, -50%);
  opacity: 1;
 }
}
@media screen and (min-width:769px) {
 .btn_slide:hover {
  color: #516EA1;
 }
 .btn_slide:hover::before {
  opacity: 1;
 }
 .btn_slide:hover .arrow_static {
  opacity: 0;
 }
 .btn_slide:hover .circle_arrow {
  right: 0;
  opacity: 1;
  animation: slideCircle .5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
 }
}
@media screen and (max-width:768px) {
 .btn_slide {
  width: 70%;
 }
}


/*----- head_banner -----*/
#head_banner .head_banner {
 /* padding: 5em 0; */
 color: #fff;
 font-size: 2em;
 line-height: 1;
 font-weight: 500;
 height: 300px;
 max-height: 300px;
 letter-spacing: 0.05em;
 display: flex;
 align-items: center;
}
@media screen and (max-width:768px) {
 #head_banner .head_banner {
  max-height: 45vw;
 }
}


/*----- nav_bread -----*/
#nav_bread .section_inner {
 padding: 2em 0 5rem;
 font-size: 12px;
}
.nav_bread {
 display: flex;
 padding: 1em auto;
}
.nav_bread a {
 text-decoration: underline;
}
.nav_bread p:has(a)::after {
 display: inline-block;
 margin: 0 1em;
 content: " >";
}


/*----- section_ttl -----*/
.section_ttl {
 display: inline-flex;
 align-items: center;
 margin-bottom: 2.5rem;
 color: #516EA1;
 font-size: 2em;
 font-weight: 500;
 letter-spacing: 0.075em;
}
.section_ttl::before {
 content: "";
 width: 2rem;
 height: 4px;
 margin-right: 0.8em;
 background: rgba(81, 110, 161, .3);
}
.section_cap {
 margin: 1em 0 2em 0;
}
@media screen and (max-width:768px) {
 .section_ttl {
  font-size: 1.4em;
  /* text-align: center;  */
 }
 .section_cap {
  text-align: center;
 }
}

/*----- #pageintro -----*/
#pageintro {
 margin-bottom: 5.5rem;
}
#pageintro .section_inner>p {
 font-size: 1.125em;
 line-height: 2;
}

/*----- #pagecontent -----*/
#pagecontent {
 margin-bottom: 5.5rem;
}

/*----- header -----*/
header div.header {
 width: 100%;
 max-width: 1200px;
 margin: 0 auto;
 padding: 0;
 display: flex;
 align-items: end;
}
.header_logo {
 width: 30%;
 padding-bottom: 1em;
}
.header_menu {
 width: 70%;
}
.header_mainmenu {
 display: flex;
 align-items: end;
 justify-content: flex-end;
 text-align: center;
}
.header_mainmenu li:not(:last-child) {
 margin-right: 0.5em;
}
.header_list {
 padding: 0 1.5em 2em;
 color: #516EA1;
 display: inline-block;
 font-size: 1.1em;
 font-weight: 500;
}
.header_list a {
 position: relative;
 display: block;
 text-decoration: none;
}
.header_list a::after {
 content: "";
 position: absolute;
 left: 0;
 bottom: -4px;
 width: 100%;
 height: 2px;
 background: #516EA1;
 transform: scaleX(0);
 transform-origin: left;
 opacity: 0;
 transition: transform .3s ease, opacity .2s ease;
}
.header_list:hover a::after {
 transform: scaleX(1);
 opacity: 1;
}

.header_about img {
 position: relative;
 bottom: 0.2em;
 display: inline-block;
 transition: transform .4s ease;
 transform-origin: center center;
 transform: rotate(0deg);
 margin-left: 0.7em;
}
.header_about:hover img {
 position: relative;
 transform: rotate(180deg);
}

.header_submenu {
 z-index: 99;
 position: absolute;
 background: #7193C7;
 width: 100%;
 opacity: 0;
 visibility: hidden;
 transition: opacity .6s ease, visibility 0s linear .6s;
}
.header_submenu.is-open {
 opacity: 1;
 visibility: visible;
 transition:
  opacity .6s ease,
  visibility 0s;
}
.header_submenu ul {
 width: 100%;
 max-width: 1000px;
 margin: 0 auto;
 display: flex;
 justify-content: space-between;
}
.header_submenu ul li {
 flex: 1;
 text-align: center;
}
.header_submenu li a {
 display: block;
 width: 100%;
 margin: 0.8em 0;
 text-align: center;
 color: #fff;
 letter-spacing: 0.1em;
}
.header_submenu ul li:not(:last-child) a {
 border-right: 1px solid #fff;
}
.header_recruit,
.header_contact {
 position: relative;
 width: 20%;
 height: 100%;
 margin-bottom: 0.5em;
 padding: 0;
 color: #fff;
 font-size: 1.2em;
 font-weight: 700;
}
.header_recruit a,
.header_contact a {
 display: block;
 padding: 2em 0.8em 1.5em;
 text-align: center;
}
.header_recruit {
 margin-left: 1em;
 background: linear-gradient(to right, #7192C7, #0D3D82);
}
.header_contact {
 background: linear-gradient(to right, #B7CE29, #50A347);
}
.header_recruit::after,
.header_contact::after {
 content: "";
 position: absolute;
 inset: 0;
 background: #fff;
 opacity: 0;
 transition: opacity .2s ease;
 pointer-events: none;
}
.header_recruit:hover::after,
.header_contact:hover::after {
 opacity: .3;
}
.header_recruit img,
.header_contact img {
 width: 2.2em;
 margin: 0 auto 0.4em;
}
@media screen and (max-width:1100px) {
 header div.header {
  padding-left: 2%;
  height: 20vw;
 }
 .header_logo {
  width: 60%;
  padding: 1em 1em 0.5em;
 }
 /* ===== ボタン ===== */
 .header_open {
  background: #516EA1;
  color: #fff;
  text-align: center;
  margin: 0.5em 5.5% 0.5em auto;
  padding: 0.6em 1em 0;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  cursor: pointer;
  user-select: none;
 }
 /* アイコン */
 .menu_icon {
  display: block;
  height: 2px;
  background: #fff;
  margin: 1em auto 1em;
  position: relative;
  transition: background .3s ease;
 }
 .menu_icon::before,
 .menu_icon::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: #fff;
  transition: transform .4s ease, top .4s ease, bottom .4s ease;
 }
 .menu_icon::before {
  top: -8px;
 }
 .menu_icon::after {
  bottom: -8px;
 }
 /* ===== 開いた状態（×） ===== */
 .header_open.active .menu_icon {
  background: transparent;
 }
 .header_open.active .menu_icon::before {
  width: 80%;
  top: 0;
  transform: rotate(45deg);
  left: 10%
 }
 .header_open.active .menu_icon::after {
  width: 80%;
  bottom: 0;
  transform: rotate(-45deg);
  left: 10%
 }
 /* ===== メニュー ===== */
 .header_menu.active {
  display: block;
  position: absolute;
  right: 0;
  top: 20vw;
  z-index: 98;
  width: 100%;
 }
 .header_mainmenu {
  display: block;
  width: 100%;
  background: #7193C7;
 }
 .header_mainmenu li {
  width: 100%;
  margin: 0;
  color: #fff;
 }
 .header_mainmenu li:not(:last-child) {
  margin-right: 0;
 }
 .header_list {
  padding: 0;
  border-bottom: 1px solid #fff;
  font-size: 1.2em;
 }
 .header_list a {
  padding: 1.5em 0;
 }
 .header_list a::after {
  display: none;
 }
 .header_about img {
  display: none;
 }
 .header_subabout {
  background: rgba(255, 255, 255, .75);
 }
 .header_subabout li:not(:last-child) {
  border-bottom: 1px solid #516EA1;
 }
 .header_subabout a {
  display: block;
  color: #516EA1;
  padding: 1.5em 0;
 }
 .header_recruit,
 .header_contact {
  padding: 0;
  font-weight: 500;
 }
 .header_recruit a,
 .header_contact a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5em 0;
 }
 .header_recruit img,
 .header_contact img {
  margin: 0 0.8em 0 0;
 }
}



/*----- footer -----*/
footer {
 background-color: #666;
 color: #fff;
 font-size: 0.88em;
 margin-top: 6.25rem;
 padding: 2em 0;
}
footer a {
 color: inherit;
 display: inline-block;
 padding: 0.5em 0;
}
footer div.footer {
 padding: 0;
 display: flex;
 justify-content: space-between;
 align-items: center;
}
.footer_left {
 display: flex;
 width: auto;
 justify-content: flex-start;
}
.footer_left p {
 padding: 0 3em 0 0;
}
.footer_copyright {
 text-align: right;
 width: auto;
 font-size: 0.85em;
}
@media screen and (min-width:769px) and (max-width:1100px) {
 .footer_left p {
  padding: 0 0.7em;
  text-align: center;
 }
}
@media screen and (max-width:768px) {
 footer {
  font-size: 0.8em;
 }
 footer a {
  padding: 0;
 }
 footer div.footer {
  display: block;
 }
 .footer_left {
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 1.5em;
 }

 .footer_left p {
  padding: 0 2em;
  text-align: center;
 }
 .footer_copyright {
  text-align: center;
 }
}









/*----- #index_html -----*/
@media screen and (max-width:768px) {
 #index_html .intro {
  width: 100%;
  padding: 5em 0;
 }
}

#intro {
 position: relative;
 background: linear-gradient(to right,
   rgba(55, 101, 175, 1) 0%,
   rgba(102, 137, 192, 1) 45%,
   rgba(163, 183, 214, .8) 80%,
   rgba(163, 183, 214, 0) 100%);
 overflow: hidden;
}
#intro::after {
 content: "";
 position: absolute;
 top: 0;
 right: 0;
 width: 50%;
 height: 100%;
 background: url("../img/top_main2.jpg") right center/200% no-repeat;
 filter: blur(20px);
 transform: scale(1.1);
 z-index: 0;
 opacity: 0.6;
 /* フェードマスク */
 -webkit-mask-image: linear-gradient(to left,
   rgba(0, 0, 0, 1) 0%,
   rgba(0, 0, 0, 1) 50%,
   rgba(0, 0, 0, 0) 100%);
 mask-image: linear-gradient(to left,
   rgba(0, 0, 0, 1) 0%,
   rgba(0, 0, 0, 1) 50%,
   rgba(0, 0, 0, 0) 100%);
}
#intro::before {
 content: "";
 position: absolute;
 top: 0;
 right: 0;
 width: 50%;
 height: 100%;
 background: #fff;
 opacity: .35;
 z-index: 1;
 /* フェードマスク */
 -webkit-mask-image: linear-gradient(to left,
   rgba(0, 0, 0, 1) 0%,
   rgba(0, 0, 0, 1) 50%,
   rgba(0, 0, 0, 0) 100%);
 mask-image: linear-gradient(to left,
   rgba(0, 0, 0, 1) 0%,
   rgba(0, 0, 0, 1) 50%,
   rgba(0, 0, 0, 0) 100%);
}
#intro>* {
 position: relative;
 z-index: 1;
}
#index_html .intro {
 margin-top: 0;
 padding-top: 8rem;
 padding-bottom: 5rem;
 position: relative;
}
.intro_img {
 position: absolute;
 pointer-events: none;
 inset: 0;
 right: -100px;
 height: 100%;
 z-index: 2;
 background: url("../img/top_main2.jpg") right bottom/auto 100% no-repeat;
 /* フェードマスク */
 -webkit-mask-image: linear-gradient(to left,
   rgba(0, 0, 0, 1) 0%,
   rgba(0, 0, 0, 1) 50%,
   rgba(0, 0, 0, 0) 100%);
 mask-image: linear-gradient(to left,
   rgba(0, 0, 0, 1) 0%,
   rgba(0, 0, 0, 1) 50%,
   rgba(0, 0, 0, 0) 100%);
}
.intro_lead {
 position: relative;
 z-index: 3;
 color: #fff;
 font-size: 1.05em;
 line-height: 2.45em;
}
.intro_headcopy {
 font-size: 2.2rem;
 line-height: 1.7em;
 margin-bottom: 2rem;
 font-family: var(--font-serif-jp);
 letter-spacing: 0.1rem;
}
.intro_headtxt {
 letter-spacing: 0.03em;
}

.btn_intro {
 position: relative;
 margin: 2em 0 0;
 font-size: 1.25em;
 font-weight: 500;
 width: 15rem;
}
.btn_intro a {
 display: flex;
 align-items: center;
 letter-spacing: 0.15em;
}
.btn_intro span {
 display: flex;
 align-items: center;
 justify-content: center;
 aspect-ratio: 1;
 border-radius: 50%;
 border: 1px solid #fff;
}
.btn_intro .circle_arrow {
 opacity: 1;
 right: 0;
 background: none;
 width: 50px;
 height: 50px;
}
.btn_intro .icon_arrow {
 color: #fff;
 background-color: #fff;
 width: 1.2em;
 height: 1.2em;
}
.btn_intro:hover {
 opacity: 0.7;
}
@media screen and (max-width:768px) {
 #intro {
  padding-top: 0;
  background: none;
 }
 #intro::after {
  display: none;
 }
 #index_html .intro {
  padding-top: 0;
  padding-bottom: 2em;
 }
 .intro_img {
  position: relative;
  height: 83vw;
  mask-image: linear-gradient(to right,
    transparent 0%,
    black 0%);
  -webkit-mask-image: linear-gradient(to right,
    transparent 0%,
    black 0%);
 }
 .intro_lead {
  color: #000;
  padding: 2em 5%;
  font-size: 1.15em;
  line-height: 2;
 }
 .intro_headcopy {
  color: #516EA1;
  font-size: 1.55em;
  margin: 1em 0 0.5em;
  line-height: 1.6;
 }
 .btn_intro {
  border: 1px solid #516EA1;
  border-radius: 3em;
  color: #516EA1;
  width: 95%;
  margin-left: auto;
  margin-right: auto;
  font-size: 1.15em;
  font-weight: 400;
 }
 .btn_intro a {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: 1em 2em;
 }
 .btn_intro span {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 0;
  padding: 0.5em 1em;
  border: none;
 }
 .btn_intro .circle_arrow {
  right: 10vw;
  background: none;
 }
 .btn_intro .icon_arrow {
  background-color: #516EA1;
  border-color: #516EA1;
  width: 1.8em;
  height: 1.8em;
 }

 .intro_link {
  display: flex;
 }
 .intro_link p {
  flex: 1;
  color: #fff;
 }
 .intro_link a {
  display: flex;
  justify-content: center;
  font-size: 1.3em;
  align-items: center;
  padding: 1.5em 0;
  text-align: center;
  font-weight: 700;
 }
 .intro_link img {
  display: inline-block;
  margin-right: 0.5em;
  width: 1.5em;
 }
 .intro_recruit {
  background: linear-gradient(to right, #7192C7, #0D3D82);
 }
 .intro_contact {
  background: linear-gradient(to right, #B7CE29, #50A347);
 }
}

#service {
 background: #8DA8D4;
}
#service .section_ttl::before {
 display: none;
}
.service {
 padding: 6rem 0;
}
.service_ttl {
 color: #fff;
 font-size: 2.2em;
 margin-bottom: 0;
}
.service_cap {
 color: #B8C9E3;
 font-size: 1.5em;
 font-family: "Barlow Condensed", system-ui, sans-serif;
 font-weight: 300;
 letter-spacing: 0.15em;
 margin: 0.5em 0 1.5em;
}
.service_frame {
 display: flex;
 justify-content: space-between;
 gap: 10%;
}
.service_box {
 display: flex;
 flex-direction: column;
 justify-content: flex-end;
 width: 45%;
 padding: 3em 3em 4em;
 background: #fff;
 border: 10px solid #698CC3;
 box-shadow: 10px 10px 5px rgba(81, 110, 161, 0.2);
 color: #516EA1;
 line-height: 1.8em;
}
.service_box01>img {
 margin: 0 auto 3em;
 width: 4.5rem;
}
.service_box02>img {
 margin: 0 auto 3em;
 width: 6rem;
}
.box_ttl {
 text-align: center;
 font-size: 1.6em;
 font-weight: 600;
 margin-bottom: 1em;
}
#service .btn_slide {
 width: 18rem;
}
@media screen and (min-width: 769px) and (max-width: 1100px) {
 .service_frame {
  gap: 0;
 }
 .service_box {
  width: 48%;
  margin-bottom: 2em;
 }
 #service .btn_slide {
  width: 90%;
 }
}
@media screen and (max-width:768px) {
 #service {
  background: #7193C7;
 }
 .service {
  padding: 3em 0 1.5em;
 }
 .service_ttl {
  display: block;
  text-align: center;
 }
 .service_frame {
  display: block;
 }
 .service_box {
  width: 100%;
  margin-bottom: 2em;
  padding: 2.5em 2em 2em;
  border: 8px solid #516EA1;
  font-size: 1.15em;
 }
 .box_ttl {
  font-size: 1.6em;
 }
 .service_box>img {
  display: none;
 }
 #service .btn_slide {
  width: 100%;
 }
}

#area {
 overflow: hidden;
}
#area .section_ttl::before {
 display: none;
}
.area {
 padding: 6rem 0 17rem;
 position: relative;
 overflow: visible;
}
.area_bg {
 position: absolute;
 top: 0;
 right: -100px;
 width: 100%;
 height: 100%;
 background: url("../img/bg_area3.png") no-repeat right top / auto 100%;
 pointer-events: none;
 z-index: -2;
}
.area_ttl {
 color: #516EA1;
 font-size: 2.2em;
 margin-bottom: 0;
}
.area_cap {
 color: #9CB3D8;
 font-size: 1.5em;
 font-family: "Barlow Condensed", system-ui, sans-serif;
 font-weight: 300;
 letter-spacing: 0.15em;
 margin: 0.5em 0 1em;
}
.area_txt {
 font-size: 1.2em;
 line-height: 2em;
}
#area .btn_slide {
 margin-left: 0;
 width: 18rem;
}
@media screen and (max-width:768px) {
 .area {
  width: 100%;
  padding: 3em 0 4em;
  position: relative;
  text-align: center;
  overflow: hidden;
 }
 .area_bg {
  right: 0;
  margin: 0 auto;
  background: url("../img/bg_area2.png") no-repeat center top / auto 95%;
  opacity: 0.4;
 }
 .area_bg.js-fade-up {
  opacity: 0.4;
 }
 #area .btn_slide {
  margin-left: auto;
  width: 66%;
 }
}

#link {
 display: flex;
 width: 100%;
 gap: 0;
 justify-content: center;
}
#link .section_ttl::before {
 display: none;
}
.link_box {
 width: 100%;
 max-width: 500px;
 text-align: center;
 z-index: 2;
 margin: 0;
}
.link_achievements .link_box {
 margin-left: auto;
}
.link_contact .link_box {
 margin-right: auto;
}
.link_ttl {
 font-size: 2.2em;
 margin-bottom: 0;
}
.link_achievements .link_ttl {
 color: #516EA1;
}
.link_contact .link_ttl {
 color: #50A447;
}
.link_cap {
 color: #fff;
 font-size: 1.5em;
 font-family: "Barlow Condensed", system-ui, sans-serif;
 font-weight: 300;
 letter-spacing: 0.15em;
 margin: 0.5em 0 1em;
}
.link_txt {
 font-size: 1.2em;
 line-height: 1.8em;
 letter-spacing: 0.05em;
}
.link_achievements,
.link_contact {
 width: 50%;
 position: relative;
 overflow: hidden;
 z-index: 0;
}
.link_achievements a,
.link_contact a {
 position: relative;
 z-index: 5;
 display: block;
 padding-top: 4em;
 padding-bottom: 4em;
}
.link_achievements::before,
.link_contact::before {
 content: "";
 position: absolute;
 inset: 0;
 z-index: 1;
 background-size: cover;
 pointer-events: none;
}
.link_achievements::after,
.link_contact::after {
 content: "";
 position: absolute;
 inset: 0;
 z-index: 2;
 pointer-events: none;
}
.link_achievements>*,
.link_contact>* {
 /* position: relative; */
 /* z-index: 3; */
}
.link_achievements::before {
 background: url("../img/top_recruitment.jpg") left bottom/cover no-repeat;
 mask-image: linear-gradient(to left,
   transparent 0%,
   transparent 20%,
   black 55%);
 -webkit-mask-image: linear-gradient(to left,
   transparent 0%,
   transparent 20%,
   black 55%);
}
.link_contact::before {
 background: url("../img/top_contact.jpg") right center/cover no-repeat;
 mask-image: linear-gradient(to right,
   transparent 0%,
   transparent 20%,
   black 55%);
 -webkit-mask-image: linear-gradient(to right,
   transparent 0%,
   transparent 20%,
   black 55%);
}
.link_achievements::before,
.link_contact::before {
 background-size: 100%;
 transition: background-size 0.3s ease;
}
.link_achievements::after {
 background: rgba(113, 147, 199, .6);
 transition: background 0.6s ease;
}
.link_contact::after {
 background: rgba(137, 186, 57, .6);
 transition: background 0.6s ease;
}

@media screen and (max-width:1100px) {
 .link_achievements::before,
 .link_contact::before {
  background-size: cover;
  mask-image: linear-gradient(to left,
    transparent 0%,
    transparent 0%,
    black 0%);
  -webkit-mask-image: linear-gradient(to left,
    transparent 0%,
    transparent 0%,
    black 0%);
  opacity: 0.3;
 }
}
@media screen and (max-width:768px) {
 #link {
  display: block;
 }
 .link_achievements,
 .link_contact {
  width: 100%;
 }
 .link_achievements .link_box,
 .link_contact .link_box {
  margin: 0 auto;
  position: relative;
  z-index: 99;
 }
 .link_achievements a,
 .link_contact a {
  display: block;
  padding: 4em 0;
 }
}
@media screen and (min-width:769px) {
 .link_achievements:hover::before,
 .link_contact:hover::before {
  background-size: 110%;
 }
 .link_achievements:hover::after {
  background: rgba(113, 147, 199, .4);
 }
 .link_contact:hover::after {
  background: rgba(137, 186, 57, .4);
 }
}

#footer_access {
 background: #F2F2F2;
 padding: 5.5em 0;
}
.footer_access {
 padding: 0;
 display: flex;
 justify-content: space-between;
 align-items: stretch;
}
.footer_txt {
 width: 45%;
 padding-right: 5em;
 display: flex;
 flex-wrap: wrap;
 align-content: space-between;
}
.address {
 width: 100%;
 margin-bottom: 2.5em;
}
.address img {
 margin-bottom: 1em;
}
.access {
 width: 100%;
 padding-left: 1em;
}
.access p.access_ttl {
 display: flex;
 align-items: center;
 margin-left: -1em;
 color: #7193C7;
 font-family: "Barlow Condensed", system-ui, sans-serif;
 font-weight: 600;
 font-size: 1.55em;
 letter-spacing: 0.075em;
}
.access_ttl::after {
 content: "";
 flex: 1;
 height: 1px;
 background-color: #7193C7;
 margin-left: 1em;
}
.access_ttl img {
 margin-right: 0.5em;
 margin-bottom: 0.3em;
}
.access div {
 margin-bottom: 1em;
 font-size: 0.87em;
}
.access p {
 font-size: 1rem;
 font-weight: 600;
 line-height: 2.5em;
}
.access_lead {
 font-size: 1.1rem;
}
.access span {
 display: block;
 font-weight: 600;
 color: #7193C7;
 line-height: 2em;
 font-size: 1rem;
}
.footer_map {
 width: 100%;
 max-width: 600px;
}
.footer_map iframe {
 border: 0;
 width: 100%;
 height: 100%;
}
@media screen and (min-width: 769px) and (max-width: 1000px) {
 .footer_access {
  width: 60%;
  margin-left: auto;
  margin-right: auto;
  display: block;
 }
 .footer_txt {
  width: 100%;
  text-align: center;
  padding-right: 0;
 }
 .access_box br {
  display: none;
 }
 .footer_map iframe {
  min-height: 45vw;
 }
}
@media screen and (max-width:768px) {
 #footer_access {
  padding: 3.5em 0;
  font-size: 1.1em;
 }
 .footer_access {
  display: block;
 }
 .footer_txt {
  width: 100%;
  text-align: center;
  padding: 0 0 2em;
 }
 .address {
  line-height: 1.5;
 }
 .address img {
  width: 80%;
  margin-left: auto;
  margin-right: auto;
 }
 .access p.access_ttl {
  border-top: 1px solid #7193C7;
  margin-right: auto;
  margin-left: auto;
  justify-content: center;
  padding-top: 1em;
 }
 .access_ttl::after {
  display: none;
 }
 .access_lead {
  margin-bottom: 1em;
 }
 .access_box {
  line-height: 1.5em;
 }
 .access_box span {
  display: block;
 }
 .footer_map {
  max-width: 100%;
  height: auto;
 }
 .footer_map iframe {
  min-height: 65vw;
 }
}

#index_html footer {
 margin-top: 0;
}


/*----- #about_html -----*/
#about_html .header_submenu {
 opacity: 1;
 visibility: visible;
}
#about_html .header_about a::after {
 transform: scaleX(1);
 opacity: 1;
}
#about_html .header_about img {
 transform: rotate(180deg);
}

#about_html #head_banner {
 margin-top: 50px;
 background: #516EA1 url("../img/bg_about_head.jpg") center center / auto 100% no-repeat;
}
@media screen and (max-width:1100px) {
 #about_html #head_banner {
  margin-top: 0;
 }
}

#about h3 {
 margin-bottom: 0.5em;
 text-align: center;
 color: #516EA1;
 font-size: 1.6em;
 line-height: 1.68;
 font-weight: 700;
 letter-spacing: 0.1em;
}
.about {
 padding-bottom: 8em;
}
.about_ttl {
 margin: 2.5em 0 0;
 text-align: center;
 color: #516EA1;
 font-size: 2em;
 line-height: 1.3;
 font-family: var(--font-serif-jp);
 font-weight: 400;
 letter-spacing: 0.1em;
}
.about_sub {
 margin: 1.5em 0 10em;
 text-align: center;
 font-size: 1.1em;
}
.about_sub span {
 display: inline-block;
 position: relative;
 margin-bottom: 0.3em;
 padding-bottom: .1em;
 letter-spacing: 0.05em;
}
.about_sub span::after {
 content: "";
 position: absolute;
 left: 0;
 bottom: 0;
 width: 100%;
 border-bottom: 2px dotted #516EA1;
}
@media screen and (min-width:1100px) {
 .about_frame {
  background: url(../img/bg_about.png) center top no-repeat;
 }
 .about_frame {
  display: flex;
  justify-content: space-evenly;
 }
 .about_frame div {
  width: 23%;
 }
}
@media screen and (min-width:769px) and (max-width:1100px) {
 .about_frame div {
  width: 70%;
  margin-left: auto;
  margin-right: auto;
 }
 .about_sub {
  margin-bottom: 2em;
 }
}
@media screen and (max-width:768px) {
 .about_frame div {
  width: 70%;
  margin-left: auto;
  margin-right: auto;
 }
 .about_sub {
  margin-bottom: 2em;
 }
}

#greeting {
 background: rgba(113, 147, 199, .2);
 padding: 5rem 0;
}
#greeting p {
 margin: 0 0 2em 0;
}
@media screen and (max-width:768px) {
 #about_html .section_ttl {
  font-size: 1.8em;
 }
}

#office {
 background: #8DA8D4;
 padding: 6rem 0;
}
.office_ttl {
 color: #fff;
}
.office_ttl::before {
 background: #DDE5F2;
}
.office_frame {
 background: rgba(255, 255, 255, 0.8);
 margin: 1em 0 3em;
 padding: 3em 3em 0.5em;
}
.office_location span {
 display: inline-block;
 margin-bottom: 0.75em;
 padding: 0.3em 1em;
 border: 2px solid #7193C7;
 color: #516EA1;
 font-size: 1.5em;
 letter-spacing: 0.1em;
}
.office_box p {
 margin: 1em 0 2em;
}
.office_cap {
 font-size: 1.2em;
 font-weight: 600;
 color: #7193C7;
}
@media screen and (min-width:769px) {
 .office_box {
  margin: 2em 0 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
 }
 .office_box div:first-child {
  width: 63%;
 }
 .office_box div:last-child {
  width: 30%;
 }
}
@media screen and (max-width:768px) {
 .office_frame {
  padding: 2em 3em 0.5em;
 }
 .office_box div:first-child {
  margin-top: 1em;
 }
}

.servicearea {
 padding: 5em 0;
}
.servicearea_ttl {
 font-weight: 500;
}
.servicearea_txt {
 line-height: 2em;
 margin-bottom: 2em;
}
.servicearea_box ul {
 color: #516EA1;
 line-height: 2em;
}
.servicearea_box li:last-child {
 color: #000;
 font-size: 0.95em;
}
@media screen and (min-width:769px) {
 .servicearea_box {
  margin: 2em auto 0 -5em;
  display: flex;
  gap: 5%;
 }
 .servicearea_img {
  width: 80%;
 }
}
@media screen and (max-width:768px) {
 .servicearea_txt {
  text-align: center;
 }
 .servicearea_box ul {
  width: 50%;
  margin-right: auto;
  margin-left: auto;
 }
}

#company {
 background: #B8C9E3;
 padding: 5em 0 2em;
 font-weight: 400;
}
.company_ttl {
 color: #fff;
 font-weight: 500;
 margin-bottom: 0.75em;
}
.company_ttl::before {
 background: #DDE5F2;
}
.company_box {
 display: flex;
 justify-content: space-between;
 gap: 10%;
}
.company_box1 {
 flex: 1;
 margin-bottom: 4em;
}
.company_box1 div {
 padding: 2em 0;
 font-size: 0.95em;
 display: flex;
}
.company_box1 div:not(:last-child) {
 border-bottom: 1px solid #fff;
}
.company_box1 div p {
 flex: 1;
}
.company_box1 div p.company_cap {
 font-weight: 600;
 font-size: 1.1em;
 flex: 0 0 10em;
 color: #516EA1;
}
.company_license.company_box1 div p.company_cap {
 flex: 0 0 16em;
}
@media screen and (max-width:768px) {
 .company_box {
  display: block;
 }
 .company_cap {
  font-size: 1em;
 }
 .company_box .company_box1:first-child {
  margin-bottom: 0;
  border-bottom: 1px solid #fff;
 }
}
#about_html footer {
 margin-top: 0;
}


/*----- #services_html -----*/
#services_html #head_banner {
 background: #516EA1 url("../img/bg_service_head.jpg") center center / auto 100% no-repeat;
}

.works {
 border-top: 2px solid rgba(113, 147, 119, .3);
 margin: 3em 0 0;
 padding: 3em 0 0;
 display: flex;
 justify-content: space-between;
 gap: 10%;
 font-weight: 400;
}
.works h3 {
 color: #516EA1;
 font-size: 1.56em;
 margin-bottom: 1em;
 font-weight: 500;
}
@media screen and (min-width:769px) {
 .works>div {
  flex: 1;
 }
 .works_img {
  flex: 0 0 40;
 }
}
@media screen and (max-width:768px) {
 .works {
  display: block;
 }
 .works_img {
  padding-top: 1em;
 }
}

#message {
 margin-bottom: 5em;
}
.message {
 background: #e2e8f4 url("../img/bg_message.jpg") right bottom / auto 100% no-repeat;
 padding: 5em;
}
.message_ttl {
 color: #516EA1;
 font-size: 2em;
 font-family: var(--font-serif-jp);
 font-weight: 400;
 line-height: 1.35;
 font-feature-settings: "palt" 1, "pkna" 1;
 letter-spacing: 0.05em;
}
.message p {
 margin: 2em 0;
 font-weight: 400;
}
.btn_recruit {
 width: 35%;
 background: #516EA1;
 position: relative;
 display: inline-flex;
 align-items: center;
 margin-top: 3em;
 padding: 1.5em 2em;
}
.btn_recruit p {
 display: inline-block;
 color: #fff;
 margin: 0;
 padding: 0;
 position: relative;
 font-weight: 500;
 font-size: 1.25em;
}
.btn_recruit:hover {
 background: #748BB4;
}
.btn_recruit span {
 position: absolute;
 left: 100%;
 margin-left: -6em;
 width: 8em;
 height: 1px;
 background: #fff;
 top: 50%;
 transform: translateY(-50%);
 pointer-events: none;
}
@media screen and (min-width:769px) and (max-width:1100px) {
 .btn_recruit {
  width: 40%;
 }
 .btn_recruit span {
  margin-left: -2em;
 }
}
@media screen and (max-width:768px) {
 .message {
  background-size: 170%;
  padding: 2em;
 }
 .message p {
  margin: 1.5em 0;
  font-size: 0.9em;
 }
 .btn_recruit p {
  margin: 0;
  font-size: 1.1em;
 }
 .btn_recruit {
  width: 80%;
 }
}


/*----- #recruitment_html -----*/
#recruitment_html #head_banner {
 background: #516EA1 url("../img/bg_recruitment_head.jpg") center center / auto 100% no-repeat;
}

.type_frame {
 display: flex;
 gap: 3%;
 margin-bottom: 6em;
}
.type_btn {
 padding: 0;
 flex: 1;
}
@media screen and (min-width:769px) {
 .type_btn a img {
  opacity: 1;
  transition: opacity 0.5s ease;
 }
 .type_btn a:hover img {
  opacity: 0.7;
 }
}
@media screen and (max-width:768px) {
 .type_frame {
  display: block;
 }
 .type_btn {
  margin-bottom: 1.5em;
 }
}

.category_frame {
 display: flex;
 justify-content: space-between;
 gap: 3%;
}
.category_frame .btn_slide {
 margin-top: 0;
 font-size: 1.3em;
 flex: 1;
}
.category_frame .btn_slide a {
 padding: 1.15em 2em;
}
.category_frame .btn_slide::before {
 box-shadow: inset 0 0 0 1px transparent;
}

.btn_newgraduate {
 background: #fff;
 color: #516EA1;
 box-shadow: inset 0 0 0 1px #516EA1;
}
.btn_newgraduate::before,
.btn_newgraduate .circle_arrow {
 background: linear-gradient(to right, #7192C7 0%, #0D3D82 100%);
}
.btn_newgraduate .arrow_static::before,
.btn_newgraduate .arrow_static::after {
 background: #516EA1;
}
.btn_newgraduate .circle_arrow {
 background: linear-gradient(to right, #7192C7 0%, #0D3D82 100%);
}
.btn_newgraduate .arrow_static .icon_arrow {
 color: #516EA1;
 background-color: #516EA1;
}

.btn_midcareer {
 background: #fff;
 color: #48A248;
 box-shadow: inset 0 0 0 1px #48A248;
}
.btn_midcareer::before {
 background: linear-gradient(to right, #88B83E 0%, #48A248 100%);
}
.btn_midcareer .arrow_static::before,
.btn_midcareer .arrow_static::after {
 background: #48A248;
}
.btn_midcareer .circle_arrow {
 background: linear-gradient(to right, #88B83E 0%, #48A248 100%);
}
.btn_midcareer .arrow_static .icon_arrow {
 color: #48A248;
 background-color: #48A248;
}

.btn_highschool {
 background: #fff;
 color: #D5C73C;
 box-shadow: inset 0 0 0 1px #D5C73C;
}
.btn_highschool::before {
 background: linear-gradient(to right, #EFE8A7 0%, #D5C73C 100%);
}
.btn_highschool .arrow_static::before,
.btn_highschool .arrow_static::after {
 background: #D5C73C;
}
.btn_highschool .circle_arrow {
 background: linear-gradient(to right, #EFE8A7 0%, #D5C73C 100%);
}
.btn_highschool .arrow_static .icon_arrow {
 color: #D5C73C;
 background-color: #D5C73C;
}

@media screen and (max-width:768px) {
 .category_frame {
  display: block;
 }
 .category_frame .btn_slide {
  width: 100%;
  margin-bottom: 1em;
 }
}

section#newgraduate,
section#midcareer,
section#highschool {
 display: none;
}
section#newgraduate.is-active,
section#midcareer.is-active,
section#highschool.is-active {
 display: block;
}
.category_box_link {
 margin: 3em 0 2em;
 font-size: 1.25em;
}
.category_box_link a {
 display: inline-block;
 text-decoration: underline;
 margin: 0 3em 0 0;
 padding: 0.5em 0;
}
.arrow_bottom {
 position: relative;
 width: 1em;
 height: 1em;
 display: inline-block;
 margin: 0 0.5em 0 0;
}
.arrow_bottom::before,
.arrow_bottom::after {
 content: "";
 position: absolute;
 bottom: 0.25em;
 width: 0.5em;
 height: 2px;
 background: currentColor;
}
.arrow_bottom::before {
 left: 2px;
 transform: rotate(45deg);
}
.arrow_bottom::after {
 right: 2px;
 transform: rotate(-45deg);
}
.category_box {
 position: relative;
 margin-top: 0.5em;
 padding: 3em;
 font-weight: 300;
}
.category_tab {
 position: absolute;
 top: 0;
 right: 3em;
 padding: 0.3em 1.5em;
 color: #fff;
}
hr {
 border: none;
 height: 2px;
 margin: 4.5em 0;
}
.category_box h4 {
 margin-bottom: 2.5em;
}
.category_box h4 span {
 display: inline-block;
 padding-bottom: 0.1em;
 border-bottom: 2px solid;
 font-size: 1.85em;
 font-weight: 500;
}
.category_box1 {
 background: #fff;
}
.category_box1 div:not(:last-child) {
 border-bottom: 1px solid;
}
.category_box1 div p {
 padding: 1em;
}
.category_conditions {
 margin: 3em 0 1em;
 font-weight: 600;
 font-size: 1.4em;
}
.category_conditions::before {
 display: inline-block;
 content: "●";
 margin-right: 0.3em;
}
@media screen and (min-width:769px) {
 .category_box1 div {
  display: flex;
 }
 .category_cap {
  width: 10em;
  border-right: 1px solid;
 }
}
@media screen and (max-width:768px) {
 .category_box h4 span {
  font-size: 1.2em;
 }
 .category_box {
  padding: 3.5em 2em 2em;
 }
 .category_tab {
  right: 2em;
  padding: 0 0.5em;
 }
 .category_box1 div p.category_cap {
  padding-bottom: 0;
 }
}

.btn_entry {
 margin: 1.5em 0 0;
 text-align: center;
 color: #fff;
 font-size: 2em;
 font-weight: 300;
}
.btn_entry a {
 width: 100%;
 display: inline-flex;
 justify-content: center;
 align-items: center;
 gap: 0.5em;
 text-decoration: none;
 padding: 0.75em 0;
 letter-spacing: 0.1em;
}
.btn_entry:hover {
 opacity: 0.7;
}
.btn_entry span {
 width: 1.2em;
 aspect-ratio: 1;
 border-radius: 50%;
 background: #fff;
 display: flex;
 align-items: center;
 justify-content: center;
 position: relative;
}
.btn_entry span::before {
 position: relative;
 content: "";
 width: 0.4em;
 height: 0.4em;
 right: 0.1em;
 transform: rotate(45deg);
}

#newgraduate .category_box_link {
 color: #516EA1;
}
#newgraduate .category_box {
 background: #E2E9F4;
}
#newgraduate hr {
 background-color: #E2E9F4;
}
#newgraduate .category_tab {
 background: #7193C7;
}
#newgraduate .category_box h4 span {
 color: #516EA1;
 border-color: #516EA1;
}
#newgraduate .category_cap {
 color: #516EA1;
 border-color: #E2E9F4;
}
#newgraduate .category_box1 div:not(:last-child) {
 border-color: #E2E9F4;
}
#newgraduate .category_conditions {
 color: #516EA1;
}
#newgraduate .category_conditions::before {
 color: #B7C4DB;
}
#newgraduate .btn_entry {
 background: linear-gradient(to right,
   #7192C7 0%,
   #0D3D82 100%);
}
#newgraduate .btn_entry span::before {
 border-top: 2px solid #516EA1;
 border-right: 2px solid #516EA1;
}

#midcareer .category_box_link {
 color: #48A248;
}
#midcareer .category_box {
 background: #E7F1D8;
}
#midcareer hr {
 background-color: #E7F1D8;
}
#midcareer .category_tab {
 background: #88B83E;
}
#midcareer .category_box h4 span {
 color: #48A248;
 border-color: #48A248;
}
#midcareer .category_cap {
 color: #48A248;
 border-color: #B4D4C0;
}
#midcareer .category_box1 div:not(:last-child) {
 border-color: #B4D4C0;
}
#midcareer .category_conditions {
 color: #48A248;
}
#midcareer .category_conditions::before {
 color: #AFD4AC;
}
#midcareer .btn_entry {
 background: linear-gradient(to right,
   #88B83E 0%,
   #48A248 100%);
}
#midcareer .btn_entry span::before {
 border-top: 2px solid #48A248;
 border-right: 2px solid #48A248;
}

#highschool .category_box_link {
 color: #D5C73C;
}
#highschool .category_box {
 background: #F3F1D7;
}
#highschool hr {
 background-color: #F3F1D7;
}
#highschool .category_tab {
 background: #EBE17A;
}
#highschool .category_box h4 span {
 color: #D5C73C;
 border-color: #D5C73C;
}
#highschool .category_cap {
 color: #D5C73C;
 border-color: #DEDFBD;
}
#highschool .category_box1 div:not(:last-child) {
 border-color: #DEDFBD;
}
#highschool .category_conditions {
 color: #D5C73C;
}
#highschool .category_conditions::before {
 color: #EFE8A7;
}
#highschool .btn_entry {
 background: linear-gradient(to right,
   #EFE8A7 0%,
   #D5C73C 100%);
}
#highschool .btn_entry span::before {
 border-top: 2px solid #D5C73C;
 border-right: 2px solid #D5C73C;
}

@media screen and (min-width:769px) {
 .category_frame .btn_slide:hover,
 .category_frame .btn_slide.is-active {
  color: #fff;
 }
 .category_frame .btn_slide.is-active::before {
  opacity: 1;
 }
 .category_frame .btn_slide.is-active .arrow_static {
  opacity: 0;
 }
 .category_frame .btn_slide.is-active .circle_arrow {
  right: 0;
  opacity: 1;
  animation: slideCircle .6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
 }
}

#introduction {
 margin-bottom: 6em;
}
.introduction {
 display: flex;
 margin-bottom: 3em;
 gap: 5%;
}
.introduction p {
 line-height: 2.2em;
}
.introduction_box {
 flex: 1;
 padding: 2.5em 2em;
 background: #D4DFEE;
 font-weight: 400;
}
.introduction_point {
 text-align: center;
 color: #fff;
}
.introduction_point span {
 display: inline-block;
 border-bottom: 2px solid #fff;
 margin-bottom: 1em;
 padding: 0 0.5em 0.2em;
 font-size: 1.1em;
 font-weight: 600;
}
.introduction_point span span {
 font-size: 1.2em;
 border-bottom: 0;
 margin: 0;
 padding: 0;
}
.introduction_lead {
 text-align: center;
 color: #516EA1;
 font-size: 1.25em;
 margin-bottom: 0.5em;
 font-weight: 600;
}
@media screen and (min-width:769px) {
 .introduction_frame {
  padding-top: 0;
  display: flex;
  gap: 4%;
 }
 .introduction_img {
  flex: 0 0 38%;
 }
}
@media screen and (max-width:768px) {
 .introduction {
  display: block;
 }
 .introduction_box {
  margin-bottom: 1em;
  padding: 2em;
 }
 .introduction p,
 .introduction img {
  margin-bottom: 1em;
 }
}

#dayflow {
 margin-bottom: 5em;
}
.break {
 color: #516EA1;
}
.dayflow_frame {
 position: relative;
 margin-top: 1em;
}
.dayflow_frame::before {
 content: "";
 position: absolute;
 left: 0;
 top: 2em;
 bottom: 2em;
 width: 2px;
 background: #B8C9E3;
 z-index: -1;
}
.dayflow_frame>div {
 padding: 1em 0;
 display: flex;
}
.time {
 width: 8.5em;
 font-size: 1.3em;
}

.content {
 flex: 1;
 font-size: 1.1em;
 font-weight: 300;
}
.time span {
 display: inline-block;
 margin: 0 2em 0 -0.4em;
 width: 0.8em;
 height: 0.8em;
 background: #7193C7;
 border-radius: 50%;
}
.content img {
 width: 40%;
 margin-bottom: 2em;
}
.content span {
 width: 55%;
 display: inline-block;
 border: 1px solid #7193C7;
 padding: 1em;
 color: #516EA1;
 margin-bottom: 2em;
}
@media screen and (min-width:769px) {
 .content {
  flex: 1;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
 }
}
@media screen and (max-width:768px) {
 .content img {
  width: 100%;
 }
 .content span {
  width: 100%;
 }
}

#category_footer {
 background: #C6D4EA;
 padding: 4em 0;
}
#category_footer .section_ttl::before {
 display: none;
}
#category_footer .category_ttl {
 display: block;
 text-align: center;
 margin-bottom: 2em;
 font-size: 2.2em;
}
#category_footer .category_frame {
 display: flex;
 justify-content: space-between;
 gap: 3%;
}
#category_footer .category_frame .btn_slide {
 margin-top: 0;
 font-size: 1.3em;
 flex: 1;
}

#category_footer .category_frame .btn_slide a {
 padding: 1.15em 2em;
}
#category_footer .category_frame .btn_slide::before {
 box-shadow: inset 0 0 0 1px transparent;
}
#category_footer .btn_newgraduate {
 background: #fff;
 color: #516EA1;
 box-shadow: inset 0 0 0 1px #516EA1;
}
#category_footer .btn_newgraduate::before,
#category_footer .btn_newgraduate .circle_arrow {
 background: linear-gradient(to right, #7192C7 0%, #0D3D82 100%);
}
#category_footer .btn_newgraduate .arrow_static::before,
#category_footer .btn_newgraduate .arrow_static::after {
 background: #516EA1;
}
#category_footer .btn_newgraduate .circle_arrow {
 background: linear-gradient(to right, #7192C7 0%, #0D3D82 100%);
}
#category_footer .btn_midcareer {
 background: #fff;
 color: #48A248;
 box-shadow: inset 0 0 0 1px #48A248;
}
#category_footer .btn_midcareer::before {
 background: linear-gradient(to right, #88B83E 0%, #48A248 100%);
}
#category_footer .btn_midcareer .arrow_static::before,
#category_footer .btn_midcareer .arrow_static::after {
 background: #48A248;
}
#category_footer .btn_midcareer .circle_arrow {
 background: linear-gradient(to right, #88B83E 0%, #48A248 100%);
}
#category_footer .btn_highschool {
 background: #fff;
 color: #D5C73C;
 box-shadow: inset 0 0 0 1px #D5C73C;
}
#category_footer .btn_highschool::before {
 background: linear-gradient(to right, #EFE8A7 0%, #D5C73C 100%);
}
#category_footer .btn_highschool .arrow_static::before,
#category_footer .btn_highschool .arrow_static::after {
 background: #D5C73C;
}
#category_footer .btn_highschool .circle_arrow {
 background: linear-gradient(to right, #EFE8A7 0%, #D5C73C 100%);
}
@media screen and (min-width:769px) {
 #category_footer .category_frame .btn_slide:hover,
 #category_footer .category_frame .btn_slide.is-active {
  color: #fff;
 }
 #category_footer .category_frame .btn_slide.is-active::before {
  opacity: 1;
 }
 #category_footer .category_frame .btn_slide.is-active .arrow_static {
  opacity: 0;
 }
 #category_footer .category_frame .btn_slide.is-active .circle_arrow {
  right: 0;
  opacity: 1;
  animation: slideCircle .6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
 }
}
@media screen and (max-width:768px) {
 #category_footer .category_frame {
  display: block;
 }
 #category_footer .category_frame .btn_slide {
  width: 100%;
  margin-bottom: 1em;
 }
}

#recruitment_html.recruitment_type footer {
 margin-top: 0;
}


/*----- #privacy_html -----*/
#privacy_html #head_banner {
 background: #516EA1 url("../img/bg_privacy_head.jpg") center center / auto 100% no-repeat;
}

#privacy .section_ttl::before {
 display: none;
}
.privacy_ttl {
 font-size: 1.5em;
 margin-bottom: 1.2em;
}
.privacy>p {
 font-weight: 300;
 margin-bottom: 3em;
}
@media screen and (max-width:768px) {
 .privacy_ttl {
  font-size: 1.2em;
 }
}



/*----- #contact_html -----*/
#contact_html #head_banner {
 background: #516EA1 url("../img/bg_contact_head.jpg") center center / auto 100% no-repeat;
}

#contact_html .pageintro span {
 color: #f00;
}

.contact>p {
 margin: 2em 0;
}
.contactform {
 background: #E3E9F4;
 padding: 3em 4em;
}
.form_checkbox label {
 margin-right: 2em;
}
form input[type=checkbox] {
 margin-right: 0.5em;
}
form input[type=text],
form textarea {
 width: 100%;
}
.mailform_frame div {
 width: 100%;
 display: flex;
 align-items: center;
 padding: 1em 0;
}
.mailform_frame div.form_massege {
 align-items: start;
}
.mailform_frame div p {
 flex: 1;
}
.mailform_frame div p.form_head {
 flex: 0 0 30%;
}
.form_head span {
 display: block;
 color: #f00;
}
.btn_entry_submit {
 border: none;
 background: linear-gradient(to right,
   #7192C7 0%,
   #0D3D82 100%);
 cursor: pointer;
 display: flex;
 justify-content: center;
 align-items: center;
 gap: 0.5em;
 width: 50%;
 margin: 0 auto;
 padding: 0.5em 0;
 color: #fff;
 font-size: 1.8em;
 font-weight: 300;
 letter-spacing: 0.1em;
}
.btn_entry_submit span {
 width: 1.2em;
 height: 1.2em;
 border-radius: 50%;
 background: #fff;
 display: flex;
 align-items: center;
 justify-content: center;
 position: relative;
}
.btn_entry_submit span::before {
 position: relative;
 content: "";
 width: 0.4em;
 height: 0.4em;
 right: 0.1em;
 transform: rotate(45deg);
 border-top: 2px solid #516EA1;
 border-right: 2px solid #516EA1;
}
.btn_entry_submit:hover {
 opacity: 0.7;
}

@media screen and (max-width:768px) {
 .contactform {
  padding: 1em 2em 2em;
 }
 .mailform_frame div {
  display: block;
 }
 .mailform_frame p {
  padding-left: 1em;
 }
 .mailform_frame p.form_head {
  padding-left: 0;
 }
 .form_head span {
  display: inline-block;
  margin-left: 1em;
 }
 .btn_entry_submit {
  width: 80%;
 }
}