@charset "utf-8";

/*
*********************************************************
campaign-contents
*********************************************************
*/
#campaign-contents {
  max-width: 100%;
  margin: 0 auto;
}

#campaign-contents .maximg {
  width: 100%;
  height: auto
}

#campaign-contents picture,
#campaign-contents picture img {
  width: 100%;
  height: auto;
  display: block;
}

.inner-xs-wrap2,
.inner-xs-wrap,
.inner-s-wrap,
.inner-wrap {
  width: calc(100% - 16px);
  overflow: visible;
}

@media (max-width: 768px) {

  .inner-xs-wrap2,
  .inner-xs-wrap,
  .inner-s-wrap,
  .inner-wrap {
    width: calc(100% - 32px);
  }
}

#campaign-contents summary {
  list-style: none;
}

#campaign-contents details>summary::-webkit-details-marker {
  display: none;
}

/* chrome 画像・グラフィック文字のぼやけ対策 */
@media (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
  #campaign-contents img {
    image-rendering: -webkit-optimize-contrast;
  }
}

/* safari 画像 デフォルト値 */
@media (-webkit-min-device-pixel-ratio: 0) {

  _::-webkit-full-page-media,
  _:future,
  :root #campaign-contents img {
    image-rendering: auto;
  }
}

/*
*********************************************************
.kounyushikin-area
*********************************************************
*/
#campaign-contents .kounyushikin-area {
  overflow: hidden;
  background-color: #fffce4;
}

@media screen and (max-width: 768px) {
  #campaign-contents .kounyushikin-area {
    overflow-x: clip;
    overflow-y: visible;
  }
}

/*
*********************************************************
.applicants-only-area
*********************************************************
*/
#campaign-contents .applicants-only-area {
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  #campaign-contents .applicants-only-area {
    overflow-x: clip;
    overflow-y: visible;
  }
}

/*
*********************************************************
#section-kv
*********************************************************
*/
#section-kv {
  overflow: hidden;
}

#section-kv .kv-text {
  color: #222;
  font-size: 3.0rem;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  line-height: 1.4;
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media (max-width:768px) {
  #section-kv .kv-text {
    font-size: 3.8vw;
    line-height: 1.6;
    margin: var(--size8) auto 0;
    padding: 0;
  }
}

/*
*********************************************************
.sec-ttl（セクション見出し共通）
*********************************************************
*/
#campaign-contents .sec-ttl {
  max-width: 1130px;
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1;
  color: #0081cc;
  text-align: center;
  border-top: 2px solid #0081cc;
  border-bottom: 2px solid #0081cc;
  margin: 0 auto;
  padding: var(--size16) 0;
}

#campaign-contents .applicants-only-area .sec-ttl {
  color: #006082;
  border-top: 2px solid #006082;
  border-bottom: 2px solid #006082;
}

#campaign-contents .sec-text {
  max-width: 1130px;
  font-size: 4.0rem;
  font-weight: bold;
  color: #0081cc;
  text-align: center;
  margin: 0 auto;
  padding: var(--size16) 0;
}

#campaign-contents .applicants-only-area .sec-text {
  color: #006082;
}

#campaign-contents .sec-text.period,
#campaign-contents .applicants-only-area .sec-text.model,
#campaign-contents .applicants-only-area .sec-text.people {
  padding-bottom: var(--size48);
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media (max-width: 768px) {
  #campaign-contents .sec-ttl {
    max-width: inherit;
    font-size: 4.6vw;
    padding: var(--size8) 0;
  }

  #campaign-contents .sec-text {
    max-width: inherit;
    font-size: 4.8vw;
    padding: var(--size8) 0;
  }

  #campaign-contents .sec-text.period,
  #campaign-contents .applicants-only-area .sec-text.model,
  #campaign-contents .applicants-only-area .sec-text.people {
    padding-bottom: 0;
  }
}

/*
*********************************************************
#section-flow
*********************************************************
*/
#section-flow {
  overflow: hidden;
  padding-top: var(--size40);
}

#section-flow .flow-inner {
  position: relative;
  margin: 0 auto;
}

#section-flow #flows {
  position: relative;
  width: 100%;
  border: 1px solid #0081cc;
  background-color: #fff;
  margin: var(--size32) auto;
  padding: var(--size16);
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-flow {
    padding-top: var(--size32);
    overflow: visible;
  }

  #section-flow #flows {
    border: 2px solid #0081cc;
    margin: var(--size24) auto 0;
    padding: 0;
  }
}

