@charset "UTF-8";
@font-face {
  font-family: "icomoon";
  src: url("fonts/icomoon.eot?wy4d3q");
  src: url("fonts/icomoon.eot?wy4d3q#iefix") format("embedded-opentype"), url("fonts/icomoon.ttf?wy4d3q") format("truetype"), url("fonts/icomoon.woff?wy4d3q") format("woff"), url("fonts/icomoon.svg?wy4d3q#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^=icon-], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-envelope-o:before {
  content: "\e902";
}

.icon-envelope:before {
  content: "\e903";
}

.icon-phone:before {
  content: "\e900";
}

.icon-mobile:before {
  content: "\e901";
}

.icon-arrow-right:before {
  content: "\ea34";
}

.icon-circle-right:before {
  content: "\ea42";
}

html {
  font-size: 14px;
}
@media (min-width: 960px) {
  html {
    font-size: 18px;
  }
}

body {
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
  max-width: 960px;
  margin: 0 auto;
}

main {
  margin: 0 2rem;
}

p {
  text-align: justify;
  line-height: 2;
}

h1 {
  color: #5F8DC3;
  font-size: 2.5rem;
  font-weight: 700;
  margin: 2rem 0;
}
@media (min-width: 960px) {
  h1 {
    font-size: 3rem;
  }
}

h2 {
  color: #5F8DC3;
  font-size: 1.5rem;
  font-weight: 700;
}

h3 {
  color: #5F8DC3;
  font-size: 1.2rem;
  margin: 1rem 0 0 0;
}

a {
  text-decoration-line: none;
  color: #333;
}
a:hover {
  text-decoration: underline;
}
@media (min-width: 960px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}

.button {
  cursor: pointer;
}
.button:hover {
  text-decoration-line: none;
  opacity: 0.8;
}

.lead {
  margin: 0;
}

.error-msg {
  color: red;
}

ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
ul li {
  text-align: justify;
}

.more {
  text-align: right;
}
.more::before {
  content: ">";
  margin-right: 0.5rem;
  font-weight: 700;
  color: #5F8DC3;
}

.pc-only {
  display: none;
}
@media (min-width: 960px) {
  .pc-only {
    display: block;
  }
}

.sp-tb-only {
  display: block;
}
@media (min-width: 960px) {
  .sp-tb-only {
    display: none;
  }
}

.pc-tb-only {
  display: none;
}
@media (min-width: 600px) {
  .pc-tb-only {
    display: block;
  }
}

.sp-only {
  display: block;
}
@media (min-width: 600px) {
  .sp-only {
    display: none;
  }
}

section {
  margin-bottom: 3rem;
}

.hidden {
  opacity: 0;
}

input[type=text],
input[type=email],
textarea {
  box-sizing: border-box;
  border: solid 0.5px #ccc;
  border-radius: 5px;
  width: 100%;
  padding: 0.5rem;
}

header .navbar-brand {
  height: 3rem;
}
header .navbar-brand img {
  height: 100%;
}
header .navbar-collapse {
  margin-top: 1rem;
  padding-bottom: 0;
}
header .navbar-collapse ul {
  text-align: center;
}
header .navbar-collapse ul li .active {
  background-color: #ccc;
}
@media (min-width: 768px) {
  header .navbar-collapse ul li .active {
    background-color: transparent;
    border-bottom: solid 0.5px black;
  }
}

.header-space {
  height: 56px;
}
@media (min-width: 768px) {
  .header-space {
    height: 71px;
  }
}
@media (min-width: 960px) {
  .header-space {
    height: 91px;
  }
}
@media (min-width: 1200px) {
  .header-space {
    height: 82px;
  }
}

footer {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 0 calc(50% - 50vw);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-color: #f0f0f0;
  padding: 2rem;
}
footer .footer-nav {
  margin-bottom: 2rem;
}
footer .footer-nav ul.menu li {
  margin-bottom: 1rem;
  text-align: center;
}
footer .company-info {
  text-align: center;
  margin-bottom: 1rem;
}
footer .company-info .logo {
  display: block;
  margin: 0 auto;
  width: 10rem;
}
footer .company-info p {
  text-align: center;
  margin-bottom: 0;
}

.contact {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 2rem calc(50% - 50vw);
  background-color: #5F8DC3;
  color: #fff;
  padding: 1rem 2rem;
}
@media (min-width: 600px) {
  .contact {
    display: flex;
    justify-content: space-between;
  }
}
@media (min-width: 960px) {
  .contact {
    padding: 1rem calc(50vw - 50%);
  }
}
.contact h2 {
  color: #fff;
}
@media (min-width: 600px) {
  .contact .contact-area {
    display: flex;
    gap: 1rem;
  }
}
.contact .contact-area .tel-contact {
  position: relative;
  margin-bottom: 1rem;
}
@media (min-width: 600px) {
  .contact .contact-area .tel-contact {
    width: 12rem;
    height: 12rem;
    margin: 0;
  }
}
.contact .contact-area .tel-contact .tel-circle {
  padding-top: 100%;
  border: 1px solid #fff;
  /* 正円の境界線 */
  border-radius: 50%;
}
@media (min-width: 600px) {
  .contact .contact-area .tel-contact .tel-circle {
    display: none;
  }
}
.contact .contact-area .tel-contact .tel-message {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media (min-width: 600px) {
  .contact .contact-area .tel-contact .tel-message {
    position: relative;
    width: 100%;
    height: 100%;
    border: 1px solid #fff;
    /* 正円の境界線 */
    border-radius: 50%;
  }
}
.contact .contact-area .tel-contact .tel-message .text-middle {
  font-size: 1.5rem;
  margin-bottom: -0.5rem;
}
@media (min-width: 600px) {
  .contact .contact-area .tel-contact .tel-message .text-middle {
    font-size: 0.8rem;
    margin-bottom: -0.5rem;
  }
}
.contact .contact-area .tel-contact .tel-message .text-large {
  font-size: 3rem;
  font-weight: 700;
  margin-bottom: 0;
}
@media (min-width: 600px) {
  .contact .contact-area .tel-contact .tel-message .text-large {
    font-size: 1.6rem;
  }
}
.contact .contact-area .tel-contact .tel-message .text-large a {
  color: white !important;
}
.contact .contact-area .tel-contact .tel-message .text-small {
  font-size: 0.6rem;
}
.contact .contact-area .mail-contact {
  position: relative;
}
@media (min-width: 600px) {
  .contact .contact-area .mail-contact {
    width: 12rem;
    height: 12rem;
  }
}
.contact .contact-area .mail-contact .mail-circle {
  padding-top: 100%;
  border: 1px solid #fff;
  /* 正円の境界線 */
  border-radius: 50%;
}
@media (min-width: 600px) {
  .contact .contact-area .mail-contact .mail-circle {
    display: none;
  }
}
.contact .contact-area .mail-contact .mail-message {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media (min-width: 600px) {
  .contact .contact-area .mail-contact .mail-message {
    position: relative;
    width: 100%;
    height: 100%;
    border: 1px solid #fff;
    /* 正円の境界線 */
    border-radius: 50%;
  }
}
.contact .contact-area .mail-contact .mail-message .text-middle {
  font-size: 1.5rem;
  margin-bottom: 0rem;
}
@media (min-width: 600px) {
  .contact .contact-area .mail-contact .mail-message .text-middle {
    font-size: 0.8rem;
  }
}
.contact .contact-area .mail-contact .mail-message .text-large {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 0;
}
@media (min-width: 600px) {
  .contact .contact-area .mail-contact .mail-message .text-large {
    font-size: 1.1rem;
  }
}
.contact .contact-area .mail-contact .mail-message .text-large a {
  color: white !important;
}
.contact .contact-area .mail-contact .mail-message .text-small {
  font-size: 1rem;
}
@media (min-width: 600px) {
  .contact .contact-area .mail-contact .mail-message .text-small {
    font-size: 0.6rem;
  }
}

.group-banner {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
}
@media (min-width: 600px) {
  .group-banner {
    flex-direction: row;
  }
}
.group-banner a {
  display: block;
  width: 80%;
}
@media (min-width: 600px) {
  .group-banner a {
    width: calc(33% - 1rem);
  }
}
.group-banner a img {
  display: block;
  width: 100%;
}

.inviewup {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1s ease-out, transform 1s ease-out;
}
.inviewup.visible {
  opacity: 1;
  transform: translateY(0);
}

.inviewup1 {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1s ease-out, transform 1s ease-out;
}
.inviewup1.visible {
  opacity: 1;
  transform: translateY(0);
}

.inviewup2 {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1s ease-out 0.5s, transform 1s ease-out 0.5s;
}
.inviewup2.visible {
  opacity: 1;
  transform: translateY(0);
}

#top-page .swiper {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  position: relative;
}
#top-page .swiper-slide__img {
  width: 100%;
}
#top-page .swiper-slide__text {
  position: absolute;
  top: 70%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
}
#top-page h2 {
  font-size: 2.5rem;
  margin: 0 0 1rem 0;
}
@media (min-width: 600px) {
  #top-page h2 {
    font-size: 2rem;
  }
}
#top-page h2 .ja {
  font-size: 1.2rem;
  margin: 0;
}
@media (min-width: 600px) {
  #top-page h2 .ja {
    font-size: 1rem;
  }
}
#top-page .top-area {
  margin-top: 0;
}
#top-page .top-area .img-wrapper .top-image {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}
#top-page .top-area .message-area .nakaya-logo {
  display: none;
}
#top-page .top-area .message-area .top-message {
  margin: 4rem auto;
}
#top-page .top-area .message-area .top-message p {
  font-size: 2rem;
  font-weight: 700;
  color: #666;
  text-align: center;
  line-height: 1.5;
}
#top-page .top-area .message-area .top-message p .lg {
  font-size: 3rem;
}
#top-page .information {
  margin: 4rem auto 4rem auto;
}
@media (min-width: 600px) {
  #top-page .information {
    width: 80%;
  }
}
#top-page .information #news-feed {
  min-height: 14rem;
}
#top-page .information #news-feed li {
  display: flex;
  flex-direction: column;
  margin-bottom: 1rem;
}
#top-page .information #news-feed li .news-date {
  width: 4rem;
}
@media (min-width: 600px) {
  #top-page .information #news-feed li {
    flex-direction: row;
    gap: 1rem;
  }
  #top-page .information #news-feed li a {
    margin-left: 2rem;
  }
}
#top-page .information #news-feed li.to-list {
  display: block;
}
#top-page .information #news-feed li.to-list::before {
  content: ">";
  margin-right: 0.5rem;
  font-weight: 700;
  color: #5F8DC3;
}
#top-page .information #news-feed li.to-list a {
  margin-left: 0;
}
#top-page .aboutus {
  display: flex;
  flex-direction: column;
}
@media (min-width: 600px) {
  #top-page .aboutus {
    flex-direction: row;
    gap: 2rem;
  }
}
#top-page .aboutus .text-group {
  display: contents;
}
@media (min-width: 600px) {
  #top-page .aboutus .text-group {
    display: flex;
    flex-direction: column;
  }
}
#top-page .aboutus .text-group h2 {
  order: -1;
}
#top-page .aboutus img {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 1rem calc(50% - 50vw);
}
@media (min-width: 600px) {
  #top-page .aboutus img {
    width: 50vw;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
    margin: 0 0 0 calc(50% - 50vw);
  }
}
#top-page .reason {
  display: flex;
  flex-direction: column;
}
@media (min-width: 600px) {
  #top-page .reason {
    flex-direction: row;
    gap: 2rem;
  }
}
#top-page .reason .text-group {
  display: contents;
}
@media (min-width: 600px) {
  #top-page .reason .text-group {
    display: flex;
    flex-direction: column;
  }
}
#top-page .reason .text-group h2 {
  order: -1;
}
#top-page .reason img {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 1rem calc(50% - 50vw);
}
@media (min-width: 600px) {
  #top-page .reason img {
    width: 50vw;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
    margin: 0 0 0 calc(50% - 50vw);
  }
}
#top-page .reason .message-area ul li .heading {
  display: flex;
  align-items: center;
}
#top-page .reason .message-area ul li .heading .list-number {
  color: #5F8DC3;
  font-size: 4rem;
  font-weight: 700;
  margin-right: 1.5rem;
  transform: translateY(-0.2rem);
}
@media (min-width: 600px) {
  #top-page .reason .message-area ul li .heading .list-number {
    font-size: 3rem;
    margin-right: 0.7rem;
  }
}
#top-page .reason .message-area ul li .heading h3 {
  font-size: 1.5rem;
  font-weight: 700;
  color: #333;
  margin-top: 0;
}
@media (min-width: 600px) {
  #top-page .reason .message-area ul li .heading h3 {
    font-size: 1.2rem;
  }
}
#top-page .service {
  display: flex;
  flex-direction: column;
}
@media (min-width: 600px) {
  #top-page .service {
    flex-direction: row;
    gap: 2rem;
  }
}
#top-page .service img {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 1rem calc(50% - 50vw);
}
@media (min-width: 600px) {
  #top-page .service img {
    width: 50vw;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
    margin: 0 0 0 calc(50% - 50vw);
  }
}
#top-page .service .text-group {
  display: contents;
}
@media (min-width: 600px) {
  #top-page .service .text-group {
    display: flex;
    flex-direction: column;
  }
}
#top-page .service .text-group h2 {
  order: -1;
}
#top-page .service .text-group li {
  line-height: 2;
}
#top-page .shop-guide {
  display: flex;
  flex-direction: column;
}
#top-page .shop-guide section {
  scroll-margin-top: 60px;
}
@media (min-width: 600px) {
  #top-page .shop-guide {
    flex-direction: row;
    gap: 2rem;
  }
}
#top-page .shop-guide .img-area {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 0.5rem calc(50% - 50vw);
}
@media (min-width: 600px) {
  #top-page .shop-guide .img-area {
    width: 50vw;
    min-width: 50vw;
    height: auto;
    margin: 0 0 0 calc(50% - 50vw);
  }
}
#top-page .shop-guide .img-area img {
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 0.5rem;
}
#top-page .shop-guide .text-group {
  display: contents;
}
@media (min-width: 600px) {
  #top-page .shop-guide .text-group {
    display: flex;
    flex-direction: column;
  }
}
#top-page .shop-guide .text-group h2 {
  order: -1;
}

