@charset "UTF-8";
/*
    Template: swell
    Theme Name: Shinfuji-Recruit
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/
/* Foundation
 * 変数、関数、mixinを定義
 * サイト全体のデフォルトスタイルを管理
======================================*/
/****** 変数定義 ******/
/****** mixin定義 ******/
/****** 関数定義 ******/
/****** ベースとなるスタイル ******/
:root {
  --swl-pad_container: 16px!important;
  --container_size: 1180px!important;
  --article_size: 900px!important;
}

html {
  visibility: hidden;
}

a {
  color: unset;
}

@media screen and (min-width: 600px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

address {
  font-style: unset;
}

figure {
  line-height: 1;
}

/* Layout
 * 接頭辞：l-
 * 各ページを構成する大枠のエリアに対するレイアウトを定義
======================================*/
/****** ヘッダー ******/
.l-header .l-header__logo {
  column-gap: clamp(10px, calc(20 / (1180 + 16 * 2) * 100vw), 20px);
  row-gap: 10px;
  justify-content: center;
}

/*雇入時健診*/
.page-id-723 .l-header {
  display: none;
}
.page-id-723 .l-fixHeader__inner {
  display: none;
}

@media screen and (min-width: 961px) {
  .l-header {
    padding-top: 20px !important;
    padding-bottom: 20px !important;
  }
  .l-header .l-header__inner {
    align-items: center !important;
  }
  .l-header .l-header__logo {
    padding: 0 !important;
  }
  .l-header .c-gnav {
    align-items: center;
  }
  .l-header .c-gnav > .menu-item:not(:nth-last-child(-n+2)) {
    border-right: 1px solid #ddd !important;
  }
  .l-header .c-gnav > .menu-item:not(.--contact) > a {
    padding: 4px clamp(10px, 20 / 1600 * 100vw, 20px) !important;
  }
  .l-header .c-gnav > .menu-item > a .ttl {
    font-size: clamp(12px, 16 / 1600 * 100vw, 16px);
  }
}
@media screen and (max-width: 960px) {
  .l-header__logo {
    display: flex;
    align-items: center;
  }
  .l-header__customBtn {
    display: none;
  }
}
/****** フッター ******/
.l-footer__body,
.l-footer__foot {
  padding-top: 60px;
  background-color: #F5F6F9;
}

.l-footer__body {
  padding-bottom: 50px;
}
@media screen and (max-width: 960px) {
  .l-footer__body {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}

.l-footer__foot {
  padding-bottom: 70px;
  border-top: 1px solid #EEEFF1;
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/texture/footer_bg.svg');
  background-repeat: no-repeat;
  background-size: 33%;
  background-position: top 0 right -5%;
}
@media screen and (max-width: 960px) {
  .l-footer__foot {
    padding-top: 0px;
    background-image: unset;
  }
}

.l-footer__inner {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 1.9607843137%;
}
@media screen and (max-width: 960px) {
  .l-footer__inner {
    display: block;
  }
}
.l-footer__inner.--foot {
  position: relative;
}

.l-footer__inner__col {
  grid-row: 1/2;
}
.l-footer__inner__col.--left {
  grid-column: 1/6;
}
.l-footer__inner__col.--right {
  grid-column: 6/-1;
}
@media screen and (max-width: 960px) {
  .l-footer__inner__col.--right {
    margin-top: 40px;
  }
}

.l-footer__copyright {
  padding-left: var(--swl-pad_container, 0);
  position: absolute;
  left: 0;
  bottom: -24px;
  font-size: 12px;
}
@media screen and (max-width: 960px) {
  .l-footer__copyright {
    padding-left: 0;
    position: static;
    text-align: center;
  }
}

/*雇入時健診*/
.page-id-723 .l-footer__head {
  display: none;
}

/****** コンテンツエリア ******/
.swiper-slide {
  transition: transform 0.6s;
}

.swiper-button-next,
.swiper-button-prev {
  width: 45px;
  height: 45px;
  border-radius: 25px;
  align-items: center;
  justify-content: center;
  display: flex;
  margin-left: -24px;
}

:root {
  --swiper-nav-size: 25px;
}

@media screen and (max-width: 960px) {
  .swiper-container {
    position: relative;
  }
}

/****** セクション ******/
/*--------------------------------
 *  CTA
--------------------------------*/
.l-sect-cta {
  padding-top: 60px;
  padding-bottom: 100px;
}
@media screen and (max-width: 599px) {
  .l-sect-cta {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
.l-sect-cta .c-btn-line {
  margin: 60px auto 0;
}
@media screen and (max-width: 599px) {
  .l-sect-cta .c-btn-line {
    margin-top: 20px;
  }
}

/*--------------------------------
 *  ホーム
--------------------------------*/
/*------ 共通 -------*/
.l-sect-home__title {
  margin-bottom: calc(60 / 26 * 1em);
  font-weight: normal;
  font-size: 26px;
  line-height: 1.8;
}
@media screen and (max-width: 960px) {
  .l-sect-home__title {
    margin-bottom: calc(40 / 22 * 1em);
    font-size: 22px;
    text-align: center;
  }
}

.l-sect-home > .l-sect-home__title {
  text-align: center;
}

.l-sect-home__desc {
  line-height: 1.8;
  font-size: 16px;
}

/*------ ファーストビジュアル -------*/
.l-sect-home-fv {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);
  padding-top: 20px;
  padding-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: clamp(10px, 640 / 1600 * 100vw, 640px);
}
@media screen and (max-width: 599px) {
  .l-sect-home-fv {
    align-items: flex-end;
    aspect-ratio: 375/440;
    height: auto;
  }
}

.l-sect-home-fv__hero {
  padding-right: calc(86 / 28 * 1em);
  width: fit-content;
  display: flex;
  font-size: clamp(10px, calc(28 / (1180 + 16 * 2) * 100vw), 28px);
  line-height: 1;
  letter-spacing: 0.05em;
  font-family: "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
}
@media screen and (max-width: 599px) {
  .l-sect-home-fv__hero {
    padding-right: 0;
    flex-direction: column;
    row-gap: 5px;
    font-size: 22px;
  }
}

.l-sect-home-fv__hero > span {
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  display: block;
  background-color: #fff;
  padding-top: calc(20 / 28 * 1em);
  padding-bottom: calc(20 / 28 * 1em);
}
@media screen and (max-width: 599px) {
  .l-sect-home-fv__hero > span {
    padding: calc(9 / 22 * 1em) calc(13 / 22 * 1em) !important;
  }
}
.l-sect-home-fv__hero > span.--beforeText {
  padding-left: calc(30 / 28 * 1em);
  padding-right: 0.4em;
}
.l-sect-home-fv__hero > span.--afterText {
  padding-left: 0.4em;
  padding-right: calc(30 / 28 * 1em);
}

/*------ お知らせ -------*/
.l-sect-home-info {
  padding-top: 80px;
  padding-bottom: 80px;
  background-color: #F5F6F9;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
@media screen and (max-width: 599px) {
  .l-sect-home-info {
    padding-top: 60px;
  }
}

/*------ グループ概要 -------*/
.l-sect-home-about {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);
  padding-top: 80px;
  padding-bottom: 80px;
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/texture/tx_03.webp'), url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/texture/tx_04.webp');
  background-size: clamp(10px, calc(740 / (1180 + 16 * 2) * 100vw), 740px) auto, clamp(10px, calc(780 / (1180 + 16 * 2) * 100vw), 780px) auto;
  background-position: calc(50% - clamp(10px, calc(290 / (1180 + 16 * 2) * 100vw), 290px)) calc(clamp(10px, calc(310 / (1180 + 16 * 2) * 100vw), 310px) * -1), right calc(50% - clamp(10px, calc(450 / (1180 + 16 * 2) * 100vw), 450px)) top calc(clamp(10px, calc(390 / (1180 + 16 * 2) * 100vw), 390px) * -1);
  background-repeat: no-repeat, no-repeat;
}
@media screen and (max-width: 599px) {
  .l-sect-home-about {
    padding-top: 40px;
    padding-bottom: 60px;
    background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/texture/tx_03.webp');
    background-size: auto 100%;
    background-position: -200px center;
    background-repeat: no-repeat;
  }
}

.l-sect-home-about__media {
  padding-left: clamp(10px, calc(80 / (1180 + 16 * 2) * 100vw), 80px);
  display: flex;
  column-gap: clamp(10px, calc(80 / (1180 + 16 * 2) * 100vw), 80px);
}
@media screen and (max-width: 960px) {
  .l-sect-home-about__media {
    padding-left: 0;
    display: block;
  }
}
.l-sect-home-about__media .c-label-more {
  margin-top: 60px;
}
@media screen and (max-width: 960px) {
  .l-sect-home-about__media .c-label-more {
    margin: 40px auto 0;
  }
}

.l-sect-home-abou__col.--title {
  flex: 1;
}

.l-sect-home-abou__col.--text {
  width: clamp(10px, calc(680 / (1180 + 16 * 2) * 100vw), 680px);
}
@media screen and (max-width: 960px) {
  .l-sect-home-abou__col.--text {
    width: auto;
  }
}

/*------ 動画 -------*/
.l-sect-home-vide {
  padding-top: 20px;
  padding-bottom: 50px;
}
@media screen and (max-width: 599px) {
  .l-sect-home-vide {
    padding-bottom: 30px;
  }
}

/*------ 募集職種 -------*/
.l-sect-home-recruit {
  padding-top: 50px;
}
@media screen and (max-width: 599px) {
  .l-sect-home-recruit {
    padding-top: 30px;
  }
}

.l-sect-home-recruit__btnWrapper {
  margin-bottom: 30px;
  display: flex;
  column-gap: clamp(10px, calc(40 / (1180 + 16 * 2) * 100vw), 40px);
}

/*------ 教育体制・入社後のサポート -------*/
.l-sect-home-support {
  padding-top: 80px;
}
@media screen and (max-width: 599px) {
  .l-sect-home-support {
    padding-top: 60px;
  }
}
.l-sect-home-support .c-label-more {
  margin-top: 60px;
}
@media screen and (max-width: 960px) {
  .l-sect-home-support .c-label-more {
    margin: 40px auto 0;
  }
}

/****** タイトルヘッダー ******/
.l-topTitleArea {
  min-height: calc(200 / 16 * 1em) !important;
}
@media screen and (max-width: 599px) {
  .l-topTitleArea {
    min-height: 100px !important;
  }
}
.l-topTitleArea .c-pageTitle {
  color: #444 !important;
}
.l-topTitleArea .c-pageTitle__subTitle {
  margin-top: calc(10 / 14 * 1em) !important;
  margin-left: 0 !important;
  display: block !important;
  color: #888888 !important;
  font-style: normal !important;
  font-weight: normal !important;
}

.l-topTitleArea__body {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: calc(30 / 16 * 1em);
  align-items: center;
}

.l-topTitleArea__icon > span {
  width: calc(50 / 16 * 1em);
  height: calc(50 / 16 * 1em);
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* Object > Component
 * 接頭辞：c-
 * 再利用できるパターンとして最小単位のモジュールを定義
======================================*/
/****** 見出し/タイトル ******/
/*--------------------------------
 *  フッター
--------------------------------*/
.c-heading-footer {
  margin-bottom: calc(25 / 18 * 1em);
  display: flex;
  align-items: center;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
}
.c-heading-footer::after {
  margin-left: calc(15 / 18 * 1em);
  height: 1px;
  flex: 1;
  content: "";
  background-color: #ddd;
}
@media screen and (max-width: 960px) {
  .c-heading-footer::before {
    margin-right: calc(15 / 18 * 1em);
    height: 1px;
    flex: 1;
    content: "";
    background-color: #ddd;
  }
}

/*--------------------------------
 *  募集要項
--------------------------------*/
.c-heading-lv1 {
  margin-bottom: calc(40 / 26 * 1em);
  font-size: 26px;
  text-align: center;
  line-height: 1.15;
  font-weight: 500;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 599px) {
  .c-heading-lv1 {
    margin-bottom: 1em;
    font-size: 20px;
  }
}

.c-heading-lv1 > span {
  margin: 0 auto;
  margin-top: 0.5em;
  padding: 0 2em;
  display: block;
  font-size: calc(14 / 26 * 1em);
  width: fit-content;
  position: relative;
}
.c-heading-lv1 > span::before, .c-heading-lv1 > span::after {
  content: "";
  width: 1.5em;
  height: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: currentColor;
}
.c-heading-lv1 > span::before {
  left: 0;
}
.c-heading-lv1 > span::after {
  right: 0;
}

.c-heading-lv1.--new-graduate > span {
  color: #EF7DAD;
}

.c-heading-lv1.--mid-career > span {
  color: #3177C9;
}

.c-heading-lv1.--part-time > span {
  color: #F2BF4E;
}

.c-heading-lv1.--doctor > span {
  color: #5FC9C1;
}

/*--------------------------------
 *  募集要項 > 最終学歴
--------------------------------*/
.c-heading-recruit {
  margin-bottom: calc(40 / 22 * 1em);
  padding: calc(12 / 22 * 1em);
  border-radius: 5px;
  font-size: 22px;
  line-height: 1.4;
  font-weight: normal;
  text-align: center;
  color: #fff;
}
.c-heading-recruit:not(:first-of-type) {
  margin-top: calc(80 / 22 * 1em);
}
@media screen and (max-width: 599px) {
  .c-heading-recruit {
    font-size: 18px;
  }
}

.c-heading-recruit.--new-graduate {
  background-color: #EF7DAD;
}

.c-heading-recruit.--mid-career {
  background-color: #3177C9;
}

.c-heading-recruit.--part-time {
  background-color: #F2BF4E;
}

.c-heading-recruit.--doctor {
  background-color: #5FC9C1;
}

/*--------------------------------
 *  エディター内
--------------------------------*/
.post_content h2:not(.is-style-section_ttl) {
  padding: calc(10 / 28 * 1em) calc(20 / 28 * 1em);
  background-color: #8EA7DE;
  color: #fff;
  border-radius: 5px 5px 0 0;
}

.post_content h3:not(.is-style-section_ttl) {
  padding-left: calc(20 / 24 * 1em);
  border-left: 4px solid var(--color_main);
}

.post_content h4:not(.is-style-section_ttl) {
  padding-left: calc(26 / 16 * 1em);
  position: relative;
}
.post_content h4:not(.is-style-section_ttl)::before {
  width: 1em;
  height: 1em;
  position: absolute;
  top: 0.2em;
  left: 0;
  content: "";
  background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16"><g transform="translate(3211 -6018)"><circle cx="8" cy="8" r="8" transform="translate(-3211 6018)" fill="%23999999"/><circle cx="5" cy="5" r="5" transform="translate(-3208 6021)" fill="%23fff"/></g></svg>');
  background-repeat: no-repeat;
  background-size: contain;
}

/****** ラベル ******/
/*--------------------------------
 *  タームバッジ
--------------------------------*/
.c-label-term {
  padding: 4px 5px 6px;
  font-size: calc(14 / 16 * 1em);
  line-height: 1;
  width: 110px;
  text-align: center;
  border: 1px solid currentColor;
  transition: 0.25s;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  -webkit-text-overflow: ellipsis;
  -o-text-overflow: ellipsis;
  border-radius: 999em;
  position: absolute;
  left: clamp(100px, 0.957vw + 2.411px, 40px);
  top: clamp(7.8rem, 1.914vw + 2.2823rem, 5rem);
}
.c-label-term:focus, .c-label-term:hover {
  border-color: transparent;
  background-color: var(--color_text);
  color: #fff;
}
@media screen and (max-width: 960px) {
  .c-label-term {
    position: absolute;
    left: clamp(25px, 0.478vw + 13.208px, 20px);
    top: clamp(278px, 105.478vw + 20.208px, 20px);
  }
}

/*--------------------------------
 *  接頭アイコン
--------------------------------*/
/*------ Font Awesome利用 -------*/
.c-label-icon, .c-label-icon-svg {
  display: flex;
  align-items: center;
  line-height: 1.15;
}
.c-label-icon::before, .c-label-icon-svg::before {
  margin-right: calc(15 / 16 * 1em);
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  color: var(--color_main);
}

a:not(.c-label-more).c-label-icon, a.c-label-icon-svg:not(.c-label-more) {
  transition: 0.25s;
}
a:not(.c-label-more).c-label-icon:focus, a.c-label-icon-svg:not(.c-label-more):focus, a:not(.c-label-more).c-label-icon:hover, a.c-label-icon-svg:not(.c-label-more):hover {
  opacity: 0.6;
}

.c-label-icon.--pen::before, .--pen.c-label-icon-svg::before {
  content: "\f304";
}

.c-label-icon.--book::before, .--book.c-label-icon-svg::before {
  content: "\f518";
}

.c-label-icon.--contact, .--contact.c-label-icon-svg {
  font-size: clamp(14px, 1vw, 16px);
  color: #F78F86;
  font-weight: bold;
  justify-content: center;
  line-height: calc(24 / 16 * 1em);
  transition: 0.25s;
}
.c-label-icon.--contact::before, .--contact.c-label-icon-svg::before {
  margin-right: calc(10 / 24 * 1em);
  font-family: "Font Awesome 6 Free";
  font-weight: 400;
  content: "\f0e0";
  color: inherit;
  font-size: calc(24 / 16 * 1em);
  line-height: 1;
}

/*------ SVG画像利用 -------*/
.c-label-icon-svg::before {
  margin-right: calc(10 / 16 * 1em);
  width: 1em;
  height: 1em;
  content: "";
  color: unset;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}

.c-label-icon-svg.--map::before {
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/icon/icon-map.svg');
}

.c-label-icon-svg.--tel::before {
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/icon/icon-tel.svg');
}

.c-label-icon-svg.--user::before {
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/icon/icon-user.svg');
}

.c-label-icon-svg.--family::before {
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/icon/icon-family.svg');
}

/*--------------------------------
 *  詳しく見る
--------------------------------*/
.c-label-more {
  padding-right: calc(30 / 16 * 1em);
  padding-bottom: calc(5 / 16 * 1em);
  width: fit-content;
  display: block;
  font-size: 16px;
  line-height: 1.5;
  transition: 0.25s;
  position: relative;
  color: inherit;
}
.c-label-more::before {
  width: 100%;
  height: 1px;
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  display: block;
  background-color: currentColor;
  transform-origin: right;
  transition: transform 0.25s;
}
.c-label-more::after {
  width: calc(12 / 16 * 1em);
  height: calc(9 / 16 * 1em);
  position: absolute;
  top: calc(8 / 16 * 1em);
  right: calc(4 / 16 * 1em);
  content: "";
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/icon/ic_03.svg');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  transition: transform 0.25s;
}
.c-label-more:focus::after, .c-label-more:hover::after {
  transform: translateX(4px);
}
.c-label-more:focus::before, .c-label-more:hover::before {
  transform: scaleX(0);
}

/*--------------------------------
 *  ラッパー
--------------------------------*/
/*------ デスクトップ：縦並び、モバイル：横並び -------*/
.c-label-vert__wrapper {
  margin: calc(-8 / 16 * 1em);
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 960px) {
  .c-label-vert__wrapper {
    flex-direction: row;
    flex-wrap: wrap;
  }
}
.c-label-vert__wrapper > * {
  margin: calc(8 / 16 * 1em);
}

/*--------------------------------
 *  カテゴリバッジ
--------------------------------*/
.c-label-cat {
  padding: 3px 3px 4px;
  font-size: 12px;
  line-height: 1.5;
  width: 80px;
  text-align: center;
  outline: 1px solid #FFF;
  outline-offset: -1px;
  transition: 0.25s;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  -webkit-text-overflow: ellipsis;
  -o-text-overflow: ellipsis;
}
.c-label-cat:focus, .c-label-cat:hover {
  background-color: #FFF;
  color: #444;
}

/****** ボタン ******/
/*--------------------------------
 *  CTA
--------------------------------*/
.c-btn-cta {
  padding: 60px;
  width: 100%;
  max-width: 100%;
  font-size: 18px;
  color: #fff !important;
  text-align: center;
  line-height: 1;
  display: block;
  border-radius: 5px;
  font-weight: bold;
  position: relative;
  background: transparent;
  z-index: 1;
  overflow: hidden;
}
@media screen and (max-width: 599px) {
  .c-btn-cta {
    padding: 30px;
    font-size: 16px;
  }
}
.c-btn-cta::before {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  z-index: -2;
  background-image: linear-gradient(259deg, #6199E8 0%, #5573D4 100%);
}
.c-btn-cta::after {
  width: 100%;
  height: 100%;
  display: block;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background-image: linear-gradient(259deg, #5573D4 0%, #6199E8 100%);
  transition: 0.25s;
}
.c-btn-cta:focus::after, .c-btn-cta:hover::after {
  opacity: 0;
}
.c-btn-cta:focus .c-btn-cta__arrow, .c-btn-cta:hover .c-btn-cta__arrow {
  background-position: left 0;
}
.c-btn-cta > span {
  display: block;
  font-size: 40px;
  font-weight: 400;
  line-height: 1;
  margin-bottom: 10px;
  font-family: "Marcellus", serif;
}
@media screen and (max-width: 599px) {
  .c-btn-cta > span {
    font-size: 28px;
  }
}

.c-btn-cta__arrow {
  width: 25px;
  height: 25px;
  position: absolute;
  top: 50%;
  right: 60px;
  transform: translateY(-50%);
  display: block;
  font-size: inherit;
  background-position: right 0;
  background-size: 50px 25px;
  background-repeat: no-repeat;
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/icon/icon-arrow-twin.svg');
  transition: 0.25s;
}
@media screen and (max-width: 599px) {
  .c-btn-cta__arrow {
    right: 20px;
  }
}

/*--------------------------------
 *  LINE
--------------------------------*/
.c-btn-line {
  padding: calc(20 / 16 * 1em) calc(40 / 16 * 1em);
  max-width: 100%;
  display: flex;
  column-gap: calc(30 / 16 * 1em);
  row-gap: 10px;
  align-items: center;
  width: fit-content;
  font-size: 16px;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1019607843);
  border-radius: 5px;
  transition: transform 0.25s;
}
@media screen and (max-width: 599px) {
  .c-btn-line {
    width: 100%;
    flex-direction: column;
    font-size: 14px;
  }
}
.c-btn-line:focus, .c-btn-line:hover {
  transform: scale(0.95);
}
.c-btn-line .fa-line {
  font-size: calc(48 / 16 * 1em);
  color: #24AE27;
}

.c-btn-line__icon {
  width: calc(20 / 16 * 1em);
  height: calc(20 / 16 * 1em);
  background-image: url('/import/tenant_1/smg-shizuoka.a-bisu.jp/html/wp-content/themes/shinfuji-recruit/img/icon/ic_01.svg');
}

/*--------------------------------
 *  求人検索（医師採用、パート採用）
--------------------------------*/
.c-btn-recruit {
  padding: 1em 2.5em;
  position: relative;
  border: 3px solid currentColor;
  border-radius: 5px;
  text-align: center;
  flex: 1;
  line-height: 1;
  font-size: 22px;
  transition: 0.25s;
}
@media screen and (max-width: 960px) {
  .c-btn-recruit {
    padding: 0.85em;
    font-size: 18px;
  }
}
.c-btn-recruit::after {
  content: "";
  position: absolute;
  right: calc(30 / 22 * 1em);
  top: 50%;
  transform: translateY(-50%);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  width: calc(16 / 22 * 1em);
  height: calc(10 / 22 * 1em);
  transition: 0.25s;
}
@media screen and (max-width: 960px) {
  .c-btn-recruit::after {
    content: none;
  }
}
.c-btn-recruit:focus, .c-btn-recruit:hover {
  opacity: 0.6;
}

.c-btn-recruit.--doctor {
  color: #5FC9C1;
}
.c-btn-recruit.--doctor::after {
  background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 11.889 8.5"><g data-name="→" fill="%235FC9C1"><path d="M10.75 5h-10A.75.75 0 0 1 0 4.25a.75.75 0 0 1 .75-.75h10a.75.75 0 0 1 .75.75.75.75 0 0 1-.75.75Z"/><path d="M6.751 8.5a.75.75 0 0 1-.494-1.314L9.612 4.25 6.257 1.314A.75.75 0 0 1 7.245.185l4.645 4.064-4.645 4.064a.748.748 0 0 1-.494.187Z"/></g></svg>');
}

.c-btn-recruit.--part {
  color: #F2BF4E;
}
.c-btn-recruit.--part::after {
  background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 11.889 8.5"><g data-name="→" fill="%23F2BF4E"><path d="M10.75 5h-10A.75.75 0 0 1 0 4.25a.75.75 0 0 1 .75-.75h10a.75.75 0 0 1 .75.75.75.75 0 0 1-.75.75Z"/><path d="M6.751 8.5a.75.75 0 0 1-.494-1.314L9.612 4.25 6.257 1.314A.75.75 0 0 1 7.245.185l4.645 4.064-4.645 4.064a.748.748 0 0 1-.494.187Z"/></g></svg>');
}

/*--------------------------------
 *  募集要項
--------------------------------*/
.c-btn-entry {
  padding: calc(20 / 18 * 1em);
  font-size: 18px;
  line-height: 1.444;
  color: #fff;
  border-radius: 5px;
  position: relative;
  background: transparent;
  z-index: 1;
  overflow: hidden;
  display: block;
  width: 232px;
  max-width: 100%;
  text-align: center;
}
.c-btn-entry::before {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  z-index: -2;
  background-image: linear-gradient(259deg, #6199E8 0%, #5573D4 100%);
}
.c-btn-entry::after {
  width: 100%;
  height: 100%;
  display: block;
  content: "" !important;
  position: absolute;
  top: 0;
  left: 0;
  bottom: unset;
  z-index: -1;
  background-image: linear-gradient(259deg, #5573D4 0%, #6199E8 100%);
  transition: 0.25s;
  transform: unset;
}
.c-btn-entry:focus::after, .c-btn-entry:hover::after {
  opacity: 0;
}
.c-btn-entry .ttl {
  font-size: inherit !important;
}

/****** ロゴ ******/
.c-logo-site {
  margin: 0;
  display: block;
  width: fit-content;
  position: relative;
}

.c-logo-site__layer {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
}
.c-logo-site__layer:focus ~ .c-logo-site__img, .c-logo-site__layer:hover ~ .c-logo-site__img {
  opacity: 0.6;
}

/*--------------------------------
 *  ヘッダー
--------------------------------*/
.c-logo-site.--header.is-fixed {
  display: block;
}
.c-logo-site.--header.is-scroll {
  display: none;
}
.c-logo-site.--header .c-logo-site__img {
  height: 40px;
  display: block;
  transition: 0.25s;
}
@media screen and (max-width: 960px) {
  .c-logo-site.--header .c-logo-site__img {
    height: 30px;
  }
}

/*------ ホーム > スクロール切り替え -------*/
[data-scrolled=true] .c-logo-site.--header.is-fixed {
  display: none;
}
[data-scrolled=true] .c-logo-site.--header.is-scroll {
  display: block;
}

/*--------------------------------
 *  フッター
--------------------------------*/
.c-logo-site.--footer .c-logo-site__img {
  height: 40px;
  display: block;
  transition: 0.25s;
}

/*--------------------------------
 *  採用サイト
--------------------------------*/
.c-logo-sub {
  padding: 3px 1em 5px;
  color: #fff;
  background-color: #DE312D;
  line-height: 1.15;
  width: fit-content;
  white-space: nowrap;
  font-size: clamp(10px, calc(14 / (1180 + 16 * 2) * 100vw), 14px);
  font-weight: normal;
}
@media screen and (max-width: 960px) {
  .c-logo-sub {
    padding: 3px 1em 5px;
    font-size: 12px;
  }
}

/****** SNS ******/
.c-sns-icon__wrapper {
  line-height: 1;
  text-align: left;
}

.c-sns-icon {
  display: inline-block;
  font-size: 1.5625rem;
  line-height: 1;
  padding: 0.3em;
  border-radius: 50%;
}
.c-sns-icon:not(:last-child) {
  margin-right: 10px;
}
.c-sns-icon:hover {
  opacity: 0.6;
}

.c-sns-icon__item {
  position: relative;
  display: block;
  width: 1em;
  height: 1em;
  transition: all ease 0.3s;
}
.c-sns-icon__item::before {
  font-family: "Font Awesome 6 Brands";
  font-weight: 400;
  color: #fff;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

/*--------------------------------
 *  各アイコン書き出し
--------------------------------*/
.c-sns-icon.--insta {
  background: linear-gradient(45deg, rgb(254, 212, 117) 0%, rgb(229, 61, 93) 50%, rgb(194, 49, 134) 70%, rgb(156, 56, 187) 100%);
}
.c-sns-icon.--insta .c-sns-icon__item::before {
  content: "\f16d";
}
.c-sns-icon.--facebook {
  background: #3b5998;
}
.c-sns-icon.--facebook .c-sns-icon__item::before {
  content: "\f39e";
}
.c-sns-icon.--twitter {
  background: #1da1f2;
}
.c-sns-icon.--twitter .c-sns-icon__item::before {
  content: "\f099";
}
.c-sns-icon.--youtube {
  background: #cd201f;
}
.c-sns-icon.--youtube .c-sns-icon__item::before {
  content: "\f167";
}
.c-sns-icon.--line {
  background: #08B901;
}
.c-sns-icon.--line .c-sns-icon__item::before {
  content: "\f3c0";
}

/****** video ******/
.c-video {
  margin: 0 auto;
  width: 100%;
  max-width: 860px;
  position: relative;
  overflow: hidden;
  border-radius: 5px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1), 0 4px 8px -4px rgba(0, 0, 0, 0.2);
  background-color: #ddd;
}
.c-video::before {
  content: "";
  display: block;
  width: 100%;
  height: auto;
  padding-top: 56.25%;
}
.c-video > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Object > Project
 * 接頭辞：p-
 * 再利用できるパターンとしてComponentの集合体を定義
 * もしくはComponentとするには大きすぎるObject（4階層構造以上を目安）を定義
======================================*/
/****** ブログカード ******/
/*--------------------------------
    お知らせ
--------------------------------*/
.p-card__unit {
  width: 100%;
  max-width: 100%;
  font-size: 16px;
}

.p-card {
  padding: 1.25em;
  display: grid;
  grid-template-columns: 0.4fr 1fr;
  column-gap: 1.25em;
  align-items: center;
  border-bottom: 1px solid #ddd;
  background-color: white;
  border-radius: 0.5em;
}
@media screen and (max-width: 960px) {
  .p-card {
    grid-template-columns: 1fr;
    /* レスポンシブ時に1カラムに変更 */
    position: relative;
  }
}
.p-card:first-child {
  border-top: 1px solid #ddd;
}

.p-card__inner.--meta {
  order: 1;
}
@media screen and (max-width: 960px) {
  .p-card__inner.--meta {
    order: 2;
    display: flex;
    justify-content: center;
    padding: 2.5rem 0 1.5rem;
  }
}
.p-card__inner.--article {
  min-width: 0;
  position: relative;
  order: 2;
}
@media screen and (max-width: 960px) {
  .p-card__inner.--article {
    order: 1;
  }
}
.p-card__inner.--article::before {
  content: "";
  /* Necessary for the pseudo-element to be generated */
  position: absolute;
  /* Position it on top of the parent */
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0);
  /* Start with a fully transparent black background */
  transition: background-color 0.3s;
  /* Smooth transition */
  pointer-events: none;
  /* Ensure the overlay doesn't interfere with clickable elements beneath */
  z-index: 1;
  /* Ensure it's below the button and other content */
}
.p-card__inner:hover::before {
  background-color: rgba(0, 0, 0, 0.3);
  /* On hover, make it 70% opaque black */
}
.p-card__inner:hover .p-card__btn {
  visibility: visible;
  opacity: 1;
  /* Fully visible */
  top: calc(50% + 8px);
  /* Return to the original top position */
}

.p-card__icatch {
  width: 100%;
  height: 250px;
  object-fit: cover;
}

.p-card__flex {
  display: flex;
  align-items: start;
  justify-content: space-between;
}

.p-card__date {
  font-size: inherit;
  display: flex;
  flex-direction: column-reverse;
  justify-content: flex-start;
}
.p-card__date span.day-part {
  line-height: 2rem;
  margin: 0 0.2em 0.1em;
  font-size: 180%;
  font-weight: bold;
  color: #FFF;
  -webkit-text-stroke: 0.02em #000;
  font-family: Dongle, sans-serif;
}

.p-card__ttl {
  font-size: large;
  display: block;
  width: 100%;
  position: relative;
  overflow: hidden;
  margin-top: 1rem;
  font-weight: 700;
}
@media screen and (max-width: 960px) {
  .p-card__ttl {
    font-size: initial;
    margin-left: 1rem;
    margin-top: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    text-overflow: ellipsis;
  }
}
.p-card__ttl:focus, .p-card__ttl:hover {
  color: var(--color_main);
}

.p-card__btn {
  position: absolute;
  z-index: 2;
  top: calc(50% + 28px);
  /* Increased from 8px to 28px for starting position */
  left: 50%;
  padding: 1.6rem 20px;
  border-radius: 99px;
  margin: auto;
  font-weight: 700;
  line-height: 1.1;
  transform: translate(-50%, -50%);
  transition: opacity 0.2s, top 0.2s;
  /* Ensure you only define transition once */
  background-color: white;
  visibility: hidden;
  opacity: 0;
  /* Initially hidden */
}

/*--------------------------------
    記事が存在しない場合
--------------------------------*/
.p-card-not {
  padding: 2em 1em;
  background-color: #efefef;
  border: 1px solid #ddd;
  display: flex;
  justify-content: center;
  align-items: center;
}

.p-card-not__txt {
  font-size: 1rem;
  font-weight: bold;
  color: #BBB;
}

/*--------------------------------
 *  トップ > 職種
--------------------------------*/
.p-card-job__unit {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
@media screen and (max-width: 960px) {
  .p-card-job__unit {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
}

.p-card-job {
  padding: clamp(10px, calc(20 / (1180 + 16 * 2) * 100vw), 20px) clamp(10px, calc(40 / (1180 + 16 * 2) * 100vw), 40px) clamp(10px, calc(40 / (1180 + 16 * 2) * 100vw), 40px);
  background-color: #fff;
  border-radius: 5px;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.1);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 10px;
}

.p-card-job__layer {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
}
.p-card-job__layer:focus ~ .p-card-job__img > i, .p-card-job__layer:hover ~ .p-card-job__img > i {
  transform: translate(-50%, -50%) scale(1);
}
.p-card-job__layer:focus ~ .c-label-more::after, .p-card-job__layer:hover ~ .c-label-more::after {
  transform: translateX(4px);
}

.p-card-job__img {
  margin: 0;
  position: relative;
  padding: 10%;
  width: 80%;
}
.p-card-job__img > img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: contain;
  position: relative;
  z-index: 1;
}
.p-card-job__img > i {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.75);
  transition: 0.25s;
}

.p-card-job__title {
  font-size: 22px;
}
@media screen and (max-width: 599px) {
  .p-card-job__title {
    font-size: 18px;
  }
}

.p-card-job .c-label-more {
  padding-right: calc(25 / 16 * 1em);
  padding-bottom: 0;
}
@media screen and (max-width: 599px) {
  .p-card-job .c-label-more {
    font-size: 14px;
  }
}
.p-card-job .c-label-more::before {
  content: none;
}

/*--------------------------------
    募集要項
--------------------------------*/
.p-card-recruit__unit {
  display: grid;
  grid-template-columns: 100%;
  row-gap: 40px;
}

.p-card-recruit {
  padding: 40px;
  border-style: solid;
  border-width: 3px;
}
@media screen and (max-width: 599px) {
  .p-card-recruit {
    padding: 15px;
  }
}

.p-card-recruit.--new-graduate {
  border-color: #EF7DAD;
}
.p-card-recruit.--new-graduate .p-card-recruit__th {
  background-color: #FCF5F6;
}

.p-card-recruit.--mid-career {
  border-color: #3177C9;
}
.p-card-recruit.--mid-career .p-card-recruit__th {
  background-color: #F5F6F9;
}

.p-card-recruit.--part-time {
  border-color: #F2BF4E;
}
.p-card-recruit.--part-time .p-card-recruit__th {
  background-color: #FAF8EF;
}

.p-card-recruit.--doctor {
  border-color: #5FC9C1;
}
.p-card-recruit.--doctor .p-card-recruit__th {
  background-color: #F5F8F8;
}

.p-card-recruit__title {
  font-size: 20px;
  margin-bottom: 1em;
  font-weight: normal;
  line-height: 1.15;
  text-align: center;
}
@media screen and (max-width: 599px) {
  .p-card-recruit__title {
    font-size: 16px;
  }
}

.p-card-recruit__table {
  margin-bottom: 40px;
  width: 100%;
  table-layout: fixed;
  font-size: 16px;
  line-height: 1.5;
  border-bottom: 1px solid #DDDDDD;
}
@media screen and (max-width: 599px) {
  .p-card-recruit__table {
    font-size: 12px;
    border-bottom-width: 0;
  }
}

.p-card-recruit__th,
.p-card-recruit__td {
  padding: 0.75em 1em;
  font-size: inherit;
  line-height: inherit;
  border-top: 1px solid #DDDDDD;
}
@media screen and (max-width: 599px) {
  .p-card-recruit__th,
  .p-card-recruit__td {
    display: block !important;
    width: 100% !important;
    border-left: 1px solid #DDDDDD;
    border-right: 1px solid #DDDDDD;
  }
}

.p-card-recruit__th {
  width: calc(200 / 16 * 1em);
  text-align: left;
  font-weight: 500;
}

.p-card-recruit__td {
  font-weight: 400;
}
@media screen and (max-width: 599px) {
  .p-card-recruit__td {
    border-bottom: 1px solid #DDDDDD;
  }
}

@media screen and (max-width: 599px) {
  tr:not(:last-child) .p-card-recruit__td {
    margin-bottom: 1em;
  }
}

.p-card-recruit .c-btn-entry {
  margin: 0 auto;
  margin-top: 40px;
}

/*------ 拡散検索用 -------*/
.p-card-recruit__unit.js-serch-unit .js-search-card {
  display: none;
}
.p-card-recruit__unit.js-serch-unit .js-search-card.is-show {
  display: block;
}

/****** ナビゲーション ******/
/*--------------------------------
	ヘッダー
--------------------------------*/
.l-header__gnav .menu-item > a::after {
  content: none !important;
}

.l-header__gnav .menu-item.current-menu-item:not(.menu-item-type-custom) > a {
  color: var(--color_main);
  pointer-events: none;
}

.l-header__gnav .menu-item:not(.--contact) > a {
  transition: 0.25s;
}
.l-header__gnav .menu-item:not(.--contact) > a:focus, .l-header__gnav .menu-item:not(.--contact) > a:hover {
  opacity: 0.6;
}
@media screen and (min-width: 600px) {
  .l-header__gnav .menu-item:not(.--contact) > a {
    font-size: clamp(10px, calc(16 / (1180 + 16 * 2) * 100vw), 16px);
  }
}

.l-header__gnav .menu-item.--contact > a {
  margin-left: calc(20 / 14 * 1em) !important;
  padding: calc(12 / 14 * 1em) calc(40 / 14 * 1em);
  font-size: clamp(10px, calc(14 / (1180 + 16 * 2) * 100vw), 14px);
  color: #fff !important;
  line-height: 1.5;
  border-radius: 5px;
  position: relative;
  background: transparent;
  z-index: 1;
  overflow: hidden;
}
.l-header__gnav .menu-item.--contact > a::before {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  z-index: -2;
  background-image: linear-gradient(259deg, #6199E8 0%, #5573D4 100%);
}
.l-header__gnav .menu-item.--contact > a::after {
  width: 100%;
  height: 100%;
  display: block;
  content: "" !important;
  position: absolute;
  top: 0;
  left: 0;
  bottom: unset;
  z-index: -1;
  background-image: linear-gradient(259deg, #5573D4 0%, #6199E8 100%);
  transition: 0.25s;
  transform: unset;
}
.l-header__gnav .menu-item.--contact > a:focus::after, .l-header__gnav .menu-item.--contact > a:hover::after {
  opacity: 0;
}
.l-header__gnav .menu-item.--contact > a .ttl {
  font-size: inherit !important;
}

/*------ 上部メニュー -------*/
.p-nav-header-top {
  margin: 0 -10px;
  padding-bottom: 1em;
  font-size: clamp(10px, calc(14 / (1180 + 16 * 2) * 100vw), 14px);
  display: flex;
  justify-content: flex-end;
}
.p-nav-header-top > * {
  margin: 0 10px;
}
.p-nav-header-top .menu-item {
  font-size: inherit;
}
.p-nav-header-top .menu-item > * {
  font-size: inherit;
}

/*--------------------------------
	フッター
--------------------------------*/
.p-nav-footer__container {
  display: flex;
  flex-wrap: wrap;
  height: 100%;
}

.p-nav-footer__wrapper {
  padding: 0 3.2894736842%;
  flex: 1;
  border-left: 1px solid #ddd;
}

.p-nav-footer {
  font-size: 14px;
}
.p-nav-footer .menu-item {
  line-height: calc(20 / 14 * 1em);
}
.p-nav-footer .menu-item:not(:last-child) {
  margin-bottom: calc(10 / 14 * 1em);
}
.p-nav-footer .menu-item > a {
  transition: 0.25s;
}
.p-nav-footer .menu-item > a:focus, .p-nav-footer .menu-item > a:hover {
  opacity: 0.6;
}

/*------ メニュー階層：親 -------*/
.p-nav-footer > .menu-item {
  font-weight: 600;
}

/*------ メニュー階層：子 -------*/
.p-nav-footer .sub-menu {
  margin-top: calc(10 / 14 * 1em);
  font-weight: normal;
}
.p-nav-footer .sub-menu .menu-item {
  display: flex;
  align-items: center;
}
.p-nav-footer .sub-menu .menu-item::before {
  margin-right: calc(10 / 14 * 1em);
  content: "";
  width: 1em;
  height: 1em;
  background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 10 1"><path d="M10 1H0V0h10Z" fill="%23707070"/></svg>');
  background-repeat: no-repeat;
  background-size: calc(10 / 14 * 1em) 1px;
  background-position: center;
}

/****** フォーム ******/
/*--------------------------------
	コンタクトフォーム
--------------------------------*/
.p-form-contact {
  margin: 0 auto;
  width: 800px;
  max-width: 100%;
  line-height: 1.5;
  vertical-align: middle;
  font-size: 14px;
  line-height: 1.8;
}
.p-form-contact > *:last-child {
  padding-bottom: 0 !important;
}

.p-form-contact__tr {
  display: flex;
  gap: 1em;
  padding-bottom: 50px;
}
@media screen and (max-width: 960px) {
  .p-form-contact__tr {
    display: block;
    padding-bottom: 30px;
  }
}

.p-form-contact__th {
  padding-bottom: 1em;
  text-align: left;
  width: 35%;
  font-weight: normal;
}
@media screen and (max-width: 960px) {
  .p-form-contact__th {
    width: 100%;
  }
}

.p-form-contact__td {
  flex: 1;
}
.p-form-contact__td input[type=text],
.p-form-contact__td input[type=tel],
.p-form-contact__td input[type=url],
.p-form-contact__td input[type=date],
.p-form-contact__td input[type=email],
.p-form-contact__td select,
.p-form-contact__td textarea {
  padding: 0.5em;
  width: 100%;
}
.p-form-contact__td .formError + input[aria-required=true]:not(input[type=file]),
.p-form-contact__td .formError + select[aria-required=true] {
  transition: background-color 0.25s;
  background-color: #ffcfcf;
}
.p-form-contact__td input[type=file] {
  background-color: transparent;
  border: none;
  padding: 0;
  font-size: 14px;
}
.p-form-contact__td .notice {
  font-size: 12px;
}
.p-form-contact__td .notice:first-of-type {
  margin-top: 1em;
}
.p-form-contact__td select {
  padding: 0.5em;
  padding-right: 2em;
  font-size: inherit;
  font-weight: 600;
  border: 1px solid hsla(0, 0%, 78%, 0.5);
  appearance: none;
  display: block;
  width: 100%;
  background: #f7f7f7 url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M5%206l5%205%205-5%202%201-7%207-7-7%202-1z%22%20fill%3D%22%23a0a5aa%22%2F%3E%3C%2Fsvg%3E) no-repeat right 8px top 55%;
  background-size: 1em 1em;
  font-weight: normal;
}
@media screen and (max-width: 960px) {
  .p-form-contact__td {
    width: 100%;
  }
}

@media screen and (max-width: 599px) {
  table.p-form-contact .p-form-contact__th {
    padding-bottom: 20px;
    padding-right: 0;
    display: block;
    width: 100%;
  }
  table.p-form-contact .p-form-contact__td {
    padding-bottom: 40px;
    display: block;
    width: 100%;
  }
}
.p-form-contact .wpcf7-form-control-wrap {
  display: block;
}
.p-form-contact .wpcf7-checkbox,
.p-form-contact .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
}
.p-form-contact .wpcf7-list-item {
  margin: 0;
}
.p-form-contact .wpcf7-list-item > label {
  display: inline-flex;
  align-items: center;
  column-gap: 0.5em;
}

span.wpcf7-not-valid-tip {
  display: none;
}

.formError,
.formError * {
  box-sizing: content-box;
}

select.drop {
  background-image: url("https://smg-shizuoka.com/wp-content/themes/img/icon/drop.svg");
  background-position: right 0.5em center;
  background-repeat: no-repeat;
  background-size: auto 1em;
}

/*--------------------------------
    ボックス
--------------------------------*/
.p-form-box {
  margin-top: 60px;
}
@media screen and (max-width: 599px) {
  .p-form-box {
    margin-top: 0;
  }
}

.p-form-box__title {
  margin-bottom: 1em;
  font-size: 1.25rem;
  text-align: center;
  font-weight: bold;
}

.p-form-box__note {
  margin: 0 auto;
  padding: 1em;
  max-width: 100%;
  height: 200px;
  background: #eee;
  font-family: "Courier 10 Pitch", courier, monospace;
  line-height: 1.5;
  overflow-y: auto;
  border: 1px solid #ccc;
}

#p-form-box .p-form-box__note * {
  font-size: 0.75rem;
}
#p-form-box .p-form-box__note h2 {
  margin-top: 2em;
  margin-bottom: 0.5em;
  padding: 0;
  color: inherit;
  background-color: transparent;
  font-size: 0.875rem;
}

.p-form-box__agree {
  margin-top: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5em;
  line-height: 1;
}
.p-form-box__agree .wpcf7-list-item {
  margin: 0;
  display: block;
  line-height: 10px;
}
@media screen and (max-width: 599px) {
  .p-form-box__agree {
    font-size: 0.875rem;
  }
}

/*--------------------------------
    ラベル
--------------------------------*/
.c-label-inquiry {
  margin-right: 0.5em;
  padding: 2px 0.5em 4px;
  color: #fff;
  font-weight: 500;
  font-size: 12px;
  line-height: 1;
}
.c-label-inquiry.--require {
  background-color: #ff4646;
}
.c-label-inquiry.--free {
  background-color: #b5b5b5;
}

/*--------------------------------
    送信ボタン
--------------------------------*/
#submit.c-btn-submit {
  margin: 0 auto;
  margin-top: 40px;
  padding: 0.5em 1em;
  color: #FFF;
  line-height: 1.15;
  display: block;
  width: 200px;
  text-align: center;
  background-color: var(--color_htag);
  border: none;
  transition: 0.25s;
}
#submit.c-btn-submit:focus, #submit.c-btn-submit:hover {
  opacity: 0.8;
}
#submit.c-btn-submit:disabled {
  background-color: #b5b5b5 !important;
  opacity: 1;
}