/*
*********************************************************
Swiper
*********************************************************
*/
/* ---------------------------------------------- */
/* ------------------- PC ----------------------- */
/* ---------------------------------------------- */
@media screen and (min-width: 769px) {

  /* ----- 共通: nav / pagination 非表示 ----- */
  #campaign-contents .swiper-button-prev,
  #campaign-contents .swiper-button-next,
  #campaign-contents .swiper-pagination {
    display: none;
  }

  #campaign-contents .swiper-container {
    width: 100%;
  }

  #campaign-contents .swiper-wrapper {
    display: flex;
    justify-content: center;
    gap: var(--size80);
    max-width: 1130px;
  }

  /* ----- #flows ----- */
  #flows .swiper-slide {
    position: relative;
    flex: 0 1 240px;
    width: 240px;
    max-width: 240px;
  }

  #flows .swiper-slide img {
    width: 100%;
    max-width: 240px;
    height: auto;
    display: block;
  }

  #flows .swiper-slide:not(:last-child)::after {
    position: absolute;
    content: "";
    top: 50%;
    left: 90%;
    border-top: solid 2px #ccc;
    border-right: solid 2px #ccc;
    width: var(--size80);
    height: var(--size80);
    transform: translateY(-50%) rotate(45deg);
    z-index: 1;
  }

  /* ----- #applicants-only-flows ----- */
  #applicants-only-flows .swiper-wrapper {
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px 0;
    background-color: #fff;
    margin-bottom: var(--size48);
    padding-top: var(--size16);
    padding-bottom: var(--size32);
  }

  #applicants-only-flows .swiper-slide {
    flex: 0 0 calc(280 / 1130 * 100%);
    min-width: 0;
  }

  #applicants-only-flows .swiper-slide.step4,
  #applicants-only-flows .swiper-slide.step7 {
    flex: 0 0 calc(245 / 1130 * 100%);
  }

  #applicants-only-flows .swiper-slide img {
    width: 100%;
    max-width: 275px;
    height: auto;
    display: block;
  }

  #applicants-only-flows .swiper-slide.step4 img,
  #applicants-only-flows .swiper-slide.step7 img {
    width: 100%;
    max-width: 245px;
    margin: 0;
  }

  /* ----- #applicants-only-conditions ----- */
  #section-applicants-only-conditions .swiper-container {
    padding: var(--size40) 0 var(--size24);
  }
}

/* ---------------------------------------------- */
/* ------------------- SP ----------------------- */
/* ---------------------------------------------- */
@media screen and (max-width: 768px) {
  #section-flow #flows {
    padding-bottom: 0;
    overflow: hidden;
  }

  #applicants-only-flows {
    padding-bottom: 0;
    overflow: visible;
  }

  /* ページネーション：#flows / #applicants-only-flows 外に配置したため自然な flow で表示 */
  #campaign-contents .flows-pagination,
  #campaign-contents .applicants-only-flows-pagination {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    width: 100%;
    text-align: center;
    padding: var(--size16) 0;
  }

  #campaign-contents .applicants-only-flows-pagination {
    padding: var(--size16) 0;
  }

  #campaign-contents .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
  #campaign-contents .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    width: 12px;
    height: 12px;
    margin: 0 12px;
  }

  #campaign-contents .swiper-pagination-bullet-active {
    opacity: var(--swiper-pagination-bullet-opacity, 1);
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
  }

  #campaign-contents .flows-pagination .swiper-pagination-bullet {
    background: #d1d1d1;
    opacity: 1;
  }

  .kounyushikin-area .flows-pagination .swiper-pagination-bullet-active {
    background: #54c3f1 !important;
  }

  .applicants-only-area .applicants-only-flows-pagination .swiper-pagination-bullet-active {
    background: #004c78 !important;
  }

  #campaign-contents .swiper-button-prev::before,
  #campaign-contents .swiper-button-next::before {
    content: '';
    position: absolute;
    top: -40px;
    bottom: -40px;
    left: 0;
    right: 0;
  }

  /* 先頭・末尾スライドではナビゲーションボタンを非表示 */
  #section-flow .swiper-button-disabled,
  #section-applicants-only-flow .swiper-button-disabled {
    display: none;
  }
}

/*
*********************************************************
.section-conditions（応募条件）
*********************************************************
*/
#campaign-contents .section-conditions {
  overflow: hidden;
}

#campaign-contents .section-conditions .conditions-inner {
  position: relative;
  margin: 0 auto;
}

#campaign-contents .section-conditions .text-wrap {
  text-align: center;
}

#campaign-contents .section-conditions .text-wrap .text-period {
  max-width: 100%;
}

#campaign-contents .section-conditions .text-wrap .model {
  white-space: nowrap;
}

#campaign-contents .section-conditions .model-list {
  max-width: 1070px;
  border: 2px solid #0081cc;
  margin: 0 auto var(--size48);
  padding: var(--size16);
}

#campaign-contents .section-conditions .model-list ul {
  display: flex;
  flex-wrap: wrap;
  gap: var(--size8) var(--size16);
  list-style: none;
  color: #0081cc;
  margin: 0;
  padding: 0;
}

#campaign-contents .section-conditions .model-list ul li {
  font-size: 2.4rem;
  font-weight: bold;
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #campaign-contents .section-conditions {
    max-width: inherit;
  }

  .kounyushikin-area .section-conditions .text-wrap {
    margin: var(--size16) auto var(--size40);
    padding: 0;
  }

  .applicants-only-area .section-conditions .text-wrap {
    margin: var(--size16) auto var(--size32);
    padding: 0;
  }

  #campaign-contents .section-conditions .text-wrap .text-row {
    flex-direction: column;
    gap: var(--size8);
  }

  #campaign-contents .section-conditions .text-wrap .text-row:nth-child(n + 2) {
    margin-top: var(--size32);
    gap: 0;
  }

  #campaign-contents .section-conditions .text-wrap .text-period {
    width: 70%;
  }

  #campaign-contents .section-conditions .text-wrap .text-model {}

  #campaign-contents .section-conditions .text-wrap .model {
    font-size: 4.6vw;
    white-space: nowrap;
  }

  #campaign-contents .section-conditions .model-list {
    max-width: inherit;
    border: 1px solid #0081cc;
    margin: 0 auto var(--size24);
    padding: var(--size8);
  }

  #campaign-contents .section-conditions .model-list ul {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2px 0;
  }

  #campaign-contents .section-conditions .model-list ul li {
    font-size: 3.5vw;
    font-weight: bold;
    text-align: left;
  }

  #campaign-contents .section-conditions .text-wrap .text-model {
    font-size: 6vw;
  }
}

