@charset "UTF-8";
/*===================================================

// 桜寿会 採用サイト 20220301
// style.css

===================================================*/
.txt--check:before, .recruit-wrapper .recruit-item__header:before, .job-slider-navigation .swiper-button-next:after, .job-slider-navigation .swiper-button-prev:after, .top-benefit-btn:before, .recruit-bnr__desc:before, .ctaArea .ctaArea-list > li > a:before, .accordion-trigger[aria-expanded=false]:after, .accordion-trigger[aria-expanded=true]:after, .mw_wp_form .form-has-error .error + .error-message:before, .mw_wp_form .form-wrap .error:before, .link-map:before, .link-tel:before, .link-launch:after, .link-pdf:before, .link-doc:before, .local-header__nav-list > li > a:before, .sp-gnav-list__item.-home .sp-gnav-list__link:before, .sp-gnav-list__link:after, .sp-gnav-small-list > li a:not(.link-launch):after, .page-navigation__btn-prev:before, .page-navigation__btn-next:after, .header-nav__item .header-enty-btn:after, .btn-primary:before, .btn-primary--back:before, .btn-secondary:before, .btn-cv:before, .btn-confirm:before, .btn-back:before, .btn-pagetop:before, .btn-map:before {
  display: inline-block;
  font-family: "Material Icons Round";
  font-weight: normal;
  line-height: 1;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;
  speak: none;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "liga";
}

html,
body,
p,
ol,
ul,
li,
dl,
dt,
dd,
blockquote,
figure,
fieldset,
legend,
textarea,
pre,
iframe,
hr,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
}

ul {
  list-style: none;
}

button {
  margin: 0;
  border: none;
  outline: none;
  padding: 0;
  background: transparent;
  -webkit-appearance: none;
  appearance: none;
  font-family: inherit;
  box-shadow: none;
}

button,
select {
  cursor: pointer;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
  -moz-appearance: textfield;
}

html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

img,
video {
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

iframe {
  border: 0;
}

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

td,
th {
  padding: 0;
}

header,
footer,
main {
  display: block;
}

@media print, screen and (max-width: 768px) {
  html,
  body {
    overflow-x: hidden;
  }
}

body {
  font-family: "Poppins", "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.7;
  color: #444;
  text-underline-position: under;
  position: relative;
}
body:before {
  content: "";
  display: block;
  width: 100%;
  height: calc(100% - 800px);
  background: #feeff5;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media print, screen and (max-width: 768px) {
  body:before {
    height: calc(100% - 600px);
  }
}
@media print, screen and (min-width: 769px) {
  body {
    font-size: 16px;
  }
}

a {
  color: #f1659d;
  text-decoration: none;
}
@media print, screen and (min-width: 769px) {
  a {
    transition: opacity 0.2s;
  }
  a:hover {
    opacity: 0.85;
  }
}

em {
  font-style: normal;
}

table th {
  font-weight: normal;
  text-align: left;
}

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

hr {
  margin: 2em 0;
  border: none;
  border-top: 1px solid #ddd;
  box-shadow: none;
}
@media print, screen and (min-width: 769px) {
  hr {
    margin: 3em 0;
  }
}

.btn-wrap {
  text-align: center;
}

.btn-primary {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 2.4em 0.5em 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 50px;
  color: #f1659d;
  background: #fff;
  border: 2px solid #f1659d;
}
.btn-primary:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
}
@media print, screen and (min-width: 769px) {
  .btn-primary {
    min-height: 54px;
  }
}

.btn-primary--launch:before {
  content: "\e895";
  right: 1em;
}

.btn-primary--back {
  margin-right: auto;
  padding: 0.5em 2em 0.5em 2.4em;
}
.btn-primary--back:before {
  right: auto;
  left: 0.8em;
  content: "\e5cb";
}

.btn-secondary {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 2.4em 0.5em 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 50px;
  background: #fff;
  color: #1b9cd5;
  border: 2px solid #1b9cd5;
}
.btn-secondary:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
}
@media print, screen and (min-width: 769px) {
  .btn-secondary {
    min-height: 54px;
  }
}

.btn-secondary--white {
  background: transparent;
  border-color: #fff;
  color: #fff;
}

.btn-cv {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 2.4em 0.5em 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 50px;
  color: #fff;
  background: #f1659d;
}
.btn-cv:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
}
@media print, screen and (min-width: 769px) {
  .btn-cv {
    min-height: 54px;
  }
}

.btn-confirm {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 2.4em 0.5em 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 50px;
  padding: 0.5em 2em;
  color: #fff;
  background: #f1659d;
  width: 100%;
  font-size: 16px;
  border: none;
  cursor: pointer;
  box-shadow: 0 -4px 0 0 rgba(0, 0, 0, 0.2) inset;
}
.btn-confirm:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
}
@media print, screen and (min-width: 769px) {
  .btn-confirm {
    min-height: 54px;
  }
}
@media print, screen and (min-width: 769px) {
  .btn-confirm {
    max-width: 360px;
    font-size: 20px;
    min-height: 72px;
  }
}

.btn-back {
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 2.4em 0.5em 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 50px;
  padding: 0.5em 2em;
  color: #fff;
  white-space: nowrap;
  background: #888;
  font-size: 14px;
  border: none;
  cursor: pointer;
  margin-right: 20px;
  box-shadow: 0 -4px 0 0 rgba(0, 0, 0, 0.2) inset;
}
.btn-back:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
}
@media print, screen and (min-width: 769px) {
  .btn-back {
    min-height: 54px;
  }
}
.btn-back:before {
  display: none;
}
@media print, screen and (min-width: 769px) {
  .btn-back {
    max-width: 120px;
    font-size: 20px;
    min-height: 72px;
  }
}

.btn-pagetop {
  z-index: 20;
  opacity: 0;
  visibility: hidden;
  transition: opacity 1s;
  position: fixed;
  background: #fff;
  border-radius: 6px;
  border: 1px solid #f1659d;
  width: 32px;
  height: 32px;
  font-size: 16px;
  display: flex;
  justify-content: center;
  align-items: center;
  bottom: 80px;
  right: 16px;
}
.btn-pagetop:before {
  content: "\f1e0";
  color: #f1659d;
}
@media print, screen and (min-width: 769px) {
  .btn-pagetop {
    width: 64px;
    height: 64px;
    bottom: 40px;
    right: 40px;
    font-size: 24px;
  }
}
.btn-pagetop.is-active {
  opacity: 1;
  visibility: visible;
  transition: opacity 1s;
}

.btn-map {
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 1em;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  background: #6dc8eb;
  color: #fff;
}
.btn-map:before {
  content: "\e55f";
  margin-right: 0.3em;
}

/*===================================================

 header

===================================================*/
.l-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
.l-header__container {
  padding: 0 0 0 16px;
  height: 50px;
  position: relative;
  display: flex;
  align-items: center;
  transition: height 0.2s;
}

@media print, screen and (min-width: 769px) {
  .l-header {
    transition: all 0.2s;
  }
  .l-header__container {
    height: 120px;
    padding: 0 4vw;
  }
}
.l-header.is-scroll {
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
  background: #fff;
}

@media print, screen and (min-width: 769px) {
  .l-header.is-scroll .l-header__container {
    height: 100px;
  }
  .l-header.is-scroll .header-logo__img {
    width: 158px;
  }
}
.header-logo > a {
  display: flex;
  align-items: center;
}
.header-logo__img {
  width: 100px;
}
.header-logo__txt {
  font-size: 10px;
  margin-left: 24px;
  color: #f1659d;
  letter-spacing: 0.1em;
  font-family: serif;
  font-weight: bold;
  white-space: nowrap;
}

@media print, screen and (min-width: 769px) {
  .header-logo__img {
    width: 200px;
  }
  .header-logo__txt {
    font-size: 16px;
    margin-top: 10px;
  }
}
@media print, screen and (min-width: 769px) and (max-width: 1100px) {
  .header-logo__img {
    width: 150px;
  }
}
.sp-header-menu-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  position: absolute;
  top: 0;
  right: 0;
}
.sp-header-menu-btn span {
  display: block;
  width: 20px;
  height: 2px;
  background: #f1659d;
  border-radius: 2px;
  margin: 3px 0;
  position: relative;
  transition: all 0.2s;
}
.sp-header-menu-btn[aria-expanded=true] span:nth-child(1) {
  transform: rotate(45deg);
  top: 4px;
}
.sp-header-menu-btn[aria-expanded=true] span:nth-child(2) {
  transform: rotate(-45deg);
  top: -4px;
}

@media print, screen and (min-width: 769px) {
  .header-nav {
    margin-left: auto;
    display: flex;
    align-items: center;
  }
}
.header-nav__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
}
.header-nav__item {
  position: relative;
  margin-left: 3vw;
}
.header-nav__item > a:not(.header-enty-btn) {
  display: flex;
  align-items: center;
  color: #444;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.05em;
  padding: 0.8em 0;
  position: relative;
}
@media print, screen and (min-width: 769px) and (max-width: 1100px) {
  .header-nav__item > a:not(.header-enty-btn) {
    font-size: 15px;
  }
}
.header-nav__item > a:not(.header-enty-btn):after {
  content: "";
  width: 0;
  height: 3px;
  display: block;
  background: #f1659d;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  transition: width 0.2s;
}
.header-nav__item > a:not(.header-enty-btn):hover {
  color: #f1659d;
  opacity: 1;
}
.header-nav__item > a:not(.header-enty-btn):hover:after {
  width: 100%;
}
@media print, screen and (min-width: 769px) and (max-width: 1460px) {
  .header-nav__item.-official {
    display: none;
  }
  .header-nav__item.-entry {
    margin-left: 0;
  }
}
.header-nav__item .official-trigger {
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  padding: 0.8em 0;
}
.header-nav__item .official-trigger:after {
  color: #999;
}
.header-nav__item .official-panel {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 90%;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 2px 10px 0 rgba(0, 0, 0, 0.2);
  padding: 0px 16px;
  transition: all 0.2s;
}
.header-nav__item .official-panel:before {
  content: "";
  border-width: 0 8px 8px;
  border-style: solid;
  border-color: transparent transparent #fff;
  position: absolute;
  bottom: 100%;
  left: 50%;
  margin-left: -4px;
}
.header-nav__item .official-panel ul > li {
  white-space: nowrap;
  padding: 16px 0;
}
.header-nav__item .official-panel ul > li:not(:last-child) {
  border-bottom: 1px solid #ddd;
}
.header-nav__item .official-panel ul > li a {
  display: block;
  color: #444;
  font-size: 14px;
  line-height: 1.4;
  position: relative;
  padding-right: 30px;
}
.header-nav__item .official-panel ul > li a:after {
  color: #999;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
.header-nav__item .official-panel ul > li a small {
  display: block;
  font-size: 11px;
}
.header-nav__item .official-panel ul > li a:hover {
  color: #f1659d;
}
.header-nav__item .official-panel ul > li a:hover:after {
  color: #f1659d;
}
.header-nav__item.-official:hover .official-trigger {
  color: #f1659d;
}
.header-nav__item.-official:hover .official-trigger:after {
  color: #f1659d;
}
.header-nav__item.-official:hover .official-panel {
  opacity: 1;
  visibility: visible;
  top: 100%;
}
.header-nav__item .header-enty-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #ee89b2;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  min-height: 72px;
  padding: 0 30px 0 40px;
  border-radius: 50px;
  position: relative;
  transition: background 0.2s;
}
.header-nav__item .header-enty-btn:after {
  content: "\e1c4";
  margin-left: 0.5em;
}
.header-nav__item .header-enty-btn:hover {
  background: #f1659d;
  opacity: 1;
}
@media print, screen and (min-width: 769px) and (max-width: 1460px) {
  .header-nav__item .header-enty-btn {
    position: fixed;
    top: 120px;
    right: 0;
    border-radius: 8px 0 0 8px;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    padding: 24px 18px;
  }
  .header-nav__item .header-enty-btn:after {
    margin: 6px 0 0;
  }
}

body.page-about .header-nav__item.-about > a,
body.page-job .header-nav__item.-job > a,
body.page-benefit .header-nav__item.-benefit > a,
body.page-recruit .header-nav__item.-recruit > a {
  color: #f1659d;
}
body.page-about .header-nav__item.-about > a:after,
body.page-job .header-nav__item.-job > a:after,
body.page-benefit .header-nav__item.-benefit > a:after,
body.page-recruit .header-nav__item.-recruit > a:after {
  width: 100%;
}

/*===================================================

 footer

===================================================*/
.l-footer {
  background: #fff;
  position: relative;
}
.l-footer__container {
  padding: 32px 16px 100px;
  text-align: center;
}

@media print, screen and (min-width: 769px) {
  .l-footer__container {
    padding: 64px 4vw;
  }
}
.footer-logo > a {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
}
.footer-logo__img {
  width: 120px;
}
.footer-logo__txt {
  font-size: 12px;
  line-height: 1;
  margin-top: 12px;
  color: #f1659d;
  letter-spacing: 0.1em;
  font-family: serif;
  font-weight: bold;
}

@media print, screen and (min-width: 769px) {
  .footer-logo__img {
    width: 200px;
  }
  .footer-logo__txt {
    font-size: 16px;
    margin-top: 20px;
  }
}
.footer-sitemap {
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.footer-sitemap > li {
  min-width: 40%;
  margin-top: 16px;
  font-size: 13px;
}
.footer-sitemap > li a {
  color: #777;
  display: block;
}
.footer-sitemap > li a small {
  display: block;
}
.footer-sitemap > li .link-launch:after {
  color: #999;
}

@media print, screen and (min-width: 769px) {
  .footer-sitemap {
    margin-top: 48px;
  }
  .footer-sitemap > li {
    min-width: initial;
    margin: 0 2vw;
    font-size: 14px;
  }
  .footer-sitemap > li a small {
    display: inline;
    margin-right: 1em;
  }
}
.footer-copyright {
  color: #999;
  font-size: 10px;
  margin-top: 48px;
}

@media print, screen and (min-width: 769px) {
  .footer-copyright {
    font-size: 12px;
  }
}
/*===================================================

  ナビゲーション

===================================================*/
/*
 SP 開閉グローバルメニュー
---------------------------------------------------*/
.sp-gnav {
  line-height: 1.4;
  position: fixed;
  top: 50px;
  left: 0;
  width: 100%;
  height: calc(100% - 50px);
  background: #feeff5;
  z-index: 99;
}
.sp-gnav__container {
  height: 100%;
  overflow-y: auto;
  padding: 24px 32px 100px;
}
.sp-gnav[aria-hidden=true] {
  visibility: hidden;
  opacity: 0;
}
.sp-gnav[aria-hidden=false] {
  visibility: visible;
  opacity: 1;
}

body.is-menu-open .l-header {
  background: #fff;
}

.sp-gnav-list__item {
  border-bottom: 1px solid rgba(241, 101, 157, 0.2);
}
.sp-gnav-list__item.-home .sp-gnav-list__link:before {
  content: "\e88a";
  color: #f1659d;
  margin-right: 8px;
}
.sp-gnav-list__link {
  display: flex;
  align-items: center;
  padding: 18px 32px 18px 0;
  color: #444;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  position: relative;
}
.sp-gnav-list__link:after {
  content: "\e5cc";
  font-size: 20px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  color: #f1659d;
}

.sp-gnav-small-list {
  margin-top: 24px;
}
.sp-gnav-small-list > li a {
  display: inline-block;
  padding: 10px 24px 10px 0;
  color: #444;
  text-decoration: none;
  position: relative;
}
.sp-gnav-small-list > li a:not(.link-launch):after {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  font-size: 16px;
}

/*
 SP ページ下部固定ナビゲーション
---------------------------------------------------*/
.sp-sticky-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
.sp-sticky-nav__list {
  display: flex;
  border-radius: 20px 20px 0 0;
  overflow: hidden;
}
.sp-sticky-nav__item {
  width: 50%;
  display: flex;
}
.sp-sticky-nav__item > a {
  width: 100%;
  height: 55px;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.1em;
  color: #fff;
  font-weight: 700;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-decoration: none;
}
.sp-sticky-nav__recruit-btn {
  background: #6dc8eb;
}
.sp-sticky-nav__entry-btn {
  background: #ee89b2;
}

/*
 下層ページ内ナビゲーション
---------------------------------------------------*/
.page-navigation {
  background: #fff;
  padding: 24px;
}
.page-navigation__btn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 700;
}
.page-navigation__btn .is-disabled {
  visibility: hidden;
}
.page-navigation__btn-prev {
  display: flex;
  align-items: center;
}
.page-navigation__btn-prev:before {
  content: "\e5cb";
  margin-right: 0.5em;
}
.page-navigation__btn-next {
  display: flex;
  align-items: center;
}
.page-navigation__btn-next:after {
  content: "\e5cc";
  margin-left: 0.5em;
}
.page-navigation__btn-list {
  margin: auto;
}

