@charset "utf-8";

.top #main-wrapp {
  margin-top: 64px;
}

body {
  background: #fff;
}

.pankuzu {
  margin-bottom: -30px;
}

.visual {
  margin-bottom: 80px;
}

.visual img {
  width: auto;
  margin: auto;
}

.visual p {
  margin-top: 40px;
  font-size: 24px;
}

.visual p span {
  font-weight: bold;
}

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

.visual .btn a,
.more-btn {
  display: inline-block;
  background: #f9cb28;
  margin-top: 30px;
  padding: 35px 100px;
  border: 0;
  font-size: 32px;
  letter-spacing: .1em;
  max-width: 720px;
}

.visual .btn a::after,
.more-btn::after {
  background-image: url(/common/images/icon-right.png);
  right: 20px;
}

.com-bnr-wrap a {
  width: auto;
  max-width: none;
  margin: 0;
}

.section {
  position: relative;
  z-index: 1;
  max-width: calc(1100px + 10%);
  margin: 0 auto;
  padding: 60px 5% 80px;
  font-weight: bold;
}

.section__background {
  position: absolute;
  left: 0;
  z-index: -2;
  width: 100%;
}

.section__background:first-child {
  top: 0;
}

.section__background:last-child {
  bottom: 0;
}

.section-title {
  margin-bottom: 30px;
  text-align: center;
}

.section-title__image {
  height: 26px;
  margin-bottom: 30px;
}

.section-title__text {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 40px;
}

.section-title__text .point {
  font-size: 44px;
  letter-spacing: .05em;
}

.magazine .section-title__text .point {
  color: #f49e00;
}

.popular .section-title__text .point {
  color: #e2591d;
}

.summer-environment .section-title__text .point {
  color: #00a5d0;
}

.about .section-title__text,
.benefits .section-title__text {
  background: url(../images/lp_summer/about-title.png) center / 50% no-repeat;
}

.about .section-title__text .point,
.benefits .section-title__text .point {
  color: #00a7b0;
}

.summer-voice .section-title__text .point {
  color: #e84051;
}

.facility .section-title__text .point {
  color: #00ab97;
}

.qa .section-title__text .point {
  color: #cf004e;
}

.section > p {
  font-size: 20px;
  text-align: center;
}

.popular ul,
.summer-environment ul,
.facility ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: -20px 0 0 -20px;
}

.popular ul li,
.summer-environment ul li,
.facility ul li {
  padding: 20px 0 0 20px;
}

.popular ul li {
  width: 33.333%;
}

.summer-environment ul li,
.facility ul li {
  width: 50%;
}

.about,
.benefits {
  background: center top / 100% no-repeat;
}

.about {
  padding-top: 500px;
  background-image: url(../images/lp_summer/about-backgraound.png);
}

.benefits {
  padding-top: 960px;
  background-image: url(../images/lp_summer/benefits-background.png);
}

.about__text,
.benefits__text {
  font-size: 24px;
  font-weight: normal;
}

.about__text span,
.benefits__text span {
  background: #d4ecea;
  font-weight: bold;
}

.benefits__outro {
  margin-top: 20px;
  text-align: center;
}

.benefits__outro span {
  color: #e14f3b;
}

.summer-voice__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: -30px;
}

.summer-voice__item {
  display: flex;
  flex-direction: column;
  position: relative;
  width: calc(50% - 30px);
  margin-top: 30px;
  padding: 20px;
  background: #fff;
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  border-radius: 40px 0 40px 0;
}

.summer-voice__item::before {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  z-index: -1;
  width: 100%;
  height: 100%;
  border-radius: 40px 0 40px 0;
}

.summer-voice__item:nth-child(4n-3)::before {
  background: #4889c7;
}

.summer-voice__item:nth-child(4n-2)::before {
  background: #f76284;
}

.summer-voice__item:nth-child(4n-1)::before {
  background: #6eb56e;
}

.summer-voice__item:nth-child(4n)::before {
  background: #fca32b;
}