/*--------------------------------
 *  希望日程
--------------------------------*/
.p-form-date {
  margin-top: 1em;
  display: grid;
  /*grid-template-columns: auto repeat(3,1fr);*/
  grid-template-columns: auto repeat(2, 1fr);
  gap: 15px;
  align-items: center;
  font-size: 14px;
}
@media screen and (max-width: 599px) {
  .p-form-date {
    /*grid-template-columns: repeat(3,1fr);*/
    grid-template-columns: 2fr 1fr;
  }
}

@media screen and (max-width: 599px) {
  .p-form-date__col:first-child {
    grid-column-start: span 3;
  }
}

.p-form-date__col {
  white-space: nowrap;
}

.error-message-rsv {
  display: none;
  color: #ff4646;
  padding: 20px 0;
}

/*--------------------------------
 *  バリデーション
--------------------------------*/
#inline-validation-engine .formError {
  margin-top: 10px !important;
  display: block !important;
}

#inline-validation-engine .formError .formErrorContent {
  padding: 0;
  font-size: 12px;
  box-sizing: border-box;
  background-color: transparent;
  color: #F00;
}

#inline-validation-engine .undefinedformError.inline {
  display: none !important;
}

/****** 管理者情報 ******/
/*--------------------------------
 *  フッター
--------------------------------*/
.p-admin-footer {
  font-size: 14px;
}
@media screen and (max-width: 960px) {
  .p-admin-footer {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}

.p-admin-footer__inner {
  margin-bottom: 20px;
}

.p-admin-footer__data {
  font-size: inherit;
  line-height: 1.5;
}
.p-admin-footer__data:not(:last-child) {
  margin-bottom: calc(8 / 14 * 1em);
}

/****** バナー ******/
/*--------------------------------
 *  フッター
--------------------------------*/
.p-banner-footer__unit {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}
@media screen and (max-width: 599px) {
  .p-banner-footer__unit {
    grid-template-columns: repeat(2, 1fr);
  }
}

.p-banner-footer {
  position: relative;
  overflow: hidden;
  outline: 1px solid #ddd;
}
.p-banner-footer::before {
  content: "";
  display: block;
  width: 100%;
  height: auto;
  padding-top: 33.3333333333%;
}
.p-banner-footer > * {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-banner-footer img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-banner-footer__layer {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
}
.p-banner-footer__layer:focus ~ .p-banner-footer__img, .p-banner-footer__layer:hover ~ .p-banner-footer__img {
  transform: scale(1.2);
}

.p-banner-footer__img {
  transition: 0.25s;
}

/****** メディアとテキスト ******/
.p-media {
  display: flex;
}
@media screen and (max-width: 960px) {
  .p-media {
    display: block;
  }
}

.p-media.--reverse {
  flex-direction: row-reverse;
}

.p-media__col {
  flex: 1;
}

@media screen and (min-width: 961px) {
  .p-media__col.--text {
    padding-right: clamp(10px, calc(80 / (1180 + 16 * 2) * 100vw), 80px);
  }
}
@media screen and (max-width: 960px) {
  .p-media__col.--text {
    margin-top: 40px;
  }
}

.p-media__img {
  margin: 0 auto;
  display: block;
  width: auto;
  height: auto;
}

/****** ボックス ******/
.p-box {
  padding: clamp(10px, calc(60 / (1180 + 16 * 2) * 100vw), 60px) clamp(10px, calc(100 / (1180 + 16 * 2) * 100vw), 100px);
  background-color: #fff;
}
@media screen and (max-width: 960px) {
  .p-box {
    padding: 25px 20px 40px;
  }
}

.p-box__head {
  margin-bottom: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.p-box__title {
  font-size: 22px;
  font-weight: normal;
  line-height: 1.8;
}
@media screen and (max-width: 960px) {
  .p-box__title {
    font-size: 18px;
  }
}

.p-box__body .c-label-more {
  margin: 40px auto 0;
}

/****** タブ ******/
.p-tab__head {
  display: flex;
  column-gap: clamp(10px, calc(40 / (1180 + 16 * 2) * 100vw), 40px);
}

.p-tab__btn {
  padding: 1em;
  position: relative;
  border: 3px solid currentColor;
  border-bottom-width: 0;
  border-radius: 5px 5px 0 0;
  font-size: 22px;
  flex-grow: 1;
  text-align: center;
  line-height: 1;
  transition: 0.25s;
  cursor: pointer;
}
@media screen and (max-width: 960px) {
  .p-tab__btn {
    padding: 0.85em;
    font-size: 18px;
  }
}
.p-tab__btn.is-active {
  pointer-events: none;
}
.p-tab__btn::after {
  width: 0;
  height: 0;
  display: block;
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  z-index: 2;
  transform: translateX(-50%);
  border-style: solid;
  border-right: 10px solid transparent;
  border-left: 10px solid transparent;
  border-top: 12px solid transparent;
  border-bottom: 0;
}
.p-tab__btn:focus, .p-tab__btn:hover {
  opacity: 0.6;
}

.p-tab__btn.--newGraduate {
  color: #EF7DAD;
}
.p-tab__btn.--newGraduate.is-active {
  color: #fff;
  background-color: #EF7DAD;
  border-color: transparent;
}
.p-tab__btn.--newGraduate.is-active::after {
  border-top-color: #EF7DAD;
}

.p-tab__btn.--midCareer {
  color: #1F51BE;
}
.p-tab__btn.--midCareer.is-active {
  color: #fff;
  background-color: #1F51BE;
  border-color: transparent;
}
.p-tab__btn.--midCareer.is-active::after {
  border-top-color: #1F51BE;
}

.p-tab__panel {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: calc(50vw - 50%);
  padding-right: calc(50vw - 50%);
  padding-top: 80px;
  padding-bottom: 100px;
  display: none;
  border-top: 3px solid;
}
@media screen and (max-width: 599px) {
  .p-tab__panel {
    padding-top: 40px;
    padding-bottom: 80px;
  }
}
.p-tab__panel.is-active {
  display: block;
  animation-name: displayAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}
.p-tab__panel.--newGraduate {
  border-color: #EF7DAD;
  background-color: #FCF5F6;
}
.p-tab__panel.--midCareer {
  border-color: #1F51BE;
  background-color: #F5F6F9;
}

@keyframes displayAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/****** 拡散検索コントローラー ******/
/*--------------------------------
 *  拡散検索コントローラー
--------------------------------*/
.p-controller {
  margin-bottom: 60px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  font-size: 14px;
  gap: 10px;
}
@media screen and (max-width: 599px) {
  .p-controller {
    margin-bottom: 35px;
    font-size: 12px;
  }
}

.p-controller__btn {
  padding: calc(7 / 14 * 1em) calc(30 / 14 * 1em);
  font-size: inherit;
  line-height: calc(20 / 14 * 1em);
  border-radius: 9999px;
  transition: 0.25s;
}
.p-controller__btn:active {
  transform: scale(0.9);
}

.p-controller.--new-graduate .p-controller__btn {
  color: #EF7DAD;
  background-color: #FCF5F6;
}
.p-controller.--new-graduate .p-controller__btn.is-active {
  background-color: #FCDCE9;
}

.p-controller.--mid-career .p-controller__btn {
  color: #3177C9;
  background-color: #F5F6F9;
}
.p-controller.--mid-career .p-controller__btn.is-active {
  background-color: #BDD5EF;
}

.p-controller.--part-time .p-controller__btn {
  color: #F4B11E;
  background-color: #FAF8EF;
}
.p-controller.--part-time .p-controller__btn.is-active {
  background-color: #FCEBC6;
}

/* Utility
 * 接頭辞：u-
 * スポットで状態変化させたいmarginなどの補助クラスを定義
======================================*/
/****** マージン ******/
.u-mt0 {
  margin-top: 0px !important;
}

.u-mb0 {
  margin-bottom: 0px !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.u-mt0e {
  margin-top: 0em !important;
}

.u-mb0e {
  margin-bottom: 0em !important;
}

.u-mt0_25e {
  margin-top: 0.25em !important;
}

.u-mb0_25e {
  margin-bottom: 0.25em !important;
}

.u-mt0_5e {
  margin-top: 0.5em !important;
}

.u-mb0_5e {
  margin-bottom: 0.5em !important;
}

.u-mt0_75e {
  margin-top: 0.75em !important;
}

.u-mb0_75e {
  margin-bottom: 0.75em !important;
}

.u-mt1e {
  margin-top: 1em !important;
}

.u-mb1e {
  margin-bottom: 1em !important;
}

.u-mt1_25e {
  margin-top: 1.25em !important;
}

.u-mb1_25e {
  margin-bottom: 1.25em !important;
}

.u-mt1_5e {
  margin-top: 1.5em !important;
}

.u-mb1_5e {
  margin-bottom: 1.5em !important;
}

.u-mt1_75e {
  margin-top: 1.75em !important;
}

.u-mb1_75e {
  margin-bottom: 1.75em !important;
}

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

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

.u-mt2_25e {
  margin-top: 2.25em !important;
}

.u-mb2_25e {
  margin-bottom: 2.25em !important;
}

.u-mt2_5e {
  margin-top: 2.5em !important;
}

.u-mb2_5e {
  margin-bottom: 2.5em !important;
}

@media screen and (min-width: 961px) {
  .l-mt0 {
    margin-top: 0px !important;
  }
  .l-mb0 {
    margin-bottom: 0px !important;
  }
  .l-mt5 {
    margin-top: 5px !important;
  }
  .l-mb5 {
    margin-bottom: 5px !important;
  }
  .l-mt10 {
    margin-top: 10px !important;
  }
  .l-mb10 {
    margin-bottom: 10px !important;
  }
  .l-mt15 {
    margin-top: 15px !important;
  }
  .l-mb15 {
    margin-bottom: 15px !important;
  }
  .l-mt20 {
    margin-top: 20px !important;
  }
  .l-mb20 {
    margin-bottom: 20px !important;
  }
  .l-mt25 {
    margin-top: 25px !important;
  }
  .l-mb25 {
    margin-bottom: 25px !important;
  }
  .l-mt30 {
    margin-top: 30px !important;
  }
  .l-mb30 {
    margin-bottom: 30px !important;
  }
  .l-mt35 {
    margin-top: 35px !important;
  }
  .l-mb35 {
    margin-bottom: 35px !important;
  }
  .l-mt40 {
    margin-top: 40px !important;
  }
  .l-mb40 {
    margin-bottom: 40px !important;
  }
  .l-mt45 {
    margin-top: 45px !important;
  }
  .l-mb45 {
    margin-bottom: 45px !important;
  }
  .l-mt50 {
    margin-top: 50px !important;
  }
  .l-mb50 {
    margin-bottom: 50px !important;
  }
  .l-mt0e {
    margin-top: 0em !important;
  }
  .l-mb0e {
    margin-bottom: 0em !important;
  }
  .l-mt0_25e {
    margin-top: 0.25em !important;
  }
  .l-mb0_25e {
    margin-bottom: 0.25em !important;
  }
  .l-mt0_5e {
    margin-top: 0.5em !important;
  }
  .l-mb0_5e {
    margin-bottom: 0.5em !important;
  }
  .l-mt0_75e {
    margin-top: 0.75em !important;
  }
  .l-mb0_75e {
    margin-bottom: 0.75em !important;
  }
  .l-mt1e {
    margin-top: 1em !important;
  }
  .l-mb1e {
    margin-bottom: 1em !important;
  }
  .l-mt1_25e {
    margin-top: 1.25em !important;
  }
  .l-mb1_25e {
    margin-bottom: 1.25em !important;
  }
  .l-mt1_5e {
    margin-top: 1.5em !important;
  }
  .l-mb1_5e {
    margin-bottom: 1.5em !important;
  }
  .l-mt1_75e {
    margin-top: 1.75em !important;
  }
  .l-mb1_75e {
    margin-bottom: 1.75em !important;
  }
  .l-mt2e {
    margin-top: 2em !important;
  }
  .l-mb2e {
    margin-bottom: 2em !important;
  }
  .l-mt2_25e {
    margin-top: 2.25em !important;
  }
  .l-mb2_25e {
    margin-bottom: 2.25em !important;
  }
  .l-mt2_5e {
    margin-top: 2.5em !important;
  }
  .l-mb2_5e {
    margin-bottom: 2.5em !important;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .l-mt0 {
    margin-top: 0px !important;
  }
  .l-mb0 {
    margin-bottom: 0px !important;
  }
  .l-mt5 {
    margin-top: 5px !important;
  }
  .l-mb5 {
    margin-bottom: 5px !important;
  }
  .l-mt10 {
    margin-top: 10px !important;
  }
  .l-mb10 {
    margin-bottom: 10px !important;
  }
  .l-mt15 {
    margin-top: 15px !important;
  }
  .l-mb15 {
    margin-bottom: 15px !important;
  }
  .l-mt20 {
    margin-top: 20px !important;
  }
  .l-mb20 {
    margin-bottom: 20px !important;
  }
  .l-mt25 {
    margin-top: 25px !important;
  }
  .l-mb25 {
    margin-bottom: 25px !important;
  }
  .l-mt30 {
    margin-top: 30px !important;
  }
  .l-mb30 {
    margin-bottom: 30px !important;
  }
  .l-mt35 {
    margin-top: 35px !important;
  }
  .l-mb35 {
    margin-bottom: 35px !important;
  }
  .l-mt40 {
    margin-top: 40px !important;
  }
  .l-mb40 {
    margin-bottom: 40px !important;
  }
  .l-mt45 {
    margin-top: 45px !important;
  }
  .l-mb45 {
    margin-bottom: 45px !important;
  }
  .l-mt50 {
    margin-top: 50px !important;
  }
  .l-mb50 {
    margin-bottom: 50px !important;
  }
  .m-mt0e {
    margin-top: 0em !important;
  }
  .m-mb0e {
    margin-bottom: 0em !important;
  }
  .m-mt0_25e {
    margin-top: 0.25em !important;
  }
  .m-mb0_25e {
    margin-bottom: 0.25em !important;
  }
  .m-mt0_5e {
    margin-top: 0.5em !important;
  }
  .m-mb0_5e {
    margin-bottom: 0.5em !important;
  }
  .m-mt0_75e {
    margin-top: 0.75em !important;
  }
  .m-mb0_75e {
    margin-bottom: 0.75em !important;
  }
  .m-mt1e {
    margin-top: 1em !important;
  }
  .m-mb1e {
    margin-bottom: 1em !important;
  }
  .m-mt1_25e {
    margin-top: 1.25em !important;
  }
  .m-mb1_25e {
    margin-bottom: 1.25em !important;
  }
  .m-mt1_5e {
    margin-top: 1.5em !important;
  }
  .m-mb1_5e {
    margin-bottom: 1.5em !important;
  }
  .m-mt1_75e {
    margin-top: 1.75em !important;
  }
  .m-mb1_75e {
    margin-bottom: 1.75em !important;
  }
  .m-mt2e {
    margin-top: 2em !important;
  }
  .m-mb2e {
    margin-bottom: 2em !important;
  }
  .m-mt2_25e {
    margin-top: 2.25em !important;
  }
  .m-mb2_25e {
    margin-bottom: 2.25em !important;
  }
  .m-mt2_5e {
    margin-top: 2.5em !important;
  }
  .m-mb2_5e {
    margin-bottom: 2.5em !important;
  }
}
@media screen and (max-width: 599px) {
  .s-mt0 {
    margin-top: 0px !important;
  }
  .s-mb0 {
    margin-bottom: 0px !important;
  }
  .s-mt5 {
    margin-top: 5px !important;
  }
  .s-mb5 {
    margin-bottom: 5px !important;
  }
  .s-mt10 {
    margin-top: 10px !important;
  }
  .s-mb10 {
    margin-bottom: 10px !important;
  }
  .s-mt15 {
    margin-top: 15px !important;
  }
  .s-mb15 {
    margin-bottom: 15px !important;
  }
  .s-mt20 {
    margin-top: 20px !important;
  }
  .s-mb20 {
    margin-bottom: 20px !important;
  }
  .s-mt25 {
    margin-top: 25px !important;
  }
  .s-mb25 {
    margin-bottom: 25px !important;
  }
  .s-mt30 {
    margin-top: 30px !important;
  }
  .s-mb30 {
    margin-bottom: 30px !important;
  }
  .s-mt35 {
    margin-top: 35px !important;
  }
  .s-mb35 {
    margin-bottom: 35px !important;
  }
  .s-mt40 {
    margin-top: 40px !important;
  }
  .s-mb40 {
    margin-bottom: 40px !important;
  }
  .s-mt45 {
    margin-top: 45px !important;
  }
  .s-mb45 {
    margin-bottom: 45px !important;
  }
  .s-mt50 {
    margin-top: 50px !important;
  }
  .s-mb50 {
    margin-bottom: 50px !important;
  }
  .s-mt0e {
    margin-top: 0em !important;
  }
  .s-mb0e {
    margin-bottom: 0em !important;
  }
  .s-mt0_25e {
    margin-top: 0.25em !important;
  }
  .s-mb0_25e {
    margin-bottom: 0.25em !important;
  }
  .s-mt0_5e {
    margin-top: 0.5em !important;
  }
  .s-mb0_5e {
    margin-bottom: 0.5em !important;
  }
  .s-mt0_75e {
    margin-top: 0.75em !important;
  }
  .s-mb0_75e {
    margin-bottom: 0.75em !important;
  }
  .s-mt1e {
    margin-top: 1em !important;
  }
  .s-mb1e {
    margin-bottom: 1em !important;
  }
  .s-mt1_25e {
    margin-top: 1.25em !important;
  }
  .s-mb1_25e {
    margin-bottom: 1.25em !important;
  }
  .s-mt1_5e {
    margin-top: 1.5em !important;
  }
  .s-mb1_5e {
    margin-bottom: 1.5em !important;
  }
  .s-mt1_75e {
    margin-top: 1.75em !important;
  }
  .s-mb1_75e {
    margin-bottom: 1.75em !important;
  }
  .s-mt2e {
    margin-top: 2em !important;
  }
  .s-mb2e {
    margin-bottom: 2em !important;
  }
  .s-mt2_25e {
    margin-top: 2.25em !important;
  }
  .s-mb2_25e {
    margin-bottom: 2.25em !important;
  }
  .s-mt2_5e {
    margin-top: 2.5em !important;
  }
  .s-mb2_5e {
    margin-bottom: 2.5em !important;
  }
}
/****** パディング ******/
.u-pt0 {
  padding-top: 0px !important;
}

.u-pb0 {
  padding-bottom: 0px !important;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.u-pt0e {
  margin-top: 0em !important;
}

.u-pb0e {
  margin-bottom: 0em !important;
}

.u-pt0_25e {
  margin-top: 0.25em !important;
}

.u-pb0_25e {
  margin-bottom: 0.25em !important;
}

.u-pt0_5e {
  margin-top: 0.5em !important;
}

.u-pb0_5e {
  margin-bottom: 0.5em !important;
}

.u-pt0_75e {
  margin-top: 0.75em !important;
}

.u-pb0_75e {
  margin-bottom: 0.75em !important;
}

.u-pt1e {
  margin-top: 1em !important;
}

.u-pb1e {
  margin-bottom: 1em !important;
}

.u-pt1_25e {
  margin-top: 1.25em !important;
}

.u-pb1_25e {
  margin-bottom: 1.25em !important;
}

.u-pt1_5e {
  margin-top: 1.5em !important;
}

.u-pb1_5e {
  margin-bottom: 1.5em !important;
}

.u-pt1_75e {
  margin-top: 1.75em !important;
}

.u-pb1_75e {
  margin-bottom: 1.75em !important;
}

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

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

.u-pt2_25e {
  margin-top: 2.25em !important;
}

.u-pb2_25e {
  margin-bottom: 2.25em !important;
}

.u-pt2_5e {
  margin-top: 2.5em !important;
}

.u-pb2_5e {
  margin-bottom: 2.5em !important;
}

@media screen and (min-width: 961px) {
  .l-pt0 {
    padding-top: 0px !important;
  }
  .l-pb0 {
    padding-bottom: 0px !important;
  }
  .l-pt5 {
    padding-top: 5px !important;
  }
  .l-pb5 {
    padding-bottom: 5px !important;
  }
  .l-pt10 {
    padding-top: 10px !important;
  }
  .l-pb10 {
    padding-bottom: 10px !important;
  }
  .l-pt15 {
    padding-top: 15px !important;
  }
  .l-pb15 {
    padding-bottom: 15px !important;
  }
  .l-pt20 {
    padding-top: 20px !important;
  }
  .l-pb20 {
    padding-bottom: 20px !important;
  }
  .l-pt25 {
    padding-top: 25px !important;
  }
  .l-pb25 {
    padding-bottom: 25px !important;
  }
  .l-pt30 {
    padding-top: 30px !important;
  }
  .l-pb30 {
    padding-bottom: 30px !important;
  }
  .l-pt35 {
    padding-top: 35px !important;
  }
  .l-pb35 {
    padding-bottom: 35px !important;
  }
  .l-pt40 {
    padding-top: 40px !important;
  }
  .l-pb40 {
    padding-bottom: 40px !important;
  }
  .l-pt45 {
    padding-top: 45px !important;
  }
  .l-pb45 {
    padding-bottom: 45px !important;
  }
  .l-pt50 {
    padding-top: 50px !important;
  }
  .l-pb50 {
    padding-bottom: 50px !important;
  }
  .l-pt0e {
    margin-top: 0em !important;
  }
  .l-pb0e {
    margin-bottom: 0em !important;
  }
  .l-pt0_25e {
    margin-top: 0.25em !important;
  }
  .l-pb0_25e {
    margin-bottom: 0.25em !important;
  }
  .l-pt0_5e {
    margin-top: 0.5em !important;
  }
  .l-pb0_5e {
    margin-bottom: 0.5em !important;
  }
  .l-pt0_75e {
    margin-top: 0.75em !important;
  }
  .l-pb0_75e {
    margin-bottom: 0.75em !important;
  }
  .l-pt1e {
    margin-top: 1em !important;
  }
  .l-pb1e {
    margin-bottom: 1em !important;
  }
  .l-pt1_25e {
    margin-top: 1.25em !important;
  }
  .l-pb1_25e {
    margin-bottom: 1.25em !important;
  }
  .l-pt1_5e {
    margin-top: 1.5em !important;
  }
  .l-pb1_5e {
    margin-bottom: 1.5em !important;
  }
  .l-pt1_75e {
    margin-top: 1.75em !important;
  }
  .l-pb1_75e {
    margin-bottom: 1.75em !important;
  }
  .l-pt2e {
    margin-top: 2em !important;
  }
  .l-pb2e {
    margin-bottom: 2em !important;
  }
  .l-pt2_25e {
    margin-top: 2.25em !important;
  }
  .l-pb2_25e {
    margin-bottom: 2.25em !important;
  }
  .l-pt2_5e {
    margin-top: 2.5em !important;
  }
  .l-pb2_5e {
    margin-bottom: 2.5em !important;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .m-pt0 {
    padding-top: 0px !important;
  }
  .m-pb0 {
    padding-bottom: 0px !important;
  }
  .m-pt5 {
    padding-top: 5px !important;
  }
  .m-pb5 {
    padding-bottom: 5px !important;
  }
  .m-pt10 {
    padding-top: 10px !important;
  }
  .m-pb10 {
    padding-bottom: 10px !important;
  }
  .m-pt15 {
    padding-top: 15px !important;
  }
  .m-pb15 {
    padding-bottom: 15px !important;
  }
  .m-pt20 {
    padding-top: 20px !important;
  }
  .m-pb20 {
    padding-bottom: 20px !important;
  }
  .m-pt25 {
    padding-top: 25px !important;
  }
  .m-pb25 {
    padding-bottom: 25px !important;
  }
  .m-pt30 {
    padding-top: 30px !important;
  }
  .m-pb30 {
    padding-bottom: 30px !important;
  }
  .m-pt35 {
    padding-top: 35px !important;
  }
  .m-pb35 {
    padding-bottom: 35px !important;
  }
  .m-pt40 {
    padding-top: 40px !important;
  }
  .m-pb40 {
    padding-bottom: 40px !important;
  }
  .m-pt45 {
    padding-top: 45px !important;
  }
  .m-pb45 {
    padding-bottom: 45px !important;
  }
  .m-pt50 {
    padding-top: 50px !important;
  }
  .m-pb50 {
    padding-bottom: 50px !important;
  }
  .m-pt0e {
    margin-top: 0em !important;
  }
  .m-pb0e {
    margin-bottom: 0em !important;
  }
  .m-pt0_25e {
    margin-top: 0.25em !important;
  }
  .m-pb0_25e {
    margin-bottom: 0.25em !important;
  }
  .m-pt0_5e {
    margin-top: 0.5em !important;
  }
  .m-pb0_5e {
    margin-bottom: 0.5em !important;
  }
  .m-pt0_75e {
    margin-top: 0.75em !important;
  }
  .m-pb0_75e {
    margin-bottom: 0.75em !important;
  }
  .m-pt1e {
    margin-top: 1em !important;
  }
  .m-pb1e {
    margin-bottom: 1em !important;
  }
  .m-pt1_25e {
    margin-top: 1.25em !important;
  }
  .m-pb1_25e {
    margin-bottom: 1.25em !important;
  }
  .m-pt1_5e {
    margin-top: 1.5em !important;
  }
  .m-pb1_5e {
    margin-bottom: 1.5em !important;
  }
  .m-pt1_75e {
    margin-top: 1.75em !important;
  }
  .m-pb1_75e {
    margin-bottom: 1.75em !important;
  }
  .m-pt2e {
    margin-top: 2em !important;
  }
  .m-pb2e {
    margin-bottom: 2em !important;
  }
  .m-pt2_25e {
    margin-top: 2.25em !important;
  }
  .m-pb2_25e {
    margin-bottom: 2.25em !important;
  }
  .m-pt2_5e {
    margin-top: 2.5em !important;
  }
  .m-pb2_5e {
    margin-bottom: 2.5em !important;
  }
}
@media screen and (max-width: 599px) {
  .s-pt0 {
    padding-top: 0px !important;
  }
  .s-pb0 {
    padding-bottom: 0px !important;
  }
  .s-pt5 {
    padding-top: 5px !important;
  }
  .s-pb5 {
    padding-bottom: 5px !important;
  }
  .s-pt10 {
    padding-top: 10px !important;
  }
  .s-pb10 {
    padding-bottom: 10px !important;
  }
  .s-pt15 {
    padding-top: 15px !important;
  }
  .s-pb15 {
    padding-bottom: 15px !important;
  }
  .s-pt20 {
    padding-top: 20px !important;
  }
  .s-pb20 {
    padding-bottom: 20px !important;
  }
  .s-pt25 {
    padding-top: 25px !important;
  }
  .s-pb25 {
    padding-bottom: 25px !important;
  }
  .s-pt30 {
    padding-top: 30px !important;
  }
  .s-pb30 {
    padding-bottom: 30px !important;
  }
  .s-pt35 {
    padding-top: 35px !important;
  }
  .s-pb35 {
    padding-bottom: 35px !important;
  }
  .s-pt40 {
    padding-top: 40px !important;
  }
  .s-pb40 {
    padding-bottom: 40px !important;
  }
  .s-pt45 {
    padding-top: 45px !important;
  }
  .s-pb45 {
    padding-bottom: 45px !important;
  }
  .s-pt50 {
    padding-top: 50px !important;
  }
  .s-pb50 {
    padding-bottom: 50px !important;
  }
  .s-pt0e {
    margin-top: 0em !important;
  }
  .s-pb0e {
    margin-bottom: 0em !important;
  }
  .s-pt0_25e {
    margin-top: 0.25em !important;
  }
  .s-pb0_25e {
    margin-bottom: 0.25em !important;
  }
  .s-pt0_5e {
    margin-top: 0.5em !important;
  }
  .s-pb0_5e {
    margin-bottom: 0.5em !important;
  }
  .s-pt0_75e {
    margin-top: 0.75em !important;
  }
  .s-pb0_75e {
    margin-bottom: 0.75em !important;
  }
  .s-pt1e {
    margin-top: 1em !important;
  }
  .s-pb1e {
    margin-bottom: 1em !important;
  }
  .s-pt1_25e {
    margin-top: 1.25em !important;
  }
  .s-pb1_25e {
    margin-bottom: 1.25em !important;
  }
  .s-pt1_5e {
    margin-top: 1.5em !important;
  }
  .s-pb1_5e {
    margin-bottom: 1.5em !important;
  }
  .s-pt1_75e {
    margin-top: 1.75em !important;
  }
  .s-pb1_75e {
    margin-bottom: 1.75em !important;
  }
  .s-pt2e {
    margin-top: 2em !important;
  }
  .s-pb2e {
    margin-bottom: 2em !important;
  }
  .s-pt2_25e {
    margin-top: 2.25em !important;
  }
  .s-pb2_25e {
    margin-bottom: 2.25em !important;
  }
  .s-pt2_5e {
    margin-top: 2.5em !important;
  }
  .s-pb2_5e {
    margin-bottom: 2.5em !important;
  }
}
/****** その他 ******/
@media screen and (min-width: 961px) {
  .md {
    display: none !important;
  }
  .sm {
    display: none !important;
  }
  .smmd {
    display: none !important;
  }
}
@media screen and (min-width: 600px) and (max-width: 960px) {
  .lg {
    display: none !important;
  }
  .sm {
    display: none !important;
  }
}
@media screen and (max-width: 599px) {
  .lg {
    display: none !important;
  }
  .md {
    display: none !important;
  }
  .mdlg {
    display: none !important;
  }
}
.clearfix::after {
  display: block;
  content: "";
  clear: both;
}

.page-id-723 .p-breadcrumb {
  display: none;
}

/*# sourceMappingURL=style.css.map */
