body.entry {
	background-color: #e8f5f0;
	display: flex;
	flex-direction: column;
	min-height: 100vh; /* ビューポートの高さを最低限確保 */
}

.mlr {
	margin-left: 0;
	margin-right: 0;
}


.btn-tg01 {
	padding-left: 22px;
	position: relative;
	margin-bottom: 40px;
	font-size: 18px;
	font-weight: 600;
	color: #004267;
}

.btn-tg01::before {
	content: "";
	background: #004267;
	background: linear-gradient(90deg, #003366 0%, #004267 100%);
	position: absolute;
	bottom: -18px;
	right: 0%;
	height: 3px;
	box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.16);
	left: 0;
}


#contact-member {
	padding: 20px 0 80px;
}

#contact-member .fcform__main {
  width: 100%;
}

#contact-member .form-caption {
	width: 30%;
}

#contact-member .caption--askerisk {
	left: 73%;
}

@media only screen and (max-width: 560px) {
	#contact-member {
		padding: 3.57vw 0 14.29vw;
	}

	#contact-member .form-caption {
		width: 100%;
	}

	#contact-member .caption--askerisk {
		left: auto;
		right: 0;
	}
}


/* キャラクターの位置（デスクトップ） */
.waku-progress__character--step1 { left: 0%; }
.waku-progress__character--step2 { left: 15.7%; }
.waku-progress__character--step3 { left: 31.3%; }
.waku-progress__character--step4 { left: 47%; }
.waku-progress__character--step5 { left: 62.7%; }
.waku-progress__character--step6 { left: 78.3%; }
.waku-progress__character--step7 { left: 94%; }

/* プログレスバーの幅（デスクトップ） */
.waku-progress__bar-fill--step1 { width: 2%; }
.waku-progress__bar-fill--step2 { width: 18.7%; }
.waku-progress__bar-fill--step3 { width: 35.3%; }
.waku-progress__bar-fill--step4 { width: 52%; }
.waku-progress__bar-fill--step5 { width: 68.7%; }
.waku-progress__bar-fill--step6 { width: 85.3%; }
.waku-progress__bar-fill--step7 { width: 100%; }

@media only screen and (max-width: 560px) {
	
	/* スマートフォン用の位置調整 */
	.waku-progress__character--step1 { left: 5%; }
	.waku-progress__character--step2 { left: 15.7%; }
	.waku-progress__character--step3 { left: 31.3%; }
	.waku-progress__character--step4 { left: 47%; }
	.waku-progress__character--step5 { left: 62.7%; }
	.waku-progress__character--step6 { left: 78.3%; }
	.waku-progress__character--step7 { left: 99%; }
	
	/* スマートフォン用の進捗バー幅調整 */
	.waku-progress__bar-fill--step1 { width: 3%; }
	.waku-progress__bar-fill--step2 { width: 15.7%; }
	.waku-progress__bar-fill--step3 { width: 31.3%; }
	.waku-progress__bar-fill--step4 { width: 47%; }
	.waku-progress__bar-fill--step5 { width: 62.7%; }
	.waku-progress__bar-fill--step6 { width: 78.3%; }
	.waku-progress__bar-fill--step7 { width: 100%; }
}




.txt__inline {
	display: inline-flex;
	align-items: center;
	gap: 20px;
}

.form-button .submit-form {
	padding-top: 30px;
}

.form-submit_back {
	background: #fff !important;
	border-radius: 5px;
	text-align: center;
	font-weight: 600;
	padding: 15px 24px;
	color: #000 !important;
	font-size: 17px;
	border: 1px solid #CCCCCC !important;
}

.form-submit_back::before {
	display: none;
}

.form-submit_back:hover {
	background: #ccc !important;
	color: #000 !important;
	text-decoration: none !important;
}

body.qualifications--opened,
body.type--opened,
body.location--opened {
	overflow-y: hidden !important;
	-webkit-overflow-scrolling: touch;
}

body.qualifications--opened,
body.qualifications--opened *,
body.qualifications--opened *:hover,
body.qualifications--opened *:focus,
body.qualifications--opened *:active,
body.type--opened,
body.type--opened *,
body.type--opened *:hover,
body.type--opened *:focus,
body.type--opened *:active,
body.location--opened,
body.location--opened *,
body.location--opened *:hover,
body.location--opened *:focus,
body.location--opened *:active {
	pointer-events: none !important;
	touch-action: none !important;
}

body.qualifications--opened .search-jobs__form__sp,
body.qualifications--opened .search-jobs__form__sp *,
body.qualifications--opened .remodal-is-opened,
body.qualifications--opened .remodal-is-opened *,
body.type--opened .search-jobs__form__sp,
body.type--opened .search-jobs__form__sp *,
body.type--opened .remodal-is-opened,
body.type--opened .remodal-is-opened *,
body.location--opened .search-jobs__form__sp,
body.location--opened .search-jobs__form__sp *,
body.location--opened .remodal-is-opened,
body.location--opened .remodal-is-opened * {
	pointer-events: visible !important;
	touch-action: auto !important;
}