/* =============================================================
 応募締切・当選発表
============================================================= */
#section-schedule .schedule-inner {
  margin: var(--size32) auto;
}

#section-schedule.requirement-result-inner {
  margin: 0 auto;
}

#section-schedule .table-wrap {
  margin: 0 auto;
}

#section-schedule .table-nml {
  width: 100%;
  margin: 0;
  border-collapse: collapse;
  border-spacing: 0;
}

#section-schedule .table-nml th {
  background-color: var(--white);
}

#section-schedule .table-nml th {
  border: 0;
  border-left: 1px solid #000000;
  border-right: 1px solid #000000;
  border-top: 1px solid #000000;
  border-bottom: 1px solid #000000;
}

#section-schedule .table-nml td {
  border: 0;
  /*2026.06.11*/
  border-left: 1px solid #000000;
  border-right: 1px solid #000000;
  border-bottom: 1px solid #000000;
}

#section-schedule .table-nml tbody tr:first-child th,
#section-schedule .table-nml tbody tr:first-child td {}

#section-schedule .table-nml thead th {
  font-size: 1.6rem;
  padding: 12px;
}

/* 各回当日の16時以降 */
#section-schedule .table-nml.ver-sm em.box {
  color: var(--black);
  border-radius: 4px;
  line-height: 1.43;
  font-size: 1.4rem;
  padding: 4px 8px;
}

#section-schedule .table-nml tbody th,
#section-schedule .table-nml tbody td {
  padding-block: 0.7rem;
}

.arrow-down {
  display: block;
  color: #535353;
  margin-block: 0;
  font-size: 1.6rem;
}

/* 当選発表日 列幅調整 */
#section-schedule .w-announcement-date {
  width: 34%;
}

/* 当選人数 列幅調整 */
#section-schedule .w-number-of-people {
  width: 33%;
}

#section-schedule .table-nml.ver-sm tbody .bg-yg {
  background-color: #e0efe1;
  padding-inline: 0.5rem;
  padding-block: 3.5rem;
}

#section-schedule .table-nml.ver-sm tbody .bg-b {
  background-color: #fff8b0;
  width: 22%;
}

#section-schedule .table-nml.ver-sm tbody th,
#section-schedule .table-nml.ver-sm tbody td {
  font-size: 1.6rem;
  white-space: nowrap;
}

#section-schedule .table-nml.ver-sm p.box {
  color: var(--black);
  font-size: 1.2rem;
  margin-block-start: 8px;
  padding: 2px;
  border-radius: 4px;
}

/* ---------------------------------------------- */
/* ------------------- SP ----------------------- */
/* ---------------------------------------------- */
@media (max-width: 768px) {
  #section-schedule .schedule-inner {
    margin: var(--size16) auto;
  }

  #section-schedule .table-nml {
    border-collapse: separate;
  }

  #section-schedule .table-nml th, #section-schedule .table-nml td {
    border: 0;
    /*2026.06.11*/
    border-right: 1px solid #000000;
    border-bottom: 1px solid #000000;
  }

  #section-schedule .table-nml tbody tr:first-child th,
  #section-schedule .table-nml tbody tr:first-child td {
    border-top: 1px solid #000000;
  }

  #section-schedule .sp-th-fixed thead tr:first-of-type th:first-of-type,
  #section-schedule .sp-th-fixed tbody th {
    position: sticky;
    left: 0;
    z-index: 1;
  }

  #section-schedule .table-nml tbody tr th:first-child {
    border-left: 1px solid #000000;
  }

  #section-schedule .sp-th-fixed thead tr:first-of-type th:first-of-type::before,
  #section-schedule .sp-th-fixed tbody th::before {
    /* module.css の border を上書き：疑似要素で固定表示するborder */
    content: "";
    position: absolute;
    top: -1px;
    left: -1px;
    width: calc(100% + 2px);
    height: calc(100% + 2px);
    box-sizing: border-box;
    border: 1px solid #000000;
    pointer-events: none;
  }

  #section-schedule .arrow-down {
    display: block;
    color: #ef8200;
    margin-block: 0;
    font-size: 1.6rem;
    text-align: center;
  }

  #section-schedule .table-nml.ver-sm tbody .bg-yg {
    text-align: center !important;
    padding-block: 0.9rem;
  }

  #section-schedule .table-nml.ver-sm tbody .bg-b {
    width: unset;
    text-align: left !important;
    padding-inline: 1.2rem;
    padding-block: 1.2rem;
  }

  #section-schedule .table-nml.ver-sm tbody .bg-b span {
    text-align: center !important;
  }

  #section-schedule .table-nml.ver-sm tbody td {
    font-size: 1.4rem;
    text-align: left !important;
    padding-inline: 1.2rem;
    padding-block: 1.2rem;
  }

  #section-schedule .table-nml.ver-sm tbody .last td {
    text-align: center !important;
  }

  #section-schedule .sp-scroll-notice span {
    font-size: 1.2rem;
    line-height: 1.5;
    color: var(--black);
    display: inline-flex;
    column-gap: 8px;
    border: 1px solid var(--silver);
    background-color: var(--white);
    padding: 12px 16px;
  }

  #section-schedule .sp-scroll-notice .icn {
    width: 22px;
  }

  #section-schedule .table-nml tbody th,
  #section-schedule .table-nml tbody td {
    padding-inline: 0.5rem;
    padding-block: 1.2rem;
  }

  #section-schedule .w-announcement-date {
    width: unset;
  }

  #section-schedule .w-number-of-people {
    width: unset;
  }
}