#about-page h1 {
  font-size: 2rem;
}
#about-page dl {
  border-bottom: 1px solid #f1f1f1;
}
@media (min-width: 960px) {
  #about-page dl {
    display: table;
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #f1f1f1;
  }
}
@media (min-width: 960px) {
  #about-page dl .list-item {
    display: table-row;
  }
}
#about-page dl .list-item dt {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #f1f1f1;
  padding: 1rem 2rem;
  color: #333;
  font-weight: 500;
}
@media (min-width: 960px) {
  #about-page dl .list-item dt {
    display: table-cell;
    width: 40%;
    border-bottom: solid 1px white;
  }
}
#about-page dl .list-item:last-child dt {
  border-bottom: solid 1px #f1f1f1;
}
#about-page dl .list-item dd {
  padding: 1rem 0;
  margin: 0;
}
@media (min-width: 960px) {
  #about-page dl .list-item dd {
    display: table-cell;
    width: 60%;
    padding: 1rem 2rem;
    border-top: solid 1px #f1f1f1;
  }
}
#about-page dl .list-item dd p {
  margin: 0;
}
#about-page dl .list-item dd .shop-info {
  margin-bottom: 2rem;
}
#about-page dl .list-item dd .shop-info .to-access {
  display: block;
}
#about-page dl .list-item dd .shop-info .to-access::before {
  content: ">";
  margin-right: 0.5rem;
  font-weight: 700;
  color: #5F8DC3;
}
#about-page dl .list-item dd .shop-info .to-access a {
  margin-left: 0;
}
#about-page table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1rem;
}
#about-page table tr th {
  background-color: #efefef;
}
#about-page table tr th, #about-page table tr td {
  padding: 0.5rem;
  border: 0.5px solid #ccc;
  white-space: nowrap;
  text-align: center;
}
#about-page ul li {
  line-height: 2;
}
#about-page ul li::before {
  content: "※"; /* ※マークを追加 */
  margin-right: 10px; /* マークとテキストの間隔を設定 */
  font-weight: bold; /* 太字に設定 */
}