.sitemap-page {
	padding-top: 47px;
	padding-bottom: 100px;
	letter-spacing: 0;
}

@media only screen and (max-width: 560px) {
	.sitemap-page {
		padding-top: 0;
	}
}

.sitemap-page__list {
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.sitemap-page__list li {
	margin-bottom: 1px;
	width: 48%;
}

.sitemap-page__list li a {
	display: block;
	position: relative;
	background: #DDEAF1;
	line-height: 61px;
	padding: 0 30px;
	transition: all .4s ease;
}

.sitemap-page__list li a::after {
	content: "";
	background: url(../img/shared/icon_arrow02.webp) no-repeat;
	background-size: 100% auto;
	width: 11px;
	height: 17px;
	position: absolute;
	top: 50%;
	right: 27px;
	transform: translateY(-50%);
}

.sitemap-page__list li a:hover {
	background: #98c8e2;
}

/* フッタースタイル */
footer {
  background-color: #00AA83;
  color: #ffffff;
  flex-shrink: 0; /* フッターを縮小させない */
}

.footer-container {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  color: #ffffff;
  padding: 20px 0;
}

.footer-links {
  display: flex;
  justify-content: center;
  list-style: none;
  padding: 0;
  margin: 0 0 10px 0;
}

.footer-links li {
  margin: 0 15px;
}

.footer-links a {
  color: #ffffff;
  text-decoration: none;
  font-size: 14px;
}

.footer-links a:hover {
  text-decoration: underline;
}

.copyright {
  font-size: 12px;
  margin: 0;
}

@media only screen and (max-width: 560px) {
  .footer-container {
    padding: 3.57vw 0;
  }
  
  .footer-links {
    margin-bottom: 1.79vw;
  }
  
  .footer-links li {
    margin: 0 2.68vw;
  }
  
  .footer-links a {
    font-size: 3.21vw;
  }
  
  .copyright {
    font-size: 2.68vw;
  }
}

/* スマホ対応 */
@media screen and (max-width: 560px) {
  .footer-links li {
    margin: 0 1.78vw;
  }
  
  .footer-links a {
    font-size: 2.5vw;
  }
  
  .copyright {
    font-size: 2.14vw;
  }
}



/* info box  */
.entry-form__info-box {
  margin-bottom: 10px;
  border: 2px solid #00AA83;
  padding: 10px;
  text-align: left;
}
.entry-form__info-box--action {
  margin-top: 10px;
  border-radius: 10px;
  border-color: #FF2C2C;
}
.entry-form__info-box-text {
  font-size: 13px;
  font-weight: 700;
  /* letter-spacing: -0.05em; */
}
.entry-form__info-box-text--color-red {
  color: #FF2C2C;
}

.entry-form__info-box-message-title {
  font-weight: 500;
  font-size: 32px;
  line-height: 1.25;
  text-align: left;
  margin-left: -100px;
  margin-bottom: 40px;
}
.entry-form__info-box-message {
  font-size: 16px;
  line-height: 2;
  text-align: left;
  margin-left: -100px;
  margin-bottom: 20px;
}
.entry-form__info-box-notice {
  font-size: 14px;
  line-height: 2;
  text-align: left;
  color: #666;
  margin-left: -100px;
  margin-bottom: 60px;
}

@media only screen and (max-width: 560px) {
  /* info box  */
  .entry-form__info-box {
    margin-bottom: 1.78vw;
    padding: 1.78vw;
  }
  .entry-form__info-box--action {
    margin-top: 1.78vw;
    border-radius: 1.78vw;
  }
  .entry-form__info-box-text {
    font-size: 2.32vw;
  }
  .entry-form__info-box-message-title {
    font-size: 3.92vw;
    line-height: 1.5;
    margin-left: 0;
    margin-bottom: 5.35vw;
  }
  .entry-form__info-box-message {
    font-size: 3.21vw;
    margin-left: 0;
    margin-bottom: 3.57vw;
  }
  .entry-form__info-box-notice {
    font-size: 2.85vw;
    margin-left: 0;
    margin-bottom: 10.71vw;
  }
  #_formConf .entry-form__info-box-message {
    margin-bottom: 10.71vw;
  }
}

/* 希望開始時期入力フォーム用スタイル */
.waku-entry {
  background-color: #ffffff;
  border-radius: 5px;
  padding: 15px 30px;
  width: 100%;
  position: relative;
  box-shadow: 0 -3px 6px rgba(0, 0, 0, 0.2), 3px 3px 6px rgba(0, 0, 0, 0.3);
}

.waku-entry__question {
  background-color: #fff;
  border-radius: 5px;
  padding: 15px 0;
  margin-bottom: 15px;
}

.waku-entry__question-title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}

.waku-entry__question-note {
  font-size: 12px;
  color: #666;
  margin-right: 10px;
}