/*
*********************************************************
#section-summary
*********************************************************
*/
#section-summary {
  margin: 0 auto;
}

#section-summary.acc-wrap {
  margin: 0 auto;
  padding: 0;
}

#section-summary .acc-wrap.nml-acc-wrap {
  max-width: 1070px;
  border-top: none;
  border-bottom: none;
  margin: var(--size64) auto;
}

#section-summary summary {
  list-style: none;
  -webkit-appearance: none;
  /* Safari/Chrome用 */
  appearance: none;
}

#section-summary .acc-wrap.nml-acc-wrap .triggle {
  color: var(--white);
  background-color: #9d9d9e;
  font-size: 2.6rem;
  text-align: center;
  padding: var(--size16) 56px var(--size16) 0;
  transition: opacity 0.3s ease;
}

#section-summary .nml-toggle-icn::before,
#section-summary .nml-toggle-icn::after {
  content: "";
  background-color: var(--white);
  position: absolute;
}

#section-summary .nml-toggle-icn::before {
  width: 32px;
  height: 2px;
  right: 31px;
  left: auto;
  top: 50%;
}

#section-summary .nml-toggle-icn::after {
  width: 2px;
  height: 32px;
  right: 46px;
  top: calc(50% - 15px);
  transition: var(--transition);
  border: none;
  transform: translate(0);
}

#section-summary .acc-wrap.nml-acc-wrap[open] .nml-toggle-icn::after {
  transform: rotate(90deg);
  opacity: 0;
}

#section-summary .acc-wrap.nml-acc-wrap .triggle h2 {
  font-weight: bold !important;
}

#section-summary .acc-wrap.nml-acc-wrap .triggle:hover {
  opacity: 0.8;
}

#section-summary .acc-wrap.nml-acc-wrap .acc-contents-inner {
  padding: 10px 0 0;
}

#section-summary .summary-inner {
  position: relative;
  width: 100%;
  background-color: var(--white);
  margin: 0 auto;
  padding: var(--size40) var(--size40) var(--size24);
}

#section-summary .summary-inner h2 {
  color: #4774b9;
  font-size: 22px;
  font-weight: 400;
  text-align: justify;
  text-decoration: none;
  line-height: 1;
  letter-spacing: 0.02em;
  padding: 10px;
}

#section-summary h3 {
  color: #1b3b49;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: justify;
  text-decoration: none;
  line-height: 1;
  letter-spacing: 0.02em;
  margin: 0 auto 12px;
  padding: 0;
}

#section-summary h3.inquiry {
  font-weight: normal;
  line-height: 1.6;
  margin: 0 auto;
}

#section-summary h4 {
  color: #00abeb;
  font-size: 16px;
  font-weight: 400;
  text-align: justify;
  text-decoration: none;
  line-height: 2;
  letter-spacing: -0.02em;
  margin: 0 auto;
  padding: 20px 0 0;
}

#section-summary .text-box {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

#section-summary .text-box.border {
  border-bottom: 2px solid #0081cc;
  margin: 0 auto var(--size24);
}

#section-summary .link-color {
  color: #0000ff;
  text-decoration: underline;
}

#section-summary .text-box p {
  overflow-wrap: anywhere;
  color: #1b3b49;
  font-size: 16px;
  font-weight: 400;
  text-align: justify;
  line-height: 2;
  letter-spacing: -0.02em;
  word-break: break-all;
  margin: 0 auto;
  padding: 0;
}

#section-summary h3.mgnb48 {
  margin-top: var(--size48);
}

#section-summary .text-box p.mgnb48 {
  margin: 0 auto var(--size48);
}

#section-summary .text-box p.mgnb48.last {
  margin: 0 auto 0;
}

#section-summary .text-box p.mgnb24 {
  margin: 0 auto var(--size24);
}

#section-summary a.link-color {
  color: #1b3b49;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 3px;
  position: relative;
}

#section-summary a.link-color:hover {
  border-color: var(--keyColor) !important;
  text-decoration: underline !important;
  color: var(--keyColor) !important;
  text-decoration-color: var(--keyColor) !important;
}

