@charset "utf-8";

/* ---------------------------------------------------
 * base
/* ---------------------------------------------------*/

html {
  font-size: 62.5%;
  /*適宜変更お願いします*/
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  scroll-behavior: smooth;
}

body {
  text-align: center;
  font-size: 10px;
  font-family: 'Noto Sans JP', YuGothic, 'Yu Gothic', 'ヒラギノ角ゴシック', 'Hiragino Sans', sans-serif;
  color: #000000;
  line-height: 1.75;
  width: 100%;
  background-color: #fff;
  font-weight: 400;
  /*適宜変更お願いします*/
  font-feature-settings: "palt" 1;
  /*自動カーニング*/
}

img {
  max-width: 100%;
  height: auto;
}

a {
  color: #fff;
}

a:hover {
  /*opacity: 0.8;*/
  text-decoration: none;
}

p {
  text-align: justify;
  hanging-punctuation: allow-end;
  /*文字のぶら下げ*/
}

#footer {
  text-align: center;
}

/* ---------------------------------------------------
 * common（PC　min-width: 1023px）
/* ---------------------------------------------------*/
.wrap {
  width: 640px;
  max-width: 100%;
  display: flex;
  justify-content: center;
  flex-direction: column;
  margin: 0 auto;
  background: #000;
}

.container {
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.shine-wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  position: relative;
  max-width: 640px;
  height: autox;
  margin-left: auto;
  margin-right: auto;
  background-color: #000;
  z-index: 99999;
}

/* リード文 */
.lead-sentence {
  display: block;
  margin: 20px auto 10px;
  width: 80%;
}

.content_form {
  display: flex;
}

/* メールアドレス入力項目 */
.mail-box {
  width: 100%;
  display: block;
  margin: 0 auto;
  text-align: center !important;
}

/* チェックボックス */
.checkbox_frame {
  display: flex !important;
  width: 100% !important;
  justify-content: center;
  /* word-wrap Specifies whether the UA may break within a word to prevent overflow when an otherwise-unbreakable string is too long to fit.: break-word; */
  vertical-align: middle;
  font-size: 1.2rem;
  color: #fff;
  margin: 20px auto -10px;
}

/* CTAボタン */
.btn {
  display: block;
  width: 80%;
  margin: 0 auto 20px;
  text-align: center;
}

.form_input_submit {
  overflow: hidden;
}

.-pc {
  display: block;
}

.-sp {
  display: none;
}

*,
*::before,
*::after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
  /*親要素のbox-sizingを継承*/
}

@keyframes pulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.05);
    opacity: 0.85;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.pulse-btn {
  animation: pulse 1.5s infinite;
  transition: transform 0.3s;
}

@keyframes pulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.05);
    opacity: 0.85;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

.pulse-btn {
  animation: pulse 1.5s infinite;
  transition: transform 0.3s;
}

/*-----------------タブレットサイズ-----------------------
@media (min-width: 600px) and (max-width: 1023px) {
    body {
        font-size: 3.2rem;
    }
    .-pc {
        display: none;
    }
    .-sp {
        display: block;
    }
    .wrap {
        max-width: 100%;
        width: 100%;
    }
}
----------------------------------------*/

/*-----------------スマホサイズ-----------------------*/

@media screen and (max-width:600px) {
  .-pc {
    display: none;
  }

  .-sp {
    display: block;
  }

  body {
    font-size: 4.2vw;
  }

  .wrap {
    max-width: 100%;
    width: 100%;
  }

  #footer {
    text-align: center;
    font-size: 0.8em;
    padding: 1em;
    margin-bottom: 50px;
  }

  #footer a {
    color: #000000;
  }

  section#section-01,
  section#section-02,
  section#section-03,
  section#section-04,
  section#section-05,
  section#section-06,
  section#section-07,
  section#section-08,
  section#section-09,
  section#section-10,
  section#section-11,
  section#section-12,
  section#section-13,
  section#section-14,
  section#section-15,
  section#section-16,
  section#section-17,
  section#section-18,
  section#section-19,
  section#section-20,
  section#section-21,
  section#section-22,
  section#section-23,
  section#section-24,
  section#section-25,
  section#section-26,
  section#section-27,
  section#section-28,
  section#section-29,
  section#section-30,
  section#section-31,
  section#section-32,
  section#section-33,
  section#section-34,
  section#section-35,
  section#section-36,
  section#section-37,
  section#section-38,
  section#section-39,
  section#section-40,
  section#section-41,
  section#section-42,
  section#section-43,
  section#section-44,
  section#section-45,
  section#section-46,
  section#section-47,
  section#section-48,
  section#section-49,
  section#section-50 {
    background: none !important;
  }
}