.waku-entry__question-required {
  display: inline-block;
  background-color: #00a381;
  color: #fff;
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 16px;
  margin-left: 10px;
}

/* プログレスバースタイル */
.waku-progress {
  padding: 15px 0;
  position: relative;
  margin-bottom: 20px;
  width: 100%;
}

.waku-progress__character {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  z-index: 2;
  transition: left 0.5s ease;
}

.waku-progress__bar {
  background-color: #fff;
  height: 16px;
  border-radius: 8px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 -3px 6px rgba(0, 0, 0, 0.2), 3px 3px 6px rgba(0, 0, 0, 0.3);
}

.waku-progress__bar-fill {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  background-color: #00a381;
  transition: width 0.5s ease;
}

.waku-progress__step {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
  color: #333;
}

/* 立地選択カードスタイル */
.waku-location {
  width: 100%;
}

.waku-location__title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}

.waku-location__required {
  display: inline-block;
  background-color: #00a381;
  color: #fff;
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 3px;
  margin-left: 10px;
}

.waku-location__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.waku-location__item {
  position: relative;
}

.waku-location__input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.waku-location__card {
  background-color: #f5f5f5;
  border-radius: 5px;
  padding: 25px;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
}

.waku-location__card:hover {
  background-color: #e0e0e0;
}

.waku-location__input:checked + .waku-location__card {
  background-color: #00a381;
  color: #fff;
}

.waku-location__icon {
  width: 60px;
  height: 60px;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* チェックボックスが選択された時のアイコンを白色に変更 */
.waku-location__input:checked + .waku-location__card .waku-location__icon img {
  filter: brightness(10);
}


.waku-location__name {
  font-size: 14px;
  font-weight: bold;
}

/* 戻る・次へボタン */
.waku-button-container {
  display: flex;
  justify-content: space-between;
  width: 100%;
  margin: 30px 0 0;
}

.waku-button-container--center {
  justify-content: center;
}

.waku-button-back {
  background: transparent;
  border: none;
  color: #333;
  font-size: 16px;
  cursor: pointer;
  padding: 5px;
  display: flex;
  align-items: center;
  width: 100px;
}

.waku-button-back::before {
  content: "＜";
  margin-right: 5px;
}

@media only screen and (max-width: 560px) {
  /* プログレスバーレスポンシブ */
  .waku-progress {
    padding: 2.68vw 0;
    margin-bottom: 4.57vw;
    width: 100%;
  }

  .waku-progress__character {
    width: 10.71vw;
    height: 10.71vw;
    transition: left 0.5s ease;
    margin-left: -5.36vw; /* 中央配置のための調整 */
  }

  .waku-progress__bar {
    height: 4.57vw;
    border-radius: 1.79vw;
  }

  .waku-progress__step {
    font-size: 2.93vw;
    margin-bottom: 3.79vw;
  }
  
  /* 立地選択カードレスポンシブ */
  .waku-location__title {
    font-size: 3.23vw;
    margin-bottom: 2.68vw;
  }
  
  .waku-location__required {
    font-size: 2.68vw;
    padding: 0.54vw 1.43vw;
    border-radius: 0.71vw;
    margin-left: 1.79vw;
  }
  
  .waku-location__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.79vw;
  }
  
  .waku-location__item {
  }
  
  .waku-location__card {
    padding: 1.79vw;
    border-radius: 2.93vw;
  }
  
  .waku-location__icon {
    width: 10.71vw;
    height: 10.71vw;
    margin-bottom: 1.79vw;
  }
  
  .waku-location__name {
    font-size: 3.57vw;
  }
  
  .waku-button-container {
    margin-top: 5.36vw;
  }
  
  .waku-button-back {
    font-size: 3.57vw;
  }
  
  /* waku-entryレスポンシブ */
  .waku-entry {
    padding: 3.57vw 5.36vw;
    width: 100%;
  }
  
  .waku-entry__question {
    padding: 3.57vw;
    margin-bottom: 3.57vw;
  }
  
  .waku-entry__question-title {
    font-size: 3.23vw;
    margin-bottom: 3.57vw;
  }
  
  .waku-entry__question-note {
    font-size: 2.02vw;
    margin-right: 1.79vw;
  }
  
  .waku-entry__question-required {
    font-size: 2.86vw;
    padding: 0.54vw 1.5vw;
    margin-left: 1.14vw;
  }
  
}

/* リゾートバイト経験選択ボタンスタイル */
.waku-choice {
  width: 100%;
}

.waku-choice__title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}

.waku-choice__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.waku-choice__item {
  position: relative;
  margin-bottom: 10px;
}

.waku-choice__input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.waku-choice__button {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #f5f5f5;
  border-radius: 5px;
  padding: 20px 10px;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s ease;
  height: 100%;
  font-size: 16px;
  font-weight: bold;
}

.waku-choice__button:hover {
  background-color: #e0e0e0;
}

.waku-choice__input:checked + .waku-choice__button {
  background-color: #00a381;
  color: #fff;
}