@media print, screen and (min-width: 769px) {
  .page-navigation {
    padding: 80px 4vw;
  }
  .page-navigation__btn {
    margin: auto;
    justify-content: center;
  }
  .page-navigation__btn-list {
    margin: 0 48px;
    width: 240px;
  }
}
/*===================================================

 下層ページ ビジュアル

===================================================*/
.local-header__mv {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
}
.local-header__mv-content {
  text-align: center;
  letter-spacing: 0.1em;
  text-shadow: 0 0 10px rgba(68, 68, 68, 0.5);
}
.local-header__mv-en {
  font-size: 16px;
  color: #f1659d;
  font-weight: 600;
}
.local-header__mv-ttl {
  font-size: 20px;
  font-weight: 700;
  color: #fff;
}
.local-header__nav {
  position: relative;
  top: -24px;
  left: 16px;
  background: #fff;
  width: calc(100% - 32px);
  border-radius: 100px;
  box-shadow: 0 4px 0 0 rgba(241, 101, 157, 0.2);
  padding: 16px;
}
.local-header__nav-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.local-header__nav-list > li {
  margin: 0.5em 1em;
  line-height: 1.2;
  font-weight: 500;
}
.local-header__nav-list > li > a {
  display: flex;
  align-items: center;
  color: #444;
}
.local-header__nav-list > li > a:before {
  content: "\e5cf";
  color: #f1659d;
  margin-right: 0.2em;
}

@media print, screen and (min-width: 769px) {
  .local-header {
    padding: 0 4vw;
    max-width: 1600px;
    margin: auto;
  }
  .local-header__mv {
    padding: 40px;
    min-height: 360px;
  }
  .local-header__mv-en {
    font-size: 24px;
    font-weight: 400;
  }
  .local-header__mv-ttl {
    font-size: 40px;
    letter-spacing: 0.1em;
  }
  .local-header__nav {
    top: -50px;
    left: 16px;
    width: 880px;
    margin: auto;
    padding: 24px;
  }
  .local-header__nav-list {
    font-size: 18px;
  }
}
.local-header-simple__content {
  padding: 0 16px 32px;
  text-align: center;
  letter-spacing: 0.1em;
}
.local-header-simple__en {
  font-size: 16px;
  color: #f1659d;
  font-weight: 400;
}
.local-header-simple__ttl {
  font-size: 18px;
  font-weight: 700;
}

@media print, screen and (min-width: 769px) {
  .local-header-simple {
    padding: 0 4vw;
    max-width: 1600px;
    margin: auto;
  }
  .local-header-simple__content {
    padding: 0 40px 40px;
  }
  .local-header-simple__en {
    font-size: 24px;
  }
  .local-header-simple__ttl {
    font-size: 40px;
  }
}
/*===================================================

 レイアウト

===================================================*/
.l-wrapper {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
  padding-top: 55px;
}
@media print, screen and (min-width: 769px) {
  .l-wrapper {
    padding-top: 160px;
  }
}

.l-main {
  position: relative;
}

.deco-triangle-01 {
  position: absolute;
  top: -150px;
  left: 35%;
  background: #f2fcfe;
  width: 100vw;
  height: 200px;
  transform: rotate(15deg);
  z-index: 0;
}

@media print, screen and (min-width: 769px) {
  .deco-triangle-01 {
    top: -300px;
    left: 20%;
    width: 100vw;
    height: 400px;
    transform: rotate(12deg);
  }
}
.deco-triangle-02 {
  position: absolute;
  top: 150px;
  left: -100px;
  background: #f7f7f7;
  width: 200px;
  height: 400px;
  transform: rotate(-30deg);
  z-index: 0;
}

@media print, screen and (min-width: 769px) {
  .deco-triangle-02 {
    top: 340px;
    left: -100px;
    width: 360px;
    height: 600px;
    transform: rotate(-45deg);
  }
}
.deco-triangle-03 {
  position: absolute;
  top: 350px;
  left: -100px;
  background: #feeff5;
  width: 200vw;
  height: 400px;
  transform: rotate(-15deg);
  z-index: 0;
}

@media print, screen and (min-width: 769px) {
  .deco-triangle-03 {
    top: 350px;
    left: -100px;
    width: 200vw;
    height: 700px;
  }
}
.deco-dot {
  background: url(/assets/img/bg-dot_pink.png) repeat;
  background-size: 57px auto;
  position: absolute;
  top: 100px;
  left: 0;
  width: 100vw;
  height: 400px;
  z-index: 0;
}

@media print, screen and (min-width: 769px) {
  .deco-dot {
    background-size: 80px auto;
    top: 240px;
    height: 500px;
  }
}
.lead-txt {
  padding: 0 16px 24px;
  font-weight: 500;
}
@media print, screen and (min-width: 769px) {
  .lead-txt {
    font-size: 18px;
    line-height: 2;
    text-align: center;
    letter-spacing: 0.1em;
    margin-bottom: 1.5em;
  }
}

.section {
  position: relative;
}
@media print, screen and (min-width: 769px) {
  .section {
    padding: 0 4vw;
  }
}
.section__container {
  padding: 32px 16px;
  position: relative;
}
@media print, screen and (min-width: 769px) {
  .section__container {
    padding: 64px 0;
    max-width: 1080px;
    margin: auto;
  }
}

.section-white {
  background: #fff;
}

.section-blue {
  background: #f2fcfe;
}

.section-dot {
  background: #fff url(/assets/img/bg-dot_pink.png) repeat;
  background-size: 57px auto;
}
@media print, screen and (min-width: 769px) {
  .section-dot {
    background-size: 80px auto;
  }
}

.section-box {
  padding: 0 16px 32px;
}
.section-box__container {
  background: #fff;
  padding: 24px;
  border-radius: 4px;
}

@media print, screen and (min-width: 769px) {
  .section-box {
    padding: 0 4vw 64px;
  }
  .section-box__container {
    padding: 64px 100px;
    max-width: 1080px;
    margin: auto;
    border-radius: 8px;
  }
}
/*===================================================

 リンク

===================================================*/
/* GoogleMap */
.link-map:before {
  content: "\e55f";
  color: #f1659d;
  vertical-align: middle;
  margin-right: 0.3em;
}

/* 電話番号 */
.link-tel {
  display: inline-flex;
  align-items: center;
  color: #444;
  font-weight: 600;
  text-decoration: none;
  line-height: 1;
}
.link-tel:before {
  content: "\e0cd";
  color: #f1659d;
  vertical-align: middle;
}
@media print, screen and (min-width: 769px) {
  .link-tel {
    pointer-events: none;
  }
}

/* 外部リンク */
.link-launch {
  margin-right: 0.2em;
}
.link-launch:after {
  content: "\e895";
  vertical-align: middle;
  margin-left: 0.2em;
  font-size: 0.9em;
  color: #f1659d;
}

/* PDF */
.link-pdf {
  margin-right: 0.2em;
}
.link-pdf:before {
  content: "\e415";
  vertical-align: middle;
  margin-right: 0.2em;
  color: #c00;
}

/* document */
.link-doc {
  margin-right: 0.2em;
}
.link-doc:before {
  content: "\e873";
  vertical-align: middle;
  margin-right: 0.2em;
  color: #4081ec;
}

/*===================================================

 heading

===================================================*/
.heading-01 {
  text-align: center;
  letter-spacing: 0.1em;
  margin-bottom: 1.5em;
  position: relative;
}
.heading-01__main {
  font-size: 20px;
}
.heading-01__sub {
  font-size: 10px;
  color: #f1659d;
  font-weight: 600;
}

@media print, screen and (min-width: 769px) {
  .heading-01 {
    margin-bottom: 2em;
  }
  .heading-01__main {
    font-size: 32px;
  }
  .heading-01__sub {
    font-size: 14px;
  }
}
.heading-02 {
  text-align: center;
  letter-spacing: 0.1em;
  margin-bottom: 1.5em;
  position: relative;
}
.heading-02__ttl {
  display: inline-block;
  font-size: 18px;
  padding: 0 32px;
  position: relative;
}
.heading-02__ttl:before, .heading-02__ttl:after {
  content: "";
  width: 20px;
  height: 2px;
  background: #f1659d;
  border-radius: 4px;
  position: absolute;
  top: calc(50% - 1px);
}
.heading-02__ttl:before {
  left: 0;
}
.heading-02__ttl:after {
  right: 0;
}

@media print, screen and (min-width: 769px) {
  .heading-02 {
    margin-bottom: 2em;
  }
  .heading-02__ttl {
    font-size: 28px;
    padding: 0 64px;
  }
  .heading-02__ttl:before, .heading-02__ttl:after {
    width: 40px;
  }
}
.heading-03 {
  background: #f2fcfe;
  border-left: 4px solid #1b9cd5;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.4;
  padding: 0.8em 1em;
  margin-top: 2em;
  margin-bottom: 1.5em;
}
@media print, screen and (min-width: 769px) {
  .heading-03 {
    font-size: 18px;
    margin-bottom: 2em;
  }
}

/*===================================================

 お問い合わせ

===================================================*/
.form-contact-box {
  text-align: center;
  border: 1px solid #ddd;
  padding: 16px;
}
@media print, screen and (min-width: 769px) {
  .form-contact-box {
    padding: 24px;
  }
}
.form-contact-box__ttl {
  margin-bottom: 0.5em;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
}
@media print, screen and (min-width: 769px) {
  .form-contact-box__ttl {
    font-size: 18px;
    margin-bottom: 1em;
  }
}
.form-contact-box__tel {
  font-size: 24px;
  line-height: 1;
}
@media print, screen and (min-width: 769px) {
  .form-contact-box__tel {
    font-size: 32px;
  }
}
.form-contact-box__tel a {
  color: #f1659d;
}
.form-contact-box__time {
  font-size: 12px;
}
@media print, screen and (min-width: 769px) {
  .form-contact-box__time {
    font-size: 14px;
  }
}

.form-wrap {
  margin-bottom: 24px;
}
@media print, screen and (min-width: 769px) {
  .form-wrap {
    margin-bottom: 40px;
  }
}
.form-wrap > dl {
  border-bottom: 1px solid #ddd;
  padding: 16px 0;
}
.form-wrap > dl:first-child {
  border-top: 1px solid #ddd;
}
@media print, screen and (min-width: 769px) {
  .form-wrap > dl {
    display: flex;
    padding: 24px 0;
  }
}
.form-wrap > dl > dt {
  display: flex;
  align-items: center;
  font-weight: 700;
  margin-bottom: 8px;
}
.form-wrap > dl > dt .required {
  margin-left: 8px;
  background: #c00;
  color: #fff;
  font-size: 12px;
  font-weight: normal;
  line-height: 1;
  border-radius: 2px;
  padding: 4px 8px;
}
@media print, screen and (min-width: 769px) {
  .form-wrap > dl > dt {
    flex-basis: 30%;
    flex-shrink: 0;
    padding-right: 2em;
    align-self: flex-start;
    margin-bottom: 0;
  }
}
.form-wrap > dl > dd {
  font-size: 16px;
}
@media print, screen and (min-width: 769px) {
  .form-wrap > dl > dd {
    flex: 1;
  }
}
.form-wrap .form-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
@media print, screen and (min-width: 769px) {
  .form-wrap .form-row {
    flex-wrap: nowrap;
  }
}
.form-wrap .form-row--name .fieldset {
  display: inline-block;
  width: calc(50% - 10px);
  margin-right: 10px;
}
@media print, screen and (min-width: 769px) {
  .form-wrap .form-row--name .fieldset {
    width: 200px;
  }
}
.form-wrap .form-help {
  color: #777;
  font-size: 12px;
  margin-top: 8px;
}
.form-wrap label {
  display: block;
  padding: 4px 0;
  margin-right: 16px;
}
.form-wrap .kengaku-facility {
  margin: 1em 0 0 0;
}
@media print, screen and (max-width: 768px) {
  .form-wrap .kengaku-facility {
    font-size: 14px;
  }
}

.input-text,
.select {
  border: 1px solid #ccc;
  height: 44px;
  font-size: 16px;
  border-radius: 3px;
  padding: 0 0.5em;
  outline: none;
}
@media print, screen and (min-width: 769px) {
  .input-text,
  .select {
    max-width: 410px;
  }
}

.input-text {
  width: 100%;
}

.input-textarea {
  border: 1px solid #ccc;
  height: 150px;
  font-size: 16px;
  border-radius: 3px;
  padding: 0.5em;
  width: 100%;
  outline: none;
}

.fieldset {
  border: 1px solid #ccc;
  border-radius: 3px;
}
.fieldset legend {
  font-size: 12px;
  line-height: 1;
  padding: 0 1em 0 0.5em;
}
.fieldset input {
  outline: none;
  margin: 0;
  border: none;
  padding: 0.5em;
  background: transparent;
  -webkit-appearance: none;
  appearance: none;
  font-family: inherit;
  box-shadow: none;
  font-size: 16px;
  width: 100%;
}

.form-address-unit__row {
  margin-top: 8px;
}
.form-address-unit .p-country-name {
  display: none;
}

.form-action {
  display: flex;
  justify-content: center;
  align-items: center;
}

.mwform-tel-field {
  display: flex;
  align-items: center;
  gap: 0 4px;
}
@media print, screen and (max-width: 768px) {
  .mwform-tel-field .input-text {
    width: 4.5em !important;
  }
}

.mw_wp_form .form-has-error .error-message {
  display: none;
}
.mw_wp_form .form-has-error .error {
  display: none;
}
.mw_wp_form .form-has-error .error + .error-message {
  display: flex;
  align-items: center;
  color: #c00;
  font-weight: 700;
  margin-bottom: 1em;
}
.mw_wp_form .form-has-error .error + .error-message:before {
  content: "\e001";
  margin-right: 0.3em;
  font-size: 1.2em;
}
.mw_wp_form .form-has-error .error + .error-message + .form-before-txt {
  display: none;
}

.mw_wp_form_confirm .form-wrap .form-help {
  display: none;
}
.mw_wp_form_confirm .form-wrap .form-row--name .fieldset {
  border: none;
}
.mw_wp_form_confirm .form-wrap .form-row--name .fieldset legend {
  display: none;
}

.mw_wp_form .form-wrap .mwform-radio-field {
  display: block;
}
.mw_wp_form .form-wrap .horizontal-item + .horizontal-item {
  margin-left: 0 !important;
}
.mw_wp_form .form-wrap .error {
  margin-bottom: 8px;
  display: inline-flex;
  align-items: center;
  color: #c00;
  background: rgba(204, 0, 0, 0.16);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.2;
  padding: 0.3em 0.6em;
  border-radius: 3px;
}
.mw_wp_form .form-wrap .error:before {
  content: "\e001";
  margin-right: 0.3em;
}

.mw_wp_form_input .form-after-txt {
  display: none;
}

.mw_wp_form_confirm .form-before-txt {
  display: none;
}

/*===================================================

 アコーディオン

===================================================*/
.accordion-trigger {
  position: relative;
  cursor: pointer;
}
.accordion-trigger:after {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  color: #e6ad3b;
  font-size: 20px;
}
.accordion-trigger[aria-expanded=false]:after {
  content: "\e145";
}
.accordion-trigger[aria-expanded=true]:after {
  content: "\e15b";
}

.accordion-body[aria-hidden=true] {
  visibility: hidden;
  opacity: 0;
  height: 0;
  transition: padding 0.2s, opacity 0.2s;
}
.accordion-body[aria-hidden=false] {
  visibility: visible;
  opacity: 1;
  height: auto;
  transition: padding 0.2s, opacity 0.2s;
}

/*===================================================

 animation

===================================================*/
.fadein {
  transition: opacity 1s;
  opacity: 0;
}
.fadein.is-move {
  opacity: 1;
}

.fadein-up {
  transition: transform 1s, opacity 1s;
  opacity: 0;
  transform: translateY(20px);
}
.fadein-up.is-move {
  opacity: 1;
  transform: translateY(0);
}

.fadein-down {
  transition: transform 1s, opacity 1s;
  opacity: 0;
  transform: translateY(-20px);
}
.fadein-down.is-move {
  opacity: 1;
  transform: translateY(0);
}

.fadein-left {
  transition: transform 1s, opacity 1s;
  opacity: 0;
  transform: translateX(-20px);
}
.fadein-left.is-move {
  opacity: 1;
  transform: translateX(0);
}

.fadein-right {
  transition: transform 1s, opacity 1s;
  opacity: 0;
  transform: translateX(20px);
}
.fadein-right.is-move {
  opacity: 1;
  transform: translateX(0);
}

.anime--fuwafuwa {
  animation: fuwafuwa 2s ease infinite;
}