#shop-guide-page .shop-guide h1 {
  font-size: 2rem;
}
#shop-guide-page .shop-guide section {
  margin-bottom: 4rem;
}
@media (min-width: 600px) {
  #shop-guide-page .shop-guide section {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 1rem;
  }
}
#shop-guide-page .shop-guide section.link-scroll {
  scroll-margin-top: 56px;
}
@media (min-width: 768px) {
  #shop-guide-page .shop-guide section.link-scroll {
    scroll-margin-top: 71px;
  }
}
@media (min-width: 960px) {
  #shop-guide-page .shop-guide section.link-scroll {
    scroll-margin-top: 91px;
  }
}
@media (min-width: 1200px) {
  #shop-guide-page .shop-guide section.link-scroll {
    scroll-margin-top: 82px;
  }
}
@media (min-width: 600px) {
  #shop-guide-page .shop-guide section .text-group {
    width: calc(50% - 0.5rem);
  }
}
#shop-guide-page .shop-guide section .text-group h2 {
  margin-bottom: 0.5rem;
}
#shop-guide-page .shop-guide section .text-group .shop-info {
  margin-bottom: 0.5rem;
}
#shop-guide-page .shop-guide section .text-group .shop-info p {
  margin: 0;
  text-align: start;
}
#shop-guide-page .shop-guide section .text-group .shop-info a {
  line-height: 2;
}
@media (min-width: 600px) {
  #shop-guide-page .shop-guide section .shop-img {
    order: 1;
    display: flex;
    justify-content: space-between;
  }
}
#shop-guide-page .shop-guide section .shop-img img {
  width: 100%;
  margin-bottom: 0.5rem;
}
@media (min-width: 600px) {
  #shop-guide-page .shop-guide section .shop-img img {
    width: calc(50% - 0.5rem);
  }
}
#shop-guide-page .shop-guide section .access-map {
  width: 100%;
  padding-top: 72%;
  position: relative;
}
@media (min-width: 600px) {
  #shop-guide-page .shop-guide section .access-map {
    width: calc(50% - 0.5rem);
    padding-top: 37%;
  }
}
#shop-guide-page .shop-guide section .access-map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#service-page .service-area h1 {
  font-size: 2rem;
}
#service-page .service-area img {
  width: 100vw;
  margin: 0 calc(50% - 50vw) 1rem calc(50% - 50vw);
}
@media (min-width: 600px) {
  #service-page .service-area .top-area {
    display: flex;
    margin-bottom: 4rem;
  }
}
@media (min-width: 600px) {
  #service-page .service-area .top-area .top-img {
    width: 50vw;
    margin: 0 1rem 0 calc(50% - 50vw);
  }
}
#service-page .service-area .top-area .heading {
  font-size: 2rem;
  font-weight: 700;
  color: #5F8DC3;
  line-height: 1.5;
  margin: 1rem 0 0.5rem 0;
}
#service-page .service-area .top-area explanation {
  margin-bottom: 3rem;
}
#service-page .service-area section {
  margin-bottom: 4rem;
  display: flex;
  flex-direction: column;
}
#service-page .service-area section .heading-wrapper {
  display: contents;
}
@media (min-width: 600px) {
  #service-page .service-area section .heading-wrapper {
    display: flex;
    align-items: center;
  }
}
#service-page .service-area section .heading-wrapper h2 {
  margin: 1rem 2rem 1rem 0;
}
#service-page .service-area section .heading-wrapper .btn-wrapper {
  margin: 0.5rem 0;
  order: 1;
}
@media (min-width: 600px) {
  #service-page .service-area section .heading-wrapper .btn-wrapper {
    margin: 0 0.5rem 0 0;
  }
}
#service-page .service-area section .heading-wrapper .btn-wrapper .btn {
  width: 100%;
  padding: 0.5rem;
  border-radius: 10px;
}
@media (min-width: 600px) {
  #service-page .service-area section .heading-wrapper .btn-wrapper .btn {
    padding: 0.2rem 1rem;
  }
}
#service-page .service-area section .heading-wrapper .btn-wrapper .btn.to-examples {
  background-color: #C272AC;
}
#service-page .service-area section .heading-wrapper .btn-wrapper .btn.to-hp {
  background-color: #625BCF;
}
#service-page .service-area section .heading-wrapper .btn-wrapper .btn a {
  font-size: 1.5rem;
  font-weight: 500;
  color: #fff;
}
@media (min-width: 600px) {
  #service-page .service-area section .heading-wrapper .btn-wrapper .btn a {
    font-size: 1rem;
  }
}
#service-page .service-area section .heading-wrapper .btn-wrapper .btn a::after {
  content: "▶";
  margin-left: 1rem;
}