@media only screen and (max-width: 560px) {
  /* リゾートバイト経験選択ボタンレスポンシブ */
  .waku-choice__title {
    font-size: 3.23vw;
    margin-bottom: 2.68vw;
  }
  
  .waku-choice__button {
    padding: 3.57vw 1.79vw;
    font-size: 3.57vw;
    border-radius: 2.93vw;
  }
}

/* 住所・国籍入力フォームスタイル */
.waku-form {
  width: 100%;
}

.waku-form__title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}

.waku-form__group {
  margin-bottom: 20px;
}

.waku-form__label {
  display: block;
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 8px;
  color: #333;
}

.waku-form__note {
  font-size: 12px;
  color: #666;
  margin-left: 5px;
  font-weight: normal;
}

.waku-form__input {
  width: 100%;
  height: 48px;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 0 15px;
  font-size: 16px;
  background-color: #fff;
}

.waku-form__input:focus {
  outline: none;
  border-color: #00a381;
  box-shadow: 0 0 0 2px rgba(0, 163, 129, 0.2);
}

.waku-form__input--disabled {
  background-color: #f5f5f5;
}

/* 国籍選択ラジオボタン */
.waku-radio-group {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
}

.waku-radio {
  position: relative;
  flex: 1;
}

.waku-radio__input {
  position: absolute;
  opacity: 0;
}

.waku-radio__label {
  display: flex;
  align-items: center;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  background-color: #fff;
  font-size: 15px;
  font-weight: bold;
  height: 48px;
  width: 100%;
  gap: 10px;
}

.waku-radio__icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.waku-radio__circle {
  width: 100%;
  height: 100%;
  display: block;
  vertical-align: top;
  line-height: 1;
}

.waku-radio__dot {
  opacity: 0;
  transition: opacity 0.3s ease;
}

.waku-radio__input:checked + .waku-radio__label {
  border-color: #00a381;
  background-color: #ffffff;
}

.waku-radio__input:checked + .waku-radio__label .waku-radio__dot {
  opacity: 1;
}

.waku-radio__input:checked + .waku-radio__label .waku-radio__circle circle:first-child {
  stroke: #00a381;
}

/* 条件付き表示コンテナ */
.waku-conditional {
  margin-top: 5px;
  transition: max-height 0.3s ease, opacity 0.3s ease;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
}

.waku-conditional.show {
  max-height: 300px;
  opacity: 1;
}

.waku-residence_status__input {
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 16px 10px;
  font-size: 16px;
  background-color: #fff;
  width: 100%;
  position: relative;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 16px;

  
}

@media only screen and (max-width: 560px) {
  /* 住所・国籍入力フォームレスポンシブ */
  .waku-form__title {
    font-size: 3.23vw;
    margin-bottom: 2.68vw;
  }
  
  
  .waku-form__group {
    margin-bottom: 3.57vw;
  }
  
  .waku-form__label {
    font-size: 3.21vw;
    margin-bottom: 1.43vw;
  }
  
  .waku-form__note {
    font-size: 2.68vw;
  }
  
  .waku-form__input {
    height: 10.71vw;
    padding: 0 2.68vw;
    font-size: 3.57vw;
  }
  
  .waku-radio-group {
    gap: 1.79vw;
  }
  
  .waku-radio__label {
    display: flex;
    align-items: center;
    padding: 2.14vw;
    font-size: 3.57vw;
    height: 10.71vw;
    gap: 1.79vw;
    border: 0.179vw solid #ddd;
    border-radius: 0.893vw;
  }
  
  .waku-radio__icon {
    width: 3.57vw;
    height: 3.57vw;
    flex-shrink: 0;
  }
  
  .waku-radio__circle {
    width: 100%;
    height: 100%;
  }
  
  .waku-radio__dot {
    opacity: 0;
    transition: opacity 0.3s ease;
  }
  
  .waku-radio__input:checked + .waku-radio__label .waku-radio__dot {
    opacity: 1;
  }
  
  .waku-radio__input:checked + .waku-radio__label {
    border-color: #00a381;
  }
  
  .waku-radio__input:checked + .waku-radio__label .waku-radio__circle circle:first-child {
    stroke: #00a381;
  }
}

/* 生年月日・性別入力フォームスタイル */
.waku-birth-gender {
  width: 100%;
}

.waku-birth-gender__title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}

.waku-birth-gender__group {
  margin-bottom: 20px;
}

.waku-birth-gender__label {
  display: block;
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 8px;
  color: #333;
}

/* 生年月日入力 */
.waku-birth {
  display: flex;
  align-items: center;
  gap: 10px;
}

.waku-birth__input {
  height: 48px;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 0 15px;
  font-size: 16px;
  background-color: #fff;
}

.waku-birth__input--year {
  width: 100px;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 16px;
}

.waku-birth__input--month,
.waku-birth__input--day {
  width: 80px;
  position: relative;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 16px;
}