@keyframes fuwafuwa {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
.anime--rotate {
  animation: rotate 10s ease infinite;
}

@keyframes rotate {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
/*===================================================

 トップページ

===================================================*/
.hero__container {
  padding: 0 16px;
}
.hero .hero-img {
  margin-bottom: 16px;
}
.hero .hero-ttl {
  font-size: 24px;
  line-height: 1.4;
  margin: 0 8px;
}
.hero .hero-txt {
  margin: 1em 8px 0;
  font-weight: 500;
  transition-delay: 0.8s;
}

@media print, screen and (min-width: 769px) {
  .hero {
    padding: 0 4vw;
  }
  .hero__container {
    max-width: 1600px;
    margin: auto;
    padding: 0;
    position: relative;
  }
  .hero__content {
    position: absolute;
    bottom: 50%;
    left: 0;
    transform: translateY(50%);
    width: 100%;
    color: #fff;
    text-align: center;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
    padding-bottom: 48px;
    z-index: 2;
  }
  .hero .hero-img {
    margin-bottom: 0;
  }
  .hero .hero-img img {
    width: 100%;
    object-fit: cover;
  }
  .hero .hero-ttl {
    font-size: 48px;
    margin: 0 8px;
    letter-spacing: 0.15em;
  }
  .hero .hero-txt {
    font-size: 24px;
    margin: 1em 8px 0;
    letter-spacing: 0.1em;
    line-height: 2;
  }
}
.top-section-container {
  padding: 56px 16px;
  position: relative;
}

.top-section-btn {
  position: absolute;
  bottom: -25px;
  left: 50%;
  width: 72vw;
  transform: translateX(-50%);
}

@media print, screen and (min-width: 769px) {
  .top-section-container {
    padding: 100px 0;
    max-width: 1080px;
    margin: auto;
  }
  .top-section-btn {
    bottom: -36px;
    width: 360px;
  }
  .top-section-btn a {
    min-height: 72px;
  }
}
.top-about {
  text-align: center;
}
.top-about__heading {
  display: inline-block;
  position: relative;
  margin-bottom: 24px;
}
.top-about__heading h2 {
  font-size: 16px;
  letter-spacing: 0.1em;
}
.top-about .deco-sakura-01 {
  background: url(/assets/img/deco-sakura-01.png) no-repeat center;
  background-size: contain;
  width: 24px;
  height: 24px;
  position: absolute;
  top: 10%;
  left: -48px;
}
.top-about .deco-sakura-02 {
  background: url(/assets/img/deco-sakura-03.png) no-repeat center;
  background-size: contain;
  width: 50px;
  height: 35px;
  position: absolute;
  top: 10%;
  right: -70px;
}
.top-about__row-col:nth-child(2) {
  margin-top: 48px;
  position: relative;
}
.top-about__row-col:nth-child(2):before {
  content: "";
  background: url(/assets/img/icon-human.svg) no-repeat center;
  background-size: contain;
  width: 72px;
  height: 64px;
  position: absolute;
  top: -54px;
  right: 10px;
}

@media print, screen and (min-width: 769px) {
  .top-about {
    padding: 0 4vw;
    position: relative;
    z-index: 1;
  }
  .top-about:before {
    content: "";
    background: url(/assets/img/icon-human.svg) no-repeat center;
    background-size: contain;
    width: 200px;
    height: 200px;
    position: absolute;
    bottom: -40px;
    right: 4vw;
  }
  .top-about__heading {
    margin-bottom: 64px;
  }
  .top-about__heading h2 {
    font-size: 28px;
  }
  .top-about .deco-sakura-01 {
    width: 50px;
    height: 50px;
    top: -10px;
    left: -80px;
  }
  .top-about .deco-sakura-02 {
    width: 100px;
    height: 100px;
    top: -42px;
    right: -120px;
  }
  .top-about__row {
    display: flex;
    justify-content: space-between;
  }
  .top-about__row-col {
    width: 47.5%;
  }
  .top-about__row-col:nth-child(2) {
    margin-top: 0;
  }
  .top-about__row-col:nth-child(2):before {
    display: none;
  }
}
.top-about-card {
  position: relative;
}
.top-about-card__img img {
  aspect-ratio: 2/1;
  object-fit: cover;
}
.top-about-card__desc {
  padding: 16px 0 0;
}
.top-about-card__desc h3 {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}
.top-about-card__desc p {
  text-align: left;
  margin-top: 1em;
}

@media print, screen and (min-width: 769px) {
  .top-about-card__img img {
    aspect-ratio: auto;
  }
  .top-about-card__desc {
    padding: 24px 0 0;
  }
  .top-about-card__desc h3 {
    font-size: 20px;
  }
}
.top-job {
  background: #fff;
  padding-top: 16px;
}
.top-job .top-section-container {
  padding-bottom: 0;
}

@media print, screen and (min-width: 769px) {
  .top-job {
    padding-top: 24px;
    position: relative;
  }
  .top-job .top-section-container {
    position: static;
  }
}
.job-slider-wrap {
  margin: 0 -16px;
  padding: 24px 0 64px;
  position: relative;
}
.job-slider-wrap:after {
  content: "INTERVIEW";
  letter-spacing: 0.05em;
  font-size: 30px;
  line-height: 1;
  font-weight: 600;
  color: #feeff5;
  position: absolute;
  top: 0;
  left: 0;
}
.job-slider-wrap:before {
  content: "";
  display: block;
  background: url(/assets/img/bg-dot_pink.png) repeat;
  background-size: 57px auto;
  width: 100%;
  height: calc(100% - 64px);
  position: absolute;
  top: 64px;
  left: 0;
  z-index: 0;
}

@media print, screen and (min-width: 769px) {
  .job-slider-wrap {
    margin: 0;
    padding: 48px 0 120px;
    position: static;
  }
  .job-slider-wrap:after {
    font-size: 80px;
    top: 280px;
    left: 0%;
  }
  .job-slider-wrap:before {
    background-size: 80px auto;
    width: 100vw;
    height: calc(100% - 360px);
    top: 360px;
  }
}
.job-slider {
  padding-bottom: 60px;
  padding-left: 16px;
  position: relative;
}

@media print, screen and (min-width: 769px) {
  .job-slider {
    overflow: visible;
    padding-bottom: 100px;
    padding-left: 0;
  }
}
.job-slider-navigation {
  position: absolute;
  width: 100%;
  bottom: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 26px;
}
.job-slider-navigation .swiper-pagination-bullets {
  position: static;
  width: auto;
  margin: 0 12px;
  padding: 0 12px;
  border-radius: 40px;
  background: #fff;
  display: flex;
  align-items: center;
  height: 100%;
}
.job-slider-navigation .swiper-pagination-bullets span {
  width: 5px;
  height: 5px;
}
.job-slider-navigation .swiper-pagination-bullet-active {
  background: #f1659d;
}
.job-slider-navigation .swiper-button-next,
.job-slider-navigation .swiper-button-prev {
  position: static;
  z-index: 2;
  background: #f1659d;
  border-radius: 50%;
  border: 1px solid #f1659d;
  background: #fff;
  width: 26px;
  height: 26px;
  margin: 0;
}
.job-slider-navigation .swiper-button-next:after,
.job-slider-navigation .swiper-button-prev:after {
  color: #f1659d;
  font-size: 14px;
}
.job-slider-navigation .swiper-button-next.swiper-button-disabled,
.job-slider-navigation .swiper-button-prev.swiper-button-disabled {
  opacity: 1;
  border-color: #ccc;
}
.job-slider-navigation .swiper-button-next.swiper-button-disabled:after,
.job-slider-navigation .swiper-button-prev.swiper-button-disabled:after {
  color: #ccc;
}
.job-slider-navigation .swiper-button-next:after {
  content: "\e5cc";
  margin-right: -1px;
}
.job-slider-navigation .swiper-button-prev:after {
  content: "\e5cb";
}

@media print, screen and (min-width: 769px) {
  .job-slider-navigation {
    height: 36px;
  }
  .job-slider-navigation .swiper-pagination-bullets {
    margin: 0 24px;
    padding: 0 24px;
  }
  .job-slider-navigation .swiper-pagination-bullets span {
    width: 8px;
    height: 8px;
    margin: 0 6px !important;
  }
  .job-slider-navigation .swiper-button-next,
  .job-slider-navigation .swiper-button-prev {
    width: 48px;
    height: 48px;
    margin: 0;
    border-width: 2px;
    transition: all 0.2s;
  }
  .job-slider-navigation .swiper-button-next:hover,
  .job-slider-navigation .swiper-button-prev:hover {
    background: #f1659d;
  }
  .job-slider-navigation .swiper-button-next:hover:after,
  .job-slider-navigation .swiper-button-prev:hover:after {
    color: #fff;
  }
  .job-slider-navigation .swiper-button-next:after,
  .job-slider-navigation .swiper-button-prev:after {
    font-size: 24px;
  }
  .job-slider-navigation .swiper-button-next:after {
    margin-right: -1px;
  }
}
.job-slider-card {
  position: relative;
  display: flex;
  color: #444;
  padding: 24px 0 0;
  margin-right: 16px;
}
.job-slider-card:before {
  content: "";
  display: block;
  background: #feeff5;
  width: calc(100% - 24px);
  height: 48px;
  position: absolute;
  bottom: 0;
  left: 24px;
  z-index: 0;
}
.job-slider-card__img {
  width: 46%;
  flex-shrink: 0;
  position: relative;
  top: -24px;
}
.job-slider-card__desc {
  padding: 40px 12px 8px;
  background: #feeff5;
  position: relative;
}
.job-slider-card__desc .category {
  background: #f1659d;
  padding: 0.4em 0.6em;
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  position: absolute;
  top: 0;
  right: 0;
}
.job-slider-card__desc .year {
  color: #f1659d;
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
}
.job-slider-card__desc .name {
  color: #f1659d;
  margin-top: 8px;
  font-size: 10px;
  line-height: 1;
}
.job-slider-card__desc .name em {
  font-size: 14px;
  font-weight: 600;
  margin-right: 0.2em;
}
.job-slider-card__desc .txt {
  margin-top: 8px;
  font-weight: 700;
  font-size: 12px;
  line-height: 1.4;
}

@media print, screen and (min-width: 769px) {
  .job-slider-card {
    padding: 40px 0 0;
    margin-right: 48px;
  }
  .job-slider-card:before {
    width: calc(100% - 40px);
    height: 40px;
    left: 40px;
  }
  .job-slider-card__img img {
    aspect-ratio: 5/6;
    object-fit: cover;
  }
  .job-slider-card__desc {
    padding: 40px 25px 32px;
    display: flex;
    flex-direction: column;
  }
  .job-slider-card__desc .category {
    padding: 0.6em 1em;
    font-size: 14px;
  }
  .job-slider-card__desc .year {
    font-size: 16px;
    margin-top: auto;
  }
  .job-slider-card__desc .name {
    margin-top: 16px;
    font-size: 12px;
  }
  .job-slider-card__desc .name em {
    font-size: 20px;
  }
  .job-slider-card__desc .txt {
    margin-top: 16px;
    font-size: 18px;
    line-height: 1.7;
  }
}
.job-slider-card--caremanager:before {
  background: #f9efff;
}
.job-slider-card--caremanager .job-slider-card__desc {
  background: #f9efff;
}
.job-slider-card--caremanager .job-slider-card__desc .category {
  background: #9e51cb;
}
.job-slider-card--caremanager .job-slider-card__desc .year,
.job-slider-card--caremanager .job-slider-card__desc .name {
  color: #9e51cb;
}

.job-slider-card--nurse:before {
  background: #fff6e5;
}
.job-slider-card--nurse .job-slider-card__desc {
  background: #fff6e5;
}
.job-slider-card--nurse .job-slider-card__desc .category {
  background: #e6ad3b;
}
.job-slider-card--nurse .job-slider-card__desc .year,
.job-slider-card--nurse .job-slider-card__desc .name {
  color: #e6ad3b;
}

.job-slider-card--caregiver:before {
  background: #f2fcfe;
}
.job-slider-card--caregiver .job-slider-card__desc {
  background: #f2fcfe;
}
.job-slider-card--caregiver .job-slider-card__desc .category {
  background: #1b9cd5;
}
.job-slider-card--caregiver .job-slider-card__desc .year,
.job-slider-card--caregiver .job-slider-card__desc .name {
  color: #1b9cd5;
}

.job-slider-card--new-caregiver:before {
  background: #e8f8fa;
}
.job-slider-card--new-caregiver .job-slider-card__desc {
  background: #e8f8fa;
}
.job-slider-card--new-caregiver .job-slider-card__desc .category {
  background: #1dbcce;
}
.job-slider-card--new-caregiver .job-slider-card__desc .year,
.job-slider-card--new-caregiver .job-slider-card__desc .name {
  color: #1dbcce;
}

.top-benefit {
  margin-top: 80px;
  background: #feeff5;
  position: relative;
}
.top-benefit:before {
  content: "";
  display: block;
  background: url(/assets/img/bg-benefit.jpg) no-repeat center top;
  background-size: contain;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

@media print, screen and (min-width: 769px) {
  .top-benefit {
    margin-top: 120px;
  }
  .top-benefit:before {
    background-size: cover;
    background-position: center;
    height: 640px;
  }
  .top-benefit .top-section-container {
    padding-top: 200px;
  }
}
.top-benefit-wrap {
  text-align: center;
  max-width: 343px;
  margin: auto;
  position: relative;
}
.top-benefit-wrap__img {
  display: block;
}
@media print, screen and (min-width: 769px) {
  .top-benefit-wrap {
    max-width: 915px;
  }
}
.top-benefit-btn {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 2.4em 0.5em 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 50px;
  background: #6dc8eb;
  color: #fff;
  width: 80%;
  margin: -25px auto 0;
}
.top-benefit-btn:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
}

@media print, screen and (min-width: 769px) {
  .top-benefit-btn {
    font-size: 16px;
    min-height: 72px;
    width: 320px;
    margin: -32px auto 0;
  }
  .top-benefit-btn:before {
    right: 1em;
  }
}
.top-recruit {
  background: #feeff5;
}
.top-recruit .top-section-container {
  padding-top: 0;
  text-align: center;
}

@media print, screen and (min-width: 769px) {
  .top-recruit {
    padding: 0 4vw;
  }
  .top-recruit .top-section-container {
    padding-top: 0;
    text-align: center;
  }
}
.top-recruit-heading {
  display: inline-block;
  position: relative;
}
.top-recruit-heading .deco-sakura-01 {
  background: url(/assets/img/deco-sakura-02.png) no-repeat center;
  background-size: contain;
  width: 50px;
  height: 50px;
  position: absolute;
  top: -20px;
  left: -80px;
}
.top-recruit-heading .deco-sakura-02 {
  background: url(/assets/img/deco-sakura-03.png) no-repeat center;
  background-size: contain;
  width: 50px;
  height: 50px;
  position: absolute;
  top: -15px;
  right: -80px;
}

@media print, screen and (min-width: 769px) {
  .top-recruit-heading {
    position: static;
  }
  .top-recruit-heading .deco-sakura-01 {
    width: 100px;
    height: 100px;
    top: 40px;
    left: -20px;
  }
  .top-recruit-heading .deco-sakura-02 {
    width: 131px;
    height: 131px;
    top: 40px;
    right: -20px;
  }
}
.recruit-bnr-list > li {
  margin-top: 16px;
  text-align: left;
}

@media print, screen and (min-width: 769px) {
  .recruit-bnr-list {
    display: flex;
    justify-content: space-between;
  }
  .recruit-bnr-list > li {
    width: calc(33.3333333333% - 24px);
    margin-top: 0;
  }
}
.recruit-bnr {
  display: flex;
  background: #fff;
  box-shadow: 4px 4px 0 0 rgba(0, 0, 0, 0.08);
  padding: 10px;
}
.recruit-bnr__img {
  width: 80px;
  flex-shrink: 0;
}
.recruit-bnr__img img {
  aspect-ratio: 1/1;
  object-fit: cover;
}
.recruit-bnr__desc {
  padding: 0 24px;
  flex: 1;
  align-self: center;
  position: relative;
}
.recruit-bnr__desc:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  color: #f1659d;
  font-size: 24px;
}
.recruit-bnr__desc .ttl {
  font-size: 18px;
  font-weight: 700;
  color: #444;
}
.recruit-bnr__desc .balloon {
  display: inline-block;
  background: #f1659d;
  color: #fff;
  font-size: 10px;
  font-weight: 500;
  line-height: 1;
  padding: 0.5em 1em;
  border-radius: 40px;
  position: relative;
  margin-bottom: 8px;
}
.recruit-bnr__desc .balloon:before {
  content: "";
  border-style: solid;
  border-width: 4px 4px 0;
  border-color: #f1659d transparent transparent;
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -2px;
}

@media print, screen and (min-width: 769px) {
  .recruit-bnr {
    display: block;
    box-shadow: 6px 6px 0 0 rgba(0, 0, 0, 0.08);
    padding: 16px 16px 0;
    transition: box-shadow 0.2s;
  }
  .recruit-bnr:hover {
    opacity: 1;
    box-shadow: 10px 10px 0 0 rgba(0, 0, 0, 0.08);
  }
  .recruit-bnr__img {
    width: auto;
    text-align: center;
  }
  .recruit-bnr__img img {
    aspect-ratio: auto;
  }
  .recruit-bnr__desc {
    padding: 32px 0;
    text-align: center;
  }
  .recruit-bnr__desc .ttl {
    font-size: 20px;
  }
  .recruit-bnr__desc .balloon {
    position: absolute;
    top: -24px;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    font-size: 14px;
    padding: 0.8em 2em;
  }
  .recruit-bnr__desc .balloon:before {
    border-width: 6px 6px 0;
    margin-left: -3px;
  }
}
.ctaArea {
  background: url(/assets/img/bg-cta.jpg) no-repeat center center;
  background-size: cover;
}
.ctaArea__container {
  text-align: center;
  padding: 40px 16px 64px;
  color: #fff;
  position: relative;
}
.ctaArea__container:before {
  content: "";
  background: url(/assets/img/icon-human.svg) no-repeat center;
  background-size: contain;
  width: 72px;
  height: 64px;
  position: absolute;
  bottom: -10px;
  right: 10px;
  opacity: 0.5;
}
.ctaArea .ctaArea-ttl {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1em;
}
.ctaArea .ctaArea-txt {
  margin-top: 1.5em;
  font-size: 13px;
  line-height: 2;
}
.ctaArea .ctaArea-list {
  width: 80%;
  margin: 0 auto;
}
.ctaArea .ctaArea-list > li {
  margin-top: 20px;
}
.ctaArea .ctaArea-list > li > a {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: none;
  text-align: center;
  border-radius: 100px;
  padding: 0.5em 2.4em 0.5em 2em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 50px;
  color: #fff;
}
.ctaArea .ctaArea-list > li > a:before {
  content: "\e5cc";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.8em;
}
.ctaArea .ctaArea-list__recruit-btn {
  background: #6dc8eb;
}
.ctaArea .ctaArea-list__entry-btn {
  background: #ee89b2;
}

@media print, screen and (min-width: 769px) {
  .ctaArea__container {
    padding: 120px 2vw;
    max-width: 1080px;
    margin: auto;
  }
  .ctaArea__container:before {
    width: 250px;
    height: 250px;
    bottom: -50px;
    right: -50px;
  }
  .ctaArea .ctaArea-ttl {
    font-size: 36px;
  }
  .ctaArea .ctaArea-txt {
    font-size: 18px;
    letter-spacing: 0.05em;
  }
  .ctaArea .ctaArea-list {
    margin: 80px auto 0;
    display: flex;
    justify-content: center;
  }
  .ctaArea .ctaArea-list > li {
    margin: 0 24px;
    min-width: 320px;
  }
  .ctaArea .ctaArea-list > li > a {
    font-size: 18px;
    min-height: 80px;
  }
  .ctaArea .ctaArea-list > li > a:hover {
    opacity: 1;
    transition: background 0.2s;
  }
  .ctaArea .ctaArea-list > li > a:before {
    right: 1em;
  }
  .ctaArea .ctaArea-list__recruit-btn:hover {
    background: #1b9cd5;
  }
  .ctaArea .ctaArea-list__entry-btn:hover {
    background: #f1659d;
  }
}
/*===================================================

 私たちについて

===================================================*/
.philosophy-box {
  background: #feeff5;
  border-radius: 8px;
  padding: 24px 24px 48px;
  text-align: center;
  position: relative;
}
.philosophy-box:before {
  content: "";
  background: url(/assets/img/deco-sakura-03.png) no-repeat center;
  background-size: contain;
  width: 50px;
  height: 50px;
  position: absolute;
  top: -15px;
  right: 10px;
}
.philosophy-box:after {
  content: "";
  background: url(/assets/img/icon-human.svg) no-repeat center;
  background-size: contain;
  width: 72px;
  height: 64px;
  position: absolute;
  bottom: -10px;
  right: 0;
}
.philosophy-box__ttl {
  color: #f1659d;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 1em;
}
.philosophy-box__underline {
  margin-top: 0.5em;
  line-height: 2;
  position: relative;
  z-index: 1;
}
.philosophy-box__underline span {
  border-bottom: 2px solid rgba(241, 101, 157, 0.4);
}

@media print, screen and (min-width: 769px) {
  .philosophy-box {
    padding: 40px 40px 64px;
  }
  .philosophy-box:before {
    width: 100px;
    height: 100px;
    top: -30px;
    right: 40px;
  }
  .philosophy-box:after {
    width: 144px;
    height: 128px;
    bottom: -20px;
    right: 20px;
  }
  .philosophy-box__ttl {
    font-size: 24px;
  }
  .philosophy-box__underline {
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.1em;
  }
  .philosophy-box__underline span {
    display: inline-block;
    padding-bottom: 0.1em;
  }
}
.business-list {
  display: flex;
  flex-wrap: wrap;
}
.business-list > li {
  width: 100%;
  padding: 0 16px;
  margin-bottom: 48px;
}
.business-list > li:last-child {
  margin-bottom: 0;
}

@media print, screen and (min-width: 769px) {
  .business-list {
    display: flex;
    flex-wrap: wrap;
  }
  .business-list > li {
    width: 33.3333%;
    padding: 0 24px;
    margin-bottom: 64px;
  }
}
.business-card__img {
  width: 60%;
  max-width: 200px;
  margin: auto;
  position: relative;
}
.business-card__num {
  background: #f1659d;
  color: #fff;
  font-size: 16px;
  line-height: 1;
  font-weight: 600;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 10px;
  left: 10px;
}
.business-card__num:before {
  content: "#";
  font-size: 12px;
}
.business-card__ttl {
  font-size: 16px;
  font-weight: 700;
  margin-top: 1em;
  text-align: center;
}
.business-card__txt {
  margin-top: 0.5em;
}

@media print, screen and (min-width: 769px) {
  .business-card__img {
    width: 280px;
    max-width: 100%;
  }
  .business-card__num {
    font-size: 20px;
    width: 60px;
    height: 60px;
  }
  .business-card__num:before {
    font-size: 14px;
  }
  .business-card__ttl {
    font-size: 18px;
    margin-top: 1.5em;
  }
  .business-card__txt {
    margin-top: 1em;
  }
}
@media print, screen and (min-width: 769px) {
  .facility-section .section__container {
    max-width: 100%;
  }
}
.facility-row {
  background: url(/assets/img/bg-dot_pink.png) repeat;
  background-size: 57px auto;
  margin: 32px -16px 0;
  padding: 24px 24px;
  position: relative;
}
.facility-row:before {
  content: "FACILITY";
  letter-spacing: 0.05em;
  font-size: 30px;
  line-height: 1;
  font-weight: 700;
  color: #feeff5;
  position: absolute;
  top: -28px;
  right: 0;
}
.facility-row__col {
  margin-bottom: 48px;
}
.facility-row__col:last-child {
  margin-bottom: 8px;
}

@media print, screen and (min-width: 769px) {
  .facility-row {
    background-size: 80px auto;
    margin: 64px -4vw 0;
    padding: 80px 4vw;
    display: flex;
    justify-content: center;
  }
  .facility-row:before {
    font-size: 80px;
    top: -72px;
  }
  .facility-row__col {
    max-width: 480px;
    margin: 0 24px;
  }
  .facility-row__col:last-child {
    margin-bottom: 0;
  }
}
.facility-card__desc {
  margin-top: 1em;
  text-align: center;
}
.facility-card__desc h3 {
  font-size: 16px;
}
.facility-card__desc .btn-map {
  font-size: 11px;
  margin-left: 1em;
}
.facility-card__btn {
  margin: 24px auto 0;
  max-width: 260px;
}

@media print, screen and (min-width: 769px) {
  .facility-card__desc {
    margin-top: 1em;
  }
  .facility-card__desc h3 {
    font-size: 20px;
  }
  .facility-card__desc .btn-map {
    font-size: 14px;
  }
  .facility-card__btn {
    max-width: 360px;
  }
}
.number-section:before {
  content: "VIEW DATA";
  letter-spacing: 0.05em;
  font-size: 40px;
  line-height: 1;
  font-weight: 700;
  color: #ddf5fc;
  position: absolute;
  top: 24px;
  left: 0;
  width: 100%;
  text-align: center;
}
.number-section .section__container {
  padding-top: 48px;
}

@media print, screen and (min-width: 769px) {
  .number-section:before {
    font-size: 80px;
    top: 72px;
  }
  .number-section .section__container {
    padding-top: 120px;
  }
}
.number-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.number-list__item {
  background: #fff;
  border-radius: 8px;
  margin-bottom: 16px;
}
.number-list__item--col3 {
  width: calc(50% - 8px);
}
@media print, screen and (max-width: 768px) {
  .number-list__item--col3 .number-card {
    padding: 20px 16px;
  }
  .number-list__item--col3 .number-card__ttl {
    font-size: 14px;
  }
}

@media print, screen and (min-width: 769px) {
  .number-list {
    margin-top: 80px;
    margin-left: -20px;
    margin-right: -20px;
  }
  .number-list__item {
    margin-left: 20px;
    margin-right: 20px;
    margin-bottom: 40px;
  }
  .number-list__item--col2 {
    width: calc(50% - 40px);
  }
  .number-list__item--col3 {
    width: calc(33.3333% - 40px);
  }
}
.number-card {
  text-align: center;
  padding: 24px 16px;
}
.number-card__ttl {
  font-size: 16px;
  line-height: 1.4;
  margin-bottom: 1em;
}
.number-card__desc {
  text-align: center;
}
.number-card__txt {
  font-size: 12px;
  margin-top: 0.5em;
}

@media print, screen and (min-width: 769px) {
  .number-card {
    padding: 32px;
  }
  .number-card__ttl {
    font-size: 24px;
  }
  .number-card__txt {
    font-size: 16px;
    margin-top: 1em;
  }
}
/*===================================================

 お仕事紹介

===================================================*/
.job-list > li {
  margin-bottom: 40px;
}
.job-list > li:last-child {
  margin-bottom: 0;
}

@media print, screen and (min-width: 769px) {
  .job-list > li {
    margin-bottom: 100px;
  }
  .job-list > li:last-child {
    margin-bottom: 40px;
  }
}
.job-card {
  background: #fff;
  display: flex;
  color: #444;
  padding-left: 12px;
  box-shadow: 0 4px 8px 0 rgba(201, 133, 160, 0.1);
  position: relative;
}
.job-card__img {
  width: 100px;
  flex-shrink: 0;
  position: relative;
  top: -12px;
}
.job-card__desc {
  padding: 36px 16px 16px;
  position: relative;
}
.job-card__desc .category {
  background: #f1659d;
  padding: 0.4em 0.6em;
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  position: absolute;
  top: 0;
  right: 0;
}
.job-card__desc .ttl {
  font-size: 15px;
  line-height: 1.4;
  font-weight: 700;
  margin-bottom: 0.5em;
}
.job-card__desc .year {
  display: inline-block;
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
  margin-right: 1em;
  color: #f1659d;
}
.job-card__desc .name {
  display: inline-block;
  font-size: 10px;
  line-height: 1;
  color: #f1659d;
}
.job-card__desc .name em {
  font-size: 14px;
  font-weight: 600;
  margin-right: 0.2em;
}
.job-card__desc .txt {
  font-size: 12px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

@media print, screen and (min-width: 769px) {
  .job-card {
    padding-left: 48px;
  }
  .job-card__img {
    top: -48px;
    width: 240px;
  }
  .job-card__desc {
    padding: 56px 48px 48px;
  }
  .job-card__desc .ttl {
    font-size: 28px;
    margin-bottom: 0.8em;
  }
  .job-card__desc .category {
    font-size: 16px;
    right: auto;
    left: 48px;
  }
  .job-card__desc .year {
    font-size: 18px;
    display: block;
  }
  .job-card__desc .name {
    display: block;
    margin-top: 0.5em;
    font-size: 14px;
  }
  .job-card__desc .name em {
    font-size: 24px;
  }
  .job-card__desc .txt {
    margin-top: 1em;
    font-size: 16px;
    -webkit-line-clamp: 3;
  }
}
.job-card--caremanager .job-card__desc .category {
  background: #9e51cb;
}
.job-card--caremanager .job-card__desc .year,
.job-card--caremanager .job-card__desc .name {
  color: #9e51cb;
}

.job-card--nurse .job-card__desc .category {
  background: #e6ad3b;
}
.job-card--nurse .job-card__desc .year,
.job-card--nurse .job-card__desc .name {
  color: #e6ad3b;
}

.job-card--caregiver .job-card__desc .category {
  background: #1b9cd5;
}
.job-card--caregiver .job-card__desc .year,
.job-card--caregiver .job-card__desc .name {
  color: #1b9cd5;
}

.job-card--new-caregiver .job-card__desc .category {
  background: #1dbcce;
}
.job-card--new-caregiver .job-card__desc .year,
.job-card--new-caregiver .job-card__desc .name {
  color: #1dbcce;
}

.job-mv__container {
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  min-height: 300px;
  padding: 24px 16px 32px;
  display: flex;
  align-items: flex-end;
}
.job-mv__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.job-mv__ttl {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
  text-shadow: 0 0 4px rgba(68, 68, 68, 0.8);
  margin-top: 0.5em;
}
.job-mv .category {
  background: #f1659d;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  padding: 0.5em 0.8em 0.4em;
}
.job-mv .detail {
  background: #fff;
  color: #f1659d;
  border: 2px solid #f1659d;
  font-size: 13px;
  line-height: 1;
  padding: 0.5em 0.8em;
}
.job-mv .detail .year {
  display: inline-block;
  font-weight: 500;
  margin-right: 1em;
}
.job-mv .detail .name {
  display: inline-block;
  line-height: 1;
  font-size: 12px;
}
.job-mv .detail .name em {
  font-size: 14px;
  font-weight: 600;
  margin-right: 0.2em;
}

@media print, screen and (min-width: 769px) {
  .job-mv {
    padding: 0 4vw;
  }
  .job-mv__container {
    max-width: 1600px;
    min-height: 33vw;
    margin: auto;
    padding: 4vw;
  }
  .job-mv__content {
    max-width: 1080px;
    margin: 0 auto;
  }
  .job-mv__ttl {
    font-size: 36px;
    margin-top: 0.8em;
    letter-spacing: 0.1em;
    text-shadow: 0 0 10px rgba(68, 68, 68, 0.8);
  }
  .job-mv .category {
    font-size: 18px;
  }
  .job-mv .detail {
    font-size: 16px;
  }
  .job-mv .detail .year {
    font-size: 16px;
    font-weight: 700;
  }
  .job-mv .detail .name {
    font-size: 14px;
  }
  .job-mv .detail .name em {
    font-size: 20px;
  }
}
.job-mv--caremanager .category {
  background: #9e51cb;
}
.job-mv--caremanager .detail {
  color: #9e51cb;
  border-color: #9e51cb;
}

.job-mv--nurse .category {
  background: #e6ad3b;
}
.job-mv--nurse .detail {
  color: #e6ad3b;
  border-color: #e6ad3b;
}

.job-mv--caregiver .category {
  background: #1b9cd5;
}
.job-mv--caregiver .detail {
  color: #1b9cd5;
  border-color: #1b9cd5;
}

.job-mv--new-caregiver .category {
  background: #1dbcce;
}
.job-mv--new-caregiver .detail {
  color: #1dbcce;
  border-color: #1dbcce;
}

.job-detail-section {
  background: #feeff5;
}
.job-detail-section:before {
  content: "";
  display: block;
  background: #fff;
  width: 100vw;
  height: calc(100% - 500px);
  position: absolute;
  top: 500px;
  left: 0;
  z-index: 0;
}
.job-detail-section:after {
  content: "";
  display: block;
  background: #fff;
  width: 100vw;
  height: 100px;
  position: absolute;
  top: 450px;
  left: 0;
  z-index: 0;
  transform: skewY(10deg);
}

@media print, screen and (min-width: 769px) {
  .job-detail-section:before {
    height: calc(100% - 800px);
    top: 800px;
  }
  .job-detail-section:after {
    height: 400px;
    top: 600px;
    transform: skewY(6deg);
  }
}
.job-detail-row {
  display: flex;
  flex-direction: column;
  margin-bottom: 1em;
  position: relative;
  z-index: 1;
}
@media print, screen and (max-width: 768px) {
  .job-detail-row.sp-reverse {
    flex-direction: column-reverse;
  }
}
.job-detail-row--border {
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  margin-bottom: 1.5em;
  padding-top: 1.5em;
}
.job-detail-row__col {
  margin-bottom: 1.5em;
}
.job-detail-row .job-detail-ttl {
  font-size: 16px;
  font-weight: 700;
  display: flex;
  align-items: flex-start;
  margin-bottom: 1em;
}
.job-detail-row .job-detail-ttl:not(:first-child) {
  margin-top: 1.5em;
}
.job-detail-row .job-detail-ttl .label {
  background: #f1659d;
  width: 2.4em;
  text-align: center;
  color: #fff;
  font-weight: 600;
  line-height: 1;
  margin: 2px 12px 0 0;
  padding: 4px 0;
}
.job-detail-row .job-detail-ttl .label:before {
  content: "#";
  font-size: 12px;
}

@media print, screen and (min-width: 769px) {
  .job-detail-row {
    flex-direction: row;
    justify-content: space-between;
    margin: 0 0 80px;
  }
  .job-detail-row--border {
    margin: 0 0 80px;
    padding: 48px 0;
  }
  .job-detail-row__col {
    width: calc(50% - 24px);
    margin: 0;
  }
  .job-detail-row .job-detail-ttl {
    font-size: 20px;
  }
  .job-detail-row .job-detail-ttl:not(:first-child) {
    margin-top: 2em;
  }
  .job-detail-row .job-detail-ttl .label {
    width: 3em;
    margin: 2px 16px 0 0;
    padding: 6px 0;
    font-size: 18px;
  }
  .job-detail-row .job-detail-ttl .label:before {
    font-size: 14px;
    margin-right: 0.1em;
  }
  .job-detail-row p {
    line-height: 2;
  }
}
.job-detail-section--caremanager .job-detail-row .job-detail-ttl .label {
  background: #9e51cb;
}

.job-detail-section--nurse .job-detail-row .job-detail-ttl .label {
  background: #e6ad3b;
}

.job-detail-section--caregiver .job-detail-row .job-detail-ttl .label {
  background: #1b9cd5;
}

.job-detail-section--new-caregiver .job-detail-row .job-detail-ttl .label {
  background: #1dbcce;
}

.job-schedule-section {
  background: #feeff5;
}
.job-schedule-section:before {
  content: "SCHEDULE";
  letter-spacing: 0.05em;
  font-size: 40px;
  line-height: 1;
  font-weight: 700;
  color: #feeff5;
  position: absolute;
  top: -32px;
  right: 0;
}

@media print, screen and (min-width: 769px) {
  .job-schedule-section:before {
    font-size: 80px;
    top: -64px;
  }
  .job-schedule-section .heading-01 {
    top: -92px;
    margin-bottom: -40px;
  }
}
.job-schedule-heading {
  color: #f1659d;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.05em;
}
@media print, screen and (min-width: 769px) {
  .job-schedule-heading {
    font-size: 18px;
    margin-top: 1em;
  }
}

.job-schedule-row {
  margin-top: 40px;
}
.job-schedule-row__col:last-child .job-schedule-item:last-child:before {
  display: none;
}

@media print, screen and (min-width: 769px) {
  .job-schedule-row {
    display: flex;
    justify-content: space-between;
    margin: 24px 0 40px;
  }
  .job-schedule-row__col {
    width: calc(50% - 40px);
  }
}
.job-schedule-item {
  display: flex;
  padding-bottom: 30px;
  position: relative;
}
.job-schedule-item:last-child {
  padding-bottom: 0;
}
.job-schedule-item:before {
  content: "";
  border-left: 2px dotted rgba(241, 101, 157, 0.5);
  width: 1px;
  height: calc(100% - 40px);
  position: absolute;
  top: 30px;
  left: 1.5em;
}
.job-schedule-item > dt {
  width: 4em;
  color: #f1659d;
  font-weight: 600;
}
.job-schedule-item > dd {
  flex: 1;
}
.job-schedule-item > dd .ttl {
  font-weight: 500;
  margin-bottom: 0.5em;
}

@media print, screen and (min-width: 769px) {
  .job-schedule-item {
    padding-bottom: 40px;
  }
  .job-schedule-item:before {
    height: calc(100% - 50px);
    top: 40px;
  }
  .job-schedule-item > dt {
    width: 4em;
    font-size: 20px;
  }
  .job-schedule-item > dd .ttl {
    font-size: 18px;
  }
}
.job-schedule-section--caremanager {
  background: #f9efff;
}
.job-schedule-section--caremanager:before {
  color: #f9efff;
}
.job-schedule-section--caremanager .job-schedule-heading {
  color: #9e51cb;
}
.job-schedule-section--caremanager .job-schedule-item:before {
  border-left-color: rgba(158, 81, 203, 0.5);
}
.job-schedule-section--caremanager .job-schedule-item > dt {
  color: #9e51cb;
}

.job-schedule-section--nurse {
  background: #fff6e5;
}
.job-schedule-section--nurse:before {
  color: #fff6e5;
}
.job-schedule-section--nurse .job-schedule-heading {
  color: #e6ad3b;
}
.job-schedule-section--nurse .job-schedule-item:before {
  border-left-color: rgba(230, 173, 59, 0.5);
}
.job-schedule-section--nurse .job-schedule-item > dt {
  color: #e6ad3b;
}

.job-schedule-section--caregiver {
  background: #f2fcfe;
}
.job-schedule-section--caregiver:before {
  color: #f2fcfe;
}
.job-schedule-section--caregiver .job-schedule-heading {
  color: #1b9cd5;
}
.job-schedule-section--caregiver .job-schedule-item:before {
  border-left-color: rgba(27, 156, 213, 0.5);
}
.job-schedule-section--caregiver .job-schedule-item > dt {
  color: #1b9cd5;
}

.job-schedule-section--new-caregiver {
  background: #e8f8fa;
}
.job-schedule-section--new-caregiver:before {
  color: #e8f8fa;
}
.job-schedule-section--new-caregiver .job-schedule-heading {
  color: #1dbcce;
}
.job-schedule-section--new-caregiver .job-schedule-item:before {
  border-left-color: rgba(29, 188, 206, 0.5);
}
.job-schedule-section--new-caregiver .job-schedule-item > dt {
  color: #1dbcce;
}

/*===================================================

 教育環境・福利厚生

===================================================*/
.training-unit:not(:last-child) {
  margin-bottom: 24px;
}
.training-unit > dt {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 16px;
  font-weight: 700;
}
.training-unit > dd {
  margin-top: 1em;
}
@media print, screen and (min-width: 769px) {
  .training-unit:not(:last-child) {
    margin-bottom: 40px;
  }
  .training-unit > dt {
    font-size: 20px;
  }
  .training-unit__icon {
    font-size: 36px;
  }
}
.education-list > li {
  padding: 0 16px;
  margin-bottom: 48px;
}
.education-list > li:last-child {
  margin-bottom: 0;
}

@media print, screen and (min-width: 769px) {
  .education-list {
    display: flex;
    margin: 0 -24px;
  }
  .education-list > li {
    flex: 1;
    padding: 0 24px;
  }
}
.education-card__img {
  width: 60%;
  max-width: 200px;
  margin: auto;
}
.education-card__ttl {
  font-size: 16px;
  font-weight: 700;
  margin-top: 1em;
  text-align: center;
}
.education-card__txt {
  margin-top: 0.5em;
}

@media print, screen and (min-width: 769px) {
  .education-card__img {
    width: auto;
    max-width: 100%;
  }
  .education-card__ttl {
    font-size: 20px;
    margin-top: 1.5em;
  }
  .education-card__txt {
    margin-top: 0.5em;
  }
}
.benefit-list > li {
  margin-bottom: 16px;
}

@media print, screen and (min-width: 769px) {
  .benefit-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .benefit-list > li {
    width: calc(50% - 24px);
    margin-bottom: 48px;
    display: flex;
  }
}
.benefit-box {
  background: #fff;
  border: 2px solid #ee89b2;
  border-radius: 8px;
  padding: 24px;
}
.benefit-box__ttl {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  color: #f1659d;
  line-height: 1.2;
}
.benefit-box__txt {
  margin-top: 1em;
}

@media print, screen and (min-width: 769px) {
  .benefit-box {
    padding: 40px;
  }
  .benefit-box__ttl {
    font-size: 20px;
  }
}
/*===================================================

 採用情報

===================================================*/
.recruit-wrapper {
  margin: 32px auto 0;
}
@media print, screen and (max-width: 768px) {
  .recruit-wrapper {
    max-width: 880px;
  }
}
.recruit-wrapper .recruit-item {
  background: #fff;
  box-shadow: 0 4px 0 0 rgba(241, 101, 157, 0.2);
  margin-bottom: 24px;
  border-radius: 8px;
}
.recruit-wrapper .recruit-item__header {
  display: flex;
  align-items: center;
  padding: 16px 36px 16px 16px;
  cursor: pointer;
  position: relative;
  min-height: 72px;
}
.recruit-wrapper .recruit-item__header:before {
  content: "\e145";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 16px;
  color: #f1659d;
  font-size: 24px;
}
.recruit-wrapper .recruit-item__header[aria-expanded=true]:before {
  content: "\e15b";
}
.recruit-wrapper .recruit-item__body {
  transition: padding 0.2s;
}
.recruit-wrapper .recruit-item[aria-hidden=true] .recruit-item__body {
  visibility: hidden;
  opacity: 0;
  height: 0;
  padding: 0 16px;
}
.recruit-wrapper .recruit-item[aria-hidden=false] .recruit-item__body {
  visibility: visible;
  opacity: 1;
  height: auto;
  padding: 8px 16px 24px;
}
.recruit-wrapper .recruit-item .recruit-ttl {
  font-weight: 700;
  font-size: 17px;
  line-height: 1.4;
}
.recruit-wrapper .recruit-item .recruit-ttl .balloon {
  display: block;
  background: #f1659d;
  color: #fff;
  font-size: 10px;
  font-weight: 500;
  line-height: 1;
  padding: 0.5em 1em;
  border-radius: 40px;
  position: relative;
  position: absolute;
  top: -14px;
  left: 16px;
}
.recruit-wrapper .recruit-item .recruit-ttl .balloon:before {
  content: "";
  border-style: solid;
  border-width: 4px 4px 0;
  border-color: #f1659d transparent transparent;
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -2px;
}
.recruit-wrapper .recruit-entry-btn {
  margin-top: 24px;
}

@media print, screen and (min-width: 769px) {
  .recruit-wrapper {
    margin-top: 40px;
  }
  .recruit-wrapper .recruit-item {
    margin-bottom: 40px;
  }
  .recruit-wrapper .recruit-item__header {
    padding: 36px 80px 36px 40px;
  }
  .recruit-wrapper .recruit-item__header:before {
    right: 20px;
    font-size: 40px;
  }
  .recruit-wrapper .recruit-item[aria-hidden=true] .recruit-item__body {
    padding: 0 40px;
  }
  .recruit-wrapper .recruit-item[aria-hidden=false] .recruit-item__body {
    padding: 16px 40px 64px;
  }
  .recruit-wrapper .recruit-item .recruit-ttl {
    font-size: 24px;
  }
  .recruit-wrapper .recruit-item .recruit-ttl .balloon {
    font-size: 14px;
    top: -16px;
    left: 40px;
  }
  .recruit-wrapper .recruit-item .recruit-ttl .balloon:before {
    border-width: 6px 6px 0;
    margin-left: -3px;
  }
  .recruit-wrapper .recruit-entry-btn {
    margin-top: 48px;
  }
  .recruit-wrapper .recruit-entry-btn .btn-cv {
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
    font-size: 20px;
    min-height: 72px;
  }
}
.recruit-table {
  width: 100%;
  font-family: "Noto Sans JP", sans-serif;
}
.recruit-table td,
.recruit-table th {
  padding: 0.8em;
  border: 1px solid #ddd;
}
.recruit-table th {
  font-size: 12px;
  width: 6em;
  background: #f7f7f7;
}

@media print, screen and (max-width: 768px) {
  .recruit-table tr {
    display: block;
  }
  .recruit-table th {
    display: block;
    width: 100%;
    border: none;
    padding: 5px 10px;
    line-height: 1.4;
  }
  .recruit-table td {
    display: block;
    width: 100%;
    border: none;
    padding: 10px 0 20px 5px;
  }
}
@media print, screen and (min-width: 769px) {
  .recruit-table td,
  .recruit-table th {
    padding: 1em;
  }
  .recruit-table th {
    font-size: 1em;
    width: 8em;
  }
}
.recruit-flow-list > li:last-child .recruit-flow-card:before {
  display: none;
}

@media print, screen and (min-width: 769px) {
  .recruit-flow-list {
    display: flex;
  }
  .recruit-flow-list > li {
    width: 33.3333%;
  }
}
.recruit-flow-card {
  display: flex;
  position: relative;
  padding: 20px 0;
}
.recruit-flow-card:before {
  content: "";
  background: #e5f7ff;
  width: 4px;
  height: 100%;
  position: absolute;
  top: 20px;
  left: 43px;
}
.recruit-flow-card__img {
  width: 90px;
  display: flex;
}
.recruit-flow-card__icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: #e5f7ff;
  color: #1b9cd5;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
}
.recruit-flow-card__txt {
  flex: 1;
  padding-left: 24px;
  align-self: center;
}

@media print, screen and (min-width: 769px) {
  .recruit-flow-card {
    flex-direction: column;
    align-items: center;
    padding: 0;
  }
  .recruit-flow-card:before {
    width: 100%;
    height: 6px;
    top: 77px;
    left: 50%;
  }
  .recruit-flow-card__img {
    width: 160px;
  }
  .recruit-flow-card__icon {
    width: 160px;
    height: 160px;
    font-size: 18px;
  }
  .recruit-flow-card__txt {
    flex: 1;
    padding: 20px 30px 0;
  }
}
.kengaku-box {
  border: 2px solid #ee89b2;
  text-align: center;
  padding: 24px;
  margin-top: 24px;
}
.kengaku-box__ttl {
  font-size: 16px;
  margin-bottom: 1em;
}
.kengaku-box__btn {
  margin-top: 24px;
}

@media print, screen and (min-width: 769px) {
  .kengaku-box {
    padding: 48px;
    margin-top: 48px;
  }
  .kengaku-box__ttl {
    font-size: 20px;
  }
  .kengaku-box__btn {
    margin-top: 24px;
  }
  .kengaku-box__btn a {
    max-width: 360px;
    margin: auto;
  }
}
.contact-box {
  text-align: center;
}
.contact-box__col {
  position: relative;
  margin-bottom: 24px;
}
.contact-box__col h3 {
  margin-bottom: 0.5em;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
}
@media print, screen and (max-width: 768px) {
  .contact-box__col:last-child {
    padding-top: 24px;
  }
  .contact-box__col:last-child:before {
    content: "";
    display: block;
    width: 60px;
    height: 1px;
    background: #f1659d;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
.contact-box__tel {
  font-size: 28px;
  line-height: 1;
}
.contact-box__tel a {
  color: #f1659d;
}
.contact-box__btn {
  margin: 16px 16px 0;
}

@media print, screen and (min-width: 769px) {
  .contact-box {
    display: flex;
  }
  .contact-box__col {
    flex: 1;
    padding: 16px 48px;
    margin: 0;
  }
  .contact-box__col h3 {
    font-size: 20px;
    margin-bottom: 1em;
  }
  .contact-box__col:last-child {
    border-left: 1px solid #f1659d;
  }
  .contact-box__tel {
    font-size: 36px;
  }
  .contact-box__btn {
    margin: 24px auto 0;
    text-align: center;
  }
  .contact-box__btn a {
    max-width: 360px;
    margin: auto;
  }
}
/*===================================================

 個人情報保護方針

===================================================*/
.privacy-wrapper p {
  margin-bottom: 2em;
}

/*===================================================

 snippet

===================================================*/
.is-hide {
  display: none !important;
}

/*
 PC/SP出し分け
---------------------------------------------------*/
@media print, screen and (max-width: 768px) {
  .sp-hide {
    display: none !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-hide {
    display: none !important;
  }
}
/*
 font
---------------------------------------------------*/
.mincho {
  font-family: "Times New Roman", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

@media print, screen and (max-width: 768px) {
  .sp-mincho {
    font-family: "Times New Roman", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-mincho {
    font-family: "Times New Roman", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  }
}
/*
 幅 width
---------------------------------------------------*/
.width--a {
  width: auto;
}

.width--100px {
  width: 100px;
}

.width--160px {
  width: 160px;
}

.width--240px {
  width: 240px;
}

.width--320px {
  width: 320px;
}

.width--400px {
  width: 400px;
}

.width--480px {
  width: 400px;
}

.width--560px {
  width: 400px;
}

.width--640px {
  width: 400px;
}

.width--720px {
  width: 400px;
}

.width--10p {
  width: 10%;
}

.width--20p {
  width: 20%;
}

.width--25p {
  width: 25%;
}

.width--33p {
  width: 33.3333%;
}

.width--30p {
  width: 30%;
}

.width--40p {
  width: 40%;
}

.width--50p {
  width: 50%;
}

.width--60p {
  width: 60%;
}

.width--70p {
  width: 70%;
}

.width--75p {
  width: 75%;
}

.width--80p {
  width: 80%;
}

.width--90p {
  width: 90%;
}

.width--100p {
  width: 100% !important;
}

.width--1em {
  width: 1em;
}

.width--2em {
  width: 2em;
}

.width--3em {
  width: 3em;
}

.width--4em {
  width: 4em;
}

.width--5em {
  width: 5em;
}

@media print, screen and (max-width: 768px) {
  .sp-width--a {
    width: auto;
  }
  .sp-width--100px {
    width: 100px;
  }
  .sp-width--160px {
    width: 160px;
  }
  .sp-width--240px {
    width: 240px;
  }
  .sp-width--320px {
    width: 320px;
  }
  .sp-width--10p {
    width: 10%;
  }
  .sp-width--20p {
    width: 20%;
  }
  .sp-width--25p {
    width: 25%;
  }
  .sp-width--33p {
    width: 33.3333%;
  }
  .sp-width--30p {
    width: 30%;
  }
  .sp-width--40p {
    width: 40%;
  }
  .sp-width--50p {
    width: 50%;
  }
  .sp-width--60p {
    width: 60%;
  }
  .sp-width--70p {
    width: 70%;
  }
  .sp-width--75p {
    width: 75%;
  }
  .sp-width--80p {
    width: 80%;
  }
  .sp-width--90p {
    width: 90%;
  }
  .sp-width--100p {
    width: 100% !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-width--a {
    width: auto;
  }
  .pc-width--100px {
    width: 100px;
  }
  .pc-width--160px {
    width: 160px;
  }
  .pc-width--240px {
    width: 240px;
  }
  .pc-width--320px {
    width: 320px;
  }
  .pc-width--400px {
    width: 400px;
  }
  .pc-width--480px {
    width: 400px;
  }
  .pc-width--560px {
    width: 400px;
  }
  .pc-width--640px {
    width: 400px;
  }
  .pc-width--720px {
    width: 400px;
  }
  .pc-width--10p {
    width: 10%;
  }
  .pc-width--20p {
    width: 20%;
  }
  .pc-width--25p {
    width: 25%;
  }
  .pc-width--30p {
    width: 30%;
  }
  .pc-width--33p {
    width: 33.3333%;
  }
  .pc-width--40p {
    width: 40%;
  }
  .pc-width--50p {
    width: 50%;
  }
  .pc-width--60p {
    width: 60%;
  }
  .pc-width--70p {
    width: 70%;
  }
  .pc-width--75p {
    width: 75%;
  }
  .pc-width--80p {
    width: 80%;
  }
  .pc-width--90p {
    width: 90%;
  }
  .pc-width--100p {
    width: 100% !important;
  }
  .pc-width--m {
    width: 848px;
  }
}
/*
 寄せ aligh
---------------------------------------------------*/
.align--c {
  text-align: center !important;
}

@media print, screen and (min-width: 769px) {
  .pc-align--c {
    text-align: center !important;
  }
}
@media print, screen and (max-width: 768px) {
  .sp-align--c {
    text-align: center !important;
  }
}
.align--l {
  text-align: left !important;
}

@media print, screen and (min-width: 769px) {
  .pc-align--l {
    text-align: left !important;
  }
}
@media print, screen and (max-width: 768px) {
  .sp-align--l {
    text-align: left !important;
  }
}
.align--r {
  text-align: right !important;
}

@media print, screen and (min-width: 769px) {
  .pc-align--r {
    text-align: right !important;
  }
}
@media print, screen and (max-width: 768px) {
  .sp-align--r {
    text-align: right !important;
  }
}
/*
 余白
---------------------------------------------------*/
@media print, screen and (max-width: 768px) {
  .sp-m-minus {
    margin-left: -16px;
    margin-right: -16px;
  }
}
.m--a {
  margin: auto;
}

.mt--a {
  margin-top: auto;
}

.ml--a {
  margin-left: auto;
}

.mr--a {
  margin-right: auto;
}

.mb--a {
  margin-bottom: auto;
}

.mlr--a {
  margin-left: auto;
  margin-right: auto;
}

@media print, screen and (max-width: 768px) {
  .sp-m--a {
    margin: auto;
  }
  .sp-mt--a {
    margin-top: auto;
  }
  .sp-ml--a {
    margin-left: auto;
  }
  .sp-mr--a {
    margin-right: auto;
  }
  .sp-mb--a {
    margin-bottom: auto;
  }
  .sp-mlr--a {
    margin-left: auto;
    margin-right: auto;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-m--a {
    margin: auto;
  }
  .pc-mt--a {
    margin-top: auto;
  }
  .pc-ml--a {
    margin-left: auto;
  }
  .pc-mr--a {
    margin-right: auto;
  }
  .pc-mb--a {
    margin-bottom: auto;
  }
  .pc-mlr--a {
    margin-left: auto;
    margin-right: auto;
  }
}
.mt--0px {
  margin-top: 0 !important;
}

.mt--4px {
  margin-top: 4px !important;
}

.mt--8px {
  margin-top: 8px !important;
}

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

.mt--16px {
  margin-top: 16px !important;
}

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

.mt--24px {
  margin-top: 24px !important;
}

.mt--28px {
  margin-top: 28px !important;
}

.mt--32px {
  margin-top: 32px !important;
}

.mt--36px {
  margin-top: 36px !important;
}

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

.mt--48px {
  margin-top: 48px !important;
}

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

.mt--64px {
  margin-top: 64px !important;
}

.mt--72px {
  margin-top: 72px !important;
}

.mt--0-5em {
  margin-top: 0.5em !important;
}

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

.mt--1-5em {
  margin-top: 1.5em !important;
}

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

.mt--2-5em {
  margin-top: 2.5em !important;
}

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

@media print, screen and (max-width: 768px) {
  .sp-mt--0px {
    margin-top: 0 !important;
  }
  .sp-mt--4px {
    margin-top: 4px !important;
  }
  .sp-mt--8px {
    margin-top: 8px !important;
  }
  .sp-mt--12px {
    margin-top: 12px !important;
  }
  .sp-mt--16px {
    margin-top: 16px !important;
  }
  .sp-mt--20px {
    margin-top: 20px !important;
  }
  .sp-mt--24px {
    margin-top: 24px !important;
  }
  .sp-mt--28px {
    margin-top: 28px !important;
  }
  .sp-mt--32px {
    margin-top: 32px !important;
  }
  .sp-mt--36px {
    margin-top: 36px !important;
  }
  .sp-mt--40px {
    margin-top: 40px !important;
  }
  .sp-mt--48px {
    margin-top: 48px !important;
  }
  .sp-mt--56px {
    margin-top: 12px !important;
  }
  .sp-mt--64px {
    margin-top: 64px !important;
  }
  .sp-mt--72px {
    margin-top: 72px !important;
  }
  .sp-mt--0-5em {
    margin-top: 0.5em !important;
  }
  .sp-mt--1em {
    margin-top: 1em !important;
  }
  .sp-mt--1-5em {
    margin-top: 1.5em !important;
  }
  .sp-mt--2em {
    margin-top: 2em !important;
  }
  .sp-mt--2-5em {
    margin-top: 2.5em !important;
  }
  .sp-mt--3em {
    margin-top: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-mt--0px {
    margin-top: 0 !important;
  }
  .pc-mt--4px {
    margin-top: 4px !important;
  }
  .pc-mt--8px {
    margin-top: 8px !important;
  }
  .pc-mt--12px {
    margin-top: 12px !important;
  }
  .pc-mt--16px {
    margin-top: 16px !important;
  }
  .pc-mt--20px {
    margin-top: 20px !important;
  }
  .pc-mt--24px {
    margin-top: 24px !important;
  }
  .pc-mt--28px {
    margin-top: 28px !important;
  }
  .pc-mt--32px {
    margin-top: 32px !important;
  }
  .pc-mt--36px {
    margin-top: 36px !important;
  }
  .pc-mt--40px {
    margin-top: 40px !important;
  }
  .pc-mt--48px {
    margin-top: 48px !important;
  }
  .pc-mt--56px {
    margin-top: 56px !important;
  }
  .pc-mt--64px {
    margin-top: 64px !important;
  }
  .pc-mt--72px {
    margin-top: 72px !important;
  }
  .pc-mt--80px {
    margin-top: 80px !important;
  }
  .pc-mt--100px {
    margin-top: 100px !important;
  }
  .pc-mt--0-5em {
    margin-top: 0.5em !important;
  }
  .pc-mt--1em {
    margin-top: 1em !important;
  }
  .pc-mt--1-5em {
    margin-top: 1.5em !important;
  }
  .pc-mt--2em {
    margin-top: 2em !important;
  }
  .pc-mt--2-5em {
    margin-top: 2.5em !important;
  }
  .pc-mt--3em {
    margin-top: 3em !important;
  }
}
.ml--0px {
  margin-left: 0 !important;
}

.ml--4px {
  margin-left: 4px !important;
}

.ml--8px {
  margin-left: 8px !important;
}

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

.ml--16px {
  margin-left: 16px !important;
}

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

.ml--24px {
  margin-left: 24px !important;
}

.ml--28px {
  margin-left: 28px !important;
}

.ml--32px {
  margin-left: 32px !important;
}

.ml--36px {
  margin-left: 36px !important;
}

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

.ml--48px {
  margin-left: 48px !important;
}

.ml--56px {
  margin-left: 56px !important;
}

.ml--64px {
  margin-left: 64px !important;
}

.ml--72px {
  margin-left: 72px !important;
}

.ml--0-5em {
  margin-left: 0.5em !important;
}

.ml--1em {
  margin-left: 1em !important;
}

.ml--1-5em {
  margin-left: 1.5em !important;
}

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

.ml--2-5em {
  margin-left: 2.5em !important;
}

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

@media print, screen and (max-width: 768px) {
  .sp-ml--0px {
    margin-left: 0 !important;
  }
  .sp-ml--4px {
    margin-left: 4px !important;
  }
  .sp-ml--8px {
    margin-left: 8px !important;
  }
  .sp-ml--12px {
    margin-left: 12px !important;
  }
  .sp-ml--16px {
    margin-left: 16px !important;
  }
  .sp-ml--20px {
    margin-left: 20px !important;
  }
  .sp-ml--24px {
    margin-left: 24px !important;
  }
  .sp-ml--28px {
    margin-left: 28px !important;
  }
  .sp-ml--32px {
    margin-left: 32px !important;
  }
  .sp-ml--36px {
    margin-left: 36px !important;
  }
  .sp-ml--40px {
    margin-left: 40px !important;
  }
  .sp-ml--48px {
    margin-left: 48px !important;
  }
  .sp-ml--56px {
    margin-left: 56px !important;
  }
  .sp-ml--64px {
    margin-left: 64px !important;
  }
  .sp-ml--72px {
    margin-left: 72px !important;
  }
  .sp-ml--0-5em {
    margin-left: 0.5em !important;
  }
  .sp-ml--1em {
    margin-left: 1em !important;
  }
  .sp-ml--1-5em {
    margin-left: 1.5em !important;
  }
  .sp-ml--2em {
    margin-left: 2em !important;
  }
  .sp-ml--2-5em {
    margin-left: 2.5em !important;
  }
  .sp-ml--3em {
    margin-left: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-ml--0px {
    margin-left: 0 !important;
  }
  .pc-ml--4px {
    margin-left: 4px !important;
  }
  .pc-ml--8px {
    margin-left: 8px !important;
  }
  .pc-ml--12px {
    margin-left: 12px !important;
  }
  .pc-ml--16px {
    margin-left: 16px !important;
  }
  .pc-ml--20px {
    margin-left: 20px !important;
  }
  .pc-ml--24px {
    margin-left: 24px !important;
  }
  .pc-ml--28px {
    margin-left: 28px !important;
  }
  .pc-ml--32px {
    margin-left: 32px !important;
  }
  .pc-ml--36px {
    margin-left: 36px !important;
  }
  .pc-ml--40px {
    margin-left: 40px !important;
  }
  .pc-ml--48px {
    margin-left: 48px !important;
  }
  .pc-ml--56px {
    margin-left: 56px !important;
  }
  .pc-ml--64px {
    margin-left: 64px !important;
  }
  .pc-ml--72px {
    margin-left: 72px !important;
  }
  .pc-ml--80px {
    margin-left: 80px !important;
  }
  .pc-ml--100px {
    margin-left: 100px !important;
  }
  .pc-ml--0-5em {
    margin-left: 0.5em !important;
  }
  .pc-ml--1em {
    margin-left: 1em !important;
  }
  .pc-ml--1-5em {
    margin-left: 1.5em !important;
  }
  .pc-ml--2em {
    margin-left: 2em !important;
  }
  .pc-ml--2-5em {
    margin-left: 2.5em !important;
  }
  .pc-ml--3em {
    margin-left: 3em !important;
  }
}
.mr--0px {
  margin-right: 0 !important;
}

.mr--4px {
  margin-right: 4px !important;
}

.mr--8px {
  margin-right: 8px !important;
}

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

.mr--16px {
  margin-right: 16px !important;
}

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

.mr--24px {
  margin-right: 24px !important;
}

.mr--28px {
  margin-right: 28px !important;
}

.mr--32px {
  margin-right: 32px !important;
}

.mr--36px {
  margin-right: 36px !important;
}

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

.mr--48px {
  margin-right: 48px !important;
}

.mr--56px {
  margin-right: 56px !important;
}

.mr--64px {
  margin-right: 64px !important;
}

.mr--72px {
  margin-right: 72px !important;
}

.mr--0-5em {
  margin-right: 0.5em !important;
}

.mr--1em {
  margin-right: 1em !important;
}

.mr--1-5em {
  margin-right: 1.5em !important;
}

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

.mr--2-5em {
  margin-right: 2.5em !important;
}

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

@media print, screen and (max-width: 768px) {
  .sp-mr--0px {
    margin-right: 0 !important;
  }
  .sp-mr--4px {
    margin-right: 4px !important;
  }
  .sp-mr--8px {
    margin-right: 8px !important;
  }
  .sp-mr--12px {
    margin-right: 12px !important;
  }
  .sp-mr--16px {
    margin-right: 16px !important;
  }
  .sp-mr--20px {
    margin-right: 20px !important;
  }
  .sp-mr--24px {
    margin-right: 24px !important;
  }
  .sp-mr--28px {
    margin-right: 28px !important;
  }
  .sp-mr--32px {
    margin-right: 32px !important;
  }
  .sp-mr--36px {
    margin-right: 36px !important;
  }
  .sp-mr--40px {
    margin-right: 40px !important;
  }
  .sp-mr--48px {
    margin-right: 48px !important;
  }
  .sp-mr--56px {
    margin-right: 56px !important;
  }
  .sp-mr--64px {
    margin-right: 64px !important;
  }
  .sp-mr--72px {
    margin-right: 72px !important;
  }
  .sp-mr--0-5em {
    margin-right: 0.5em !important;
  }
  .sp-mr--1em {
    margin-right: 1em !important;
  }
  .sp-mr--1-5em {
    margin-right: 1.5em !important;
  }
  .sp-mr--2em {
    margin-right: 2em !important;
  }
  .sp-mr--2-5em {
    margin-right: 2.5em !important;
  }
  .sp-mr--3em {
    margin-right: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-mr--0px {
    margin-right: 0 !important;
  }
  .pc-mr--4px {
    margin-right: 4px !important;
  }
  .pc-mr--8px {
    margin-right: 8px !important;
  }
  .pc-mr--12px {
    margin-right: 12px !important;
  }
  .pc-mr--16px {
    margin-right: 16px !important;
  }
  .pc-mr--20px {
    margin-right: 20px !important;
  }
  .pc-mr--24px {
    margin-right: 24px !important;
  }
  .pc-mr--28px {
    margin-right: 28px !important;
  }
  .pc-mr--32px {
    margin-right: 32px !important;
  }
  .pc-mr--36px {
    margin-right: 36px !important;
  }
  .pc-mr--40px {
    margin-right: 40px !important;
  }
  .pc-mr--48px {
    margin-right: 48px !important;
  }
  .pc-mr--56px {
    margin-right: 56px !important;
  }
  .pc-mr--64px {
    margin-right: 64px !important;
  }
  .pc-mr--72px {
    margin-right: 72px !important;
  }
  .pc-mr--80px {
    margin-right: 80px !important;
  }
  .pc-mr--100px {
    margin-right: 100px !important;
  }
  .pc-mr--0-5em {
    margin-right: 0.5em !important;
  }
  .pc-mr--1em {
    margin-right: 1em !important;
  }
  .pc-mr--1-5em {
    margin-right: 1.5em !important;
  }
  .pc-mr--2em {
    margin-right: 2em !important;
  }
  .pc-mr--2-5em {
    margin-right: 2.5em !important;
  }
  .pc-mr--3em {
    margin-right: 3em !important;
  }
}
.mb--0px {
  margin-bottom: 0 !important;
}

.mb--4px {
  margin-bottom: 4px !important;
}

.mb--8px {
  margin-bottom: 8px !important;
}

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

.mb--16px {
  margin-bottom: 16px !important;
}

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

.mb--24px {
  margin-bottom: 24px !important;
}

.mb--28px {
  margin-bottom: 28px !important;
}

.mb--32px {
  margin-bottom: 32px !important;
}

.mb--36px {
  margin-bottom: 36px !important;
}

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

.mb--48px {
  margin-bottom: 48px !important;
}

.mb--56px {
  margin-bottom: 56px !important;
}

.mb--64px {
  margin-bottom: 64px !important;
}

.mb--72px {
  margin-bottom: 72px !important;
}

.mb--0-5em {
  margin-bottom: 0.5em !important;
}

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

.mb--1-5em {
  margin-bottom: 1.5em !important;
}

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

.mb--2-5em {
  margin-bottom: 2.5em !important;
}

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

@media print, screen and (max-width: 768px) {
  .sp-mb--0px {
    margin-bottom: 0 !important;
  }
  .sp-mb--4px {
    margin-bottom: 4px !important;
  }
  .sp-mb--8px {
    margin-bottom: 8px !important;
  }
  .sp-mb--12px {
    margin-bottom: 12px !important;
  }
  .sp-mb--16px {
    margin-bottom: 16px !important;
  }
  .sp-mb--20px {
    margin-bottom: 20px !important;
  }
  .sp-mb--24px {
    margin-bottom: 24px !important;
  }
  .sp-mb--28px {
    margin-bottom: 28px !important;
  }
  .sp-mb--32px {
    margin-bottom: 32px !important;
  }
  .sp-mb--36px {
    margin-bottom: 36px !important;
  }
  .sp-mb--40px {
    margin-bottom: 40px !important;
  }
  .sp-mb--48px {
    margin-bottom: 48px !important;
  }
  .sp-mb--56px {
    margin-bottom: 56px !important;
  }
  .sp-mb--64px {
    margin-bottom: 64px !important;
  }
  .sp-mb--72px {
    margin-bottom: 72px !important;
  }
  .sp-mb--0-5em {
    margin-bottom: 0.5em !important;
  }
  .sp-mb--1em {
    margin-bottom: 1em !important;
  }
  .sp-mb--1-5em {
    margin-bottom: 1.5em !important;
  }
  .sp-mb--2em {
    margin-bottom: 2em !important;
  }
  .sp-mb--2-5em {
    margin-bottom: 2.5em !important;
  }
  .sp-mb--3em {
    margin-bottom: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-mb--0px {
    margin-bottom: 0 !important;
  }
  .pc-mb--4px {
    margin-bottom: 4px !important;
  }
  .pc-mb--8px {
    margin-bottom: 8px !important;
  }
  .pc-mb--12px {
    margin-bottom: 12px !important;
  }
  .pc-mb--16px {
    margin-bottom: 16px !important;
  }
  .pc-mb--20px {
    margin-bottom: 20px !important;
  }
  .pc-mb--24px {
    margin-bottom: 24px !important;
  }
  .pc-mb--28px {
    margin-bottom: 28px !important;
  }
  .pc-mb--32px {
    margin-bottom: 32px !important;
  }
  .pc-mb--36px {
    margin-bottom: 36px !important;
  }
  .pc-mb--40px {
    margin-bottom: 40px !important;
  }
  .pc-mb--48px {
    margin-bottom: 48px !important;
  }
  .pc-mb--56px {
    margin-bottom: 56px !important;
  }
  .pc-mb--64px {
    margin-bottom: 64px !important;
  }
  .pc-mb--72px {
    margin-bottom: 72px !important;
  }
  .pc-mb--80px {
    margin-bottom: 80px !important;
  }
  .pc-mb--100px {
    margin-bottom: 100px !important;
  }
  .pc-mb--0-5em {
    margin-bottom: 0.5em !important;
  }
  .pc-mb--1em {
    margin-bottom: 1em !important;
  }
  .pc-mb--1-5em {
    margin-bottom: 1.5em !important;
  }
  .pc-mb--2em {
    margin-bottom: 2em !important;
  }
  .pc-mb--2-5em {
    margin-bottom: 2.5em !important;
  }
  .pc-mb--3em {
    margin-bottom: 3em !important;
  }
}
.p--0px {
  padding: 0 !important;
}

.p--4px {
  padding: 4px !important;
}

.p--8px {
  padding: 8px !important;
}

.p--12px {
  padding: 12px !important;
}

.p--16px {
  padding: 16px !important;
}

.p--20px {
  padding: 20px !important;
}

.p--24px {
  padding: 24px !important;
}

.p--28px {
  padding: 28px !important;
}

.p--32px {
  padding: 32px !important;
}

.p--36px {
  padding: 36px !important;
}

.p--40px {
  padding: 40px !important;
}

.p--48px {
  padding: 48px !important;
}

.p--56px {
  padding: 56px !important;
}

.p--64px {
  padding: 64px !important;
}

.p--72px {
  padding: 72px !important;
}

.p--0-5em {
  padding: 0.5em !important;
}

.p--1em {
  padding: 1em !important;
}

.p--1-5em {
  padding: 1.5em !important;
}

.p--2em {
  padding: 2em !important;
}

.p--2-5em {
  padding: 2.5em !important;
}

.p--3em {
  padding: 3em !important;
}

@media print, screen and (max-width: 768px) {
  .sp-p--0px {
    padding: 0 !important;
  }
  .sp-p--4px {
    padding: 4px !important;
  }
  .sp-p--8px {
    padding: 8px !important;
  }
  .sp-p--12px {
    padding: 12px !important;
  }
  .sp-p--16px {
    padding: 16px !important;
  }
  .sp-p--20px {
    padding: 20px !important;
  }
  .sp-p--24px {
    padding: 24px !important;
  }
  .sp-p--28px {
    padding: 28px !important;
  }
  .sp-p--32px {
    padding: 32px !important;
  }
  .sp-p--36px {
    padding: 36px !important;
  }
  .sp-p--40px {
    padding: 40px !important;
  }
  .sp-p--48px {
    padding: 48px !important;
  }
  .sp-p--56px {
    padding: 56px !important;
  }
  .sp-p--64px {
    padding: 64px !important;
  }
  .sp-p--72px {
    padding: 72px !important;
  }
  .sp-p--0-5em {
    padding: 0.5em !important;
  }
  .sp-p--1em {
    padding: 1em !important;
  }
  .sp-p--1-5em {
    padding: 1.5em !important;
  }
  .sp-p--2em {
    padding: 2em !important;
  }
  .sp-p--2-5em {
    padding: 2.5em !important;
  }
  .sp-p--3em {
    padding: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-p--0px {
    padding: 0 !important;
  }
  .pc-p--4px {
    padding: 4px !important;
  }
  .pc-p--8px {
    padding: 8px !important;
  }
  .pc-p--12px {
    padding: 12px !important;
  }
  .pc-p--16px {
    padding: 16px !important;
  }
  .pc-p--20px {
    padding: 20px !important;
  }
  .pc-p--24px {
    padding: 24px !important;
  }
  .pc-p--28px {
    padding: 28px !important;
  }
  .pc-p--32px {
    padding: 32px !important;
  }
  .pc-p--36px {
    padding: 36px !important;
  }
  .pc-p--40px {
    padding: 40px !important;
  }
  .pc-p--48px {
    padding: 48px !important;
  }
  .pc-p--56px {
    padding: 56px !important;
  }
  .pc-p--64px {
    padding: 64px !important;
  }
  .pc-p--72px {
    padding: 72px !important;
  }
  .pc-p--80px {
    padding: 80px !important;
  }
  .pc-p--100px {
    padding: 100px !important;
  }
  .pc-p--0-5em {
    padding: 0.5em !important;
  }
  .pc-p--1em {
    padding: 1em !important;
  }
  .pc-p--1-5em {
    padding: 1.5em !important;
  }
  .pc-p--2em {
    padding: 2em !important;
  }
  .pc-p--2-5em {
    padding: 2.5em !important;
  }
  .pc-p--3em {
    padding: 3em !important;
  }
}
.pt--0px {
  padding-top: 0 !important;
}

.pt--4px {
  padding-top: 4px !important;
}

.pt--8px {
  padding-top: 8px !important;
}

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

.pt--16px {
  padding-top: 16px !important;
}

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

.pt--24px {
  padding-top: 24px !important;
}

.pt--28px {
  padding-top: 28px !important;
}

.pt--32px {
  padding-top: 32px !important;
}

.pt--36px {
  padding-top: 36px !important;
}

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

.pt--48px {
  padding-top: 48px !important;
}

.pt--56px {
  padding-top: 56px !important;
}

.pt--64px {
  padding-top: 64px !important;
}

.pt--72px {
  padding-top: 72px !important;
}

.pt--0-5em {
  padding-top: 0.5em !important;
}

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

.pt--1-5em {
  padding-top: 1.5em !important;
}

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

.pt--2-5em {
  padding-top: 2.5em !important;
}

.pt--3em {
  padding-top: 3em !important;
}

@media print, screen and (max-width: 768px) {
  .sp-pt--0px {
    padding-top: 0 !important;
  }
  .sp-pt--4px {
    padding-top: 4px !important;
  }
  .sp-pt--8px {
    padding-top: 8px !important;
  }
  .sp-pt--12px {
    padding-top: 12px !important;
  }
  .sp-pt--16px {
    padding-top: 16px !important;
  }
  .sp-pt--20px {
    padding-top: 20px !important;
  }
  .sp-pt--24px {
    padding-top: 24px !important;
  }
  .sp-pt--28px {
    padding-top: 28px !important;
  }
  .sp-pt--32px {
    padding-top: 32px !important;
  }
  .sp-pt--36px {
    padding-top: 36px !important;
  }
  .sp-pt--40px {
    padding-top: 40px !important;
  }
  .sp-pt--48px {
    padding-top: 48px !important;
  }
  .sp-pt--56px {
    padding-top: 56px !important;
  }
  .sp-pt--64px {
    padding-top: 64px !important;
  }
  .sp-pt--72px {
    padding-top: 72px !important;
  }
  .sp-pt--0-5em {
    padding-top: 0.5em !important;
  }
  .sp-pt--1em {
    padding-top: 1em !important;
  }
  .sp-pt--1-5em {
    padding-top: 1.5em !important;
  }
  .sp-pt--2em {
    padding-top: 2em !important;
  }
  .sp-pt--2-5em {
    padding-top: 2.5em !important;
  }
  .sp-pt--3em {
    padding-top: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-pt--0px {
    padding-top: 0 !important;
  }
  .pc-pt--4px {
    padding-top: 4px !important;
  }
  .pc-pt--8px {
    padding-top: 8px !important;
  }
  .pc-pt--12px {
    padding-top: 12px !important;
  }
  .pc-pt--16px {
    padding-top: 16px !important;
  }
  .pc-pt--20px {
    padding-top: 20px !important;
  }
  .pc-pt--24px {
    padding-top: 24px !important;
  }
  .pc-pt--28px {
    padding-top: 28px !important;
  }
  .pc-pt--32px {
    padding-top: 32px !important;
  }
  .pc-pt--36px {
    padding-top: 36px !important;
  }
  .pc-pt--40px {
    padding-top: 40px !important;
  }
  .pc-pt--48px {
    padding-top: 48px !important;
  }
  .pc-pt--56px {
    padding-top: 56px !important;
  }
  .pc-pt--64px {
    padding-top: 64px !important;
  }
  .pc-pt--72px {
    padding-top: 72px !important;
  }
  .pc-pt--80px {
    padding-top: 80px !important;
  }
  .pc-pt--100px {
    padding-top: 100px !important;
  }
  .pc-pt--0-5em {
    padding-top: 0.5em !important;
  }
  .pc-pt--1em {
    padding-top: 1em !important;
  }
  .pc-pt--1-5em {
    padding-top: 1.5em !important;
  }
  .pc-pt--2em {
    padding-top: 2em !important;
  }
  .pc-pt--2-5em {
    padding-top: 2.5em !important;
  }
  .pc-pt--3em {
    padding-top: 3em !important;
  }
}
.pl--0px {
  padding-left: 0 !important;
}

.pl--4px {
  padding-left: 4px !important;
}

.pl--8px {
  padding-left: 8px !important;
}

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

.pl--16px {
  padding-left: 16px !important;
}

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

.pl--24px {
  padding-left: 24px !important;
}

.pl--28px {
  padding-left: 28px !important;
}

.pl--32px {
  padding-left: 32px !important;
}

.pl--36px {
  padding-left: 36px !important;
}

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

.pl--48px {
  padding-left: 48px !important;
}

.pl--56px {
  padding-left: 56px !important;
}

.pl--64px {
  padding-left: 64px !important;
}

.pl--72px {
  padding-left: 72px !important;
}

.pl--0-5em {
  padding-left: 0.5em !important;
}

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

.pl--1-5em {
  padding-left: 1.5em !important;
}

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

.pl--2-5em {
  padding-left: 2.5em !important;
}

.pl--3em {
  padding-left: 3em !important;
}

@media print, screen and (max-width: 768px) {
  .sp-pl--0px {
    padding-left: 0 !important;
  }
  .sp-pl--4px {
    padding-left: 4px !important;
  }
  .sp-pl--8px {
    padding-left: 8px !important;
  }
  .sp-pl--12px {
    padding-left: 12px !important;
  }
  .sp-pl--16px {
    padding-left: 16px !important;
  }
  .sp-pl--20px {
    padding-left: 20px !important;
  }
  .sp-pl--24px {
    padding-left: 24px !important;
  }
  .sp-pl--28px {
    padding-left: 28px !important;
  }
  .sp-pl--32px {
    padding-left: 32px !important;
  }
  .sp-pl--36px {
    padding-left: 36px !important;
  }
  .sp-pl--40px {
    padding-left: 40px !important;
  }
  .sp-pl--48px {
    padding-left: 48px !important;
  }
  .sp-pl--56px {
    padding-left: 56px !important;
  }
  .sp-pl--64px {
    padding-left: 64px !important;
  }
  .sp-pl--72px {
    padding-left: 72px !important;
  }
  .sp-pl--0-5em {
    padding-left: 0.5em !important;
  }
  .sp-pl--1em {
    padding-left: 1em !important;
  }
  .sp-pl--1-5em {
    padding-left: 1.5em !important;
  }
  .sp-pl--2em {
    padding-left: 2em !important;
  }
  .sp-pl--2-5em {
    padding-left: 2.5em !important;
  }
  .sp-pl--3em {
    padding-left: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-pl--0px {
    padding-left: 0 !important;
  }
  .pc-pl--4px {
    padding-left: 4px !important;
  }
  .pc-pl--8px {
    padding-left: 8px !important;
  }
  .pc-pl--12px {
    padding-left: 12px !important;
  }
  .pc-pl--16px {
    padding-left: 16px !important;
  }
  .pc-pl--20px {
    padding-left: 20px !important;
  }
  .pc-pl--24px {
    padding-left: 24px !important;
  }
  .pc-pl--28px {
    padding-left: 28px !important;
  }
  .pc-pl--32px {
    padding-left: 32px !important;
  }
  .pc-pl--36px {
    padding-left: 36px !important;
  }
  .pc-pl--40px {
    padding-left: 40px !important;
  }
  .pc-pl--48px {
    padding-left: 48px !important;
  }
  .pc-pl--56px {
    padding-left: 56px !important;
  }
  .pc-pl--64px {
    padding-left: 64px !important;
  }
  .pc-pl--72px {
    padding-left: 72px !important;
  }
  .pc-pl--80px {
    padding-left: 80px !important;
  }
  .pc-pl--100px {
    padding-left: 100px !important;
  }
  .pc-pl--0-5em {
    padding-left: 0.5em !important;
  }
  .pc-pl--1em {
    padding-left: 1em !important;
  }
  .pc-pl--1-5em {
    padding-left: 1.5em !important;
  }
  .pc-pl--2em {
    padding-left: 2em !important;
  }
  .pc-pl--2-5em {
    padding-left: 2.5em !important;
  }
  .pc-pl--3em {
    padding-left: 3em !important;
  }
}
.pr--0px {
  padding-right: 0 !important;
}

.pr--4px {
  padding-right: 4px !important;
}

.pr--8px {
  padding-right: 8px !important;
}

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

.pr--16px {
  padding-right: 16px !important;
}

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

.pr--24px {
  padding-right: 24px !important;
}

.pr--28px {
  padding-right: 28px !important;
}

.pr--32px {
  padding-right: 32px !important;
}

.pr--36px {
  padding-right: 36px !important;
}

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

.pr--48px {
  padding-right: 48px !important;
}

.pr--56px {
  padding-right: 56px !important;
}

.pr--64px {
  padding-right: 64px !important;
}

.pr--72px {
  padding-right: 72px !important;
}

.pr--0-5em {
  padding-right: 0.5em !important;
}

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

.pr--1-5em {
  padding-right: 1.5em !important;
}

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

.pr--2-5em {
  padding-right: 2.5em !important;
}

.pr--3em {
  padding-right: 3em !important;
}

@media print, screen and (max-width: 768px) {
  .sp-pr--0px {
    padding-right: 0 !important;
  }
  .sp-pr--4px {
    padding-right: 4px !important;
  }
  .sp-pr--8px {
    padding-right: 8px !important;
  }
  .sp-pr--12px {
    padding-right: 12px !important;
  }
  .sp-pr--16px {
    padding-right: 16px !important;
  }
  .sp-pr--20px {
    padding-right: 20px !important;
  }
  .sp-pr--24px {
    padding-right: 24px !important;
  }
  .sp-pr--28px {
    padding-right: 28px !important;
  }
  .sp-pr--32px {
    padding-right: 32px !important;
  }
  .sp-pr--36px {
    padding-right: 36px !important;
  }
  .sp-pr--40px {
    padding-right: 40px !important;
  }
  .sp-pr--48px {
    padding-right: 48px !important;
  }
  .sp-pr--56px {
    padding-right: 56px !important;
  }
  .sp-pr--64px {
    padding-right: 64px !important;
  }
  .sp-pr--72px {
    padding-right: 72px !important;
  }
  .sp-pr--0-5em {
    padding-right: 0.5em !important;
  }
  .sp-pr--1em {
    padding-right: 1em !important;
  }
  .sp-pr--1-5em {
    padding-right: 1.5em !important;
  }
  .sp-pr--2em {
    padding-right: 2em !important;
  }
  .sp-pr--2-5em {
    padding-right: 2.5em !important;
  }
  .sp-pr--3em {
    padding-right: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-pr--0px {
    padding-right: 0 !important;
  }
  .pc-pr--4px {
    padding-right: 4px !important;
  }
  .pc-pr--8px {
    padding-right: 8px !important;
  }
  .pc-pr--12px {
    padding-right: 12px !important;
  }
  .pc-pr--16px {
    padding-right: 16px !important;
  }
  .pc-pr--20px {
    padding-right: 20px !important;
  }
  .pc-pr--24px {
    padding-right: 24px !important;
  }
  .pc-pr--28px {
    padding-right: 28px !important;
  }
  .pc-pr--32px {
    padding-right: 32px !important;
  }
  .pc-pr--36px {
    padding-right: 36px !important;
  }
  .pc-pr--40px {
    padding-right: 40px !important;
  }
  .pc-pr--48px {
    padding-right: 48px !important;
  }
  .pc-pr--56px {
    padding-right: 56px !important;
  }
  .pc-pr--64px {
    padding-right: 64px !important;
  }
  .pc-pr--72px {
    padding-right: 72px !important;
  }
  .pc-pr--80px {
    padding-right: 80px !important;
  }
  .pc-pr--100px {
    padding-right: 100px !important;
  }
  .pc-pr--0-5em {
    padding-right: 0.5em !important;
  }
  .pc-pr--1em {
    padding-right: 1em !important;
  }
  .pc-pr--1-5em {
    padding-right: 1.5em !important;
  }
  .pc-pr--2em {
    padding-right: 2em !important;
  }
  .pc-pr--2-5em {
    padding-right: 2.5em !important;
  }
  .pc-pr--3em {
    padding-right: 3em !important;
  }
}
.pb--0px {
  padding-bottom: 0 !important;
}

.pb--4px {
  padding-bottom: 4px !important;
}

.pb--8px {
  padding-bottom: 8px !important;
}

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

.pb--16px {
  padding-bottom: 16px !important;
}

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

.pb--24px {
  padding-bottom: 24px !important;
}

.pb--28px {
  padding-bottom: 28px !important;
}

.pb--32px {
  padding-bottom: 32px !important;
}

.pb--36px {
  padding-bottom: 36px !important;
}

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

.pb--48px {
  padding-bottom: 48px !important;
}

.pb--56px {
  padding-bottom: 56px !important;
}

.pb--64px {
  padding-bottom: 64px !important;
}

.pb--72px {
  padding-bottom: 72px !important;
}

.pb--0-5em {
  padding-bottom: 0.5em !important;
}

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

.pb--1-5em {
  padding-bottom: 1.5em !important;
}

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

.pb--2-5em {
  padding-bottom: 2.5em !important;
}

.pb--3em {
  padding-bottom: 3em !important;
}

@media print, screen and (max-width: 768px) {
  .sp-pb--0px {
    padding-bottom: 0 !important;
  }
  .sp-pb--4px {
    padding-bottom: 4px !important;
  }
  .sp-pb--8px {
    padding-bottom: 8px !important;
  }
  .sp-pb--12px {
    padding-bottom: 12px !important;
  }
  .sp-pb--16px {
    padding-bottom: 16px !important;
  }
  .sp-pb--20px {
    padding-bottom: 20px !important;
  }
  .sp-pb--24px {
    padding-bottom: 24px !important;
  }
  .sp-pb--28px {
    padding-bottom: 28px !important;
  }
  .sp-pb--32px {
    padding-bottom: 32px !important;
  }
  .sp-pb--36px {
    padding-bottom: 36px !important;
  }
  .sp-pb--40px {
    padding-bottom: 40px !important;
  }
  .sp-pb--48px {
    padding-bottom: 48px !important;
  }
  .sp-pb--56px {
    padding-bottom: 56px !important;
  }
  .sp-pb--64px {
    padding-bottom: 64px !important;
  }
  .sp-pb--72px {
    padding-bottom: 72px !important;
  }
  .sp-pb--0-5em {
    padding-bottom: 0.5em !important;
  }
  .sp-pb--1em {
    padding-bottom: 1em !important;
  }
  .sp-pb--1-5em {
    padding-bottom: 1.5em !important;
  }
  .sp-pb--2em {
    padding-bottom: 2em !important;
  }
  .sp-pb--2-5em {
    padding-bottom: 2.5em !important;
  }
  .sp-pb--3em {
    padding-bottom: 3em !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-pb--0px {
    padding-bottom: 0 !important;
  }
  .pc-pb--4px {
    padding-bottom: 4px !important;
  }
  .pc-pb--8px {
    padding-bottom: 8px !important;
  }
  .pc-pb--12px {
    padding-bottom: 12px !important;
  }
  .pc-pb--16px {
    padding-bottom: 16px !important;
  }
  .pc-pb--20px {
    padding-bottom: 20px !important;
  }
  .pc-pb--24px {
    padding-bottom: 24px !important;
  }
  .pc-pb--28px {
    padding-bottom: 28px !important;
  }
  .pc-pb--32px {
    padding-bottom: 32px !important;
  }
  .pc-pb--36px {
    padding-bottom: 36px !important;
  }
  .pc-pb--40px {
    padding-bottom: 40px !important;
  }
  .pc-pb--48px {
    padding-bottom: 48px !important;
  }
  .pc-pb--56px {
    padding-bottom: 56px !important;
  }
  .pc-pb--64px {
    padding-bottom: 64px !important;
  }
  .pc-pb--72px {
    padding-bottom: 72px !important;
  }
  .pc-pb--80px {
    padding-bottom: 80px !important;
  }
  .pc-pb--100px {
    padding-bottom: 100px !important;
  }
  .pc-pb--0-5em {
    padding-bottom: 0.5em !important;
  }
  .pc-pb--1em {
    padding-bottom: 1em !important;
  }
  .pc-pb--1-5em {
    padding-bottom: 1.5em !important;
  }
  .pc-pb--2em {
    padding-bottom: 2em !important;
  }
  .pc-pb--2-5em {
    padding-bottom: 2.5em !important;
  }
  .pc-pb--3em {
    padding-bottom: 3em !important;
  }
}
/*
 テキストウエイト
---------------------------------------------------*/
.fw--normal {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: normal;
}

.fw--bold,
b {
  font-weight: 700 !important;
}

@media print, screen and (min-width: 769px) {
  .pc-fw--bold {
    font-weight: 700 !important;
  }
}
/*
 テキストサイズ
---------------------------------------------------*/
.fs--xs {
  font-size: 11px !important;
}
@media print, screen and (min-width: 769px) {
  .fs--xs {
    font-size: 12px !important;
  }
}

.fs--s {
  font-size: 12px !important;
}
@media print, screen and (min-width: 769px) {
  .fs--s {
    font-size: 14px !important;
  }
}

.fs--sm {
  font-size: 13px !important;
}
@media print, screen and (min-width: 769px) {
  .fs--sm {
    font-size: 15px !important;
  }
}

.fs--m {
  font-size: 14px !important;
}
@media print, screen and (min-width: 769px) {
  .fs--m {
    font-size: 16px !important;
  }
}

.fs--l {
  font-size: 16px !important;
}
@media print, screen and (min-width: 769px) {
  .fs--l {
    font-size: 18px !important;
  }
}

.fs--xl {
  font-size: 18px !important;
}
@media print, screen and (min-width: 769px) {
  .fs--xl {
    font-size: 22px !important;
  }
}

.fs--xxl {
  font-size: 20px !important;
}
@media print, screen and (min-width: 769px) {
  .fs--xxl {
    font-size: 24px !important;
  }
}

@media print, screen and (max-width: 768px) {
  .sp-fs--xs {
    font-size: 11px !important;
  }
  .sp-fs--s {
    font-size: 12px !important;
  }
  .sp-fs--sm {
    font-size: 13px !important;
  }
  .sp-fs--m {
    font-size: 14px !important;
  }
  .sp-fs--l {
    font-size: 16px !important;
  }
  .sp-fs--xl {
    font-size: 18px !important;
  }
  .sp-fs--xxl {
    font-size: 20px !important;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-fs--xs {
    font-size: 12px !important;
  }
  .pc-fs--s {
    font-size: 14px !important;
  }
  .pc-fs--sm {
    font-size: 15px !important;
  }
  .pc-fs--m {
    font-size: 16px !important;
  }
  .pc-fs--l {
    font-size: 18px !important;
  }
  .pc-fs--xl {
    font-size: 22px !important;
  }
  .pc-fs--xxl {
    font-size: 24px !important;
  }
  .pc-fs--32px {
    font-size: 32px !important;
  }
}
/*
 テキストカラー
---------------------------------------------------*/
.fc--red {
  color: #c00;
}

.fc--blue {
  color: #1b9cd5;
}

.fc--l-blue {
  color: #6dc8eb;
}

.fc--orange {
  color: #e6ad3b;
}

.fc--gray {
  color: #777;
}

.fc--pink {
  color: #f1659d;
}

.fc--green {
  color: #1dbcce;
}

.fc--purple {
  color: #9e51cb;
}

/*
 背景
---------------------------------------------------*/
.bg--gray {
  background: #f8f8f8;
}

/*
 行間
---------------------------------------------------*/
.lh--2 {
  line-height: 2;
}

@media print, screen and (min-width: 769px) {
  .pc-lh--2 {
    line-height: 2;
  }
}
.lh--1 {
  line-height: 1;
}

@media print, screen and (min-width: 769px) {
  .pc-lh--1 {
    line-height: 1;
  }
}
/*
 flex
---------------------------------------------------*/
.row {
  display: flex;
}

@media print, screen and (max-width: 768px) {
  .sp-row {
    display: flex;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-row {
    display: flex;
  }
}
.row--dr-column {
  flex-direction: column;
}

.row--jc-start {
  justify-content: flex-start;
}

.row--jc-between {
  justify-content: space-between;
}

.row--jc-center {
  justify-content: center;
}

.row--wrap {
  flex-wrap: wrap;
}

.row--al-center {
  align-items: center;
}

.row--al-end {
  align-items: flex-end;
}

.row--self-center {
  align-self: center;
}

.row--self-end {
  align-self: flex-end;
}

.flex1 {
  flex: 1;
}

@media print, screen and (max-width: 768px) {
  .sp-flex1 {
    flex: 1;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-flex1 {
    flex: 1;
  }
}
@media print, screen and (max-width: 768px) {
  .sp-row--wrap {
    display: flex;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-row--wrap {
    display: flex;
  }
}
.row--col-2 > .row__col {
  width: calc(50% - 12px);
}

.row--col-3 > .row__col {
  width: calc(33.3333% - 12px);
}

.row--col-4 > .row__col {
  width: calc(25% - 12px);
}

.row--col-5 > .row__col {
  width: calc(20% - 12px);
}

@media print, screen and (max-width: 768px) {
  .sp-row--col-2 > .row__col {
    width: calc(50% - 6px);
  }
  .sp-row--col-3 > .row__col {
    width: calc(33.3333% - 6px);
  }
  .sp-row--col-4 > .row__col {
    width: calc(25% - 6px);
  }
  .sp-row--col-5 > .row__col {
    width: calc(20% - 6px);
  }
}
@media print, screen and (min-width: 769px) {
  .pc-row--col-2 > .row__col {
    width: calc(50% - 24px);
  }
  .pc-row--col-3 > .row__col {
    width: calc(33.3333% - 18px);
  }
  .pc-row--col-4 > .row__col {
    width: calc(25% - 12px);
  }
  .pc-row--col-5 > .row__col {
    width: calc(20% - 12px);
  }
}
/*
 改行させない
---------------------------------------------------*/
.nowrap {
  white-space: nowrap;
}

/*
 文章＋画像の組み合わせ
---------------------------------------------------*/
.unit__img {
  margin-left: -16px;
  margin-right: -16px;
}
.unit__txt {
  margin-top: 2em;
}

@media print, screen and (min-width: 769px) {
  .unit {
    display: flex;
    justify-content: space-between;
  }
  .unit__img {
    align-self: flex-start;
    width: calc(50% - 24px);
    margin: 0;
    position: relative;
  }
  .unit__img:before {
    content: "";
    display: block;
    width: 50vw;
    height: 100%;
    background: #f2fcfe;
    position: absolute;
    top: 20%;
  }
  .unit__img img {
    position: relative;
  }
  .unit__txt {
    width: calc(50% - 24px);
    margin: 0;
    position: relative;
  }
  .unit--txt-l .unit__txt {
    order: -1;
  }
  .unit--txt-l .unit__img:before {
    left: 20%;
  }
  .unit--txt-r .unit__txt {
    order: 1;
  }
  .unit--txt-r .unit__img:before {
    right: 20%;
  }
}
/* 枠付きボックスの組み合わせ
---------------------------------------------------*/
.unit-border {
  border-style: solid;
  border-width: 1px 0 0 1px;
  border-color: #ddd;
  display: flex;
  flex-wrap: wrap;
}
.unit-border__col {
  width: 50%;
  border-style: solid;
  border-width: 0 1px 1px 0;
  border-color: #ddd;
}

@media print, screen and (max-width: 768px) {
  .sp-unit-border {
    border-style: solid;
    border-width: 1px 0 0 1px;
    border-color: #ddd;
    display: flex;
    flex-wrap: wrap;
  }
  .sp-unit-border__col {
    width: 50%;
    border-style: solid;
    border-width: 0 1px 1px 0;
    border-color: #ddd;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-unit-border {
    border-style: solid;
    border-width: 1px 0 0 1px;
    border-color: #ddd;
    display: flex;
    flex-wrap: wrap;
  }
  .pc-unit-border__col {
    width: 50%;
    border-style: solid;
    border-width: 0 1px 1px 0;
    border-color: #ddd;
  }
}
/*
 写真セット
---------------------------------------------------*/
@media print, screen and (max-width: 768px) {
  .unit-gallery {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .unit-gallery__main {
    width: 100%;
    margin-bottom: 4px;
  }
  .unit-gallery__sub {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .unit-gallery__sub img {
    width: calc(50% - 2px);
    margin-bottom: 4px;
  }
}
@media print, screen and (min-width: 769px) {
  .unit-gallery {
    display: flex;
    justify-content: space-between;
  }
  .unit-gallery__main {
    width: calc(66.6666666667% - 4px);
  }
  .unit-gallery__main img {
    height: 100%;
    object-fit: cover;
  }
  .unit-gallery__sub {
    width: calc(33.3333333333% - 4px);
  }
  .unit-gallery__sub img {
    width: auto;
  }
  .unit-gallery__sub img:nth-child(1) {
    margin-bottom: 8px;
  }
}
/*
 画像のアスペクト比
---------------------------------------------------*/
.aspect-2-1 {
  aspect-ratio: 2/1;
  object-fit: cover;
  object-position: center;
}

.aspect-3-1 {
  aspect-ratio: 3/1;
  object-fit: cover;
  object-position: center;
}

@media print, screen and (max-width: 768px) {
  .sp-aspect-2-1 {
    aspect-ratio: 2/1;
    object-fit: cover;
    object-position: center;
  }
  .sp-aspect-3-1 {
    aspect-ratio: 3/1;
    object-fit: cover;
    object-position: center;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-aspect-2-1 {
    aspect-ratio: 2/1;
    object-fit: cover;
    object-position: center;
  }
  .pc-aspect-3-1 {
    aspect-ratio: 3/1;
    object-fit: cover;
    object-position: center;
  }
}
.aspect-pos-center {
  object-position: center;
}

.aspect-pos-top {
  object-position: top;
}

.aspect-pos-btm {
  object-position: bottom;
}

/*
 リスト
---------------------------------------------------*/
.list-dot > li {
  text-indent: -1em;
  padding-left: 1em;
}
.list-dot > li:before {
  content: "・";
}
.list-dot > li * {
  text-indent: 0;
}

@media print, screen and (min-width: 769px) {
  .list-dot--orange,
  .list-dot--red,
  .list-dot--blue {
    line-height: 1.7;
  }
}
.list-dot--orange > li,
.list-dot--red > li,
.list-dot--blue > li {
  padding-left: 1em;
  margin: 0.6em 0;
  position: relative;
}
.list-dot--orange > li:before,
.list-dot--red > li:before,
.list-dot--blue > li:before {
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  position: absolute;
  top: 0.6em;
  left: 0;
}

.list-dot--orange > li:before {
  background: #e6ad3b;
}

.list-dot--red > li:before {
  background: #c00;
}

.list-dot--blue > li:before {
  background: #1b9cd5;
}

.list-number {
  margin-left: 1.5em;
}
.list-number > li {
  list-style-type: decimal;
}

.list-link > li:not(:last-child) {
  margin-bottom: 0.8em;
}
.list-link.-col2 {
  display: flex;
  flex-wrap: wrap;
}
.list-link.-col2 > li {
  width: 50%;
}
@media print, screen and (min-width: 769px) {
  .list-link.-pc-col2 {
    display: flex;
    flex-wrap: wrap;
  }
  .list-link.-pc-col2 > li {
    width: 50%;
  }
}

/*
 装飾テキスト
---------------------------------------------------*/
.txt--check {
  padding-left: 1.7em;
  position: relative;
}
.txt--check:before {
  content: "\e5ca";
  color: #e6ad3b;
  font-size: 1.5em;
  position: absolute;
  top: 0;
  left: 0;
}

.txt-dot,
.txt-dot--red,
.txt-dot--blue {
  padding-left: 1em;
  position: relative;
}
.txt-dot:before,
.txt-dot--red:before,
.txt-dot--blue:before {
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  position: absolute;
  top: 0.65em;
  left: 0.25em;
  background: #e6ad3b;
}

.txt-dot--red:before {
  background: #c00;
}

.txt-dot--blue:before {
  background: #6dc8eb;
}

.txt-indent {
  text-indent: -1em;
  padding-left: 1em;
}

.txt-caption {
  font-size: 12px;
  margin-top: 0.5em;
  text-align: center;
}
@media print, screen and (min-width: 769px) {
  .txt-caption {
    font-size: 14px;
  }
}

.txt-space--1 {
  letter-spacing: 0.1em;
}

@media print, screen and (min-width: 769px) {
  .pc-txt-space--1 {
    letter-spacing: 0.1em;
  }
}
/*
 ボーダー
---------------------------------------------------*/
.border--gray {
  border: 1px solid #ddd;
}

@media print, screen and (max-width: 768px) {
  .sp-border--gray {
    border: 1px solid #ddd;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-border--gray {
    border: 1px solid #ddd;
  }
}
.border--red {
  border: 1px solid #c00;
}

@media print, screen and (max-width: 768px) {
  .sp-border--red {
    border: 1px solid #c00;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-border--red {
    border: 1px solid #c00;
  }
}
/*
 コンテナ
---------------------------------------------------*/
@media print, screen and (max-width: 768px) {
  .container {
    padding: 0 0 48px;
  }
}
@media print, screen and (min-width: 769px) {
  .container {
    max-width: 1080px;
    margin-left: auto;
    margin-right: auto;
    padding: 48px 0;
  }
}

/*
 フロート
---------------------------------------------------*/
.img-float--r {
  float: right;
}

.img-float--l {
  float: left;
}

@media print, screen and (max-width: 768px) {
  .sp-img-float--r {
    float: right;
  }
  .sp-img-float--l {
    float: left;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-img-float--r {
    float: right;
  }
  .pc-img-float--l {
    float: left;
  }
}
.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

/*
 テーブルレイアウト
---------------------------------------------------*/
.table-l-fixed {
  table-layout: fixed;
}

/*
 overflow
---------------------------------------------------*/
.overflow--hidden {
  overflow: hidden;
}

@media print, screen and (max-width: 768px) {
  .sp-overflow--hidden {
    overflow: hidden;
  }
}
@media print, screen and (min-width: 769px) {
  .pc-overflow--hidden {
    overflow: hidden;
  }
}