/*背景画像を指定*/
/* section#section-01 {
  background: url(../img/section_01.png)no-repeat top center;
  height: px;
} */

/* ---------------------------------------------------
 * accordion
/* ---------------------------------------------------*/

:root {
  /* 色味：マテリアル系 */
  --page: #f9f9fb;
  /* ページ背景（淡いグレー） */
  --card: #ffffff;
  /* カード背景 */
  --border: #e0e0e0;
  /* 罫線の薄いグレー */
  --title: #202124;
  /* 見出し/名前の濃いグレー黒 */
  --text: #202124;
  /* 本文のグレー */
  --chevron: #5f6368;
  /* Vアイコンの灰色 */

  /* タイポ／幅 */
  --wrap-w: 580px;
  --name: clamp(15px, 3.8vw, 18px);
  --body: clamp(14px, 3.6vw, 17px);
  --block-title: clamp(17px, 4.2vw, 21px);
}

/* ベース */

.accordion {
  color: var(--title);
  background: #000;
  width: var(--wrap-w);
  max-width: 100%;
  margin: 0 auto;
  padding: 60px 12px 0;
}

/* ブロック見出し（カードの外／左寄せ） */
.section {
  margin: 0 0 28px;
}

.section-title {
  margin: 0 0 10px 4px;
  font-weight: 700;
  font-size: var(--block-title);
  color: var(--title);
  text-align: left;
  letter-spacing: .01em;
  color: #ffeb3b;
  /* ← 濃すぎない黄色（GoogleマテリアルのYellow 300） */
}

/* カード */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .04);
  overflow: hidden;
}

/* アコーディオン要素 */
details {
  background: var(--card);
}

/* 各行のヘッダー（名前） */
summary {
  list-style: none;
  cursor: pointer;
  padding: 16px 44px 14px 16px;
  position: relative;
  outline: none;
  user-select: none;
  border-bottom: 1px solid var(--border);
}

/* 最後の行のボーダーは消す */
.card details:last-of-type summary {
  border-bottom: 0;
}

/* 名前（太字・濃い文字色） */
.name {
  font-weight: 800;
  font-size: var(--name);
  color: var(--title);
  line-height: 1.45;
  width: 100%;
}

/* 右側の“∨”アイコン（灰色） */
summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 1em;
    color: #333333;
    font-weight: 600;
    cursor: pointer;
}

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

summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 30px;
    border-bottom: 3px solid #c2c2c2;
    border-right: 3px solid #c2c2c2;
    content: '';
    transition: transform .3s;
}

.accordion [open] summary::after {
    transform: translateY(-50%) rotate(225deg);
}


/* 展開エリア（本文） */
.panel {
  padding: 0 16px 16px 16px;
}

.title {
  margin-top: 8px;
  font-size: var(--body);
  color: var(--text);
  line-height: 1.8;
}

/* ちょい気持ちよく：ホバー */
summary:hover {
  background: #fff9e6;
}

/* アクセシビリティ */
summary:focus-visible {
  box-shadow: inset 0 0 0 3px rgba(0, 0, 0, .08);
  border-radius: 6px;
}


/* ---------------------------------------------------
 * フッター
/* ---------------------------------------------------*/

.footer-block {
  color: #ffffff;
  background-color: #2c2c2c;
  border-radius: 0;
  transform: rotate(0deg);
  animation-duration: 0.5s;
  font-size: 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1em;
  max-width: 640px;
  margin: 0 auto;
}

.footer-wrap {
  margin-bottom: 2em;
  flex-direction: column;
  display: flex;
  justify-content: flex-end;
  margin: 0 auto;
}

.footer-wrap ul {
  list-style: none;
}

.footer-copyright {
  padding: 1rem;
}

.footer-links {}