#recruit-page h1 {
  font-size: 2rem;
}
@media (min-width: 600px) {
  #recruit-page .top-area {
    display: flex;
    margin-bottom: 4rem;
  }
}
#recruit-page .top-area .top-img {
  width: 100%;
}
@media (min-width: 600px) {
  #recruit-page .top-area .top-img {
    width: 50%;
    margin: 0 1rem 0 0;
  }
}
#recruit-page .top-area .heading {
  font-size: 2rem;
  font-weight: 700;
  color: #5F8DC3;
  line-height: 1.5;
  margin: 1rem 0 0.5rem 0;
}
#recruit-page .top-area explanation {
  margin-bottom: 3rem;
}
#recruit-page .job-discriptions dl {
  border-bottom: 1px solid #cad9eb;
}
@media (min-width: 960px) {
  #recruit-page .job-discriptions dl {
    display: table;
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #cad9eb;
  }
}
@media (min-width: 960px) {
  #recruit-page .job-discriptions dl .list-item {
    display: table-row;
  }
}
#recruit-page .job-discriptions dl .list-item dt {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #cad9eb;
  padding: 1rem 2rem;
  color: #333;
  font-weight: 500;
}
@media (min-width: 960px) {
  #recruit-page .job-discriptions dl .list-item dt {
    display: table-cell;
    width: 40%;
    border-bottom: solid 1px white;
  }
}
#recruit-page .job-discriptions dl .list-item:last-child dt {
  border-bottom: solid 1px #cad9eb;
}
#recruit-page .job-discriptions dl .list-item dd {
  padding: 1rem 0;
  margin: 0;
}
@media (min-width: 960px) {
  #recruit-page .job-discriptions dl .list-item dd {
    display: table-cell;
    width: 60%;
    padding: 1rem 2rem;
    border-top: solid 1px #cad9eb;
  }
}
#recruit-page .job-discriptions dl .list-item dd p {
  margin: 0;
}
#recruit-page .mail-area {
  margin: 0;
}
#recruit-page .mail-area h2,
#recruit-page .mail-area .mail-message {
  margin: 0 0 0.5rem 0;
}
#recruit-page .mail-area .mail-message {
  margin-bottom: 2rem;
}
@media (min-width: 960px) {
  #recruit-page .mail-area dl {
    display: table;
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #cad9eb;
  }
}
@media (min-width: 960px) {
  #recruit-page .mail-area dl .list-item {
    display: flex;
  }
}
#recruit-page .mail-area dl .list-item dt {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #cad9eb;
  padding: 1rem 2rem;
}
@media (min-width: 960px) {
  #recruit-page .mail-area dl .list-item dt {
    display: table-cell;
    width: 40%;
    margin: 0;
    border-bottom: solid 1px white;
  }
}
#recruit-page .mail-area dl .list-item dt.required {
  display: flex;
  justify-content: space-between;
}
#recruit-page .mail-area dl .list-item dt.required::after {
  content: "必須";
  color: white;
  background-color: red;
  font-size: 0.8rem;
  padding: 0.2rem;
  height: -moz-fit-content;
  height: fit-content;
}
#recruit-page .mail-area dl .list-item dd {
  padding: 1rem 0;
}
@media (min-width: 960px) {
  #recruit-page .mail-area dl .list-item dd {
    display: table-cell;
    width: 60%;
    padding: 1rem 2rem;
    border-top: solid 1px #cad9eb;
  }
}
#recruit-page .mail-area dl .list-item dd.radiobox {
  display: flex;
  gap: 2rem;
}
#recruit-page .mail-area dl .list-item dd.checkbox {
  display: flex;
  flex-direction: column;
}
#recruit-page .mail-area dl .list-item dd.checkbox .check-area {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 2rem;
  margin: 1rem 0;
}
#recruit-page .mail-area dl .list-item dd.checkbox .check-area .check-item {
  line-height: 1;
}
#recruit-page .mail-area dl .list-item dd.checkbox .other {
  display: flex;
  align-items: center;
}
#recruit-page .mail-area dl .list-item dd.checkbox .other span {
  margin-right: 1rem;
}
#recruit-page .mail-area .button {
  background-color: #5F8DC3;
  width: 100%;
  padding: 1rem 1.5rem;
  margin: 2rem 0rem 4rem 0rem;
  border-radius: 50px;
  font-size: 1.8rem;
  border: none;
  color: white;
}