.waku-birth__unit {
  font-size: 16px;
  color: #333;
}

/* 性別選択 */
.waku-gender {
  display: flex;
  gap: 10px;
}

.waku-gender__item {
  position: relative;
  flex: 1;
}

.waku-gender__input {
  position: absolute;
  opacity: 0;
}

.waku-gender__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 64px;
  background-color: #f5f5f5;
  border-radius: 5px;
  cursor: pointer;
  transition: all 0.3s ease;
  font-size: 16px;
  font-weight: bold;
}

.waku-gender__button:hover {
  background-color: #e0e0e0;
}

.waku-gender__input:checked + .waku-gender__button {
  background-color: #00a381;
  color: #fff;
}

@media only screen and (max-width: 560px) {
  /* 生年月日・性別入力フォームレスポンシブ */
  .waku-birth-gender__title {
    font-size: 2.93vw;
    margin-bottom: 2.68vw;
  }
  
  .waku-birth-gender__group {
    margin-bottom: 3.57vw;
  }
  
  .waku-birth-gender__label {
    font-size: 3.21vw;
    margin-bottom: 1.43vw;
  }
  
  .waku-birth {
    gap: 1.79vw;
  }
  
  .waku-birth__input {
    height: 10.71vw;
    padding: 0 2.68vw;
    font-size: 3.57vw;
  }
  
  .waku-birth__input--year {
    width: 21.43vw;
  }
  
  .waku-birth__input--month,
  .waku-birth__input--day {
    width: 17.86vw;
    background-size: 3.57vw;
    background-position: right 2.14vw center;
  }
  
  .waku-birth__unit {
    font-size: 3.57vw;
  }
  
  .waku-gender {
    gap: 1.79vw;
  }
  
  .waku-gender__button {
    height: 14.29vw;
    font-size: 3.57vw;
    border-radius: 2.93vw;
  }
}

/* 名前入力フォームスタイル */
.waku-name {
  width: 100%;
}

.waku-name__title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}

.waku-name__group {
  margin-bottom: 20px;
}

.waku-name__row {
  display: flex;
  gap: 15px;
  margin-bottom: 15px;
}

.waku-name__field {
  flex: 1;
}

.waku-name__label {
  display: block;
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 8px;
  color: #333;
}

.waku-name__note {
  font-size: 12px;
  color: #666;
  margin-left: 5px;
  font-weight: normal;
}

.waku-name__input {
  width: 100%;
  height: 48px;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 0 15px;
  font-size: 16px;
  background-color: #fff;
}

.waku-name__input:focus {
  outline: none;
  border-color: #00a381;
  box-shadow: 0 0 0 2px rgba(0, 163, 129, 0.2);
}

@media only screen and (max-width: 560px) {
  /* 名前入力フォームレスポンシブ */
  .waku-name__title {
    font-size: 3.23vw;
    margin-bottom: 2.68vw;
  }
  
  
  .waku-name__group {
    margin-bottom: 3.57vw;
  }
  
  .waku-name__row {
    gap: 2.68vw;
    margin-bottom: 2.68vw;
  }
  
  .waku-name__label {
    font-size: 3.21vw;
    margin-bottom: 1.43vw;
  }
  
  .waku-name__note {
    font-size: 2.68vw;
  }
  
  .waku-name__input {
    height: 10.71vw;
    padding: 0 2.68vw;
    font-size: 3.57vw;
  }
}

/* 連絡先入力フォームスタイル */
.waku-contact {
  width: 100%;
}

.waku-contact__title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
}

.waku-contact__group {
  margin-bottom: 20px;
}

.waku-contact__label {
  display: block;
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 8px;
  color: #333;
}

.waku-contact__input {
  width: 100%;
  height: 48px;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 0 15px;
  font-size: 16px;
  background-color: #fff;
}

.waku-contact__phone {
  display: flex;
  gap: 10px;
}

.waku-contact__input--phone {
  flex: 1;
}

.waku-contact__terms {
  margin: 20px 0;
}

.waku-contact__checkbox {
  display: flex;
  align-items: center;
  cursor: pointer;
  position: relative;
  padding-left: 30px;
}

.waku-contact__checkbox input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}

.waku-contact__checkbox-label {
  position: relative;
  font-size: 15px;
}

.waku-contact__checkbox-label::before {
  content: "";
  position: absolute;
  left: -30px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border: 2px solid #ccc;
  border-radius: 3px;
  background-color: #fff;
}

.waku-contact__checkbox input[type="checkbox"]:checked + .waku-contact__checkbox-label::before {
  background-color: #00a381;
  border-color: #00a381;
}

.waku-contact__checkbox input[type="checkbox"]:checked + .waku-contact__checkbox-label::after {
  content: "";
  position: absolute;
  left: -24px;
  top: 50%;
  transform: translateY(-60%) rotate(45deg);
  width: 6px;
  height: 12px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
}

.waku-contact__notice {
  font-size: 13px;
  text-align: left;
  margin-top: 10px;
}