.summer-voice__content {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

.summer-voice__text {
  margin-bottom: auto;
  margin-top: 20px;
  text-align: left;
  font-size: 14px;
}

.summer-voice__item .kodawari-btn {
  margin-top: 20px;
  font-size: 16px;
  padding: 12px 0;
  border: 0;
  border-top: 1px solid;
  border-bottom: 1px solid;
  text-align: center;
  max-width: none !important;
}

.summer-voice__item:nth-child(4n-3) .kodawari-btn {
  border-color: #4889c7;
}

.summer-voice__item:nth-child(4n-2) .kodawari-btn {
  border-color: #f76284;
}

.summer-voice__item:nth-child(4n-1) .kodawari-btn {
  border-color: #6eb56e;
}

.summer-voice__item:nth-child(4n) .kodawari-btn {
  border-color: #fca32b;
}

.summer-voice__item:nth-child(4n-3) .kodawari-btn::after {
  background-image: url(/common/images/lp_summer/icon-right-blue.png);
}

.summer-voice__item:nth-child(4n-2) .kodawari-btn::after {
  background-image: url(/common/images/lp_summer/icon-right-red.png);
}

.summer-voice__item:nth-child(4n-1) .kodawari-btn::after {
  background-image: url(/common/images/lp_summer/icon-right-green.png);
}

.summer-voice__item:nth-child(4n) .kodawari-btn::after {
  background-image: url(/common/images/lp_summer/icon-right-orange.png);
}

.qa {
  margin-top: 40px;
}

.qa dt {
  min-height: 70px;
  font-size: 32px;
  font-weight: bold;
  padding: 7px 0 0 80px;
  background: url('../images/lp_summer/q.png') left top / 60px no-repeat;
}

.qa dd {
  margin-top: 20px;
  min-height: 60px;
  font-size: 20px;
  font-weight: bold;
  padding: 12px 0 12px 83px;
  background: #faf1f6 url('../images/lp_summer/a.png') 11px 11px / 33px no-repeat;
  line-height: 1.7;
}

.magazine .tx-center {
  width: 560px;
  margin: 0 auto 60px;
}

#footer {
  margin-top: 80px;
}

@media screen and (max-width: 1200px) {
  .about {
    padding-top: 30% !important;
  }
  .benefits {
    padding-top: 70% !important;
  }
}

@media screen and (max-width: 650px) {
  #main-wrapp .mywidth {
    padding: 0;
  }
  .top #main-wrapp {
    margin: 4px 0 0;
  }
  .visual {
    margin-bottom: 40px;
  }
  .visual p {
    font-size: 12px;
    margin: 5% 0 0;
  }
  .visual .btn a {
    margin-top: 5%;
    padding: 4% 0;
    width: 90%;
  }
  .visual .btn a,
  .more-btn {
    font-size: 16px;
  }
  .com-bnr-wrap {
    display: block;
    padding: 0 5%;
  }
  .section {
    padding: 32px 5% 40px;
  }
  .section-title {
    margin-bottom: 20px;
  }
  .section-title__image {
    height: 18px;
    margin-bottom: 20px;
  }
  .section-title__text {
    font-size: 20px;
  }
  .section-title__text .point {
    font-size: 27px;
  }
  .about .section-title__text,
  .benefits .section-title__text {
    background-size: 85%;
  }
  .section > p {
    font-size: 10px;
  }
  .section .kodawari-btn {
    max-width: 280px;
  }
  .popular ul,
  .summer-environment ul,
  .facility ul {
    margin: -7px 0 0 -7px;
  }
  .popular ul li,
  .summer-environment ul li,
  .facility ul li {
    padding: 7px 0 0 7px;
  }
  .popular ul li {
    width: 50%;
  }
  .summer-environment ul li,
  .facility ul li {
    width: 100%;
  }
  .about__text,
  .benefits__text {
    font-size: 12px;
  }
  .summer-voice__item {
    width: 100%;
  }
  .summer-voice__text {
    font-size: 10px;
  }
  .summer-voice__item .kodawari-btn {
    font-size: 12px;
  }
  .qa {
    margin-top: 20px;
  }
  .qa dt {
    min-height: 35px;
    font-size: 16px;
    font-weight: bold;
    padding: 4px 0 0 40px;
    background-size: 30px;
  }
  .qa dd {
    margin-top: 10px;
    min-height: 30px;
    font-size: 10px;
    padding: 8px 0 6px 42px;
    background: #e9dbe1 url('../ski_image/a.png') 7px 6px / 16px no-repeat;
  }
  .magazine .tx-center {
    width: 280px;
    margin: 0 auto 40px;
  }
  #footer {
    margin-top: 40px;
  }
}




/* -------- 2024/06/13 リニューアル -------- */

/* 元のスタイルを上書き */
.summer-voice__item {
  flex-direction: row;
}
@media screen and (max-width: 650px) {
  .section > p {
      font-size: 13px;
  }

  .summer-voice__text {
      font-size: 13px;
  }

  .qa dd {
      margin-top: 10px;
      min-height: 30px;
      font-size: 13px;
      padding: 8px 0 6px 42px;
      background: #e9dbe1 url(../ski_image/a.png) 7px 6px / 16px no-repeat;
  }
}

.top #main-wrapp {
  margin-top: 0px;
}