#contact-page h1 {
  font-size: 2rem;
}
#contact-page .top-area {
  margin: 1rem 0 4rem 0;
}
@media (min-width: 600px) {
  #contact-page .top-area {
    display: flex;
  }
}
#contact-page .top-area .contact-top {
  width: 30%;
  display: block;
  margin: 0 auto;
  margin-bottom: 1rem;
}
@media (min-width: 600px) {
  #contact-page .top-area .contact-top {
    margin: 0 2rem;
  }
}
#contact-page .top-area .top-message {
  margin: 2rem 0;
}
#contact-page .tel-area {
  margin: 1rem 0 4rem 0;
}
#contact-page .tel-area h2 {
  margin: 0 0 0.5rem 0;
}
#contact-page .tel-area .contact-tel-btn {
  width: 100%;
  max-width: 600px;
  padding: 0.5rem;
  border: none;
  border-radius: 3rem;
  background-color: #5F8DC3;
}
#contact-page .tel-area .contact-tel-btn a {
  font-size: 1.4;
  color: #fff;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  position: relative;
}
#contact-page .tel-area .contact-tel-btn a:hover {
  text-decoration: none;
}
#contact-page .tel-area .contact-tel-btn a::before {
  content: "\e901";
  /* 指定したいアイコンの番号 */
  font-family: "icomoon";
  font-size: 3rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 1.5rem;
}
#contact-page .tel-area .contact-tel-btn a::after {
  content: "\ea42";
  /* 指定したいアイコンの番号 */
  font-family: "icomoon";
  font-size: 2rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 1.5rem;
}
#contact-page .tel-area .contact-tel-btn a .tel-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}
#contact-page .tel-area .contact-tel-btn a .tel-inner .contact-tel {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 0.1rem;
}
#contact-page .tel-area .contact-tel-btn a .tel-inner .reception-time {
  font-size: 0.8rem;
}
#contact-page .mail-area {
  margin: 0;
}
#contact-page .mail-area h2,
#contact-page .mail-area .mail-message {
  margin: 0 0 0.5rem 0;
}
#contact-page .mail-area .mail-message {
  margin-bottom: 2rem;
}
@media (min-width: 960px) {
  #contact-page .mail-area dl {
    display: table;
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #cad9eb;
  }
}
@media (min-width: 960px) {
  #contact-page .mail-area dl .list-item {
    display: flex;
  }
}
#contact-page .mail-area dl .list-item dt {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #cad9eb;
  padding: 1rem 2rem;
}
@media (min-width: 960px) {
  #contact-page .mail-area dl .list-item dt {
    display: table-cell;
    width: 40%;
    margin: 0;
    border-bottom: solid 1px white;
  }
}
#contact-page .mail-area dl .list-item dt.required {
  display: flex;
  justify-content: space-between;
}
#contact-page .mail-area dl .list-item dt.required::after {
  content: "必須";
  color: white;
  background-color: red;
  font-size: 0.8rem;
  padding: 0.2rem;
  height: -moz-fit-content;
  height: fit-content;
}
#contact-page .mail-area dl .list-item dd {
  padding: 1rem 0;
}
@media (min-width: 960px) {
  #contact-page .mail-area dl .list-item dd {
    display: table-cell;
    width: 60%;
    padding: 1rem 2rem;
    border-top: solid 1px #cad9eb;
  }
}
#contact-page .mail-area dl .list-item dd.radiobox {
  display: flex;
  gap: 2rem;
}
#contact-page .mail-area dl .list-item dd.checkbox {
  display: flex;
  flex-direction: column;
}
#contact-page .mail-area dl .list-item dd.checkbox .check-area {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 2rem;
  margin: 1rem 0;
}
#contact-page .mail-area dl .list-item dd.checkbox .check-area .check-item {
  line-height: 1;
}
#contact-page .mail-area dl .list-item dd.checkbox .other {
  display: flex;
  align-items: center;
}
#contact-page .mail-area dl .list-item dd.checkbox .other span {
  margin-right: 1rem;
}
#contact-page .mail-area .button {
  background-color: #5F8DC3;
  width: 100%;
  padding: 1rem 1.5rem;
  margin: 2rem 0rem 4rem 0rem;
  border-radius: 50px;
  font-size: 1.8rem;
  border: none;
  color: white;
}