.waku-button-container--wide {
  max-width: 400px;
}

.waku-button-submit {
  background: #FF6C00;
  border-radius: 40px;
  text-align: center;
  font-weight: 600;
  padding: 15px 24px;
  color: #fff;
  font-size: 17px;
  border: 1px solid #FF6C00;
  cursor: pointer;
  width: 150px;
  margin: 0 auto;
  display: block;
  flex: 1;
}

.waku-button-submit:hover {
  background: #e55f00;
}

@media only screen and (max-width: 560px) {
  /* 連絡先入力フォームレスポンシブ */
  .waku-contact__title {
    font-size: 3.23vw;
    margin-bottom: 2.68vw;
  }
  
  .waku-contact__group {
    margin-bottom: 3.57vw;
  }
  
  .waku-contact__label {
    font-size: 3.21vw;
    margin-bottom: 1.43vw;
  }
  
  .waku-contact__input {
    height: 10.71vw;
    padding: 0 2.68vw;
    font-size: 3.57vw;
  }
  
  .waku-contact__phone {
    gap: 1.79vw;
  }
  
  .waku-contact__terms {
    margin: 3.57vw 0;
  }
  
  .waku-contact__checkbox {
    padding-left: 5.36vw;
  }
  
  .waku-contact__checkbox-label {
    font-size: 3.39vw;
  }
  
  .waku-contact__checkbox-label::before {
    left: -5.36vw;
    width: 3.57vw;
    height: 3.57vw;
  }
  
  .waku-contact__checkbox input[type="checkbox"]:checked + .waku-contact__checkbox-label::after {
    left: -3.73vw;
    width: 1.07vw;
    height: 2.14vw;
  }
  
  .waku-contact__notice {
    font-size: 2.32vw;
    margin-top: 1.79vw;
  }
  
  .waku-button-container--wide {
    max-width: 71.43vw;
  }
  
  .waku-button-submit {
    padding: 3.21vw 5.36vw;
    font-size: 4.11vw;
    width: 35.71vw;
  }
}

.waku-container {
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}

/* バナー画像のスタイル */
.banner-container {
  width: 100%;
  margin: 0 auto;
}

.banner-image {
  width: 100%;
  height: auto;
  display: block;
}

/* 応募対象のリゾートバイト表示 */
.apply-target {
  width: 100%;
  margin: 20px 0;
}

.apply-target__inner {
  background-color: #ffffff;
  border-radius: 5px;
  padding: 12px 16px;
  box-shadow: 0 -3px 6px rgba(0, 0, 0, 0.2), 3px 3px 6px rgba(0, 0, 0, 0.3);
}

.apply-target__title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 10px;
  color: #333;
}

.apply-target__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.apply-target__item {
  font-size: 14px;
  position: relative;
  padding-left: 18px;
}

.apply-target__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  background: #00a381;
  border-radius: 50%;
}

@media only screen and (max-width: 560px) {
  .waku-container {
  }
}

/* 応募対象のリゾートバイト表示（SP） */
@media only screen and (max-width: 560px) {
  .apply-target {
    margin: 3.57vw 0;
  }

  .apply-target__inner {
    border-radius: 0.893vw;
    padding: 2.14vw 2.85vw;
  }

  .apply-target__title {
    font-size: 2.85vw;
    margin-bottom: 1.78vw;
  }

  .apply-target__list {
    gap: 1.42vw;
  }

  .apply-target__item {
    font-size: 2.5vw;
    padding-left: 3.21vw;
  }

  .apply-target__item::before {
    width: 1.42vw;
    height: 1.42vw;
  }
}

/* 生年月日・性別入力フォーム */
.waku-birth-gender__group {
  margin-bottom: 20px;
}

.waku-birth-gender__label {
  display: block;
  font-size: 14px;
  font-weight: bold;
  margin-bottom: 8px;
  color: #333;
}

.waku-birth {
  display: flex;
  align-items: center;
  width: 100%;
  margin-bottom: 10px;
}

.waku-birth__input {
  height: 48px;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 0 10px;
  font-size: 16px;
  background-color: #fff;
}

.waku-birth__input--year {
  width: 30%;
}

.waku-birth__input--month,
.waku-birth__input--day {
  width: 20%;
}

.waku-birth__unit {
  padding: 0 8px;
  font-size: 14px;
  color: #333;
}

/* 性別選択スタイル */
.waku-gender {
  display: flex;
  gap: 10px;
  width: 100%;
}

.waku-gender__option {
  flex: 1;
  position: relative;
}

.waku-gender__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.waku-gender__label {
  display: block;
  text-align: center;
  background-color: #f5f5f5;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 14px 0;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.3s ease;
}

.waku-gender__input:checked + .waku-gender__label {
  background-color: #00a381;
  color: white;
  border-color: #00a381;
}