/* メインビジュアル */
.visual-bg {
  position: relative;
  height: 800px;
  background-image: url(/common/images/lp_summer/main_visual.jpg);
  background-size: cover;
  background-position: center;
  margin-bottom: 0px;
  padding-top: 30px;
}
.visual-bg .title {
  font-size: 200%;
  font-weight: bold;
  text-align: center;
  text-shadow: 0 0 5px #002e4d;
  color: #fff;
}
.visual-bg .title .sub {
  font-size: 130%;
  margin-bottom: 10px;
}
.visual-bg .title .sub span {
  font-size: 150%;
}
.visual-bg .title .main1 {
  font-size: 220%;
  line-height: 1.8;
}
.visual-bg .title .main1 span {
  background: linear-gradient(transparent 70%, #ffeb00 70%);
}
.visual-bg .title .main2 {
  font-size: 180%;
  line-height: 1.8;
}
.visual-bg ul {
  position: absolute;
  bottom: 30px;
  left: calc(50% - 400px);
  display: flex;
  justify-content: space-between;
  width: 800px;
  padding: 0 15px;
}
.visual-bg ul li {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 31%;
  height: 150px;
  background: rgba(255, 255, 255, 0.5);
  border-radius: 20px;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.25);
  text-align: center;
  font-weight: bold;
  font-size: 24px;
}
.visual-bg ul li .brackets {
position: relative;
padding: 0.5em 1em;
margin: 0;
}
.visual-bg ul li .brackets::before,
.visual-bg ul li .brackets::after {
position: absolute;
width: 15px;
height: 20px;
content: '';
}
.visual-bg ul li .brackets::before {
border-left: solid 2px rgba(235, 145, 75, 0.8);
border-top: solid 2px rgba(235, 145, 75, 0.8);
top: 0;
left: 0;
}
.visual-bg ul li .brackets::after {
border-right: solid 2px rgba(235, 145, 75, 0.8);
border-bottom: solid 2px rgba(235, 145, 75, 0.8);
bottom: 0;
right: 0;
}
@media screen and (max-width: 650px) {
  .visual-bg {
      height: 400px;
  }
  .visual-bg .title {
      font-size: 100%;
  }
  .visual-bg ul {
      bottom: 15px;
      left: 0;
      width: 100%;
      padding: 0 15px;
  }
  .visual-bg ul li {
      height: 80px;
      font-size: 16px;
      border-width: 3px;
  }
  .visual-bg ul li .brackets {
      padding: 0.25em .5em;
  }
}

/* スライド */
.slide {
  background: #fff;
  margin-bottom: 0px;
  padding: 10px 0;
}
.slide ul li {
  margin-right: 10px;
}

/* 冒頭レター部分 */
.letter {
  max-width: calc(1100px + 10%);
  background-color: #f8f8f8;
  z-index: -1;
  background-image:  radial-gradient(#eee 2px, transparent 2px), radial-gradient(#eee 2px, #f8f8f8 2px);
  background-size: 40px 40px;
  background-position: 0 0,20px 20px;
  margin: 0 auto;
  padding: 20px 5%;
}
.letter .title {
  text-align: center;
  font-size: 28px;
  font-weight: bold;
  margin: 20px 0 40px;
  position: relative;
  padding: 0.25em 1em 0.25em 0.5em;
}
.letter .tx-blue {
  color: #00a5d0;
}
.letter h3 {
  background: linear-gradient(transparent 70%, #00a5d0 70%);
}
@media screen and (max-width: 650px) {
  .letter .title {
      font-size: 20px;
  }
}

/* PC用 幅制御 */
.inner-pc {
  width: 800px;
  margin: 0 auto;
}
@media screen and (max-width: 650px) {
  .inner-pc {
      width: 100%;
      margin: 0;
  }
}

/* 人気条件から探す */
.popular ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px 0 0 0;
}

/* PC表示最終行の数合わせ用 */
.popular ul::after {
  content: "";
  display: block;
  width: 32%;
}

.popular ul li {
  width: 32% !important;
  background: #fff;
  border: solid 1px #ccc;
  border-radius: 5px;
  box-shadow: 0 0 5px rgba(32, 32, 32, 0.3);
  margin-bottom: 18px;
  padding: 0;
}
@media screen and (max-width: 650px) {
  .popular ul li {
      width: 47.5% !important;
  }
}
.popular ul li a {
  display: block;
  height: 100%;
  position: relative;
  padding: 0 0 35px 0;
}
.popular ul li a::after {
  position: absolute;
  right: 8px;
  bottom: 8px;
  content: "→ 求人詳細へ";
  width: 6.5em;
  height: 1em;
  line-height: 1;
  background: #1f7fb2;
  border-radius: 3px;
  text-align: center;
  font-size: 15px;
  font-weight: normal;
  color: #fff;
  opacity: 0.9;
  padding: 3px;
}
.popular ul li img {
  border-radius: 5px 5px 0 0;
}
.popular ul li .text {
  padding: 8px 10px 0 10px;
}
.popular ul li .text h3 {
  text-align: center;
  color: #1f7fb2;
  margin-bottom: 8px;
}
.popular ul li .text p {
  font-size: 16px;
  font-weight: normal;
}
@media screen and (max-width: 650px) {
  .popular ul li .text p {
      font-size: 13px;
  }
  .popular ul li a::after {
      font-size: 13px;
  }
}

/* 環境から探す */
.summer-environment ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px 0 0 0;
}
.summer-environment ul li {
  width: 49%;
  background: #fff;
  border: solid 1px #ccc;
  border-radius: 5px;
  box-shadow: 0 0 5px rgba(32, 32, 32, 0.3);
  margin-bottom: 18px;
  padding: 0;
}
@media screen and (max-width: 650px) {
  .summer-environment ul li {
      width: 100% !important;
  }
}
.summer-environment ul li a {
  display: flex;
  position: relative;
  justify-content: space-between;
}
.summer-environment ul li a .btn {
  position: absolute;
  right: 8px;
  bottom: 8px;
  line-height: 1;
  background: #1f7fb2;
  border-radius: 3px;
  font-size: 15px;
  color: #fff;
  opacity: 0.9;
  padding: 3px 5px;
}
.summer-environment ul li img {
  width: 36%;
  border-radius: 5px 0 0 5px;
}
.summer-environment ul li .text {
  width: 64%;
  padding: 10px 10px 30px 10px;
}
.summer-environment ul li h3 {
  color: #1f7fb2;
  margin-bottom: 8px;
}
.summer-environment ul li p {
  font-size: 16px;
  font-weight: normal;
}
@media screen and (max-width: 650px) {
  .summer-environment ul li p {
      font-size: 13px;
  }
  .summer-environment ul li a .btn {
      font-size: 13px;
  }
}

