@charset "UTF-8";
@media (max-width: 360px) {
  html {
    font-size: 4.4444444444vw;
  }
}
@media (min-width: 361px) {
  html {
    font-size: 100%;
  }
}
@media screen and (min-width: 768px) {
  html {
    font-size: max(10px, 1.3913043478vw);
  }
}
@media (min-width: 1150px) {
  html {
    font-size: 100%;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #000000;
}
@media screen and (min-width: 768px) {
  body {
    min-width: 1280px;
    overflow-x: auto;
  }
}

body.fixed {
  overflow: hidden;
}

@media screen and (min-width: 768px) {
  a,
  button {
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  a:hover,
  button:hover {
    opacity: 0.8;
    cursor: pointer;
  }
}

/*
	* Modern CSS Reset (2024 Updated Version)
	* Based on modern-css-reset with additional optimizations
	*/
/* Box sizing rules */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Remove default margin and padding */
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd,
ul,
ol,
li {
  margin: 0;
  padding: 0;
}

/* List reset */
ul,
ol {
  list-style: none;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  min-height: 100dvh;
  /* Modern viewport height */
  text-rendering: optimizeSpeed;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Link reset */
a {
  text-decoration: none;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
}

/* Modern image handling */
img,
picture,
svg,
video,
canvas {
  display: block;
  max-width: 100%;
  width: 100%;
  height: auto;
  vertical-align: middle;
}

/* Aspect ratio support */
img[style*=aspect-ratio] {
  height: 100%;
}

/* Form element reset */
input,
button,
textarea,
select {
  padding: 0;
  margin: 0;
}

/* Modern button reset */
button {
  cursor: pointer;
  color: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border: none;
}

/* Smooth scrolling with fallback */
/* Remove animations for users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
  }
}
/* Details and summary reset */
summary {
  display: block;
  cursor: pointer;
}

summary::-webkit-details-marker {
  display: none;
}

/* Modern hover states */
@media (any-hover: hover) {
  a,
  button {
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }
  a:hover,
  button:hover {
    opacity: 0.7;
  }
}
/* Touch device optimization */
@media (hover: none) {
  a:hover,
  button:hover {
    opacity: 1;
  }
}
/* Modern focus styles */
/* Modern scrollbar styling */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, .3) transparent;
}

*::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

*::-webkit-scrollbar-track {
  background: transparent;
}

*::-webkit-scrollbar-thumb {
  background-color: rgba(0, 0, 0, .3);
  border-radius: 4px;
}

/* Prevent image drag and select */
img {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-user-drag: none;
  -webkit-touch-callout: none;
}

/* Fix for iOS tap highlight */
* {
  -webkit-tap-highlight-color: transparent;
}

/* Modern text selection */
::-moz-selection {
  background-color: rgba(0, 0, 0, .1);
}
::selection {
  background-color: rgba(0, 0, 0, .1);
}

.l-about-fv {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 768px) {
  .l-about-fv {
    height: 62.3125rem;
  }
}

.l-about-lead {
  padding: 1.5rem 0;
}
@media screen and (min-width: 768px) {
  .l-about-lead {
    padding: 2.0625rem 0 3.0625rem;
  }
}

.l-about-service {
  padding: 1.875rem 0 0;
}
@media screen and (min-width: 768px) {
  .l-about-service {
    padding: 4.875rem 0 0;
  }
}

.l-access {
  padding-top: 2.5rem;
}
@media screen and (min-width: 768px) {
  .l-access {
    padding-top: 6.25rem;
  }
}

.l-archive {
  padding: 2.5rem 0;
}
@media screen and (min-width: 768px) {
  .l-archive {
    padding: 4.6875rem 0;
  }
}

.l-art {
  margin-top: 0.3125rem;
  padding: 1.25rem 0 1.625rem;
}
@media screen and (min-width: 768px) {
  .l-art {
    margin-top: 0.75rem;
    padding: 4.375rem 0;
  }
}

.l-blog-fv {
  margin-top: 4rem;
  padding: 3.75rem 0;
}
@media screen and (min-width: 768px) {
  .l-blog-fv {
    margin-top: 7.6875rem;
  }
}

.l-blog {
  padding: 1.5rem 0 2.25rem;
}
@media screen and (min-width: 768px) {
  .l-blog {
    padding: 4.625rem 0 4.375rem;
  }
}

.l-contact-box {
  padding: 3.75rem 0 2.8125rem;
}
@media screen and (min-width: 768px) {
  .l-contact-box {
    padding: 4.375rem 0 6.25rem;
  }
}

.l-contact {
  padding: 2.5rem 0;
}
@media screen and (min-width: 768px) {
  .l-contact {
    padding: 4rem 0 5rem;
  }
}

.l-disclosure {
  padding: 1.5rem 0 1.875rem;
}
@media screen and (min-width: 768px) {
  .l-disclosure {
    padding: 4rem 0 4.75rem;
  }
}

.l-footer {
  margin-top: -0.6875rem;
}
@media screen and (min-width: 768px) {
  .l-footer {
    margin-top: -1.875rem;
  }
}

.l-fv {
  padding: 0.3125rem;
  margin-top: 4rem;
}
@media screen and (min-width: 768px) {
  .l-fv {
    padding: 0 1.25rem;
    margin-top: 7.5rem;
  }
}

.l-header {
  width: 100%;
  height: 4rem;
}
@media screen and (min-width: 768px) {
  .l-header {
    height: 7.5rem;
  }
}

.l-history {
  padding: 1.5rem 0 0;
}
@media screen and (min-width: 768px) {
  .l-history {
    padding: 3.75rem 0 4.375rem;
  }
}

.l-info {
  padding: 1.625rem 0 2.25rem;
}
@media screen and (min-width: 768px) {
  .l-info {
    padding: 3.75rem 0;
  }
}

.l-inner {
  width: 100%;
  padding-right: 1.25rem;
  padding-left: 1.25rem;
  margin-right: auto;
  margin-left: auto;
  max-width: 34.375rem;
}
@media screen and (min-width: 768px) {
  .l-inner {
    max-width: 1150px;
    padding-right: 1.5625rem;
    padding-left: 1.5625rem;
  }
}

.l-member {
  padding: 1.5rem 0;
}
@media screen and (min-width: 768px) {
  .l-member {
    padding: 3.25rem 0 4rem;
  }
}

.l-message {
  padding: 1.25rem 0 1.875rem;
}
@media screen and (min-width: 768px) {
  .l-message {
    padding: 5rem 0 4.6875rem;
  }
}

.l-outline {
  padding: 1.5rem 0 0;
}
@media screen and (min-width: 768px) {
  .l-outline {
    padding: 4.5rem 0 4.6875rem;
  }
}

.l-philosophy {
  padding: 1.875rem 0 1.5rem;
}
@media screen and (min-width: 768px) {
  .l-philosophy {
    padding: 4.75rem 0 4.5rem;
  }
}

.l-pickup {
  padding: 0.5rem 0 1rem;
}
@media screen and (min-width: 768px) {
  .l-pickup {
    padding: 1.25rem 0;
    margin-top: 1.25rem;
  }
}

.l-recruit {
  padding-top: 1.875rem;
  padding-left: 0.3125rem;
  padding-right: 0.3125rem;
}
@media screen and (min-width: 768px) {
  .l-recruit {
    padding-top: 5rem;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }
}

.l-service {
  padding: 1.25rem 0 1.875rem;
}
@media screen and (min-width: 768px) {
  .l-service {
    padding: 4rem 0 4.625rem;
  }
}

.l-shisetsu-access {
  padding: 1.5rem 0 1.875rem;
}
@media screen and (min-width: 768px) {
  .l-shisetsu-access {
    padding: 5.625rem 0;
  }
}

@media screen and (min-width: 768px) {
  .l-shisetsu-content {
    padding-top: 4.75rem;
    padding-bottom: 4.5625rem;
  }
}

@media screen and (min-width: 768px) {
  .l-shisetsu-content.mt-0 {
    padding-top: 0;
  }
}

.l-shisetsu-fv {
  height: 29.1875rem;
}
@media screen and (min-width: 768px) {
  .l-shisetsu-fv {
    height: 49.25rem;
  }
}

@media screen and (min-width: 768px) {
  .l-shisetsu-fv.service {
    height: 43.25rem;
  }
}

.l-shisetsu-message {
  padding: 1.25rem 0 1.875rem;
}
@media screen and (min-width: 768px) {
  .l-shisetsu-message {
    padding: 4rem 0 2.875rem;
  }
}

.l-support {
  padding: 1.25rem 0 2.1875rem;
}
@media screen and (min-width: 768px) {
  .l-support {
    padding: 4rem 0 4.75rem;
  }
}

.l-top {
  padding-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .l-top {
    padding-top: 4.6875rem;
  }
}

.c-article-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 1rem 1.875rem 1rem 0.5rem;
  height: auto;
  background-color: #ffffff;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  border-top: 1px solid #e5e5e5;
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-article-item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    height: 6.75rem;
    padding: 0 1.25rem;
  }
}

.c-article-item:last-child {
  border-bottom: 1px solid #e5e5e5;
}

.c-article-item:hover {
  background: url(../images/bg-blue.webp) repeat center/contain;
  opacity: 1;
}

.c-article-item__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.c-article-item__time {
  font-size: 0.75rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .c-article-item__time {
    font-size: 0.8125rem;
  }
}

.c-article-item__category {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 7.5rem;
  height: 1.25rem;
  background-color: #ffffff;
  padding: 0 0.25rem;
  border: 1px solid;
  border-radius: 0.75rem;
  margin-left: 1rem;
  font-size: 0.75rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .c-article-item__category {
    min-width: 8.0625rem;
    height: 1.5rem;
    font-size: 0.8125rem;
    padding: 0 0.5rem;
  }
}

.c-article-item__category.is-cat-info_com {
  border-color: #fe4d11;
}

.c-article-item__category.is-cat-info_himeji {
  border-color: #d70000;
}

.c-article-item__category.is-cat-info_kobe {
  border-color: #0066cf;
}

.c-article-item__category.is-cat-info_kobe_duo {
  border-color: #00cfff;
}

.c-article-item__category.is-cat-info_nishinomiya {
  border-color: #079d00;
}

.c-article-item__category.is-cat-info_ikeda {
  border-color: #d29700;
}

.c-article-item__category.is-cat-info_important {
  border-color: #d600d0;
}

.c-article-item__category.is-cat-info_recruit {
  border-color: #ff9320;
}

.c-article-item__category.is-cat-info_open {
  border-color: #999999;
}

.c-article-item__title {
  margin-top: 0.5rem;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.006em;
  color: #333;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media screen and (min-width: 768px) {
  .c-article-item__title {
    margin-left: 2.0625rem;
    margin-top: 0;
    font-size: 1.0625rem;
    line-height: 1.7647058824;
  }
}

.c-article-item span {
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background-color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 50%;
  right: 0.5rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border: 1px solid #ff7500;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
@media screen and (min-width: 768px) {
  .c-article-item span {
    width: 1.625rem;
    height: 1.625rem;
    position: static;
    margin-left: 0.5rem;
    -webkit-transform: none;
            transform: none;
  }
}

.c-article-item:hover span {
  background-color: #ff7500;
}

.c-article-item span::after {
  content: "";
  width: 0.625rem;
  height: 0.25rem;
  background: url(../images/icon_arrow-orange.webp) no-repeat center/contain;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
@media screen and (min-width: 768px) {
  .c-article-item span::after {
    width: 0.75rem;
    height: 0.3125rem;
  }
}

.c-article-item:hover span::after {
  background: url(../images/icon_arrow-white.webp) no-repeat center/contain;
}

.c-box-footer {
  background-color: #ffffff;
  border-radius: 0.625rem 0.625rem 0 0;
  padding: 1rem 1.25rem 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-box-footer {
    border-radius: 1.25rem;
    padding: 1.5rem 1.875rem;
  }
}

.c-box-footer__text {
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.7142857143;
}
@media screen and (min-width: 768px) {
  .c-box-footer__text {
    font-size: 0.9375rem;
    letter-spacing: 0.025em;
  }
}

.c-box-footer__table {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table {
    margin-top: 0.5rem;
  }
}

.c-box-footer__table-box:not(:last-child) {
  padding-bottom: 1.25rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box:not(:last-child) {
    padding-bottom: 1rem;
  }
}

.c-box-footer__table-box:not(:last-child)::after {
  content: "";
  width: 100vw;
  height: 1px;
  background-color: #ff7500;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box:not(:last-child)::after {
    width: 100%;
    border-bottom: 1px dashed #ff7500;
    background-color: transparent;
  }
}

.c-box-footer__table-box:nth-child(n+2) {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box:nth-child(n+2) {
    margin-top: 0.625rem;
  }
}

.c-box-footer__table-box dt {
  font-size: 0.9375rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box dt {
    font-size: 1rem;
  }
}

.c-box-footer__table-box dd {
  margin-top: 0.375rem;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  color: #333;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box dd {
    font-size: 0.9375rem;
  }
}

.c-box-footer__table-box dd .bold {
  font-weight: bold;
  font-size: 0.8125rem;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box dd .bold {
    font-size: 0.9375rem;
  }
}

.c-box-footer__table-box dd .la {
  font-size: 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box dd .la {
    font-size: 1.375rem;
  }
}

.c-box-footer__table-box dd .fax {
  margin-left: 0.875rem;
}
@media screen and (min-width: 768px) {
  .c-box-footer__table-box dd .fax {
    margin-left: 0.9375rem;
  }
}