@media only screen and (max-width: 560px) {
  .waku-birth-gender__label {
    font-size: 3.21vw;
    margin-bottom: 1.43vw;
  }
  
  
  .waku-birth {
    margin-bottom: 1.79vw;
  }
  
  .waku-birth__input {
    height: 10.71vw;
    padding: 0 1.79vw;
    font-size: 3.57vw;
  }
  
  .waku-birth__unit {
    padding: 0 1.43vw;
    font-size: 2.5vw;
  }
  
  .waku-gender__label {
    padding: 2.5vw 0;
    font-size: 3.39vw;
  }
}

/* フッター固定用スタイル */
body.entry main {
  flex: 1 0 auto; /* メインコンテンツを伸縮可能に */
  display: flex;
  flex-direction: column;
}

body.entry main > section {
  flex: 1 0 auto; /* セクションも伸縮可能に */
}

/* 利用規約と個人情報リンクのスタイル */
.waku-contact__link {
  color: #0071BC;
  text-decoration: underline;
}

/* 応募完了ページのスタイル */
.thanks-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 60px 20px;
  min-height: 500px;
}

.thanks-card {
  background-color: #ffffff;
  border-radius: 10px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  position: relative;
  width: 500px;
  padding: 50px 30px;
  text-align: center;
  box-shadow: 0 -3px 6px rgba(0, 0, 0, 0.2), 3px 3px 6px rgba(0, 0, 0, 0.3);
}

.check-icon {
  margin: 0 auto 20px;
  width: 80px;
  height: 80px;
}

.check-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.thanks-title {
  font-size: 22px;
  font-weight: 600;
  color: #00a381;
  margin-bottom: 30px;
}

.thanks-description {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 30px;
}

.thanks-info {
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 30px;
}

.thanks-button {
  margin: 30px auto 15px;
  max-width: 360px;
  width: 100%;
}

.thanks-button a {
  display: block;
  background-color: #00a381;
  color: #ffffff;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  padding: 15px 20px;
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.thanks-button a:hover {
  opacity: 0.8;
}

.thanks-link {
  text-align: center;
  margin-bottom: 20px;
}

.thanks-link a {
  font-size: 14px;
  color: #0071BC;
  text-decoration: underline;
  position: relative;
}

.thanks-link a:hover {
  text-decoration: underline;
}

.character-image {
  position: absolute;
  bottom: 90px;
  right: -8px;
  width: 78px;
  height: auto;
  pointer-events: none;
  z-index: 10;
}

.character-image img {
  width: 100%;
  height: auto;
}

.line-banner {
  display: block;
  width: 80%;
  margin: 0 auto;
}

/* レスポンシブスタイル */
@media only screen and (max-width: 560px) {
  .thanks-container {
    padding: 10.71vw 5.36vw;
    min-height: 80vh;
  }
  
  .thanks-card {
    border-radius: 1.79vw;
    box-shadow: 0 0.71vw 3.57vw rgba(0, 0, 0, 0.05);
    position: relative;
    width: 89.29vw;
    padding: 8.93vw 5.36vw;
    text-align: center;
    box-shadow: 0 -0.54vw 1.07vw rgba(0, 0, 0, 0.2), 0.54vw 0.54vw 1.07vw rgba(0, 0, 0, 0.3);
  }
  
  .check-icon {
    width: 14.29vw;
    height: 14.29vw;
    margin-bottom: 3.57vw;
  }
  
  .thanks-title {
    font-size: 5.36vw;
    margin-bottom: 4.46vw;
  }
  
  .thanks-description {
    font-size: 2.57vw;
    margin-bottom: 3.57vw;
  }
  
  .thanks-info {
    font-size: 2.57vw;
    margin-bottom: 5.36vw;
  }
  
  .thanks-button {
    max-width: 56.86vw;
    margin: 5.36vw auto 2.68vw;
  }
  
  .thanks-button a {
    font-size: 3.57vw;
    padding: 2.68vw 3.57vw;
  }
  
  .thanks-link {
    margin-bottom: 3.57vw;
  }
  
  .thanks-link a {
    font-size: 3.21vw;
  }
  
  .character-image {
    width: 16.43vw;
    bottom: 14.29vw;
    right: -1.579vw;
  }
}

/* lazysizes用のCSS設定 */
.lazyload {
  opacity: 0;
  transition: opacity 0.3s ease;
}

.lazyloaded {
  opacity: 1;
}

.lazyloading {
  opacity: 0;
}

/* 営業時間・電話番号情報ボックス */
.contact-info {
  border: 2px solid #00a381;
  border-radius: 8px;
  padding: 20px;
  margin: 20px 0 40px;
  background-color: #ffffff;
  text-align: center;
}

/* ========== FLOW page tweaks (reuse existing components) ========== */
.flow .sc-stories-details__content2 {
  padding: 0 0 80px;
}
.flow .sc-stories-details__lead {
  margin-top: 16px;
  font-size: 16px;
  line-height: 1.8;
}

.flow .sc-stories-details__section-title {
  display: block;
}

.flow .sc-stories-details__step-label {
  display: inline-block;
  margin-bottom: 8px;
  padding: 4px 10px;
  background: #0F7AC9;
  color: #fff;
  font-weight: 700;
  border-radius: 4px;
  font-size: 14px;
}

.flow .sc-stories-details__section-title .sc-stories-details__step-label {
  display: inline-block;
  margin-right: 10px;
}
@media screen and (max-width: 560px) {
  .flow .sc-stories-details__content2 {
    padding: 0 0 14.28vw;
  }
  .flow .sc-stories-details__lead { font-size: 3.57vw; }
  .flow .sc-stories-details__step-label {
    margin-bottom: 1.42vw;
    padding: 0.71vw 1.78vw;
    border-radius: 0.71vw;
    font-size: 2.5vw;
  }
  .flow .sc-stories-details__section-title .sc-stories-details__step-label {
    margin-right: 1.78vw;
  }
}

/* ========== Introduce (friend referral) page styles ========== */
.introduce .sc-stories-details__content2 {
  padding: 0 0 80px;
}
.introduce .introduce-steps {
  margin-top: 16px;
}
.introduce .introduce-steps__item {
  padding: 20px 20px 0;
  margin-bottom: 28px;
}
.introduce .introduce-steps__title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 8px;
}
.introduce .introduce-steps__label {
  display: inline-block;
  background: #0F7AC9;
  color: #fff;
  border-radius: 4px;
  padding: 4px 10px;
  font-size: 14px;
  margin-right: 10px;
}
.introduce .introduce-steps__text {
  font-size: 14px;
  line-height: 1.8;
}
.introduce .introduce-notes {
  padding: 20px 20px 0;
  list-style: disc;
  margin-left: 20px;
  line-height: 1.8;
}
.introduce .introduce-notes li {
  font-size: 14px; /* match .sc-stories-details__section-text */
  line-height: 24px;
  margin-bottom: 8px;
}
@media screen and (max-width: 560px) {
  .introduce .introduce-steps {
    margin-top: 2.85vw;
  }
  .introduce .introduce-steps__item {
    margin-bottom: 5vw;
  }
  .introduce .introduce-steps__title {
    font-size: 4.1vw;
    margin-bottom: 1.42vw;
  }
  .introduce .introduce-steps__label {
    padding: 0.71vw 1.78vw;
    border-radius: 0.71vw;
    font-size: 2.5vw;
    margin-right: 1.78vw;
  }
  .introduce .introduce-steps__text {
    font-size: 4.1vw;
  }
  .introduce .introduce-notes li {
    font-size: 4.1vw;
    line-height: 1.5;
    margin-bottom: 1.42vw;
  }
}