@media screen and (min-width: 769px) and (max-width: 1310px) {
  #section-summary .summary {
    width: calc(100% - 80px);
    max-width: inherit;
    margin: 60px 20px 16px;
  }

  #section-summary .summary-inner {
    max-width: inherit;
    background-color: var(--greyK2);
  }
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-summary {
    padding: 0 0 var(--size16);
  }

  #section-summary .acc-wrap.nml-acc-wrap {
    max-width: inherit;
    margin: var(--size32) auto;
  }

  #section-summary .nml-toggle-icn::before {
    right: 16px;
  }

  #section-summary .nml-toggle-icn::after {
    right: 31px;
  }

  #section-summary .acc-wrap.nml-acc-wrap .triggle:hover {
    opacity: 1;
  }

  #section-summary .acc-wrap.nml-acc-wrap .triggle {
    padding: 12px 15% 12px 5%;
  }

  #section-summary .acc-wrap.nml-acc-wrap .triggle h2 {
    font-size: 3.8vw;
  }

  #section-summary .summary-inner {
    width: 100%;
    max-width: inherit;
    margin: 0 auto;
    padding: var(--size24) var(--size16) var(--size16);
  }

  .acc-wrap.nml-acc-wrap .acc-contents-inner {
    padding: 10px 0 20px;
  }

  #section-summary h3 {
    font-size: max(1.1rem, 2.0vw);
    line-height: 1.4;
    margin: 0 auto var(--size8);
  }

  #section-summary .text-box p {
    font-size: max(1.1rem, 2.0vw);
  }

  #section-summary .text-box p.mgnb24 {
    margin: 0 auto var(--size16);
  }

  #section-summary .text-box.text_space_sp p {
    text-align: left;
  }

  #section-summary .text-box p.mgnb50 {
    margin: 0 auto 30px;
  }

  #section-summary .text-box p.mgnb20 {
    margin: 0 auto 10px;
  }

  #section-summary .text-box.border {
    margin: 0 auto var(--size16);
  }

  #section-summary h3.mgnb48 {
    margin-top: var(--size16);
  }
}

@media screen and (max-width: 320px) {
  #section-summary .text-box p {
    font-size: 1.1rem;
  }
}

/*
*********************************************************
#section-applicants-only-kv
*********************************************************
*/
#section-applicants-only-kv {
  overflow: hidden;
  padding-top: var(--size64);
}

#section-applicants-only-kv .kv-photo {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1130/554;
}

#section-applicants-only-kv .kv-photo h2 {
  position: absolute;
  width: 100%;
  top: 0;
  right: 0;
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media (max-width: 768px) {
  #section-applicants-only-kv {
    width: 100%;
    margin: 0;
    padding: 0;
  }

  #section-applicants-only-kv .kv-photo {
    width: 100%;
    aspect-ratio: auto;
  }
}

/*
*********************************************************
#section-applicants-only-greeting
*********************************************************
*/
#section-applicants-only-greeting {
  overflow: hidden;
  padding: var(--size24) 0 var(--size48);
}

#section-applicants-only-greeting .greeting-text {
  font-size: min(2rem, 1.7vw);
  font-weight: bold;
  text-align: center;
  line-height: 1.8;
  margin: 0 auto var(--size32);
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media (max-width: 768px) {
  #section-applicants-only-greeting {
    overflow: hidden;
    padding: var(--size24) 0;
  }

  #section-applicants-only-greeting .greeting-text {
    font-size: 3.3vw;
    text-align: justify;
    line-height: 2;
    letter-spacing: -0.02em;
    margin: 0 auto var(--size32);
  }
}

@media (max-width: 344px) {
  #section-applicants-only-greeting .greeting-text {
    font-size: 3.6vw;
    text-align: justify;
    line-height: 2;
    letter-spacing: -0.02em;
    margin: 0 auto var(--size32);
  }

  #section-applicants-only-greeting .greeting-text br {
    display: none;
  }
}

/*
*********************************************************
.applicants-only-area（応募者限定エリア）
*********************************************************
*/
.applicants-only-area .section-conditions {
  background-color: #eef3f6;
  padding-top: var(--size64);
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  .applicants-only-area .section-conditions {
    padding-top: var(--size24);
  }
}

/*
*********************************************************
#section-applicants-only-flow
*********************************************************
*/
#section-applicants-only-flow {
  overflow: hidden;
  background-color: #eef3f6;
  padding: 0 var(--size8);
}

@media screen and (max-width: 768px) {
  #section-applicants-only-flow {
    overflow-x: clip;
    overflow-y: visible;
  }
}

#section-applicants-only-flow .flow-inner {
  position: relative;
  max-width: 1130px;
  margin: var(--size40) auto var(--size64);
  padding-left: 0;
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-applicants-only-flow {
    width: 100%;
    margin: 0;
    padding: 0 var(--size16) var(--size8);
  }

  #section-applicants-only-flow .flow-inner {
    max-width: inherit;
    margin: var(--size24) auto var(--size32);
  }
}

/*
***************************************************************
#section-testdrive-note
***************************************************************
*/
#section-testdrive-note {
  color: #333;
  margin: var(--size64) auto var(--size32);
  padding: 0 var(--size8);
}

#section-testdrive-note .testdrive-note-inner {
  max-width: 1066px;
}