#confirm-page h1 {
  font-size: 2rem;
}
@media (min-width: 960px) {
  #confirm-page dl {
    display: table;
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #f1f1f1;
  }
}
@media (min-width: 960px) {
  #confirm-page dl .list-item {
    display: flex;
  }
}
#confirm-page dl .list-item dt {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  background-color: #f1f1f1;
  padding: 1rem 2rem;
}
@media (min-width: 960px) {
  #confirm-page dl .list-item dt {
    display: table-cell;
    width: 40%;
    margin: 0;
    border-bottom: solid 1px white;
  }
}
#confirm-page dl .list-item dd {
  padding: 1rem 0;
}
@media (min-width: 960px) {
  #confirm-page dl .list-item dd {
    display: table-cell;
    width: 60%;
    padding: 1rem 2rem;
    border-top: solid 1px #f1f1f1;
  }
}
#confirm-page .btn-area {
  display: flex;
  gap: 10px;
}
#confirm-page .btn-area .button {
  background-color: #5F8DC3;
  width: 100%;
  padding: 1rem 1.5rem;
  margin: 2rem 0rem 4rem 0rem;
  border-radius: 50px;
  font-size: 1.8rem;
  border: none;
  color: white;
}
#confirm-page .btn-area .button.back-btn {
  text-align: center;
  color: #5F8DC3;
  background-color: white;
  border: solid 1px #5F8DC3;
}