.contact-info__hours {
  margin-bottom: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.contact-info__label {
  font-size: 12px;
  font-weight: 500;
  background-color: #b2d8c2;
  padding: 2px 10px;
  border-radius: 15px;
}

.contact-info__text {
  font-size: 16px;
  font-weight: 400;
  color: #000000;
}

.contact-info__phones {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.contact-info__phone {
  display: flex;
  align-items: center;
  gap: 8px;
}

.contact-info__phone::before {
  content: "";
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%2300a381'%3e%3cpath d='M6.62 10.79c1.44 2.83 3.76 5.14 6.59 6.59l2.2-2.2c.27-.27.67-.36 1.02-.24 1.12.37 2.33.57 3.57.57.55 0 1 .45 1 1V20c0 .55-.45 1-1 1-9.39 0-17-7.61-17-17 0-.55.45-1 1-1h3.5c.55 0 1 .45 1 1 0 1.25.2 2.45.57 3.57.11.35.03.74-.25 1.02l-2.2 2.2z'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  width: 30px;
  height: 30px;
  display: inline-block;
}

.contact-info__number {
  font-size: 26px;
  font-weight: 700;
  color: #00a381;
}

.contact-info__office {
  font-size: 20px;
  color: #00a381;
  font-weight: 700;
  align-self: flex-end;
}

@media only screen and (max-width: 560px) {
    /* 営業時間・電話番号情報ボックス - スマートフォン */
    .contact-info {
      border: 0.36vw solid #00a381;
      border-radius: 1.43vw;
      padding: 3.57vw;
      margin: 3.57vw 0;
    }
    
    .contact-info__hours {
      margin-bottom: 2.68vw;
      gap: 1.79vw;
    }
    
    .contact-info__label {
      font-size: 2.5vw;
      padding: 1.07vw 2.14vw;
      border-radius: 2.68vw;
    }
    
    .contact-info__text {
      font-size: 2.86vw;
    }
    
    .contact-info__phones {
      gap: 1.43vw;
    }
    
    .contact-info__phone {
      gap: 0.43vw;
    }
    
    .contact-info__phone::before {
      width: 5.357vw;
      height: 5.357vw;
    }
    
    .contact-info__number {
      font-size: 5vw;
      line-height: 1;
    }
    
    .contact-info__office {
      font-size: 2.86vw;
    }
}