.c-btn {
  width: 17.1875rem;
  height: 3.125rem;
  border: 1px solid #ff7500;
  background-color: #ffffff;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border-radius: 1.5rem;
  font-size: 0.8125rem;
  color: #333;
  position: relative;
  padding-right: 2rem;
}
@media screen and (min-width: 768px) {
  .c-btn {
    width: 24.25rem;
    height: 4.625rem;
    border-radius: 2.3125rem;
    font-size: 0.9375rem;
    background-color: transparent;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
}

@media screen and (min-width: 768px) {
  .c-btn:hover {
    background-color: #ff7500;
    color: #ffffff;
    opacity: 1;
  }
}

.c-btn span {
  width: 1.875rem;
  height: 1.875rem;
  background-color: #ff7500;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 50%;
  right: 0.625rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .c-btn span {
    width: 2.875rem;
    height: 2.875rem;
    right: 0.875rem;
  }
}

@media screen and (min-width: 768px) {
  .c-btn:hover span {
    background-color: #ffffff;
  }
}

.c-btn span::after {
  content: "";
  width: 1rem;
  height: 0.25rem;
  background: url(../images/icon_arrow-white.webp) no-repeat center/contain;
}

.c-btn:hover span::after {
  background: url(../images/icon_arrow-orange.webp) no-repeat center/contain;
}

.c-card-about-service:nth-child(odd) {
  background-color: #ffffff;
}
@media screen and (min-width: 768px) {
  .c-card-about-service:nth-child(odd) {
    background-color: transparent;
  }
}

.c-card-about-service__title {
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .c-card-about-service__title {
    font-size: 1.375rem;
  }
}

.c-card-about-service__text {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  text-align: justify;
  letter-spacing: -0.06em;
  color: #333;
}
@media screen and (min-width: 768px) {
  .c-card-about-service__text {
    margin-top: 1rem;
    font-size: 1rem;
    line-height: 2;
    color: #666666;
  }
}

.c-card-about-service__img {
  margin-top: 1rem;
}

.c-card-about-service__img img {
  aspect-ratio: 481/300;
  width: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.c-card-access {
  border: 1px solid #e5e5e5;
  border-radius: 1.25rem;
}

.c-card-access__img img {
  aspect-ratio: 333/196;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 1.25rem 1.25rem 0 0;
}
@media screen and (min-width: 768px) {
  .c-card-access__img img {
    aspect-ratio: 363/249;
  }
}

.c-card-access__body {
  padding: 0.75rem 1.25rem 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-card-access__body {
    padding: 1.25rem 1.6875rem 1.5rem;
  }
}

.c-card-access__title {
  font-size: 1rem;
  font-weight: bold;
  line-height: 1.875;
}
@media screen and (min-width: 768px) {
  .c-card-access__title {
    font-size: 1.125rem;
    line-height: 1.6666666667;
  }
}

.c-card-access__text {
  font-size: 0.9375rem;
  color: #666666;
  line-height: 1.7333333333;
  text-align: justify;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .c-card-access__text {
    font-size: 1rem;
    line-height: 1.625;
  }
}

.c-card-access__btns {
  margin-top: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.8125rem;
}
@media screen and (min-width: 768px) {
  .c-card-access__btns {
    margin-top: 1.25rem;
  }
}

.c-card-access__btn a {
  width: 8.75rem;
  height: 1.875rem;
  border-radius: 1.875rem;
  background-color: #f9e76f;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 0.8125rem;
  line-height: 1;
}
.c-card-access__btn + .c-card-access__btn a {
	padding: 0 0 0.25rem 0;
}
@media screen and (min-width: 768px) {
  .c-card-access__btn a {
    width: 9.375rem;
    height: 2.3125rem;
    font-size: 0.9375rem;
    font-weight: bold;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
}

@media screen and (min-width: 768px) {
  .c-card-access__btn a:hover {
    background-color: #fcda03;
    opacity: 1;
  }
}

.c-card-banner {
  padding: 0.3125rem;
  background-color: #fcc800;
}
@media screen and (min-width: 768px) {
  .c-card-banner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0;
  }
}

@media screen and (min-width: 768px) {
  .c-card-banner__body {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    padding: 0.625rem 0 0.625rem 0.625rem;
  }
}

.c-card-banner__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.c-card-banner__img {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  position: relative;
}

.c-card-banner__img img {
  aspect-ratio: 365/190;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .c-card-banner__img img {
    aspect-ratio: 309/394;
  }
}

.c-card-banner__btn {
  position: absolute;
  left: 50%;
  bottom: 0.3125rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .c-card-banner__btn {
    bottom: 0.875rem;
  }
}

.c-card-banner__btn a {
  width: 11.5625rem;
  height: 1.5rem;
  background-color: #ff7500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  color: #ffffff;
  border-radius: 0.75rem;
  font-size: 0.8125rem;
  font-weight: bold;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 768px) {
  .c-card-banner__btn a {
    height: 1.875rem;
    border-radius: 0.9375rem;
    font-size: 1rem;
    color: #ff7500;
    background-color: #ffffff;
  }
}

.c-card-banner__title {
  width: 1.6875rem;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  background-color: #ffffff;
  font-size: 0.875rem;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.375rem;
}
@media screen and (min-width: 768px) {
  .c-card-banner__title {
    width: 2.8125rem;
    gap: 1.125rem;
    font-size: 1.625rem;
  }
}

@media screen and (min-width: 768px) {
  .c-card-banner__title.sp {
    display: none;
  }
}

.c-card-banner__title.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .c-card-banner__title.pc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.c-card-banner__title span {
  color: #ffffff;
  width: 100%;
  height: 4.0625rem;
  background-color: #8abb01;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .c-card-banner__title span {
    height: 7.5rem;
    font-size: 1.625rem;
  }
}

.c-card-banner__capa {
  text-align: center;
  font-size: 0.875rem;
  font-weight: bold;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  .c-card-banner__capa {
    font-size: 1rem;
  }
}

.c-card-banner__capa span {
  font-size: 1.625rem;
  color: #b70000;
}
@media screen and (min-width: 768px) {
  .c-card-banner__capa span {
    font-size: 1.75rem;
  }
}

.c-card-blog {
  display: block;
}

.c-card-blog__img img {
  aspect-ratio: 1/1;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0.625rem;
  border: 1px solid #e5e5e5;
}

.c-card-blog__body {
  margin-top: 0.5rem;
}
@media screen and (min-width: 768px) {
  .c-card-blog__body {
    margin-top: 1.25rem;
    padding-bottom: 0.25rem;
  }
}

.c-card-blog__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.c-card-blog__time {
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.25;
  padding-right: 0.8125rem;
  border-right: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .c-card-blog__time {
    font-size: 0.875rem;
    padding-right: 0.6875rem;
  }
}

.c-card-blog__category {
  margin-left: 0.625rem;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .c-card-blog__category {
    font-size: 0.875rem;
  }
}

.c-card-blog__category.is-cat-blog_honbu {
  color: #fe4d11;
}

.c-card-blog__category.is-cat-blog_himeji {
  color: #d70000;
}

.c-card-blog__category.is-cat-blog_kobe {
  color: #0066cf;
}

.c-card-blog__category.is-cat-blog_kobe_duo {
  color: #00cfff;
}

.c-card-blog__category.is-cat-blog_nishinomiya {
  color: #079d00;
}

.c-card-blog__category.is-cat-blog_ikeda {
  color: #d29700;
}

.c-card-blog__title {
  margin-top: 0.25rem;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
}
@media screen and (min-width: 768px) {
  .c-card-blog__title {
    font-size: 1.125rem;
  }
}

.c-card-member {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.25rem;
}

.c-card-member__img img {
  aspect-ratio: 167/166;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top;
     object-position: top;
}
@media screen and (min-width: 768px) {
  .c-card-member__img img {
    aspect-ratio: 265/315;
  }
}

.c-card-member__name {
  font-size: 0.8125rem;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .c-card-member__name {
    font-size: 1rem;
  }
}

.c-card-modal {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.25rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-card-modal {
    gap: 0.5rem;
  }
}

.c-card-modal__img img {
  aspect-ratio: 218/128;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-card-modal__title {
  font-size: 0.875rem;
  font-weight: 500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-right: 0.25rem;
}
@media screen and (min-width: 768px) {
  .c-card-modal__title {
    font-size: 1rem;
    padding-right: 0.5625rem;
  }
}

.c-card-modal__title span {
  width: 0.875rem;
  height: 0.875rem;
  border-radius: 50%;
  background-color: #ff7500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 768px) {
  .c-card-modal__title span {
    width: 1.1875rem;
    height: 1.1875rem;
  }
}

.c-card-modal__title span::after {
  content: "";
  width: 0.5rem;
  height: 0.1875rem;
  background: url(../images/icon_arrow-white.webp) no-repeat center/contain;
}
@media screen and (min-width: 768px) {
  .c-card-modal__title span::after {
    width: 0.6875rem;
    height: 0.25rem;
  }
}

.c-card-pickup {
  aspect-ratio: 1/1;
  position: relative;
  border-radius: 0.9375rem;
  border: 1px solid #f1f1f1;
}
@media screen and (min-width: 768px) {
  .c-card-pickup {
    border-radius: 1.4375rem 2.25rem 2.25rem 2.25rem;
    border: none;
  }
}

.c-card-pickup--title {
  display: none;
}
@media screen and (min-width: 768px) {
  .c-card-pickup--title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    font-family: "arial", sans-serif;
    font-size: 2rem;
    font-weight: normal;
    font-style: italic;
    color: #ff7500;
    line-height: 1.25;
    background-color: #ffffff;
    border-radius: 1.4375rem 2.25rem 2.25rem 2.25rem;
  }
}

.c-card-pickup__title {
  padding: 0.25rem 0.1875rem;
  font-size: 0.55rem;
  font-weight: 500;
  /* -webkit-writing-mode: vertical-rl; */
  -ms-writing-mode: tb-rl;
  /* writing-mode: vertical-rl; */
  background-color: #ffffffbf;
  border-radius: 4px;
  position: absolute;
  line-height: 1;
  z-index: 10;
  bottom: 0.2rem;
  left: 50%;
  transform: translateY(0%) translateX(-50%);
  white-space: nowrap;
  color: #333;
}
@media screen and (min-width: 768px) {
  .c-card-pickup__title {
    font-size: 1.75rem;
    padding: 0.4375rem 0.5rem;
    border-radius: 0.3125rem;
    font-size: 1.3rem;
    bottom: 0.5rem;
  }
}

.c-card-pickup__img {
  position: absolute;
  top: 0;
  left: 0;
}

.c-card-pickup__img img {
  aspect-ratio: 1/1;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .c-card-pickup__img img {
    border-radius: 1.4375rem 2.25rem 2.25rem 2.25rem;
  }
}

.c-card-service {
  padding-bottom: 1.875rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-card-service {
    padding-bottom: 4.375rem;
  }
}

.c-card-service::after {
  content: "";
  width: 100%;
  height: 3px;
  background: url(../images/line.webp) no-repeat center/cover;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .c-card-service::after {
    height: 4px;
  }
}

.c-card-service__img img {
  aspect-ratio: 500/256;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-card-service__tag {
  margin-top: 0.9375rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  height: 1.25rem;
  padding: 0 0.25rem;
  background-color: #ff7500;
  color: #ffffff;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.9375rem;
  font-weight: 900;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .c-card-service__tag {
    margin-top: 1.125rem;
    height: 1.375rem;
    font-size: 1.125rem;
  }
}

.c-card-service__tag.green {
  background-color: #8ec700;
}

.c-card-service__lead {
  margin-top: 0.25rem;
  font-size: 1.125rem;
  font-weight: 900;
}
@media screen and (min-width: 768px) {
  .c-card-service__lead {
    font-size: 1.375rem;
  }
}

.c-card-service__lead span {
  font-size: 0.875rem;
}
@media screen and (min-width: 768px) {
  .c-card-service__lead span {
    font-size: 1.125rem;
  }
}

.c-card-service__text {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  text-align: justify;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: #666;
}
@media screen and (min-width: 768px) {
  .c-card-service__text {
    margin-top: 0.75rem;
    font-size: 1.125rem;
  }
}

.c-card-service__condition {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-card-service__condition {
    margin-top: 1.5rem;
  }
}

.c-card-service__condition-title {
  font-size: 0.9375rem;
  font-weight: bold;
  color: #ff7500;
  padding-bottom: 0.375rem;
  border-bottom: 1px solid #ff7500;
}
@media screen and (min-width: 768px) {
  .c-card-service__condition-title {
    font-size: 1.125rem;
    padding-bottom: 1rem;
  }
}

.c-card-service__condition-title.green {
  color: #8ec700;
  border-bottom: 1px solid #8ec700;
}

.c-card-service__item {
  padding: 1rem 0;
  font-size: 0.9375rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  border-bottom: 1px solid #e5e5e5;
  line-height: 1.8666666667;
  letter-spacing: -0.014em;
}
@media screen and (min-width: 768px) {
  .c-card-service__item {
    font-size: 1.125rem;
  }
}

.c-card-service__caption {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: justify;
  color: #333;
  text-indent: -1em;
  padding-left: 1em;
}
@media screen and (min-width: 768px) {
  .c-card-service__caption {
    margin-top: 1rem;
    font-size: 1rem;
  }
}

.c-card-service__btn {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-card-service__btn {
    margin-top: 2.1875rem;
  }
}

.c-card-service__btn a {
  width: 100%;
  height: 3.4375rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border: 1px solid #ff7500;
  border-radius: 1.6875rem;
  font-size: 0.875rem;
  letter-spacing: 0.03em;
  color: #333;
  position: relative;
  padding-right: 2rem;
}
@media screen and (min-width: 768px) {
  .c-card-service__btn a {
    width: 24.25rem;
    height: 4.625rem;
    font-size: 0.9375rem;
    border-radius: 2.3125rem;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
}

.c-card-service__btn.green a {
  border: 1px solid #8ec700;
}

@media screen and (min-width: 768px) {
  .c-card-service__btn a:hover {
    opacity: 1;
    background-color: #ff7500;
    color: #ffffff;
  }
}

@media screen and (min-width: 768px) {
  .c-card-service__btn.green a:hover {
    background-color: #8ec700;
  }
}

.c-card-service__btn a span {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background-color: #ff7500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  top: 50%;
  right: 1rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .c-card-service__btn a span {
    width: 2.875rem;
    height: 2.875rem;
    right: 0.9375rem;
  }
}

.c-card-service__btn.green a span {
  background-color: #8ec700;
}

@media screen and (min-width: 768px) {
  .c-card-service__btn a:hover span {
    background-color: #ffffff;
  }
}

.c-card-service__btn a span::after {
  content: "";
  width: 1.125rem;
  height: 0.3125rem;
  background: url(../images/icon_arrow-white.webp) no-repeat center/contain;
}

@media screen and (min-width: 768px) {
  .c-card-service__btn a:hover span::after {
    background: url(../images/icon_arrow-orange.webp) no-repeat center/contain;
  }
}

@media screen and (min-width: 768px) {
  .c-card-service__btn.green a:hover span::after {
    background: url(../images/icon_arrow-green.webp) no-repeat center/contain;
  }
}

.c-card-shisetsu {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 7;
  gap: 0 !important;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.c-card-shisetsu__img img {
  aspect-ratio: 335/185;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 1.25rem 1.25rem 0 0;
}

.c-card-shisetsu__head {
  margin-top: 0.375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__head {
    margin-top: 1.25rem;
    gap: 1.875rem;
  }
}

.c-card-shisetsu__place {
  font-size: 0.9375rem;
  color: #ff7500;
  font-weight: bold;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  letter-spacing: 0.075em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__place {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__place.green {
  color: #7ac500;
}

.c-card-shisetsu__place.min {
  font-size: 0.8125rem;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__place.min {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__title {
  font-size: 0.8125rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__title {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__title.min {
  font-size: 0.6875rem;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__title.min {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__title span {
  font-size: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__title span {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__title.min span {
  font-size: 0.875rem;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__title.min span {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__tag-list {
  margin-top: 0.625rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.75rem 0.6875rem;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__tag-list {
    margin-top: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0.625rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.c-card-shisetsu__tag {
  height: 1.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #f9e76f;
  border-radius: 0.625rem;
  font-size: 0.875rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__tag {
    height: 1.6875rem;
    padding: 0 0.9375rem;
    border-radius: 0.875rem;
    font-size: 1rem;
  }
}

.c-card-shisetsu__tag.green {
  background-color: #cbef8f;
}

.c-card-shisetsu__address {
  margin-top: 0.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: #333;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__address {
    margin-top: 1.25rem;
    gap: 0.625rem;
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__address::before {
  content: "";
  width: 0.75rem;
  height: 1rem;
  background: url(../images/icon_point.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__address::before {
    width: 0.9375rem;
    height: 1.3125rem;
  }
}

.c-card-shisetsu__address.green::before {
  background: url(../images/icon_point-green.webp) no-repeat center/cover;
}

.c-card-shisetsu__tel-box {
  margin-top: 0.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__tel-box {
    margin-top: 0.625rem;
    gap: 1.25rem;
  }
}

.c-card-shisetsu__tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: #333;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__tel {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__tel::before {
  content: "";
  width: 0.6875rem;
  height: 1.0625rem;
  background: url(../images/icon_tel.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__tel::before {
    width: 1rem;
    height: 1rem;
  }
}

.c-card-shisetsu__tel.green::before {
  background: url(../images/icon_tel-green.webp) no-repeat center/cover;
}

.c-card-shisetsu__fax {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: #333;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__fax {
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__fax::before {
  content: "";
  width: 0.9375rem;
  height: 0.875rem;
  background: url(../images/icon_fax.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__fax::before {
    width: 1.375rem;
    height: 1.25rem;
  }
}

.c-card-shisetsu__fax.green::before {
  background: url(../images/icon_fax-green.webp) no-repeat center/cover;
}

.c-card-shisetsu__text {
  margin-top: 0.9375rem;
  padding-top: 0.625rem;
  position: relative;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: justify;
  color: #333;
  letter-spacing: 0.014em;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__text {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    font-size: 1.125rem;
  }
}

.c-card-shisetsu__text::before {
  content: "";
  width: 100%;
  height: 3px;
  background: url(../images/line.webp) no-repeat center/cover;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__text::before {
    height: 4px;
  }
}

.c-card-shisetsu__btns {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.6875rem;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__btns {
    margin-top: 1.25rem;
    gap: 1.125rem;
  }
}

.c-card-shisetsu__btn a {
  height: 2.1875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 1.0625rem;
  border: 1px solid #ff7500;
  font-size: 0.875rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  position: relative;
  background-color: #ffffff;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__btn a {
    height: 2.3125rem;
    font-size: 0.9375rem;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
}

.c-card-shisetsu__btn.green a {
  border: 1px solid #7ac500;
}

.c-card-shisetsu__btn a::after {
  content: "";
  width: 1.125rem;
  height: 0.3125rem;
  background: url(../images/icon_arrow-black.webp) no-repeat center/contain;
  position: absolute;
  top: 50%;
  right: 0.6875rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .c-card-shisetsu__btn a::after {
    right: 1.25rem;
  }
}

@media screen and (min-width: 768px) {
  .c-card-shisetsu__btn a:hover {
    opacity: 1;
    background-color: #ff7500;
    color: #ffffff;
  }
}

@media screen and (min-width: 768px) {
  .c-card-shisetsu__btn a:hover::after {
    background: url(../images/icon_arrow-white.webp) no-repeat center/contain;
  }
}

@media screen and (min-width: 768px) {
  .c-card-shisetsu__btn.green a:hover {
    background-color: #7ac500;
  }
}

.c-card-support__img img {
  aspect-ratio: 335/185;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .c-card-support__img img {
    aspect-ratio: 360/284;
  }
}

.c-card-support__body {
  background-color: #ffffff;
  padding: 1rem 1.125rem;
}
@media screen and (min-width: 768px) {
  .c-card-support__body {
    padding: 1rem 1rem 1.5rem;
  }
}

.c-card-support__title {
  font-size: 0.9375rem;
  font-weight: 500;
  color: #ff7500;
  letter-spacing: 0.075em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .c-card-support__title {
    font-size: 1.125rem;
  }
}

.c-card-support__text {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  color: #333;
  letter-spacing: 0.072em;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .c-card-support__text {
    font-size: 1rem;
    letter-spacing: 0.04em;
  }
}

@media screen and (min-width: 768px) {
  .c-card-support__text.ls-0 {
    letter-spacing: 0.04em;
  }
}

.c-flow__title {
  font-size: 1.125rem;
  font-weight: bold;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .c-flow__title {
    font-size: 1.625rem;
  }
}

.c-flow__title span {
  font-size: 0.875rem;
  font-weight: normal;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .c-flow__title span {
    font-size: 1.125rem;
  }
}

.c-flow__list {
  margin-top: 0.5rem;
}
@media screen and (min-width: 768px) {
  .c-flow__list {
    margin-top: 1.25rem;
  }
}

.c-flow__item {
  padding: 1rem 0.875rem;
  border: 1px solid #ff7500;
  border-radius: 0.625rem;
  font-size: 0.9375rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .c-flow__item {
    padding: 1.25rem;
    font-size: 1.25rem;
  }
}

.c-flow__item:nth-child(n+2) {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .c-flow__item:nth-child(n+2) {
    margin-top: 1.6875rem;
  }
}

.c-flow__item span {
  font-size: 0.875rem;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .c-flow__item span {
    font-size: 0.9375rem;
  }
}

.c-flow__item:not(:last-of-type) {
  position: relative;
}

.c-flow__item:not(:last-of-type)::after {
  content: "";
  position: absolute;
  bottom: -30%; /* ▼の位置調整 */
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 8px solid transparent;  /* 左斜辺 */
  border-right: 8px solid transparent; /* 右斜辺 */
  border-top: 10px solid #f57c00; /* ▼の色（変更OK） */
}

.c-item-info {
  display: block;
  padding: 0.9375rem 0 0.5rem;
  border-top: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .c-item-info {
    padding: 1.375rem 0.625rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.c-item-info__meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.c-item-info__time {
  font-size: 0.75rem;
  font-weight: 500;
  padding-right: 0.8125rem;
  border-right: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .c-item-info__time {
    padding-right: 2rem;
  }
}

.c-item-info__category {
  padding: 0 0.6875rem;
  min-width: 8.75rem;
  height: 1.25rem;
  border-radius: 0.625rem;
  border: 1px solid;
  font-size: 0.8125rem;
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-left: 0.625rem;
}
@media screen and (min-width: 768px) {
  .c-item-info__category {
    margin-right: 0.625rem;
  }
}

.c-item-info__category.is-cat-info_com {
  border-color: #fe4d11;
}

.c-item-info__category.is-cat-info_himeji {
  border-color: #d70000;
}

.c-item-info__category.is-cat-info_kobe {
  border-color: #0066cf;
}

.c-item-info__category.is-cat-info_kobe_duo {
  border-color: #00cfff;
}

.c-item-info__category.is-cat-info_nishinomiya {
  border-color: #079d00;
}

.c-item-info__category.is-cat-info_ikeda {
  border-color: #d29700;
}

.c-item-info__category.is-cat-info_important {
  border-color: #d600d0;
}

.c-item-info__category.is-cat-info_recruit {
  border-color: #ff9320;
}

.c-item-info__category.is-cat-info_open {
  border-color: #999999;
}

.c-item-info__title {
  margin-top: 0.625rem;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.625;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
}
@media screen and (min-width: 768px) {
  .c-item-info__title {
    font-size: 1.125rem;
    margin-top: 0;
    padding-left: 0.625rem;
    position: relative;
    -webkit-line-clamp: 2;
  }
}

@media screen and (min-width: 768px) {
  .c-item-info__title::before {
    content: "";
    width: 1px;
    height: 0.8125rem;
    background-color: #e5e5e5;
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

.c-item-philosophy {
  color: #ffffff;
  width: 16.6875rem;
}
@media screen and (min-width: 768px) {
  .c-item-philosophy {
    width: auto;
  }
}

.c-item-philosophy__lead {
  font-size: 0.9375rem;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: -0.014em;
}
@media screen and (min-width: 768px) {
  .c-item-philosophy__lead {
    font-size: 1.375rem;
  }
}

.c-item-philosophy__text {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: -0.045em;
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .c-item-philosophy__text {
    margin-top: 1rem;
    font-size: 1rem;
    line-height: 2;
  }
}

.c-pagination-post {
  padding: 0.5rem 0;
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .c-pagination-post {
    padding: 1rem 0;
  }
}

.c-pagination-post__inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  font-size: 0.75rem;
  color: #666;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .c-pagination-post__inner {
    font-size: 0.9375rem;
  }
}

.c-pagination-post__prev,
.c-pagination-post__back,
.c-pagination-post__next {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.5rem;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

.c-pagination-post__prev:hover,
.c-pagination-post__back:hover,
.c-pagination-post__next:hover {
  opacity: 1;
  color: #ff7500;
}

.c-pagination-post__prev {
  border-right: 1px solid #000000;
}

.c-pagination-post__prev::before {
  content: "";
  width: 0.375rem;
  height: 0.375rem;
  border-left: 1px solid #666;
  border-top: 1px solid #666;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

.c-pagination-post__prev:hover::before {
  border-left: 1px solid #ff7500;
  border-top: 1px solid #ff7500;
}

.c-pagination-post__back::before {
  content: "";
  width: 0.75rem;
  height: 0.75rem;
  background: url(../images/icon_back.webp) no-repeat center/cover;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
@media screen and (min-width: 768px) {
  .c-pagination-post__back::before {
    width: 1rem;
    height: 1rem;
  }
}

.c-pagination-post__back:hover::before {
  background: url(../images/icon_back-orange.webp) no-repeat center/cover;
}

.c-pagination-post__next {
  border-left: 1px solid #000000;
}

.c-pagination-post__next::after {
  content: "";
  width: 0.375rem;
  height: 0.375rem;
  border-right: 1px solid #666;
  border-bottom: 1px solid #666;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

.c-pagination-post__next:hover::after {
  border-right: 1px solid #ff7500;
  border-bottom: 1px solid #ff7500;
}

.c-pagination--blog {
  padding-left: 1.8125rem;
}

.c-pagination .nav-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .c-pagination .nav-links {
    gap: 1.25rem;
  }
}

@media screen and (min-width: 768px) {
  .c-pagination--blog .nav-links {
    gap: 0.625rem;
  }
}

.c-pagination .nav-links span,
.c-pagination .nav-links a {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  border: 1px solid #ff7500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background-color: #ffffff;
  font-size: 0.875rem;
  color: #ff7500;
  letter-spacing: 0.1em;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
@media screen and (min-width: 768px) {
  .c-pagination .nav-links span,
  .c-pagination .nav-links a {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1.125rem;
  }
}

.c-pagination--blog .nav-links span,
.c-pagination--blog .nav-links a {
  min-width: 2.875rem;
  width: auto;
  height: 2.5rem;
  border: 1px solid #f1f1f1;
  border-radius: 0.1875rem;
  -webkit-box-shadow: 2px 0 0 #f1f1f1;
          box-shadow: 2px 0 0 #f1f1f1;
  color: #666666;
  padding: 0 1.25rem;
}
.c-pagination .nav-links span.current {
  background-color: #ff7500;
  color: #ffffff;
}

.c-pagination--blog .nav-links span.current {
  background-color: #f5c92f;
  color: #ffffff;
}

.c-pagination .nav-links a.prev::after,
.c-pagination .nav-links a.next::after {
  content: "";
  width: 0.75rem;
  height: 0.25rem;
  background: url(../images/icon_arrow-orange.webp) no-repeat center/contain;
}
@media screen and (min-width: 768px) {
  .c-pagination .nav-links a.prev::after,
  .c-pagination .nav-links a.next::after {
    width: 1.125rem;
    height: 0.3125rem;
  }
}

.c-pagination--blog .nav-links a.prev::after,
.c-pagination--blog .nav-links a.next::after {
  content: none;
}

.c-pagination .nav-links a.prev::after {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.c-pagination .nav-links a:hover {
  background-color: #ff7500;
  color: #ffffff;
  opacity: 1;
}

.c-pagination--blog .nav-links a:hover {
  background-color: #f5c92f;
  color: #ffffff;
  opacity: 1;
}

.c-pagination .nav-links a.prev:hover::after,
.c-pagination .nav-links a.next:hover::after {
  background: url(../images/icon_arrow-white.webp) no-repeat center/contain;
}

.c-section-title {
  font-size: 1.625rem;
  font-weight: 900;
  color: #ff7500;
  letter-spacing: 0.075em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .c-section-title {
    font-size: 2.25rem;
    letter-spacing: 0.23em;
  }
}
.p-recruit .c-section-title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  white-space: nowrap;
}

.c-section-title::before {
  content: attr(data-en);
  font-size: 0.8125rem;
  color: #000000;
  letter-spacing: 0.075em;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .c-section-title::before {
    font-size: 0.875rem;
  }
}
@media (max-width: 750px) {
  .c-section-title {
    font-size: 1.3rem;
    letter-spacing: 0em;
  }
}

.c-title-box__title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  padding-bottom: 0.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-title-box__title {
    padding-bottom: 0.75rem;
  }
}

.c-title-box__title::after {
  content: "";
  width: 100%;
  height: 3px;
  background: url(../images/line.webp) no-repeat center/cover;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .c-title-box__title::after {
    height: 4px;
  }
}

.c-title-box__title-icon {
  width: 5.875rem;
  margin-right: 0.625rem;
}
@media screen and (min-width: 768px) {
  .c-title-box__title-icon {
    width: 8.6875rem;
    margin-right: 0.9375rem;
  }
}

.c-title-box__title-icon--kayou {
  width: 4.875rem;
}
@media screen and (min-width: 768px) {
  .c-title-box__title-icon--kayou {
    width: 7.25rem;
  }
}

.c-title-box__name {
  padding-left: 0.625rem;
  font-size: 1.125rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  border-left: 1px solid #e5e5e5;
  margin-top: 3.5rem;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .c-title-box__name {
    padding-left: 1rem;
    font-size: 1.625rem;
    margin-top: 5.25rem;
  }
}

.c-title-box__name.min {
  font-size: 1rem;
  letter-spacing: -0.04em;
}
@media screen and (min-width: 768px) {
  .c-title-box__name.min {
    font-size: 1.625rem;
    letter-spacing: 0.05em;
  }
}

.c-title-box__name span {
  font-size: 0.875rem;
  font-weight: normal;
}

.c-title-box__name.min span {
  font-size: 0.75rem;
}
@media screen and (min-width: 768px) {
  .c-title-box__name.min span {
    font-size: 0.875rem;
  }
}

.c-title-box__text {
  margin-top: 0.625rem;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  text-align: justify;
  color: #666;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .c-title-box__text {
    margin-top: 1rem;
    font-size: 1.125rem;
    letter-spacing: 0.05em;
  }
}

@media screen and (min-width: 768px) {
  .c-title-box__text.ls-0 {
    letter-spacing: 0;
  }
}

.c-top-title {
  font-size: 1.125rem;
  font-weight: bold;
  letter-spacing: 0.075em;
  line-height: 1.5;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .c-top-title {
    font-size: 1.25rem;
    line-height: 1.7;
    letter-spacing: 0.06em;
  }
}

.c-top-title span.marker {
  display: inline-block;
  font-size: 0.9375rem;
  letter-spacing: 0.02em;
  color: #ffffff;
  line-height: 1;
  background-color: #ff4d0b;
  padding: 0.125rem 0.25rem 0.1875rem;
}
@media screen and (min-width: 768px) {
  .c-top-title span.marker {
    font-size: 1.25rem;
    line-height: 1.2;
    letter-spacing: 0.075em;
  }
}

.c-top-title span.mid {
  font-weight: 900;
  font-size: 1.0625rem;
}
@media screen and (min-width: 768px) {
  .c-top-title span.mid {
    font-size: 1.625rem;
  }
}

.c-top-title span.la {
  font-size: 1.25rem;
  color: #ff7500;
  font-weight: 900;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  .c-top-title span.la {
    font-size: 2.25rem;
    letter-spacing: 0.07em;
  }
}

.c-top-title span.la.black {
  color: #000000;
}

.p-about-fv {
  background: url(../images/about-fv-sp.webp) no-repeat center/cover;
  aspect-ratio: 375/474;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-about-fv {
    background: url(../images/about-fv.webp) no-repeat center/cover;
    aspect-ratio: 1400/997;
  }
}

.p-about-fv__inner {
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (min-width: 768px) {
  .p-about-fv__inner {
    padding-bottom: 2rem;
  }
}

.p-about-fv__lead .sukima {
	width: 0.3rem;
	display: inline-block;
}
.p-about-fv__lead {
  font-family: "Montserrat", sans-serif;
  font-size: 2.3rem;
  font-weight: 700;
  color: #1e2136;
  line-height: 1.05;
  margin-bottom: -0.1rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: 0.02em; /* ← Safari・Chromeの差を吸収 */
}

@media screen and (min-width: 768px) {
  .p-about-fv__lead {
    font-size: 5.625rem;
    line-height: 1.1;
    letter-spacing: 0.04em;
  }
}

.p-about-lead {
  background: url(../images/about-lead_bg.webp) no-repeat center/cover;
  position: relative;
}

@media screen and (min-width: 768px) {
  .p-about-lead__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 2.625rem;
  }
}

.p-about-lead__body {
  position: relative;
  z-index: 10;
}
@media screen and (min-width: 768px) {
  .p-about-lead__body {
    width: 50%;
  }
}

.p-about-lead__title {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 1.6666666667;
}
@media screen and (min-width: 768px) {
  .p-about-lead__title {
    font-size: 1.625rem;
  }
}

.p-about-lead__text-area {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-about-lead__text-area {
    margin-top: 1.875rem;
  }
}

@media screen and (min-width: 768px) {
  .p-about-lead__text-area.sp {
    display: none;
  }
}

.p-about-lead__text-area.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-about-lead__text-area.pc {
    display: block;
  }
}

.p-about-lead__text {
  font-size: 0.875rem;
  line-height: 1.86;
  letter-spacing: -0.05em;
}
@media screen and (min-width: 768px) {
  .p-about-lead__text {
    font-size: 1rem;
    letter-spacing: -0.03em;
  }
}

.p-about-lead__text:nth-child(n+2) {
  margin-top: 0.5em;
}

.p-about-lead__img {
  max-width: 22.25rem;
  margin-top: -2.1875rem;
}
@media screen and (min-width: 768px) {
  .p-about-lead__img {
    max-width: 100%;
    width: 44.4545454545%;
    margin-top: 0;
  }
}

.p-about-service__blocks {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-about-service__blocks {
    margin-top: 4.375rem;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
}

@media screen and (min-width: 768px) {
  .p-access__inner {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.1875rem;
  }
}

@media screen and (min-width: 768px) {
  .p-access__title-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    border: 1px solid #ff7500;
    border-radius: 1.25rem;
  }
}

.p-access__cards {
  margin-top: 1.375rem;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-access__cards {
    display: contents;
  }
}

.p-archive {
  background: url(../images/bg-grey.webp) repeat center/contain;
}

.p-archive--single {
  background: none;
}

.p-archive--blog {
  background: none;
}

.p-archive__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  gap: 2.5rem;
}
@media screen and (min-width: 768px) {
  .p-archive__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 6.25rem;
  }
}

@media screen and (min-width: 768px) {
  .p-archive__article {
    width: 74%;
  }
}

@media screen and (min-width: 768px) {
  .p-archive__aside {
    width: 26%;
    position: relative;
    z-index: 100;
  }
}

.p-art {
  background-color: #fbfbfb;
}

.p-art__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-art__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 6.25rem;
  }
}

@media screen and (min-width: 768px) {
  .p-art__img {
    width: 40.9090909091%;
  }
}

.p-art__img img {
  aspect-ratio: 335/200;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-art__img img {
    aspect-ratio: 448/394;
  }
}

@media screen and (min-width: 768px) {
  .p-art__body {
    width: 50%;
  }
}

.p-art__title {
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.075em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.5rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .p-art__title {
    font-size: 2.25rem;
    gap: 0.9375rem;
  }
}

.p-art__title span {
  font-size: 0.8125rem;
}
@media screen and (min-width: 768px) {
  .p-art__title span {
    font-size: 1.375rem;
  }
}

.p-art__text {
  margin-top: 1.125rem;
  font-size: 1rem;
  line-height: 1.75;
  letter-spacing: -0.05em;
  color: #333;
}
@media screen and (min-width: 768px) {
  .p-art__text {
    margin-top: 2rem;
    font-size: 1.125rem;
    line-height: 1.7777777778;
  }
}

.p-art__btn {
  margin-top: 1.25rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-art__btn {
    margin-top: 3.25rem;
    text-align: left;
  }
}

.p-art__btn a {
  background-color: #ffffff;
}

@media screen and (min-width: 768px) {
  .p-article--blog {
    border: 1px solid #e5e5e5;
    border-radius: 0.6875rem;
    padding-bottom: 2.6875rem;
  }
}

.p-article__pagination {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-article__pagination {
    margin-top: 2.875rem;
  }
}

.p-article__cards {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-article__cards {
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
  }
}

.p-article__card {
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
@media screen and (min-width: 768px) {
  .p-article__card {
    padding: 1.75rem;
    border: 1px solid #e5e5e5;
  }
}

.p-article__card:hover {
  opacity: 1;
  background-color: #fffcf1;
}

.p-aside__box:nth-child(n+2) {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-aside__box:nth-child(n+2) {
    margin-top: 2.625rem;
  }
}

.p-aside__box-title {
  font-size: 1rem;
  font-weight: bold;
  line-height: 2;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid #000000;
}
@media screen and (min-width: 768px) {
  .p-aside__box-title {
    font-size: 1.125rem;
    padding-bottom: 1rem;
  }
}

.p-aside__list {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 2.5;
}
@media screen and (min-width: 768px) {
  .p-aside__list {
    margin-top: 1rem;
    font-size: 1rem;
  }
}

.p-aside__item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

.p-aside__item a.current {
  color: #ff7500;
}

.p-aside__item a::before {
  content: "";
  width: 0.25rem;
  height: 0.25rem;
  border-right: 1.5px solid #000000;
  border-bottom: 1.5px solid #000000;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
@media screen and (min-width: 768px) {
  .p-aside__item a::before {
    width: 0.375rem;
    height: 0.375rem;
  }
}

.p-aside__item a:hover {
  opacity: 1;
  color: #ff7500;
}

.p-aside__select {
  margin-top: 1rem;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-aside__select {
    margin-top: 1.875rem;
  }
}

.p-aside__select select {
  width: 100%;
  height: 2.5rem;
  border: 1px solid #e5e5e5;
  border-radius: 0;
  padding: 0 0.5rem 0 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: #cccccc;
  appearance: none; /* 標準の矢印を非表示（Chrome・Safari） */
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
  background-color: #fbfbfb;
}
@media screen and (min-width: 768px) {
  .p-aside__select select {
    height: 3.4375rem;
    padding: 0 0.875rem 0 1.8125rem;
    font-size: 1rem;
  }
}

.p-aside__select::after {
  content: "";
  display: block;
  width: 0.375rem;
  height: 0.375rem;
  border-right: 1.5px solid #000000;
  border-bottom: 1.5px solid #000000;
  position: absolute;
  top: 50%;
  right: 0.875rem;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

@media screen and (min-width: 768px) {
  .p-block-service {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
  }
}

@media screen and (min-width: 768px) {
  .p-block-service::after {
    content: "";
    width: 100vw;
    height: 100%;
    background: url(../images/about-lead_bg.webp) repeat center/contain;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    z-index: -1;
  }
}

.p-block-service__img {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .p-block-service__img {
    margin-right: 0;
    width: 50%;
    background-color: #ffffff;
  }
}

@media screen and (min-width: 768px) {
  .p-block-service__img picture {
    position: sticky;
    top: 0;
  }
}

.p-block-service__img img {
  aspect-ratio: 375/215;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: top;
     object-position: top;
}
@media screen and (min-width: 768px) {
  .p-block-service__img img {
    aspect-ratio: 7/11;
  }
}

.p-block-service__body {
  position: relative;
  padding: 1.875rem 0 0;
}
@media screen and (min-width: 768px) {
  .p-block-service__body {
    width: 50%;
    padding: 2.9375rem 9.3125rem 7.375rem 4.0625rem;
  }
}

.p-block-service__body::after {
  content: "";
  width: 100vw;
  height: 100%;
  background: url(../images/about-lead_bg.webp) repeat center/contain;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .p-block-service__body::after {
    content: none;
  }
}

.p-block-service__title-box {
  padding-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-block-service__title-box {
    padding-bottom: 3rem;
    position: relative;
  }
}

@media screen and (min-width: 768px) {
  .p-block-service__title-box::before {
    content: "";
    width: 100%;
    height: 3px;
    background: url(../images/line.webp) no-repeat center/cover;
    position: absolute;
    top: -2.9375rem;
    left: 0;
  }
}

.p-block-service__title {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  height: 1.75rem;
  padding: 0 1.25rem;
  font-size: 1.125rem;
  font-weight: 900;
  letter-spacing: 0.075em;
  color: #ffffff;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .p-block-service__title {
    font-size: 1.75rem;
    height: 2.375rem;
    padding: 0 0.25rem;
  }
}

.p-block-service__title.orange {
  background-color: #ff7500;
}

.p-block-service__title.green {
  background-color: #5ec700;
}

.p-block-service__text {
  margin-top: 1rem;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  color: #333;
  text-align: justify;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: -0.045em;
}
@media screen and (min-width: 768px) {
  .p-block-service__text {
    margin-top: 1.5rem;
    font-size: 1rem;
    line-height: 2;
    color: #666666;
    letter-spacing: 0.075em;
  }
}

.p-block-service__card {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 1.5rem 1.25rem 1.875rem;
}
@media screen and (min-width: 768px) {
  .p-block-service__card {
    margin-left: 0;
    margin-right: 0;
    padding: 0;
  }
}

@media screen and (min-width: 768px) {
  .p-block-service__card:nth-child(n+2) {
    margin-top: 2.625rem;
  }
}

.p-block-shisetsu__swiper-content {
  position: relative;
}

@media screen and (min-width: 768px) {
  .p-block-shisetsu__img {
    border-radius: 1.25rem;
  }
}

.p-block-shisetsu__img img {
  aspect-ratio: 335/225;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-block-shisetsu__img img {
    border-radius: 1.25rem;
    aspect-ratio: 585/388;
  }
}

.p-block-shisetsu__prev,
.p-block-shisetsu__next {
  width: 1.875rem;
  height: 1.875rem;
  background-color: #ff7500;
  border-radius: 50%;
}
@media screen and (min-width: 768px) {
  .p-block-shisetsu__prev,
  .p-block-shisetsu__next {
    width: 2.875rem;
    height: 2.875rem;
  }
}

.p-block-shisetsu__prev {
  left: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}

.p-block-shisetsu__prev::after,
.p-block-shisetsu__next::after {
  content: "";
  width: 0.375rem;
  height: 0.5625rem;
  background: url(../images/icon_arrow-swiper.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-block-shisetsu__prev::after,
  .p-block-shisetsu__next::after {
    width: 1.125rem;
    height: 0.3125rem;
    background: url(../images/icon_arrow-white.webp) no-repeat center/cover;
  }
}

.p-block-shisetsu__prev::after {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.p-block-shisetsu__next {
  right: 0;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
}

.p-block-shisetsu__boxies {
  margin-top: -2rem;
  position: relative;
  z-index: 20;
}
@media screen and (min-width: 768px) {
  .p-block-shisetsu__boxies {
    margin-top: -3.875rem;
  }
}

.p-block-shisetsu__box:nth-child(n+2) {
  margin-top: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p-block-shisetsu__box:nth-child(n+2) {
    margin-top: 2rem;
  }
}

.p-block-shisetsu__title-box.mt40 {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-block-shisetsu__title-box.mt40 {
    margin-top: 2rem;
  }
}

.p-block-shisetsu__flow {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-block-shisetsu__flow {
    margin-top: 2.625rem;
  }
}

.p-blog-fv {
  background: url(../images/blog-fv_bg.webp) repeat center/contain;
  position: relative;
}

@media screen and (min-width: 768px) {
  .p-blog-fv::after {
    content: "";
    width: 100%;
    height: 61.75rem;
    background: url(../images/blog-bg.webp) no-repeat center/cover;
    position: absolute;
    top: -7.6875rem;
    left: 0;
  }
}

.p-blog-fv__title {
  color: #000000;
}

.p-blog {
  position: relative;
  overflow: hidden;
}

.p-blog::before {
  content: "";
  width: 100%;
  height: 0.25rem;
  background: url(../images/line.webp) no-repeat center/cover;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .p-blog::before {
    background: url(../images/line-pc.webp) no-repeat center/cover;
  }
}

.p-blog--shisetsu::before {
  content: none;
}

@media screen and (min-width: 768px) {
  .p-blog__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    gap: 3.125rem;
  }
}

@media screen and (min-width: 768px) {
  .p-blog__title-box {
    width: 17.375rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

@media screen and (min-width: 768px) {
  .p-blog_title {
    width: 100%;
    aspect-ratio: 1/1;
    border-radius: 0.625rem;
    background-color: #ff7500;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    color: #ffffff;
    font-family: "arial", sans-serif;
    font-style: italic;
    font-size: 2rem;
    line-height: 1.25;
    letter-spacing: 0.066em;
  }
}

@media screen and (min-width: 768px) {
  .p-blog__body {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 auto;
            flex: 1 1 auto;
    min-width: 0;
  }
}

.p-blog__categories {
  margin-top: 2.25rem;
}
@media screen and (min-width: 768px) {
  .p-blog__categories {
    margin-top: 0;
  }
}

.p-blog__swiper {
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-blog__swiper {
    margin-top: 1.875rem;
    margin-right: calc(50% - 50vw);
    height: 22.375rem;
  }
}

.p-blog__card {
  width: 14.0625rem;
}
@media screen and (min-width: 768px) {
  .p-blog__card {
    width: 17.375rem;
  }
}

.p-blog__btn {
  margin-top: 1.25rem;
  text-align: center;
}

@media screen and (min-width: 768px) {
  .p-blog__btn a {
    width: 100%;
    height: 3.75rem;
  }
}

.p-categories {
  border: 1px solid #e5e5e5;
  border-radius: 0.375rem;
  color: #333;
}
@media screen and (min-width: 768px) {
  .p-categories {
    border: none;
  }
}

.p-categories__title {
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.064em;
  padding: 0.75rem 1.0625rem 0.75rem 1.25rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-categories__title {
    display: none;
  }
}

.p-categories__title::before,
.p-categories__title::after {
  content: "";
  width: 0.875rem;
  height: 1px;
  background-color: #333;
  position: absolute;
  top: 50%;
  right: 1.0625rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

.p-categories__title::after {
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
}

.p-categories__title.close::after {
  -webkit-transform: translateY(-50%) rotate(0deg);
          transform: translateY(-50%) rotate(0deg);
}

.p-categories__list {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-categories__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0.625rem 0.5rem;
  }
}

.p-categories__category {
  border-top: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .p-categories__category {
    border-top: none;
  }
}

.p-categories__category button {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.064em;
  padding: 0.75rem 1.25rem 0.6875rem;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (min-width: 768px) {
  .p-categories__category button {
    font-size: 0.875rem;
    font-weight: normal;
    color: #000000;
    padding: 0 0.75rem 0.1em;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 1.25rem;
    border-radius: 0.625rem;
    border: 1px solid;
    letter-spacing: 0;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category button:hover {
    color: #ffffff;
    opacity: 1;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-active button {
    color: #ffffff;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-all button {
    border-color: #ff0000;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-all.is-active button {
    background-color: #ff0000;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-all button:hover {
    background-color: #ff0000;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_com button,
  .p-categories__category.is-cat-blog_honbu button {
    border-color: #fe4d11;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_com.is-active button,
  .p-categories__category.is-cat-blog_honbu.is-active button {
    background-color: #fe4d11;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_com button:hover,
  .p-categories__category.is-cat-blog_honbu button:hover {
    background-color: #fe4d11;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_himeji button,
  .p-categories__category.is-cat-blog_himeji button {
    border-color: #d70000;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_himeji.is-active button,
  .p-categories__category.is-cat-blog_himeji.is-active button {
    background-color: #d70000;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_himeji button:hover,
  .p-categories__category.is-cat-blog_himeji button:hover {
    background-color: #d70000;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_kobe button,
  .p-categories__category.is-cat-blog_kobe button {
    border-color: #0066cf;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_kobe.is-active button,
  .p-categories__category.is-cat-blog_kobe.is-active button {
    background-color: #0066cf;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_kobe button:hover,
  .p-categories__category.is-cat-blog_kobe button:hover {
    background-color: #0066cf;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_kobe_duo button,
  .p-categories__category.is-cat-blog_kobe_duo button {
    border-color: #00cfff;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_kobe_duo.is-active button,
  .p-categories__category.is-cat-blog_kobe_duo.is-active button {
    background-color: #00cfff;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_kobe_duo button:hover,
  .p-categories__category.is-cat-blog_kobe_duo button:hover {
    background-color: #00cfff;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_nishinomiya button,
  .p-categories__category.is-cat-blog_nishinomiya button {
    border-color: #079d00;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_nishinomiya.is-active button,
  .p-categories__category.is-cat-blog_nishinomiya.is-active button {
    background-color: #079d00;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_nishinomiya button:hover,
  .p-categories__category.is-cat-blog_nishinomiya button:hover {
    background-color: #079d00;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_ikeda button,
  .p-categories__category.is-cat-blog_ikeda button {
    border-color: #d29700;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_ikeda.is-active button,
  .p-categories__category.is-cat-blog_ikeda.is-active button {
    background-color: #d29700;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_ikeda button:hover,
  .p-categories__category.is-cat-blog_ikeda button:hover {
    background-color: #d29700;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_important button {
    border-color: #d600d0;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_important.is-active button {
    background-color: #d600d0;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_important button:hover {
    background-color: #d600d0;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_recruit button {
    border-color: #ff9320;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_recruit.is-active button {
    background-color: #ff9320;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_recruit button:hover {
    background-color: #ff9320;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_open button {
    border-color: #999999;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_open.is-active button {
    background-color: #999999;
  }
}

@media screen and (min-width: 768px) {
  .p-categories__category.is-cat-info_open button:hover {
    background-color: #999999;
  }
}

.p-categories__category button::after {
  content: "";
  width: 0.5rem;
  height: 0.3125rem;
  background: url(../images/icon_arrow.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-categories__category button::after {
    content: none;
  }
}

.p-contact-box {
  background-color: #fef4d1;
  text-align: center;
}

.p-contact-box__title {
  color: #000000;
  font-family: "dnp-shuei-gothic-gin-std", sans-serif;
  letter-spacing: 0.075em;
}

.p-contact-box__title::before {
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0.15em;
  margin-bottom: 0.25rem;
}
@media screen and (min-width: 768px) {
  .p-contact-box__title::before {
    margin-bottom: 0.625rem;
  }
}

.p-contact-box__text {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.075em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .p-contact-box__text {
    font-size: 1.125rem;
  }
}

.p-contact__btns {
  margin-top: 1.75rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .p-contact__btns {
    margin-top: 1.625rem;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 4.125rem;
  }
}

.p-contact-box__btn a {
  background-color: #ffffff;
}

.p-contact {
  position: relative;
  z-index: 10;
}

.p-contact__block:nth-child(n+2) {
  /* margin-top: 2.5rem; */
  margin-top: -2.5rem;
  padding-top: 5rem;
}
@media screen and (min-width: 768px) {
  .p-contact__block:nth-child(n+2) {
    /* margin-top: 4.5rem; */
    margin-top: unset;
    padding-top: 4.5rem;
  }
}

.p-contact__title {
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.3636363636;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
  padding-bottom: 1rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-contact__title {
    font-size: 1.375rem;
    padding-bottom: 1.5rem;
  }
}

.p-contact__title::after {
  content: "";
  width: 100%;
  height: 0.1875rem;
  background: url(../images/line.webp) no-repeat center/cover;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .p-contact__title::after {
    height: 0.25rem;
    background: url(../images/line-pc.webp) no-repeat center/cover;
  }
}

.p-contact__tel-boxies {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-contact__tel-boxies {
    margin-top: 1.5rem;
  }
}

.p-contact__tel-box:nth-child(n+2) {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-contact__tel-box:nth-child(n+2) {
    margin-top: 2.625rem;
  }
}

.p-contact__tel-title {
  font-size: 1rem;
  font-weight: bold;
  line-height: 1.5;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
  color: #ff7500;
}
@media screen and (min-width: 768px) {
  .p-contact__tel-title {
    font-size: 1.25rem;
  }
}

.p-contact__tel-cards {
  margin-top: 1rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .p-contact__tel-cards {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 4.375rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

@media screen and (min-width: 768px) {
  .p-contact__tel-card {
    width: calc(50% - 2.1875rem);
  }
}

.p-contact__tel-card {
  padding: 1rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .p-contact__tel-card {
    padding: 1rem 1.625rem 1rem 0;
  }
}

.p-contact__tel-name {
  font-size: 1rem;
  font-weight: bold;
  line-height: 1.6666666667;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-contact__tel-name {
    font-size: 1.125rem;
  }
}

.p-contact__tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.375rem;
}
@media screen and (min-width: 768px) {
  .p-contact__tel {
    gap: 0.75rem;
  }
}

.p-contact__tel a,
.p-contact__tel span {
  font-size: 1rem;
  font-weight: bold;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
  color: #333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.375rem;
}
@media screen and (min-width: 768px) {
  .p-contact__tel a,
  .p-contact__tel span {
    font-size: 1.125rem;
    gap: 0.6875rem;
  }
}

.p-contact__tel a::before,
.p-contact__tel span::before {
  content: "";
  width: 1.25rem;
  height: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-contact__tel a::before,
  .p-contact__tel span::before {
    width: 1.5625rem;
    height: 1.5625rem;
  }
}

.p-contact__tel a::before {
  background: url(../images/icon_contact-tel.webp) no-repeat center/cover;
}

.p-contact__tel span::before {
  background: url(../images/icon_contact-fax.webp) no-repeat center/cover;
}

.p-contact__form {
  margin-top: 1.5rem;
  max-width: 48.125rem;
}
@media screen and (min-width: 768px) {
  .p-contact__form {
    margin-top: 4.5rem;
  }
}

.p-contact__form-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 2.5rem;
  }
}

.p-contact__form-box:nth-child(n+2) {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box:nth-child(n+2) {
    margin-top: 2.5rem;
  }
}

.p-contact__form-box dt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1rem;
  font-size: 0.9375rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box dt {
    width: 27.9220779221%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-top: 1.25rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.p-contact__form-box dt span {
  color: #c12b0f;
}

.p-contact__form-box dd {
  font-size: 0.9375rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box dd {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
}
@media (max-width: 750px) {
	.p-contact__form-box dd {
	margin: 0 auto;
	}
}

.p-contact__form-box dd span.wpcf7-form-control-wrap {
  width: 100%;
}

.p-contact__form-box dd input[type=text],
.p-contact__form-box dd input[type=email],
.p-contact__form-box dd input[type=tel] {
  width: 100%;
  height: 2.5rem;
  background-color: #fbfbfb;
  border: 1px solid #e8e8e8;
  font-size: 0.9375rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
  padding: 0 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box dd input[type=text],
  .p-contact__form-box dd input[type=email],
  .p-contact__form-box dd input[type=tel] {
    width: 100%;
    height: 4.0625rem;
    padding: 0 1rem;
  }
}

.p-contact__form-box dd input[type=radio] {
  opacity: 0;
  position: absolute;
}

.p-contact__form-box .wpcf7-form-control.wpcf7-radio {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box .wpcf7-form-control.wpcf7-radio {
    gap: 1.5625rem 2.5rem;
  }
}

.p-contact__form-box .wpcf7-list-item {
  margin: 0;
}

.p-contact__form-box .wpcf7-list-item-label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box .wpcf7-list-item-label {
    gap: 1rem;
  }
}

.p-contact__form-box .wpcf7-list-item-label::before {
  background: #ffffff;
  border: 1px solid #e8e8e8;
  border-radius: 100%; /* ラジオボタンっぽく丸くする */
  content: "";
  height: 0.875rem;
  -webkit-transition: background-color 0.5s;
  transition: background-color 0.5s; /* 色をじんわり変化させる */
  width: 0.875rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box .wpcf7-list-item-label::before {
    width: 1.125rem;
    height: 1.125rem;
  }
}

/* チェック後のボタン */
input[type=radio]:checked + .wpcf7-list-item-label::before {
  background-color: #c12b0f; /* チェック後の中心の色 */
  -webkit-box-shadow: inset 0 0 0 2px #fff;
          box-shadow: inset 0 0 0 2px #fff; /* 中心の色のスタイル */
}
@media screen and (min-width: 768px) {
  input[type=radio]:checked + .wpcf7-list-item-label::before {
    -webkit-box-shadow: inset 0 0 0 3px #fff;
            box-shadow: inset 0 0 0 3px #fff;
  }
}

.p-contact__form-box dd textarea {
  width: 100%;
  height: 10rem;
  background-color: #fbfbfb;
  border: 1px solid #e8e8e8;
  font-size: 0.9375rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
  padding: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-contact__form-box dd textarea {
    height: 14.375rem;
    padding: 1rem;
  }
}

.p-contact__form-box dd input[type=button],
.p-contact__form-box dd input[type=submit] {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border: none;
  background-color: transparent;
  font-size: 0.9375rem;
  cursor: pointer;
  color: #000;
}

.p-contact__form-box dd.column {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.5rem;
}

.p-contact__form-box dd.column .c-btn .back_button {
  background-color: transparent;
  border: none;
  font-size: 0.9375rem;
  cursor: pointer;
}

.p-contact__form-box dd.column .c-btn.previous span {
  right: auto;
  left: 0.875rem;
}

.p-contact__form-box dd.column .c-btn.previous span::after {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.p-contact__form.confirm {
  display: none;
}

/*デフォルトのサンクスメッセージを非表示*/
.wpcf7-response-output {
  display: none;
}

.p-content {
  position: relative;
  z-index: 100;
}

.p-content__title-box {
  padding: 1rem 0;
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
}
@media screen and (min-width: 768px) {
  .p-content__title-box {
    padding: 1.5625rem 0 1.25rem;
  }
}

.p-content__title-box {
  border: none;
}

.p-content__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.p-content__time {
  font-size: 0.75rem;
  font-weight: 500;
  padding-right: 1.875rem;
  border-right: 1px solid #e5e5e5;
}

.p-content__category {
  margin-left: 0.625rem;
  min-width: 8.0625rem;
  height: 1.25rem;
  border-radius: 0.625rem;
  border: 1px solid;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.75rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  padding: 0 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-content__category {
    font-size: 0.8125rem;
  }
}

.p-content__category.is-cat-info_com {
  border-color: #fe4d11;
}

.p-content__category.is-cat-info_himeji {
  border-color: #d70000;
}

.p-content__category.is-cat-info_kobe {
  border-color: #0066cf;
}

.p-content__category.is-cat-info_kobe_duo {
  border-color: #00cfff;
}

.p-content__category.is-cat-info_nishinomiya {
  border-color: #079d00;
}

.p-content__category.is-cat-info_ikeda {
  border-color: #d29700;
}

.p-content__category.is-cat-info_important {
  border-color: #d600d0;
}

.p-content__category.is-cat-info_recruit {
  border-color: #ff9320;
}

.p-content__category.is-cat-info_open {
  border-color: #999999;
}

.p-content__category.is-cat-blog_honbu {
  border-color: #fe4d11;
}

.p-content__category.is-cat-blog_himeji {
  border-color: #d70000;
}

.p-content__category.is-cat-blog_kobe {
  border-color: #0066cf;
}

.p-content__category.is-cat-blog_kobe_duo {
  border-color: #00cfff;
}

.p-content__category.is-cat-blog_nishinomiya {
  border-color: #079d00;
}

.p-content__category.is-cat-blog_ikeda {
  border-color: #d29700;
}

.p-content__title {
  margin-top: 0.5rem;
  font-size: 1rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1.6666666667;
  letter-spacing: 0.006em;
  color: #333333;
}
@media screen and (min-width: 768px) {
  .p-content__title {
    margin-top: 1rem;
    font-size: 1.125rem;
  }
}

.p-content__thumbnail {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-content__thumbnail {
    margin-top: 2.125rem;
  }
}

.p-content__thumbnail img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-content__contents {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-content__contents {
    margin-top: 2.125rem;
  }
}

.p-content__contents h2 {
  margin-top: 1.5rem;
  font-size: 1.125rem;
}
@media screen and (min-width: 768px) {
  .p-content__contents h2 {
    margin-top: 2rem;
    font-size: 1.5rem;
  }
}

.p-content__contents h3 {
  margin-top: 1.25rem;
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  .p-content__contents h3 {
    margin-top: 1.5rem;
    font-size: 1.25rem;
  }
}

.p-content__contents p {
  margin-top: 0.875rem;
  font-size: 0.875rem;
  text-align: justify;
  color: #333;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1.7;
}
@media screen and (min-width: 768px) {
  .p-content__contents p {
    margin-top: 1rem;
    font-size: 1rem;
  }
}

.p-content__contents img {
  margin-top: 1rem;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-content__contents img {
    margin-top: 1.25rem;
  }
}

.p-content__pagination {
  margin-top: 2rem;
}
@media screen and (min-width: 768px) {
  .p-content__pagination {
    margin-top: 4rem;
  }
}

.p-disclosure {
  background: url(../images/bg-blue.webp) repeat center/contain;
}

.p-disclosure__title {
  color: #000000;
}

.p-disclosure__tables {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-disclosure__tables {
    margin-top: 2.5rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2.75rem;
  }
}

.p-disclosure__table-area:nth-child(n+2) {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-disclosure__table-area:nth-child(n+2) {
    margin-top: 0;
  }
}

.p-disclosure__table-title {
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-disclosure__table-title {
    font-size: 1.25rem;
  }
}

.p-disclosure__cards {
  margin-top: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-disclosure__cards {
    margin-top: 1.5rem;
  }
}

.p-disclosure__card {
  background-color: #ffffff;
  border: 1px solid #e5e5e5;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-disclosure__card {
    padding: 1.5rem;
    font-size: 1.125rem;
  }
}

.p-disclosure__card:nth-child(n+2) {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-disclosure__card:nth-child(n+2) {
    margin-top: 0.9375rem;
  }
}

.p-disclosure__card-title a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.p-disclosure__card-title a::after {
  content: "";
  width: 1rem;
  height: 1rem;
  background: url(../images/icon_link.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-disclosure__card-title a::after {
    width: 1.1875rem;
    height: 1.1875rem;
  }
}

.p-disclosure__card-title span {
  display: block;
  position: relative;
  cursor: pointer;
}

.p-disclosure__card-title span::before,
.p-disclosure__card-title span::after {
  content: "";
  width: 0.8125rem;
  height: 1px;
  background-color: #000000;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
@media screen and (min-width: 768px) {
  .p-disclosure__card-title span::before,
  .p-disclosure__card-title span::after {
    width: 1.0625rem;
  }
}

.p-disclosure__card-title span::after {
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
}

.p-disclosure__card-title span.close::after {
  -webkit-transform: translateY(-50%) rotate(0);
          transform: translateY(-50%) rotate(0);
}

.p-disclosure__list-box {
  display: none;
}

.p-disclosure__list {
  margin-top: 0.5rem;
  padding-bottom: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-disclosure__list {
    margin-top: 1.25rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 2.9375rem;
    padding-bottom: 1.25rem;
  }
}

.p-disclosure__item a {
  padding: 0.5rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  font-size: 0.875rem;
  font-weight: 500;
  border-bottom: 1px solid #000000;
}
@media screen and (min-width: 768px) {
  .p-disclosure__item a {
    font-size: 1rem;
    padding: 1.25rem 0 0.5rem 0;
  }
}

.p-disclosure__item a::after {
  content: "";
  width: 1.25rem;
  height: 0.6875rem;
  background: url(../images/icon_download.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-disclosure__item a::after {
    width: 1.5rem;
    height: 0.8125rem;
  }
}

.p-footer__top {
  background-color: #ff7500;
  border-radius: 0.625rem 0.625rem 0 0;
  padding: 1.25rem 0;
}
@media screen and (min-width: 768px) {
  .p-footer__top {
    padding: 2.5rem 0 3.125rem;
    border-radius: 2.5rem 2.5rem 0 0;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__body {
    width: 50%;
    padding-right: 4.6875rem;
  }
}

.p-footer__logo {
  width: 15rem;
}
@media screen and (min-width: 768px) {
  .p-footer__logo {
    width: 19.625rem;
    margin-left: -1.75rem;
  }
}

.p-footer__logo img {
  aspect-ratio: 240/50;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-footer__address-table {
  margin-top: 0.9375rem;
  padding-top: 0.625rem;
  position: relative;
  font-size: 0.8125rem;
  line-height: 1.5384615385;
  letter-spacing: 0.036em;
}
@media screen and (min-width: 768px) {
  .p-footer__address-table {
    margin-top: 1.25rem;
    padding-top: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    letter-spacing: 0;
  }
}

.p-footer__address-table::before {
  content: "";
  width: 100vw;
  height: 1px;
  background-color: #ffffff;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .p-footer__address-table::before {
    content: none;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__address-table dt {
    font-size: 1.125rem;
    font-weight: 500;
    padding-right: 0.9375rem;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__address-table dd {
    font-size: 1rem;
    line-height: 1.5;
    padding-left: 1rem;
    border-left: 1px solid #333;
  }
}

.p-footer__address-table dd span {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-footer__address-table dd span {
    display: inline;
  }
}

.p-footer__box {
  margin-top: 1rem;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .p-footer__box {
    margin-top: 2.125rem;
    margin-left: 0;
    margin-right: 0;
  }
}

.p-footer__nav.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-footer__nav.pc {
    display: block;
    width: 50%;
    margin-top: 0.625rem;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__nav.sp {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__menus {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.0625rem;
  }
}

.p-footer__menu {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 1.1875rem;
}
@media screen and (min-width: 768px) {
  .p-footer__menu {
    display: block;
    border-bottom: 1px solid #ffffff;
  }
}

.p-footer__item a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 2.75rem;
  color: #ffffff;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  border-bottom: 1px solid #ffffff;
}
@media screen and (min-width: 768px) {
  .p-footer__item a {
    height: auto;
    font-size: 1rem;
    padding: 1.25rem 0 1.25rem 1.6875rem;
    border-bottom: none;
    border-top: 1px solid #ffffff;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__item span {
    display: block;
    padding-top: 1.25rem;
    font-size: 1rem;
    font-weight: 500;
    color: #ffffff;
    letter-spacing: 0.05em;
    padding-left: 1.6875rem;
    border-top: 1px solid #ffffff;
  }
}

.p-footer__item a::after {
  content: "";
  width: 1.125rem;
  height: 0.3125rem;
  background: url(../images/icon_arrow-white.webp) no-repeat center/cover;
}

@media screen and (min-width: 768px) {
  .p-footer__sub-menu {
    padding-left: 1.6875rem;
    text-indent: 1em;
    margin-top: 1rem;
    padding-bottom: 1.25rem;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__sub-item a {
    padding: 0;
    border-bottom: none;
    font-size: 0.9375rem;
    border-top: none;
  }
}

.p-footer__sub-item:nth-child(n+2) {
  margin-top: 1rem;
}

.p-footer__btns {
  margin-top: 1.4375rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.1875rem;
}
@media screen and (min-width: 768px) {
  .p-footer__btns {
    margin-top: 1.625rem;
    gap: 1.0625rem;
  }
}

.p-footer__btn a {
  height: 1.75rem;
  border-radius: 0.875rem;
  border: 1px solid #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.4375rem;
  padding-left: 0.875rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #ffffff;
  letter-spacing: -0.075em;
}
@media screen and (min-width: 768px) {
  .p-footer__btn a {
    height: 2.875rem;
    border-radius: 1.4375rem;
    font-size: 1rem;
    letter-spacing: 0;
    gap: 0.5625rem;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__btn.insta a {
    padding-left: 2.1875rem;
  }
}

@media screen and (min-width: 768px) {
  .p-footer__btn.x a {
    padding-left: 3.6875rem;
  }
}

.p-footer__btn a::before {
  content: "";
}

.p-footer__btn.insta a::before {
  width: 0.9375rem;
  height: 0.9375rem;
  background: url(../images/icon_insta.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-footer__btn.insta a::before {
    width: 1.3125rem;
    height: 1.3125rem;
  }
}

.p-footer__btn.x a::before {
  width: 1rem;
  height: 1rem;
  background: url(../images/icon_x.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-footer__btn.x a::before {
    width: 1.1875rem;
    height: 1.125rem;
  }
}

.p-footer__bottom {
  padding: 0.625rem 0;
}
@media screen and (min-width: 768px) {
  .p-footer__bottom {
    padding: 0.9375rem 0;
  }
}

.p-footer__copyright {
  font-size: 0.75rem;
  font-weight: 500;
  text-align: center;
  color: #333;
}
@media screen and (min-width: 768px) {
  .p-footer__copyright {
    font-size: 0.875rem;
  }
}

.p-fv {
  border-top: 1px solid #f1f1f1;
}
@media screen and (min-width: 768px) {
  .p-fv {
    border-top: none;
  }
}

.p-fv__imgs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.3125rem;
}
@media screen and (min-width: 768px) {
  .p-fv__imgs {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 1.25rem;
    position: relative;
  }
}

@media screen and (min-width: 768px) {
  .p-fv__imgs::after {
    content: "";
    width: 3.125rem;
    height: 3.125rem;
    background: url(../images/icon_plus.webp) no-repeat center/cover;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    z-index: 300;
  }
}

.p-fv__swiper {
  position: relative;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-fv__swiper {
    width: 50%;
  }
}

.p-fv__swiper span {
  position: absolute;
  right: 2.5rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 1.75rem;
  font-weight: bold;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
  letter-spacing: 0.3em;
  z-index: 300;
  text-shadow: 2px 2px 0 #fff, -2px 2px 0 #fff, 2px -2px 0 #fff, -2px -2px 0 #fff, 2px 0px 0 #fff, 0px 2px 0 #fff, -2px 0px 0 #fff, 0px -2px 0 #fff;
  color: #333;
}
@media screen and (min-width: 768px) {
  .p-fv__swiper span {
    font-size: 3.5rem;
    right: auto;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}

.p-fv__swiper:nth-child(2) span {
  right: auto;
  left: 2.5rem;
  letter-spacing: 0.14em;
}
@media screen and (min-width: 768px) {
  .p-fv__swiper:nth-child(2) span {
    left: 50%;
  }
}

.p-fv__img img {
  aspect-ratio: 365/245;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-fv__img img {
    aspect-ratio: 67/85;
    border-radius: 1.8125rem;
  }
}
.p-header {
  transition: background-color .5s ease;
}

.p-header {
  position: fixed;
  top: 0;
  z-index: 1000;
  background-color: #ffffff;
}
.p-header.white {
  background-color: unset;
}
@media screen and (min-width: 768px) {
  .p-header {
    position: absolute;
    top: 0;
    background-color: transparent;
  }
}

@media screen and (min-width: 768px) {
  .p-header.white {
    background-color: #ffffff;
    position: static;
  }
}

.p-header__inner {
  height: 100%;
  padding-left: 1.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .p-header__inner {
    padding-left: 3.875rem;
    padding-right: 3.875rem;
  }
}
@media screen and (min-width: 1280px) {
  .p-header__inner {
    padding-right: 7.6875rem;
  }
}

.p-header__logo {
  width: 11.25rem;
  z-index: 1050;
}
@media screen and (min-width: 768px) {
  .p-header__logo {
    width: 17.1875rem;
  }
}

.p-header__logo img {
  aspect-ratio: 180/39;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.p-header__nav {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  z-index: 1000;
  padding: 6.25rem 1.25rem 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-header__nav {
    display: block;
    position: static;
    background-color: transparent;
    padding: 0;
    width: auto;
    height: auto;
  }
}

.p-header__menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-header__menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
@media screen and (min-width: 1280px) {
  .p-header__menu {
    gap: 2.25rem;
  }
}

@media screen and (min-width: 768px) {
  .p-header__item a {
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.05em;
  }
}

.p-header__toggle {
  width: 4.125rem;
  height: 4rem;
  background-color: #fbc800;
  border-radius: 0 0 0 1.25rem;
  color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
  gap: 0.6875rem;
  z-index: 1050;
}
@media screen and (min-width: 768px) {
  .p-header__toggle {
    display: none;
  }
}

.p-header.white .p-header__toggle {
  background-color: #ffffff;
  color: #000000;
}

.p-header.orange .p-header__toggle {
  background-color: #fbc800;
  color: #ffffff;
}

.p-header__toggle-box {
  width: 2.125rem;
  height: 1rem;
  position: relative;
}

.p-header__toggle-box span {
  width: 100%;
  height: 1px;
  background-color: #ffffff;
  position: absolute;
  left: 0;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

.p-header.white .p-header__toggle-box span {
  background-color: #000000;
}

.p-header.orange .p-header__toggle-box span {
  background-color: #ffffff;
}

.p-header__toggle-box span:nth-child(1) {
  top: 0;
}

.p-header__toggle-box span:nth-child(2) {
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.p-header__toggle-box span:nth-child(3) {
  bottom: 0;
}

.p-header__toggle.show .p-header__toggle-box span:nth-child(1) {
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.p-header__toggle.show .p-header__toggle-box span:nth-child(2) {
  opacity: 0;
}

.p-header__toggle.show .p-header__toggle-box span:nth-child(3) {
  top: 50%;
  bottom: auto;
  -webkit-transform: translateY(-50%) rotate(-45deg);
          transform: translateY(-50%) rotate(-45deg);
}

.p-history {
  background: url(../images/about-lead_bg.webp) repeat center/contain;
}
@media screen and (min-width: 768px) {
  .p-history {
    background: none;
  }
}

.p-history__title {
  color: #000000;
}

@media screen and (min-width: 768px) {
  .p-history__tables {
    margin-top: 2.5rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2.75rem;
  }
}

.p-history__table-area {
  padding: 1.25rem 1.25rem 1.875rem;
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .p-history__table-area {
    padding: 0;
    margin-left: 0;
    margin-right: 0;
  }
}

.p-history__table-area:nth-child(even) {
  background-color: #ffffff;
}

.p-history__table-title {
  font-size: 1rem;
  font-weight: bold;
  color: #ff4d0b;
  line-height: 1.875;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-history__table-title {
    font-size: 1.25rem;
  }
}

.p-history__table-box {
  padding: 1rem 0;
  border-bottom: 1px solid #e5e5e5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.375rem;
}
@media screen and (min-width: 768px) {
  .p-history__table-box {
    padding: 1.25rem 0;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0;
  }
}

.p-history__table-box dt {
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-history__table-box dt {
    width: 28.4090909091%;
    font-size: 1rem;
  }
}

.p-history__table-box dd {
  font-size: 0.8125rem;
  color: #666;
  line-height: 1.6923076923;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .p-history__table-box dd {
    width: 71.9696969697%;
    font-size: 1rem;
  }
}

@media screen and (min-width: 768px) {
  .p-history__table-box dd span {
    font-size: 0.875rem;
  }
}

@media screen and (min-width: 768px) {
  .p-info__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 3.125rem;
  }
}

@media screen and (min-width: 768px) {
  .p-info__title-box {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    padding-top: 0.5rem;
  }
}

.p-info__title {
  color: #000000;
  font-family: "dnp-shuei-gothic-gin-std", sans-serif;
}

.p-info__title::before {
  letter-spacing: 0;
  color: #ff7500;
}
@media screen and (min-width: 768px) {
  .p-info__title::before {
    color: #000000;
    letter-spacing: 0.07em;
    margin-bottom: 0.625rem;
  }
}

.p-info__text {
  margin-top: 0.375rem;
  font-size: 0.8125rem;
  letter-spacing: 0.064em;
  color: #ffffff;
}
@media screen and (min-width: 768px) {
  .p-info__text {
    margin-top: 1.25rem;
    font-size: 1rem;
    letter-spacing: 0;
  }
}

.p-info__text span {
  display: inline-block;
  background-color: #ff7500;
  padding: 0 0.25rem;
  line-height: 1.6;
}
@media screen and (min-width: 768px) {
  .p-info__text span {
    line-height: 1.2;
  }
}

.p-info__text span:nth-child(n+2) {
  margin-top: 0.375rem;
}
@media screen and (min-width: 768px) {
  .p-info__text span:nth-child(n+2) {
    margin-top: 0.5rem;
  }
}

.p-info__body {
  margin-top: 1.6875rem;
}
@media screen and (min-width: 768px) {
  .p-info__body {
    margin-top: 2.1875rem;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
}

.p-info__items {
  margin-top: 2.5rem;
}
@media screen and (min-width: 768px) {
  .p-info__items {
    margin-top: 1.625rem;
  }
}

.p-info__item:last-child {
  border-bottom: 1px solid #e5e5e5;
}

.p-info__btn {
  margin-top: 1.4375rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-info__btn {
    margin-top: 3.75rem;
    text-align: left;
  }
}

@media screen and (min-width: 768px) {
  .p-info__btn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    font-size: 1rem;
    font-weight: 500;
    letter-spacing: 0.075em;
  }
}

@media screen and (min-width: 768px) {
  .p-info__btn a:hover {
    opacity: 1;
  }
}

@media screen and (min-width: 768px) {
  .p-info__btn a::after {
    content: "";
    width: 5.4375rem;
    height: 4.125rem;
    background: url(../images/icon_info-arrow-white.webp) no-repeat center/cover;
  }
}

@media screen and (min-width: 768px) {
  .p-info__btn a:hover::after {
    background: url(../images/icon_info-arrow.webp) no-repeat center/cover;
  }
}

@media screen and (min-width: 768px) {
  .p-info__btn a span {
    padding-bottom: 0.9375rem;
    border-bottom: 2px solid #000000;
    margin-top: 0.75rem;
  }
}

.p-member {
  background: url(../images/about-lead_bg.webp) repeat center/contain;
}

.p-member__title {
  color: #000000;
}

.p-member__cards {
  margin-top: 0.625rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem 1px;
}
@media screen and (min-width: 768px) {
  .p-member__cards {
    margin-top: 2.5rem;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.8125rem;
  }
}

.p-message {
  background-color: #1e2136;
}

@media screen and (min-width: 768px) {
  .p-message__inner {
    padding: 0 1.5625rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    gap: 4.1875rem;
  }
}

.p-message__body {
  color: #ffffff;
}
@media screen and (min-width: 768px) {
  .p-message__body {
    width: 43.9090909091%;
    margin-top: -0.625rem;
  }
}

.p-message__title {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 1.6666666667;
}
@media screen and (min-width: 768px) {
  .p-message__title {
    font-size: 1.625rem;
  }
}

.p-message__text-area {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-message__text-area {
    margin-top: 1.875rem;
  }
}

@media screen and (min-width: 768px) {
  .p-message__text-area.sp {
    display: none;
  }
}

.p-message__text-area.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-message__text-area.pc {
    display: block;
  }
}

.p-message__text {
  font-size: 0.875rem;
  line-height: 1.86;
}
@media screen and (min-width: 768px) {
  .p-message__text {
    font-size: 1rem;
    letter-spacing: -0.03em;
  }
}

.p-message__text:nth-child(n+2) {
  margin-top: 0.5em;
}

.p-message__name {
  margin-top: 1.25rem;
  font-size: 0.8125rem;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .p-message__name {
    margin-top: 1.875rem;
    font-size: 1rem;
    line-height: 1.63;
  }
}

.p-message__name span {
  font-family: "Yuji Syuku", serif;
  font-size: 1.125rem;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-message__name span {
    font-size: 1.25rem;
  }
}

.p-message__img {
  margin-top: 1.25rem;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .p-message__img {
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
    width: 50%;
  }
}

.p-message__img img {
  aspect-ratio: 335/215;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-message__img img {
    aspect-ratio: 550/586;
  }
}

.p-modal {
  width: 90%;
  padding: 1rem;
  background-color: #ffffff;
  border-radius: 0.625rem;
  position: fixed;
  top: 4rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.2s ease, -webkit-transform 0.2s ease;
  transition: opacity 0.2s ease, -webkit-transform 0.2s ease;
  transition: opacity 0.2s ease, transform 0.2s ease;
  transition: opacity 0.2s ease, transform 0.2s ease, -webkit-transform 0.2s ease;
}
@media screen and (min-width: 768px) {
  .p-modal {
    width: 47.5625rem;
    padding: 2.5rem;
    border-radius: 1.25rem;
    top: 7.5rem;
  }
}

.p-modal.is-open {
  opacity: 1;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  pointer-events: auto;
  background: #fff;
}

@media (max-width: 750px) {
  height: 100%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 100px;
}

.p-modal[aria-hidden=true] {
  visibility: hidden;
}

.p-modal.is-open {
  visibility: visible;
}

#modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .69);
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
  z-index: 9998;
}

#modal-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}

.p-modal::before {
  content: "";
  width: 0.375rem;
  height: 0.375rem;
  background-color: #ff7500;
  border-radius: 0.3125rem 0.3125rem 0 0;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -100%);
  transform: translate(-50%, -100%);
  opacity: 0;
}
@media screen and (min-width: 768px) {
  .p-modal::before {
    width: 0.75rem;
    height: 0.75rem;
  }
}


.p-modal__title {
	width: 80%;
	margin: 0 auto;
}
@media screen and (min-width: 768px) {
	width: 28.75rem;
}
.p-modal__title a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border-radius: 50px;
  border: 1px solid #ff7500;
  height: 3rem;
  font-size: 0.875rem;
  font-weight: 500;
  position: relative;
  outline: none;
}
@media screen and (min-width: 768px) {
  .p-modal__title a {
    height: 4.0625rem;
    font-size: 1rem;
    border-radius: 50px;
  }
}

.p-modal__title a span {
  width: 0.875rem;
  height: 0.875rem;
  border-radius: 50%;
  background-color: #ff7500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  right: 1.25rem;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .p-modal__title a span {
    width: 1.1875rem;
    height: 1.1875rem;
    right: 1.6rem;
  }
}

.p-modal__title a span::after {
  content: "";
  width: 0.5rem;
  height: 0.1875rem;
  background: url(../images/icon_arrow-white.webp) no-repeat center/contain;
}
@media screen and (min-width: 768px) {
  .p-modal__title a span::after {
    width: 0.6875rem;
    height: 0.25rem;
  }
}

.p-modal__cards {
  margin-top: 1rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-modal__cards {
    margin-top: 2.1875rem;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.875rem 0.9375rem;
  }
}

.p-nishinomiya-fv {
  position: relative;
  aspect-ratio: 375/725;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv {
    aspect-ratio: 1400/2193;
  }
}

.p-nishinomiya-fv__deko {
  width: 89.3333333333%;
  position: absolute;
  top: 2.125rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 50;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv__deko {
    width: 88.9285714286%;
  }
}

.p-nishinomiya-fv::before {
  content: "";
  width: 100%;
  aspect-ratio: 375/285;
  background: url(../images/nishinomiya-fv.webp) no-repeat center/cover;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv::before {
    aspect-ratio: 140/101;
    background: url(../images/nishinomiya-fv-pc.webp) no-repeat center/cover;
  }
}

.p-nishinomiya-fv::after {
  content: "";
  width: 100%;
  aspect-ratio: 375/285;
  background: url(../images/nishimomiya-fv_bg.webp) no-repeat center/cover;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv::after {
    background: url(../images/nishimomiya-fv_bg-pc.webp) no-repeat center/cover;
    z-index: 30;
  }
}

.p-nishinomiya-fv__swiper {
  padding-top: 22.6519337017%;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv__swiper {
    padding-top: 17%;
  }
}

.p-nishinomiya-fv__text-box {
  position: absolute;
  top: 46.7586206897%;
  z-index: 50;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv__text-box {
    top: 55.7163531114%;
  }
}

.p-nishinomiya-fv__title {
  font-size: 1.125rem;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv__title {
    font-size: 2.25rem;
  }
}

.p-nishinomiya-fv__text {
  margin-top: 0.625rem;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.8666666667;
  color: #333;
  text-align: justify;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: -0.04em;
}
@media screen and (min-width: 768px) {
  .p-nishinomiya-fv__text {
    margin-top: 2rem;
    font-size: 1.25rem;
    line-height: 2;
    color: #000000;
  }
}

.p-outline {
  background: url(../images/about-lead_bg.webp) repeat center/contain;
}
@media screen and (min-width: 768px) {
  .p-outline {
    background: none;
  }
}

.p-outline__title {
  color: #000000;
}

@media screen and (min-width: 768px) {
  .p-outline__tables {
    margin-top: 2.5rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2.75rem;
  }
}

.p-outline__table-area {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 1rem 1.25rem 1.875rem;
}
@media screen and (min-width: 768px) {
  .p-outline__table-area {
    margin-left: 0;
    margin-right: 0;
    padding: 0;
  }
}

.p-outline__table-area:nth-child(even) {
  background-color: #ffffff;
}

.p-outline__table-title {
  font-size: 1rem;
  font-weight: bold;
  color: #ff4d0b;
  line-height: 1.875;
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-outline__table-title {
    font-size: 1.25rem;
  }
}

.p-outline__table-box {
  padding: 1rem 0;
  border-bottom: 1px solid #e5e5e5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-outline__table-box {
    padding: 1.25rem 0;
  }
}

.p-outline__table-box dt {
  width: 35.8208955224%;
  font-size: 0.8125rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-outline__table-box dt {
    width: 28.4090909091%;
    font-size: 1rem;
  }
}

.p-outline__table-box dd {
  width: 64.1791044776%;
  font-size: 0.8125rem;
  line-height: 1.7;
  color: #666;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .p-outline__table-box dd {
    width: 71.5909090909%;
    font-size: 1rem;
  }
}

.p-philosophy {
  background: url(../images/philosophy.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-philosophy {
    background: url(../images/philosophy-pc.webp) no-repeat center/cover;
  }
}

.p-philosophy__title {
  width: 17.5rem;
}
@media screen and (min-width: 768px) {
  .p-philosophy__title {
    width: 34.625rem;
  }
}

.p-philosophy__title span {
  margin-top: 1.25rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 4.375rem;
  height: 1.25rem;
  background-color: #ffffff;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.8125rem;
  font-weight: bold;
  color: #476c7e;
}
@media screen and (min-width: 768px) {
  .p-philosophy__title span {
    margin-top: 3.75rem;
    font-size: 0.9375rem;
  }
}

.p-philosophy__items {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-philosophy__items {
    margin-top: 1.25rem;
  }
}

.p-philosophy__item:nth-child(n+2) {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-philosophy__item:nth-child(n+2) {
    margin-top: 2rem;
  }
}

.p-pickup {
  background-color: #fceaaa;
}

.p-pickup__title {
  font-family: "arial", sans-serif;
  font-size: 1.125rem;
  font-weight: bold;
  font-style: italic;
  letter-spacing: 0.03em;
  color: #ff7500;
  padding-left: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-pickup__title {
    width: 17.375rem;
    aspect-ratio: 1/1;
    position: relative;
    border-radius: 1.4375rem 2.25rem 2.25rem 2.25rem;
    border: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    font-family: "arial", sans-serif;
    font-size: 2rem;
    font-weight: normal;
    font-style: italic;
    color: #ff7500;
    line-height: 1.25;
    background-color: #ffffff;
    padding-left: 0;
    position: absolute;
    top: 0;
    left: 10.7142857143%;
    z-index: 200;
  }
}

@media screen and (min-width: 768px) {
  .p-pickup__title.sp {
    display: none;
  }
}

.p-pickup__title.pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-pickup__title.pc {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.p-pickup__swiper {
  margin-top: 0.5rem;
  padding-left: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-pickup__swiper {
    margin-top: 0;
    padding-left: 10.7142857143%;
  }
}

.p-pickup__slide {
  width: auto;
  min-width: 6.875rem;
  margin-right: 0.9375rem;
}
@media screen and (min-width: 768px) {
  .p-pickup__slide {
    width: auto;
    min-width: 17.375rem;
    -webkit-transition: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transition-delay: 0.2s;
            transition-delay: 0.2s;
    margin-right: 3.125rem;
  }
}

@media screen and (min-width: 768px) {
  .p-pickup__slide.swiper-slide-active {
    opacity: 0;
    -webkit-transition-delay: 0ms;
            transition-delay: 0ms;
  }
}

.p-pickup__slide img {
  aspect-ratio: 1/1;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}


.p-recruit__grid .text01 {
	color: #ea5514;
	position: relative;
}
.p-recruit__grid .text01 .en {
	border:  1px solid #ea5514;
	border-radius: 50px;
	padding: 0 0.5rem 0.125rem;
	font-weight: 600;
	background: #ffffffe3;
}
@media screen and (min-width: 768px) {
	.p-recruit__grid .text01 .en {
	padding: 0 1rem 0.125rem;
	}
}
@media (max-width: 750px) {
	.p-recruit__grid .text01 .en {
	font-size: 0.75rem;
	padding: 0 0.5rem 0.05rem;
}

}

.p-recruit__grid .text01:hover .en {
	color: #fff;
	background: #ea5514;
}
.p-recruit__grid .text01 .jp {
	color: #333;
	text-shadow:
            1px 1px 0px #fff,
            -1px -1px 0px #fff,
            -1px 1px 0px #fff,
            1px -1px 0px #fff,
            1px 0px 0px #fff,
            -1px 0px 0px #fff,
            0px 1px 0px #fff,
            0px -1px 0px #fff;
	/* text-shadow:
            2px 2px 1px #fff,
            -2px 2px 1px #fff,
            2px -2px 1px #fff,
            -2px -2px 1px #fff,
            2px 0px 1px #fff,
            0px 2px 1px #fff,
            -2px 0px 1px #fff,
            0px -2px 1px #fff; */
	/* text-shadow:
            2px 2px 0 #fff,
            -2px 2px 0 #fff,
            2px -2px 0 #fff,
            -2px -2px 0 #fff,
            2px 0px 0 #fff,
            0px 2px 0 #fff,
            -2px 0px 0 #fff,
            0px -2px 0 #fff; */
}
.p-recruit__grid .text01:hover {
opacity: 1;
}
.p-recruit__grid .text01::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: 0.35s ease;
  z-index: 1; 
}
.p-recruit__grid .text01:hover::after {
  background: rgba(0,0,0,0.35);
}
.p-recruit__grid .text01 span {
  position: relative;
  z-index: 2;
}


.p-recruit__grid {
	
}

@media screen and (min-width: 768px) {
    .p-recruit__grid {
        display: grid;
        grid-template-columns: repeat(4, calc(25% - 0.46875rem));
        grid-template-rows: repeat(2, calc(50% - 0.41625rem)); /* 2段に調整 */
        gap: 0.625rem;
        grid-template-areas:
        "area1 area1 area2 area2"
        "area1 area1 area3 area4";
    }
}


@media screen and (min-width: 768px) {
  .area1 {
    grid-area: area1;
  }
  .area2 {
    grid-area: area2;
  }
  .area3 {
    grid-area: area3;
  }
  .area4 {
    grid-area: area4;
  }
  .area5 {
    grid-area: area5;
  }
}
.p-recruit__title-box {
  background: url(../images/recruit-title-box-pc--2.webp) no-repeat center/cover;
  aspect-ratio: 683/516;
  padding: 1.5rem 0.9375rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-recruit__title-box {
    aspect-ratio: 683/516;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    padding: 5.3125rem 3.125rem 0 5rem;
    background: url(../images/recruit-title-box-pc--2.webp) no-repeat center/cover;
  }
}
@media (max-width: 750px) {
  .area5 {
    display: none!important;
  }
}


.p-recruit__title {
  text-shadow: 1px 1px 0 #ffffff, -1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px -1px 0 #ffffff, 1px 0 0 #ffffff, -1px 0 0 #ffffff, 0 1px 0 #ffffff, 0 -1px 0 #ffffff;
}

.p-recruit__text {
  margin-top: 1rem;
  font-size: 0.9375rem;
  line-height: 2;
  text-shadow: 1px 1px 0 #ffffff, -1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px -1px 0 #ffffff, 1px 0 0 #ffffff, -1px 0 0 #ffffff, 0 1px 0 #ffffff, 0 -1px 0 #ffffff;
  letter-spacing: 0;
  text-align: justify;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-recruit__text {
    margin-top: 1.5rem;
    font-size: 1.125rem;
    line-height: 2.4444444444;
  }
}


@media screen and (min-width: 768px) {
  .p-recruit__grid2 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-template-rows: 335px; /* 高さ固定 */
    gap: 0.625rem;
    grid-template-areas:
      "area6 area7 area8";
  }

  .area6 { grid-area: area6; }
  .area7 { grid-area: area7; }
  .area8 { grid-area: area8; }

  .p-recruit__grid2 img {
    width: 100%;
    aspect-ratio: 452 / 335; /*比率維持*/
    object-fit: cover;
  }
}



.p-recruit__voice2 {
  margin-top: 0.3125rem;
  background: url(../images/cross01.webp) no-repeat center/cover;
  aspect-ratio: 365/163;
  padding: 0.3125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.3125rem;
}
.p-recruit__voice2.area7 {
	background: url(../images/cross02.webp) no-repeat center/cover;
}
.p-recruit__voice2.area8 {
	background: url(../images/cross03.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-recruit__voice2 {
    margin-top: 0.3125rem;
    aspect-ratio: 452/335;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    padding: 0.9375rem;
  }
}

.p-recruit__voice2 .taidan {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
}
.p-recruit__voice2 .taidan img {
	width: 104px;
	height: 129px;
}
@media (max-width: 750px) {
	.p-recruit__voice2 .taidan img {
	width: 60px;
	height: 74px;
	margin: 0 0 40px 0;
	}
}

.p-recruit__vision {
  margin-top: 0.3125rem;
  background: url(../images/vision.webp) no-repeat center/cover;
  aspect-ratio: 365/163;
  padding: 0.3125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.3125rem;
}
@media screen and (min-width: 768px) {
  .p-recruit__vision {
    margin-top: 0;
    aspect-ratio: 683/253;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    padding: 0.9375rem;
  }
}

.p-recruit__grid .text01 span {
  display: inline-block;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  line-height: 1.2;
}

.p-recruit__vision span.en {
  font-size: 0.75rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-recruit__vision span.en {
    font-size: 1rem;
  }
}

.p-recruit__grid .text01 span.jp {
  font-size: 1rem;
  font-weight: 900;
}
@media screen and (min-width: 768px) {
  .p-recruit__grid .text01 span.jp {
    font-size: 1.375rem;
  }
}

.p-recruit__guideline {
  margin-top: 0.3125rem;
  padding: 0.3125rem;
  width: calc(50% - 0.3125rem);
  width: calc(50% - 0.15625rem);
  background: url(../images/guideline.webp) no-repeat center/cover;
  aspect-ratio: 180/163;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.3125rem;
  gap: 0.15625rem;
  /* margin-right: 0.3125rem; */
  margin-right: 0.078125rem;
}
@media screen and (min-width: 768px) {
  .p-recruit__guideline {
    margin-top: 0;
    margin-right: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    aspect-ratio: 337/253;
    padding: 0.9375rem;
    gap: 0.625rem;
  }
}

.p-recruit__guideline span {
  display: inline-block;
  /* background-color: #ffffff; */
  padding: 0 0.25rem;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  line-height: 1.2;
}

.p-recruit__guideline span.en {
  font-size: 0.75rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-recruit__guideline span.en {
    font-size: 1rem;
  }
}

.p-recruit__guideline span.jp {
  font-size: 1rem;
  font-weight: 900;
}
@media screen and (min-width: 768px) {
  .p-recruit__guideline span.jp {
    font-size: 1.375rem;
  }
}

.p-recruit__benefit {
  margin-top: 0.3125rem;
  padding: 0.3125rem;
  width: calc(50% - 0.3125rem);
  width: calc(50% - 0.15625rem);
  background: url(../images/benefit.webp) no-repeat center/cover;
  aspect-ratio: 180/163;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 0.3125rem;
  gap: 0.15625rem;
}
@media screen and (min-width: 768px) {
  .p-recruit__benefit {
    margin-top: 0;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    aspect-ratio: 337/253;
    padding: 0.9375rem;
    gap: 0.625rem;
  }
}
@media (max-width: 750px) {
	.p-recruit__benefit {
    /* padding: 0.9375rem; */
 }
}

.p-recruit__benefit span {
  display: inline-block;
  line-height: 1.2;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  /* background-color: #ffffff; */
  padding: 0 0.25rem;
}

.p-recruit__benefit span.en {
  font-size: 0.75rem;
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  .p-recruit__benefit span.en {
    font-size: 1rem;
  }
}

.p-recruit__benefit span.jp {
  font-size: 1rem;
  font-weight: 900;
}
@media screen and (min-width: 768px) {
  .p-recruit__benefit span.jp {
    font-size: 1.375rem;
  }
}

.p-recruit__voice {
  display: block;
  margin-top: 0.3125rem;
  aspect-ratio: 365/148;
}
@media screen and (min-width: 768px) {
  .p-recruit__voice {
    aspect-ratio: 1376/335;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    margin-top: 0;
  }
}

.p-service {
  background: url(../images/about-lead_bg.webp) repeat center/contain;
}

@media screen and (min-width: 768px) {
  .p-service__wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6.25rem;
  }
}

.p-service__block:nth-child(n+2) {
  margin-top: 1.875rem;
}
@media screen and (min-width: 768px) {
  .p-service__block:nth-child(n+2) {
    margin-top: 0;
  }
}

.p-service__title {
  font-size: 1.125rem;
  font-weight: 900;
  letter-spacing: 0.075em;
  color: #ff7500;
}
@media screen and (min-width: 768px) {
  .p-service__title {
    font-size: 2rem;
  }
}

.p-service__title.green {
  color: #8ec700;
}

.p-service__cards {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-service__cards {
    margin-top: 1.5rem;
  }
}

.p-service__card:nth-child(n+2) {
  margin-top: 1.875rem;
}
@media screen and (min-width: 768px) {
  .p-service__card:nth-child(n+2) {
    margin-top: 4.375rem;
  }
}

.p-shisetsu-about__img {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.p-shisetsu-about__img img {
  aspect-ratio: 375/285;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-about__img img {
    aspect-ratio: 1400/648;
  }
}

.p-shisetsu-about__body {
  padding-top: 1rem;
  padding-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-about__body {
    padding-top: 4rem;
    padding-bottom: 4.375rem;
  }
}

.p-shisetsu-about__title {
  display: inline-block;
  font-size: 1.125rem;
  font-weight: bold;
  letter-spacing: 0.075em;
  padding-bottom: 0.375rem;
  border-bottom: 1px dashed #000000;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-about__title {
    font-size: 1.875rem;
    padding-bottom: 0.75rem;
  }
}

.p-shisetsu-about__text {
  margin-top: 0.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  text-align: justify;
  line-height: 1.8666666667;
  color: #333;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-about__text {
    margin-top: 1rem;
    font-size: 1.125rem;
    color: #000000;
    line-height: 2.2222222222;
  }
}

.p-shisetsu-access {
  background: url(../images/about-lead_bg.webp) repeat center/contain;
}

@media screen and (min-width: 768px) {
  .p-shisetsu-access__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    gap: 6rem;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu-access__body {
    width: 37.8181818182%;
    padding-top: 1.25rem;
  }
}

.p-shisetsu-access__title {
  font-size: 0.9375rem;
  font-weight: bold;
  letter-spacing: 0.075em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .p-shisetsu-access__title {
    font-size: 1.125rem;
  }
}

.p-shisetsu-access__title::before {
  content: attr(data-en);
  font-size: 0.8125rem;
  display: block;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-access__title::before {
    font-size: 1.125rem;
  }
}

.p-shisetsu-access__title span {
  font-size: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-access__title span {
    font-size: 1.625rem;
  }
}

.p-shisetsu-access__table {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-access__table {
    margin-top: 1.25rem;
  }
}

.p-shisetsu-access__table-box {
  font-size: 0.875rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-access__table-box {
    font-size: 1.125rem;
  }
}

.p-shisetsu-access__table-box:nth-child(n+2) {
  margin-top: 0.5rem;
}

.p-shisetsu-access__table-box dt {
  font-weight: 500;
}

.p-shisetsu-access__table-box dd {
  color: #666;
  line-height: 1.8571428571;
}

.p-shisetsu-access__map {
  margin-top: 1rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-access__map {
    margin-top: 0;
    width: 53.2727272727%;
  }
}

.p-shisetsu-access__map iframe {
  aspect-ratio: 335/190;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-access__map iframe {
    aspect-ratio: 586/388;
    border-radius: 1.25rem;
  }
}

.p-shisetsu-content__banners {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1px;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__banners {
    margin-left: 0;
    margin-right: 0;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
  }
}

.p-shisetsu-content__blocks-wrap {
  margin-top: 2.25rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__blocks-wrap {
    margin-top: 4.75rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 3rem;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu-content__blocks-wrap.mt-0 {
    margin-top: 0;
  }
}

.p-shisetsu-content__blocks-wrap.mt-0--sp {
  margin-top: 0;
}

.p-shisetsu-content__blocks {
  padding-bottom: 1.875rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__blocks {
    width: 53.0909090909%;
  }
}

.p-shisetsu-content__block:nth-child(n+2) {
  margin-top: 2.125rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__block:nth-child(n+2) {
    margin-top: 4.375rem;
  }
}

.p-shisetsu-content__meta {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: 1.5rem 1.25rem 1.875rem;
  background: url(../images/about-lead_bg.webp) repeat center/contain;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__meta {
    margin-left: 0;
    margin-right: 0;
    width: 42.2727272727%;
    border-radius: 1.25rem;
    padding: 3.125rem;
    border: 1px solid #e5e5e5;
    position: sticky;
    top: 4.375rem;
  }
}

.p-shisetsu-content__table-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-shisetsu-content__table-box:nth-child(n+2) {
  margin-top: 0.5rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-box:nth-child(n+2) {
    margin-top: 1rem;
  }
}

.p-shisetsu-content__table-box dt {
  width: 5.5625rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  padding-top: 0.25rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-box dt {
    font-size: 1rem;
    padding-top: 0.125rem;
  }
}

.p-shisetsu-content__table-box dd {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.05em;
  color: #333;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-box dd {
    font-size: 1rem;
    line-height: 1.625;
  }
}

.p-shisetsu-content__table-box dd.ls-0 {
  letter-spacing: -0.02em;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-box dd.ls-0 {
    letter-spacing: 0.05em;
  }
}

.p-shisetsu-content__table-box dd.ls--4 {
  letter-spacing: -0.04em;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-box dd.ls--4 {
    letter-spacing: -0.06em;
  }
}

.p-shisetsu-content__table-box dd strong {
  font-weight: bold;
}

.p-shisetsu-content__table-box dd .min {
  font-size: 0.8125rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-box dd .min {
    font-size: 0.9375rem;
  }
}

.p-shisetsu-content__table-box dd .la {
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-box dd .la {
    font-size: 1.25rem;
  }
}

.p-shisetsu-content__table-item.ls-0 {
  letter-spacing: -0.05em;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-item.ls-0 {
    letter-spacing: -0.07em;
  }
}

.p-shisetsu-content__table-item.ls-0 span {
  letter-spacing: 0;
}

.p-shisetsu-content__table-item:nth-child(n+2) {
  margin-top: 0.5rem;
}

@media screen and (min-width: 768px) {
  .p-shisetsu-content__table-item span {
    font-size: 0.875rem;
  }
}

.p-shisetsu-content__btns {
  margin-top: 1.875rem;
}

.p-shisetsu-content__btn {
  text-align: center;
}

.p-shisetsu-content__btn:nth-child(n+2) {
  margin-top: 1.25rem;
}

.p-shisetsu-content__btn a,
.p-shisetsu-content__btn span {
  width: 20.9375rem;
  height: 2.25rem;
  background-color: #f9e76f;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 0.875rem;
  font-weight: bold;
  letter-spacing: 0.01em;
  border-radius: 1.3125rem;
  position: relative;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-content__btn a,
  .p-shisetsu-content__btn span {
    width: 22.8125rem;
    height: 2.625rem;
    font-size: 1rem;
  }
}

.p-shisetsu-content__btn span::after {
  content: "";
  width: 0.375rem;
  height: 0.375rem;
  border-right: 1px solid #ff7500;
  border-top: 1px solid #ff7500;
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
  -webkit-transform-origin: top;
          transform-origin: top;
  position: absolute;
  top: 50%;
  right: 1.125rem;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}

.p-shisetsu-content__btn span.close {
  border-radius: 1.3125rem 1.3125rem 0 0;
}

.p-shisetsu-content__btn span.close::after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.p-shisetsu-content__btn-list {
  padding: 1rem 1.8125rem;
  background-color: #fcf7d3;
  display: none;
}

.p-shisetsu-content__btn-item:nth-child(n+2) {
  margin-top: 0.5rem;
}

.p-shisetsu-content__btn-item a {
  width: 100%;
  height: auto;
  background-color: transparent;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  gap: 0.5rem;
}

.p-shisetsu-content__btn-item a::before {
  content: "";
  width: 0.375rem;
  height: 0.375rem;
  border-right: 1px solid #ff7500;
  border-bottom: 1px solid #ff7500;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.p-shisetsu-fv {
  background: url(../images/shisetsu-fv.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-fv {
    background: url(../images/shisetsu-fv-pc.webp) no-repeat top/cover;
  }
}

.p-shisetsu-fv.service {
  background: url(../images/service-fv.webp) no-repeat center/cover;
  background: url(../images/service-fv.webp) no-repeat top/cover;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-fv.service {
    background: url(../images/service-fv-pc.webp) no-repeat top/cover;
  }
}

.p-shisetsu-fv.info {
  background: url(../images/info-fv.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-fv.info {
    background: url(../images/info-fv-pc.webp) no-repeat top/cover;
  }
}

.p-shisetsu-fv__title {
  padding-top: 7.375rem;
  color: #000000;
  text-shadow: 1px 1px 0 #ffffff, -1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px -1px 0 #ffffff, 1px 0 0 #ffffff, -1px 0 0 #ffffff, 0 1px 0 #ffffff, 0 -1px 0 #ffffff;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-fv__title {
    padding-top: 11.875rem;
    letter-spacing: 0.05em;
  }
}

.p-shisetsu-fv__title::before {
  text-shadow: none;
}

.p-shisetsu-fv__lead {
  margin-top: 5.625rem;
  font-size: 1.25rem;
  font-weight: bold;
  margin-top: 6.875rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-fv__lead {
    margin-top: 4.375rem;
    font-size: 1.875rem;
    -webkit-font-feature-settings: "palt";
            font-feature-settings: "palt";
  }
}

.p-shisetsu-fv__lead span {
  display: block;
  font-size: 0.8125rem;
  margin-bottom: 0.625rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-fv__lead span {
    letter-spacing: 0.075em;
    font-size: 0.9375rem;
  }
}

.p-shisetsu-fv__text {
  margin-top: 0.625rem;
  font-size: 0.875rem;
  color: #666;
  line-height: 1.8571428571;
  /* -webkit-font-feature-settings: "palt"; */
  /* font-feature-settings: "palt"; */
  text-align: justify;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-fv__text {
    margin-top: 2.625rem;
    max-width: 31.875rem;
    font-size: 1.125rem;
    max-width: 468px;
    letter-spacing: 0.06em;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu-fv__text.info {
    max-width: 28.25rem;
  }
}

.p-shisetsu-message {
  background: url(../images/bg-pink.webp) repeat center/contain;
}

.p-shisetsu-message__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-message__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 3.75rem;
  }
}

.p-shisetsu-message__img {
  width: 14.9375rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-message__img {
    width: 35.5454545455%;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu-message__body {
    width: 53.6363636364%;
  }
}

.p-shisetsu-message__title {
  font-size: 1.25rem;
  font-weight: bold;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-top: -0.4375rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-message__title {
    margin-top: 0;
    font-size: 1.625rem;
    gap: 0.25rem;
  }
}

.p-shisetsu-message__title::before {
  content: attr(data-en);
  font-size: 0.8125rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-message__title::before {
    font-size: 1rem;
  }
}

.p-shisetsu-message__name {
  margin-top: 1rem;
  font-size: 0.875rem;
  font-weight: bold;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-message__name {
    margin-top: 2.625rem;
    font-size: 1rem;
  }
}

.p-shisetsu-message__name span {
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-message__name span {
    font-size: 1.625rem;
    letter-spacing: 0.17em;
  }
}

.p-shisetsu-message__text {
  margin-top: 1.5rem;
  font-size: 0.875rem;
  line-height: 1.8571428571;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: justify;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .p-shisetsu-message__text {
    margin-top: 1.875rem;
    font-size: 1.125rem;
    letter-spacing: 0.08em;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu {
    position: relative;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu::after {
    content: "";
    width: 100%;
    height: 100%;
    background: url(../images/about-lead_bg.webp) repeat center/contain;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu__tab-area {
    margin-top: -6.625rem;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu__tab-area[data-scheme=orange] {
    background-color: #ff7500;
    color: #ffffff;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu__tab-area[data-scheme=green] {
    background-color: #8ec700;
    color: #ffffff;
  }
}

.p-shisetsu__tab-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}

.p-shisetsu__tab {
  height: 2.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border: 1px solid #e5e5e5;
  color: #ffffff;
  font-size: 1rem;
  font-weight: bold;
  background-color: #ffffff;
}
@media screen and (min-width: 768px) {
  .p-shisetsu__tab {
    width: 100%;
    height: 6.625rem;
    font-size: 1.625rem;
    font-weight: 900;
    cursor: pointer;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
}

.p-shisetsu__tab.orange {
  background-color: #ff7500;
  border-radius: 0.3125rem 0 0 0;
}
@media screen and (min-width: 768px) {
  .p-shisetsu__tab.orange {
    border-radius: 0;
    background-color: #ffffff;
    color: #ff7500;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu__tab.orange:hover {
    background-color: #ff7500;
    color: #ffffff;
  }
}

.p-shisetsu__tab.green {
  background-color: #8ec700;
  border-radius: 0 0.3125rem 0 0;
}
@media screen and (min-width: 768px) {
  .p-shisetsu__tab.green {
    border-radius: 0;
    background-color: #ffffff;
    color: #8ec700;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu__tab.green:hover {
    background-color: #8ec700;
    color: #ffffff;
  }
}

.p-shisetsu__tab.orange[aria-selected=true] {
  background-color: #ff7500;
  color: #ffffff;
}

.p-shisetsu__tab.green[aria-selected=true] {
  background-color: #8ec700;
  color: #ffffff;
}

.p-shisetsu__tab-box {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .p-shisetsu__tab-box {
    margin-left: 0;
    margin-right: 0;
  }
}

.p-shisetsu__tab-box [hidden] {
  display: none;
}

.p-shisetsu__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (min-width: 768px) {
  .p-shisetsu__list {
    grid-template-columns: repeat(4, 1fr);
  }
}

.p-shisetsu__item {
  height: 2.8125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border: 1px solid #e5e5e5;
  font-size: 0.875rem;
  font-weight: 500;
  padding-right: 0.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-shisetsu__item {
    height: 6.5625rem;
    font-size: 1.125rem;
    background-color: #ffffff;
    cursor: pointer;
    -webkit-transition: 0.3s ease;
    transition: 0.3s ease;
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu__item.orange,
  .p-shisetsu__item.green {
    color: #000000;
  }
}

.p-shisetsu__item::after {
  content: "";
  width: 0.8125rem;
  height: 0.8125rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: url(../images/icon_arrow-en.webp) no-repeat center/cover;
}
@media screen and (min-width: 768px) {
  .p-shisetsu__item::after {
    width: 1.375rem;
    height: 1.375rem;
    position: absolute;
    top: 50%;
    right: 1.375rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}

.p-shisetsu__item.green::after {
  background: url(../images/icon_arrow-en-green.webp) no-repeat center/cover;
}

@media screen and (min-width: 768px) {
  .p-shisetsu__item.orange:hover {
    background-color: rgb(255, 186, 128);
  }
}

@media screen and (min-width: 768px) {
  .p-shisetsu__item.green:hover {
    background-color: rgb(199, 227, 128);
  }
}

.p-shisetsu__item.orange.is-active,
.p-shisetsu__item.orange[aria-selected=true] {
  background-color: rgb(255, 186, 128);
}

.p-shisetsu__item.green.is-active,
.p-shisetsu__item.green[aria-selected=true] {
  background-color: rgb(199, 227, 128);
}

.p-shisetsu__item span {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  text-align: center;
}
@media screen and (min-width: 768px) {
	.p-shisetsu__item span {
	margin-right: 1.5rem;
	}
}

.p-shisetsu__cards {
  background: url(../images/about-lead_bg.webp) repeat center/contain;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .p-shisetsu__cards {
    margin-top: 4.375rem;
    background: none;
    margin-left: 0;
    margin-right: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 4.375rem;
  }
}

.p-shisetsu__card {
  padding: 1.5625rem 1.25rem 0.75rem;
}
@media screen and (min-width: 768px) {
  .p-shisetsu__card {
    padding: 0;
    margin-bottom: 4.375rem;
  }
}

.p-shisetsu__card.is-hidden {
  display: none;
}

.p-support {
  background: url(../images/bg-blue.webp) repeat center/contain;
}

.p-support__title {
  font-size: 1.125rem;
  font-weight: bold;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0.075em;
}
@media screen and (min-width: 768px) {
  .p-support__title {
    font-size: 1.875rem;
  }
}

.p-support__cards {
  margin-top: 0.75rem;
}
@media screen and (min-width: 768px) {
  .p-support__cards {
    margin-top: 1.5rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.625rem;
  }
}

.p-support__card:nth-child(n+2) {
  margin-top: 1.25rem;
}
@media screen and (min-width: 768px) {
  .p-support__card:nth-child(n+2) {
    margin-top: 0;
  }
}

.p-top {
  position: relative;
}

.p-top::after {
  content: "";
  width: 100%;
  height: 70.625rem;
  background: url(../images/top_bg.webp) no-repeat center/cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}

@media screen and (min-width: 768px) {
  .p-top__wrap {
    margin-top: 5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 7.5rem;
  }
}

.p-top__img {
  margin-top: 1.5rem;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}
@media screen and (min-width: 768px) {
  .p-top__img {
    margin-top: 0;
    width: 67.2727272727%;
    margin-right: 0;
    margin-left: -9.375rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.p-top__img img {
  aspect-ratio: 0 0 5rem 0;
  aspect-ratio: 375/196;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px) {
  .p-top__img img {
    aspect-ratio: 740/539;
    border-radius: 1.3125rem 1.3125rem 13.625rem 1.3125rem;
  }
}

.p-top__body {
  margin-top: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top__body {
    margin-top: 0;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    position: relative;
    width: 35.4545454545%;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}

.p-top__lead {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 1.5555555556;
}
@media screen and (min-width: 768px) {
  .p-top__lead {
    font-size: 1.625rem;
  }
}
@media screen and (min-width: 1280px) {
  .p-top__lead {
    font-size: 2rem;
  }
}

.p-top__text {
  margin-top: 0.5rem;
  font-size: 1rem;
  line-height: 1.75;
  color: #333;
  text-align: justify;
  letter-spacing: -0.054em;
}
@media screen and (min-width: 768px) {
  .p-top__text {
    margin-top: 0;
    margin-right: 1.5rem;
    letter-spacing: 0.03em;
    line-height: 1.7777777778;
  }
}
@media screen and (min-width: 1280px) {
  .p-top__text {
    margin-right: 2.625rem;
    font-size: 1.125rem;
    line-height: 2.4444444444;
  }
}

.p-top__btn {
  margin-top: 1.25rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-top__btn {
    margin-top: 0;
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    position: absolute;
    bottom: 0;
    right: 0;
  }
}

.u-desktop {
  display: none;
}
@media screen and (min-width: 768px) {
  .u-desktop {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .u-mobile {
    display: none;
  }
}