/* 夏休みのリゾートバイトとは */
.about .text {
  font-size: 16px;
  font-weight: normal;
  line-height: 1.5;
  text-align: left;
}
.about .text span {
  font-weight: bold;
}
@media screen and (max-width: 650px) {
  .about .text {
      font-size: 13px;
  }
}

/* 体験談 */
.summer-voice .summer-voice__item img {
  border-radius: 25px 0 25px 0;
}
.summer-voice .summer-voice__item .type-location {
  background: #eee;
  border-radius: 5px;
  font-weight: bold;
  margin-top: 10px;
  padding: 5px 10px;
}
.summer-voice .summer-voice__item a {
  display: flex;
  flex-direction: column;
}

/* 求人施設 */
.facility ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px 0 0 0;
}
.facility ul li {
  display: flex;
  justify-content: space-between;
  width: 49%;
  background: #fff;
  border: solid 1px #ccc;
  margin-bottom: 15px;
  padding: 10px;
}
.facility ul li img {
  width: 45%;
}
.facility ul li .text {
  width: 52%;
}
.facility ul li h3 {
  margin-bottom: 8px;
}
.facility ul li p {
  font-size: 16px;
  font-weight: normal;
}
@media screen and (max-width: 650px) {
  .facility ul li {
      width: 100% !important;
  }
  .facility ul li p {
      font-size: 13px;
  }
}

/* 想い・特典 */
.benefits .text {
  font-size: 16px;
  font-weight: normal;
  line-height: 1.5;
  text-align: left;
}
.benefits .text span {
  font-weight: bold;
}
@media screen and (max-width: 650px) {
  .benefits .text {
      font-size: 13px;
  }
}

/* ボタン色 */
.kodawari-btn.btn-blue {
  background: #1f7fb2 !important;
  color: #fff !important;
}
.kodawari-btn.btn-blue::after {
  background: url(/common/images/icon-right-white.png) center / contain;
}

/* Q&A アコーディオン */
dl.qa dt {
  position: relative;
  cursor: pointer;
  padding-right: 40px;
}
dl.qa dt::after {
  content: "＋";
  position: absolute;
  right: 0;
  top: 8px;
  font-size: 32px;
  width: 1em;
  height: 1em;
  line-height: 1;
  border: solid 1px #666;
  padding: 1px;
}
dl.qa dd {
  display: none;
  padding-right: 8px;
  color: #444;
}
dl.qa dd.stay {
  display: block;
}
dl.qa dt.open::after {
  content: "－";
}
@media screen and (max-width:650px) {
  dl.qa dt {
      padding-right: 30px;
  }

  dl.qa dt::after {
      top: 4px;
      font-size: 16px;
  }    
}