#section-testdrive-note h3 {
  font-size: 2.2rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: var(--size16);
}

#section-testdrive-note p {
  font-size: 1.4rem;
  line-height: 1.8;
  text-align: justify;
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media screen and (max-width: 768px) {
  #section-testdrive-note {
    margin: var(--size32) auto;
    padding: 0;
  }

  #section-testdrive-note .testdrive-note-inner {
    max-width: inherit;
  }

  #section-testdrive-note h3 {
    font-size: 4vw;
    margin-bottom: var(--size16);
  }

  #section-testdrive-note p {
    font-size: max(1.1rem, 2.0vw);
    text-align: justify;
    line-height: 2;
  }
}

/*
***********************************************************
SNS注意喚起
***********************************************************
*/
#section-notice {
  margin: 0 auto;
  padding: 0;
}

#section-notice .notice-area {
  margin: 0 auto;
}

#section-notice .notice-area .notice-txt {
  text-align: justify !important;
}

@media (max-width: 768px) {
  #section-notice .notice-area {
    max-width: inherit;
    padding: 0;
  }
}

/*
***************************************************************
btn-page-top
***************************************************************
*/
#campaign-contents .btn-page-top {
  position: fixed;
  right: var(--size48);
  bottom: 80px;
  z-index: 1000;
  width: var(--size48);
  height: var(--size48);
  background-color: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

#campaign-contents .btn-page-top.show {
  opacity: 1;
  visibility: visible;
}

#campaign-contents .btn-page-top img {
  width: var(--size24);
  height: var(--size24);
}

/* ---------------------------------------------  */
/* --------------------- SP --------------------  */
/* ---------------------------------------------  */
@media (max-width: 768px) {
  #campaign-contents .btn-page-top {
    right: var(--size8);
  }
}

/*
**************************************************
  fixed-menu
**************************************************
*/
#fixedBottomBtn {
  position: fixed;
  bottom: -56px;
  left: 0;
  width: 100%;
  background: rgb(255, 255, 255, 0.9);
  box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
  opacity: 0;
  margin: 0 auto;
  padding: var(--size8) 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, bottom 0.3s ease, visibility 0.3s ease;
  z-index: 10;
}

#fixedBottomBtn.show {
  bottom: 0px;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  padding: 0;
}

#fixedBottomBtn .btn-note {
  color: #333;
  font-size: 1.2rem;
  text-align: center;
  padding: var(--size8) 0;
}

/*
*********************************************************
.apply-button-container（ご応募はこちら）
*********************************************************
*/
/*ご応募はこちら*/
.apply-button-container {
  display: block;
  position: relative;
  width: 100%;
  max-width: 430px;
  height: 100%;
  margin: 0 auto;
  padding: 0;
}

.apply-button-container .apply-button,
#fixedBottomBtn .apply-button-container .apply-button {
  width: 100%;
  max-width: 430px;
  margin: 0 auto;
  padding: var(--size8) auto;
}

/* #fixedBottomBtn の closeTxt は #fixedBottomBtn 全体を基準に配置 */
#fixedBottomBtn .apply-button-container {
  position: static;
}

#fixedBottomBtn .apply-button-container .apply-button {
  position: static;
}

/*KV直下 */
#section-kv .apply-button-container .apply-button {
  margin: var(--size40) auto 0;
}

/*応募者限定 > お申し込みの流れ直下 */
#section-flow .apply-button-container .apply-button {
  margin: var(--size40) auto 0;
}

/*追従ボタン */
#fixedBottomBtn .apply-button-container .apply-button {
  margin: var(--size8) auto 0;
}

.apply-button-container .apply-button a,
#fixedBottomBtn .apply-button a {
  width: 400px;
  height: auto;
  margin: 0 auto;
  padding: 0;
}

#campaign-contents .btn-nml,
#fixedBottomBtn .btn-nml {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 400px;
  min-height: 47px;
  color: var(--white);
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  border-radius: 100vw;
  padding: 0;
  transition: opacity 0.3s ease;
}

/* 共通CSSのaタグ::afterは.btnの外・下に出るため非表示にする */
#campaign-contents .apply-button-container .apply-button a[target="_blank"]:not(.icn-none)::after,
#fixedBottomBtn .apply-button a[target="_blank"]:not(.icn-none)::after {
  display: none;
}

/* .btn（position:relative）を基準に右上へアイコンを配置 */
#campaign-contents .apply-button-container .apply-button a[target="_blank"]:not(.icn-none) .btn::after,
#fixedBottomBtn .apply-button a[target="_blank"]:not(.icn-none) .btn::after {
  content: "";
  display: block;
  position: absolute;
  width: 17px;
  height: 17px;
  background: url(/assets/images/icn_blank_white.svg) no-repeat center center / contain;
  top: var(--size8);
  right: var(--size8);
}

#campaign-contents .btn-wrap .btn-ttl {
  font-size: 2.4rem;
  font-weight: normal;
}

#campaign-contents .btn-wrap .btn-note {
  font-size: 1.2rem;
  line-height: 1;
  text-align: center;
  padding-top: var(--size16);
}

#fixedBottomBtn .btn-wrap .btn-note {
  font-size: 1.2rem;
  line-height: 1;
  text-align: center;
  padding-top: var(--size8);
}