#thanks-page h1, #thanks-page h3, #thanks-page p {
  text-align: center;
}
#thanks-page h1 {
  margin-bottom: 2rem;
}
#thanks-page h3 {
  margin-bottom: 1.5rem;
}
#thanks-page a {
  display: block;
  text-align: center;
  margin-bottom: 2rem;
}

#privacy-page ul li, #privacy-page ol li {
  line-height: 2;
}
#privacy-page ul li ul, #privacy-page ol li ul {
  list-style-type: circle;
  margin-left: 4rem;
}

/*========= スクロールダウンのためのCSS ===============*/
/*=== 9-1-4 矢印が動いてスクロールを促す  ====*/
/*スクロールダウン全体の場所*/
.scrolldown4 {
  /*描画位置※位置は適宜調整してください*/
  position: absolute;
  left: 50%;
  opacity: 0;
  /*矢印の動き1秒かけて永遠にループ*/
  animation: fadeIn 3s 13s forwards, arrowmove 1s ease-in-out infinite;
}

/*下からの距離が変化して全体が下→上→下に動く*/
@keyframes arrowmove {
  0% {
    bottom: 7%;
  }
  50% {
    bottom: 10%;
  }
  100% {
    bottom: 7%;
  }
}
/*Scrollテキストの描写*/
.scrolldown4 span {
  /*描画位置*/
  position: absolute;
  left: -20px;
  bottom: 10px;
  /*テキストの形状*/
  color: #333;
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  /*縦書き設定*/
  writing-mode: vertical-rl;
}

/* 矢印の描写 */
.scrolldown4:before {
  content: "";
  /*描画位置*/
  position: absolute;
  bottom: 0;
  right: -6px;
  /*矢印の形状*/
  width: 1px;
  height: 20px;
  background: #333;
  transform: skewX(-31deg);
}

.scrolldown4:after {
  content: "";
  /*描画位置*/
  position: absolute;
  bottom: 0;
  right: 0;
  /*矢印の形状*/
  width: 1px;
  height: 50px;
  background: #333;
}

#test-page {
  margin: 0 2rem;
}
#test-page dl dt {
  background-color: #ccc;
  margin: 0 calc(50% - 50vw);
  padding: 1rem 2rem;
}
#test-page dl dd {
  margin: 0;
}
#test-page img {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}/*# sourceMappingURL=style.css.map */