/* ---------------------------------------------- */
/* ------------------- SP ----------------------- */
/* ---------------------------------------------- */
@media screen and (max-width: 768px) {

  /*KV直下 */
  #section-kv .apply-button-container .apply-button {
    margin: var(--size24) auto 0;
  }

  #campaign-contents #section-kv .btn-nml {
    width: calc(100% - 40px);
    max-width: calc(100% - 40px);
    min-height: 44px;
    font-size: 4vw;
    font-weight: bold;
    padding: var(--size8) 0;
  }

  #campaign-contents #section-applicants-only-greeting .btn-nml {
    width: calc(100% - 8px);
    max-width: calc(100% - 8px);
    min-height: 44px;
    font-size: 4vw;
    font-weight: bold;
    padding: var(--size8) 0;
  }

  #campaign-contents #section-applicants-only-flow .btn-nml {
    width: 100%;
    max-width: 100%;
    min-height: 44px;
    font-size: 4vw;
    font-weight: bold;
    padding: var(--size8) 0;
  }

  #fixedBottomBtn .btn-nml {
    width: calc(100% - 32px);
    max-width: calc(100% - 32px);
    min-height: 44px;
    font-size: 4vw;
    font-weight: bold;
    padding: var(--size8) 0 !important;
  }

  #fixedBottomBtn.cta-following-wrap {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  #fixedBottomBtn .btn-wrap-container {
    display: block !important;
    gap: 0;
    padding: var(--size8) 0;
  }

  #campaign-contents .btn-wrap .btn-ttl {
    font-size: 4vw;
    line-height: 1;
  }

  #campaign-contents .btn-wrap .btn-note,
  #fixedBottomBtn .btn-wrap .btn-note {
    font-size: min(2.8vw, 1.2rem);
    line-height: 1.6;
  }
}

@media screen and (min-width: 600px) and (max-width: 768px) {

  #campaign-contents .btn-wrap .btn-note,
  #fixedBottomBtn .btn-wrap .btn-note {
    font-size: 1.8vw;
  }

  #fixedBottomBtn .btn-wrap-container {
    padding: var(--size8) 0 max(var(--size8), env(safe-area-inset-bottom));
  }
}

@media (max-width: 320px) {
  #section-kv .btn-wrap .btn-note {
    font-size: min(2.8vw, 1.2rem);
    line-height: 1.6;
    text-align: center;
  }

  #section-applicants-only-greeting .btn-wrap .btn-note {
    font-size: min(2.8vw, 1.2rem);
    line-height: 1.6;
    text-align: center;
  }

  #fixedBottomBtn .btn-wrap .btn-note {
    font-size: 1.0rem;
    text-align: center;
  }
}

/*
***********************************************************
closeTxt
***********************************************************
*/
#campaign-contents .closeTxt {
  display: none;
}

#campaign-contents .close a,
#campaign-contents .close button,
#fixedBottomBtn .close a,
#fixedBottomBtn .close button {
  pointer-events: none;
  cursor: default;
}

#campaign-contents .btn-wrap .apply-button,
#fixedBottomBtn .btn-wrap-container .apply-button {
  position: relative;
}

/* #fixedBottomBtn の .apply-button は static に：closeTxt が #fixedBottomBtn 全体を基準に配置されるよう */
#fixedBottomBtn .apply-button-container .apply-button {
  position: static;
}

#campaign-contents #section-kv .close .closeTxt,
#campaign-contents #section-applicants-only-greeting .close .closeTxt,
#campaign-contents #section-applicants-only-flow .close .closeTxt {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(100% + 16px);
  height: calc(100% + 24px);
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  font-size: 20px;
  font-weight: bold;
  line-height: 1.2;
  background: rgba(0, 0, 0, 0.9);
  z-index: 5;
  margin: 0 auto;
}

#fixedBottomBtn .close .closeTxt {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: none;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.2;
  background: rgba(0, 0, 0, 0.9);
  z-index: 5;
}

#campaign-contents .close.btn-nml,
#fixedBottomBtn .close.btn-nml {
  position: static;
  animation: none;
}

/* ---------------------------------------------- */
/* ------------------- SP ----------------------- */
/* ---------------------------------------------- */
@media screen and (max-width: 768px) {

  #campaign-contents #section-kv .close .closeTxt,
  #campaign-contents #section-applicants-only-greeting .close .closeTxt,
  #campaign-contents #section-applicants-only-flow .close .closeTxt {
    height: calc(100% + var(--size16));
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.2;
    background: rgba(0, 0, 0, 0.9);
    z-index: 5;
    margin: 0 auto;
  }

  #campaign-contents #section-kv .close .closeTxt {
    width: calc(100% - 32px);
  }

  #campaign-contents #section-applicants-only-greeting .close .closeTxt {
    width: calc(100% + 16px);
  }

  #campaign-contents #section-applicants-only-flow .close .closeTxt {
    width: calc(100% + 2px);
  }

  #fixedBottomBtn .close .closeTxt {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: none;
  }
}

/*
***********************************************************
キャンペーン終了エリア
***********************************************************
*/
/*
  テキストを縦並び＆中央寄せ
  module.css のレイアウトをベースに、余白を最適化
*/
.notice-area-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

#section-notice .notice-area {
  padding-bottom: var(--size24);
}

.notice-area.alert .notice-area-inner {
  padding-top: 10px;
  padding-bottom: 10px;
  margin: 0 var(--size8);
}

@media screen and (max-width: 768px) {
  .notice-area.alert .notice-area-inner {
    margin: 0;
  }

  .notice-area.alert .notice-txt {
    font-size: 1.6rem;
  }
}

/*
***********************************************************
シンプルフッターマージン調整
***********************************************************
*/
.footer.footer-simple {
  margin-top: 0;
}

/*
***********************************************************
PRINT
***********************************************************
*/
#campaign-contents img.pr-img {
  display: none !important;
}

@media print {
  @page {
    margin: 15mm 10mm;
    size: A4 portrait;
  }

  #fixedBottomBtn {
    display: none;
  }

  .swiper-pagination,
  .swiper-button-prev,
  .swiper-button-next {
    display: none !important;
  }

  *, *::before, *::after {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }

  body {
    font-size: 10pt;
    line-height: 1.6;
    width: 100% !important;
  }

  /* 非表示 */
  header, footer, nav, .global-nav, .breadcrumb,
  #fixedBottomBtn, .cta-following-wrap, .btn-page-top,
  .swiper-button-prev, .swiper-button-next, .swiper-pagination,
  .apply-button-container,
  #section-flow .apply-button-container,
  .btn-wrap.testdrive,
  .closeTxt {
    display: none !important;
  }

  /* レイアウト */
  #campaign-contents {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  /* #flows Swiper 横並び展開 */
  #section-flow .swiper-container,
  #flows.swiper-container {
    overflow: visible !important;
  }

  #flows .swiper-wrapper {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 4mm !important;
    transform: none !important;
  }

  #flows .swiper-slide {
    flex: 0 1 50mm !important;
    width: 50mm !important;
    max-width: 50mm !important;
    page-break-inside: avoid;
  }

  #flows .swiper-slide img {
    width: 100% !important;
    height: auto !important;
  }

  #flows .swiper-slide:not(:last-child)::after {
    display: none !important;
  }

  #section-summary details,
  #section-summary details.acc-wrap {
    display: block !important;
  }

  #section-summary .acc-contents,
  #section-summary .js-acc-contents,
  #section-summary .acc-wrap .acc-contents,
  #section-summary .acc-wrap .js-acc-contents {
    display: block !important;
    visibility: visible !important;
    height: auto !important;
    overflow: visible !important;
    opacity: 1 !important;
  }

  #section-summary .acc-wrap .acc-contents .acc-contents-inner {
    display: block !important;
  }

  #section-summary .nml-toggle-icn::before,
  #section-summary .nml-toggle-icn::after,
  #section-summary .title02.nml-toggle-icn::before,
  #section-summary .title02.nml-toggle-icn::after {
    display: none !important;
  }

  #section-applicants-only-kv .kv-photo {
    position: relative !important;
    display: block !important;
    aspect-ratio: auto !important;
    height: auto !important;
    min-height: 0 !important;
    width: 100% !important;
  }

  #section-applicants-only-kv .kv-photo>picture:first-child {
    display: block !important;
    width: 100% !important;
    position: relative !important;
    z-index: 0 !important;
  }

  #section-applicants-only-kv .kv-photo>picture:first-child img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
  }

  #section-applicants-only-kv .kv-photo h2 {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: auto !important;
    z-index: 1 !important;
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
  }

  #section-applicants-only-kv .kv-photo h2 picture {
    display: block !important;
  }

  #section-applicants-only-kv .kv-photo h2 img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
    margin: 0 !important;
  }

  #section-applicants-only-kv .kv-photo .kv-text {
    position: absolute !important;
    bottom: 10% !important;
    left: 50% !important;
    top: auto !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    z-index: 2 !important;
    display: block !important;
    width: 50% !important;
    max-width: 50% !important;
    font-size: 8pt !important;
    font-weight: bold !important;
    line-height: 1.5 !important;
    text-align: justify !important;
    padding: 0 !important;
  }

  .applicants-only-area {
    break-before: always !important;
  }

  /* #applicants-only-flow 横並び展開 */
  #applicants-only-flows.swiper-container {
    overflow: visible !important;
  }

  #applicants-only-flows .swiper-wrapper {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 3mm !important;
    transform: none !important;
  }

  #applicants-only-flows .swiper-slide {
    flex: 0 1 36mm !important;
    width: 36mm !important;
    max-width: 36mm !important;
    page-break-inside: avoid;
  }

  #applicants-only-flows .swiper-slide img {
    width: 100% !important;
    height: auto !important;
  }

  a[href]::after {
    content: none !important;
  }

  img {
    max-width: 100% !important;
    page-break-inside: avoid;
  }

  h1, h2, h3 {
    page-break-after: avoid;
  }

  section {
    page-break-inside: auto;
  }

  /* アコーディオン共通 */
  details {
    display: block !important;
  }

  details>.acc-contents,
  details>.js-acc-contents {
    display: block !important;
    visibility: visible !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    opacity: 1 !important;
  }
}



